

INTEGRATED CIRCUIT TECHNICAL DATA

# **MICROCOMPUTER DATA BOOK**

**2nd Edition**

**Mar., 1982**



**TOSHIBA**

## PREFACE

Since LSIs for the microcomputer manufactured first in Japan by Toshiba was put on the market in 1973, Toshiba has devoted efforts in strengthening its semiconductor devices for microcomputer. Toshiba has been developing various highly efficient and low power consumption type LSIs for microcomputers to more and more diversifying application fields, and supplying numerous kinds of new products to users.

This manual covers the technical description of LSIs for microcomputers supplied by Toshiba, including TLCS-43 Series (NMOS), TLCS-46A Series (CMOS) and TLCS-47 Series (NMOS and CMOS) 4-bit single chip microcomputer, TLCS-84 Series (NMOS and CMOS) 8-bit single chip microcomputer and TLCS-85A Family (NMOS) 8-bit microcomputer.

In addition to this manual, the technical description of the microcomputer development system is also available.

Further, examples of application circuits listed in this manual are only for reference in using the LSIs. Toshiba will not assume any responsibility for problem relative to patent rights which may be generated from use of the said application circuits.



## CONTENTS

|                                                                                 | Page |
|---------------------------------------------------------------------------------|------|
| <b>4BIT SINGLE CHIP MICROCOMPUTER</b>                                           |      |
| <b>TLCS-43 (NMOS)</b>                                                           |      |
| ● TMP4310AP/TMP4315BP/TMP4320AP/TMP4300C . . . . .                              | 7    |
| ● TMP4310APL/TMP4310APLL . . . . .                                              | 82   |
| ● TMP4321AP . . . . .                                                           | 88   |
| ● TMP4399C . . . . .                                                            | 93   |
| <b>4BIT SINGLE CHIP MICROCOMPUTER</b>                                           |      |
| <b>TLCS-46A (CMOS)</b>                                                          |      |
| ● TCP4620AP/TCP4630AP . . . . .                                                 | 99   |
| ● TCP4620AF/TCP4630AF . . . . .                                                 | 173  |
| ● TCP4620BP . . . . .                                                           | 179  |
| ● TCP4621AP . . . . .                                                           | 195  |
| ● TCP4632BF . . . . . PRELIMINARY                                               | 201  |
| ● TCP4600AC . . . . .                                                           | 230  |
| <b>4BIT SINGLE CHIP MICROCOMPUTER</b>                                           |      |
| <b>TLCS-47 (NMOS/CMOS) . . . . . PRELIMINARY</b>                                |      |
| ● TMP4700C/TMP4720P/TMP4740P/TMP499C (NMOS) . . . . .                           | 257  |
| ● TMP47C20P/TMP47C40P/TMP47C22F (CMOS)<br>/TMP47C41P/TMP47C21P . . . . .        | 357  |
| <b>8BIT SINGLE CHIP MICROCOMPUTER</b>                                           |      |
| <b>TLCS-84 (NMOS/CMOS)</b>                                                      |      |
| ● TMP8048P/TMP8035P/TMP8048PI/TMP8035PI . . . . .                               | 509  |
| ● TMP8049P/TMP8049P-6/TMP8039P/TMP8039P-6<br>/TMP8049PI-6/TMP8039PI-6 . . . . . | 542  |
| ● TMP8243P/TMP8243PI . . . . .                                                  | 575  |
| ● TMP8022P . . . . .                                                            | 584  |
| ● TMP80C49-6/TMP80C39P-6 . . . . . PRELIMINARY                                  | 602  |

- TMP82C43P ..... 615

## **8BIT MICROPROCESSOR**

### **TLCS-85A (NMOS)**

- TMP8085AP ..... 623

## **8BIT MICROPROCESSOR**

### **PERIPHERALS (NMOS)**

- TMP8155/TMP8156P ..... 655
- TMP8355P ..... 672
- TMP8755AC ..... 682
- TMP8259AP ..... 694

## **MICROCOMPUTER APPLICATION DEVELOPMENT TOOL ..... 701**

### TLCS-43 (4 BIT SINGLE CHIP NMOS MICROCOMPUTER)

#### TLCS-43 SERIES (NMOS)

| Device Number | RAM     | ROM         | I/O      | Instruction Cycle Time (Min.) | Power Supply Current (Typ.) | Power Supply | Operating Temperature | Package Type   | Alternate Source |  |
|---------------|---------|-------------|----------|-------------------------------|-----------------------------|--------------|-----------------------|----------------|------------------|--|
| TMP4300C      | 128 × 4 | Without ROM | 35 Lines | 4 µs                          | 70 mA                       | 5V±10%       | -10°C ~ 70°C          | Ceramic 64 pin | Toshiba Original |  |
| TMP4399C      | 128 × 4 | Without ROM |          | 4 µs                          | 70 mA                       | 5V±10%       | -10°C ~ 70°C          | Ceramic 42 pin |                  |  |
| TMP4310AP     | 48 × 4  | 1024 × 8    |          | 22 Lines                      | 4 µs                        | 40 mA        | 5V±10%                | -10°C ~ 70°C   |                  |  |
| TMP4315BP     | 64 × 4  | 1536 × 8    |          | 35 Lines                      | 4 µs                        | 40 mA        | 5V±10%                | -10°C ~ 70°C   |                  |  |
| TMP4320AP     | 128 × 4 | 2048 × 8    |          | 35 Lines                      | 4 µs                        | 40 mA        | 5V±10%                | -10°C ~ 70°C   |                  |  |
| TMP4321AP     | 128 × 4 | 2048 × 8    |          | 35 Lines                      | 4 µs                        | 40 mA        | 5V±10%                | -10°C ~ 70°C   |                  |  |
| TMP4310APL    | 48 × 4  | 1024 × 8    |          | 22 Lines                      | 5 µs                        | 30 mA        | 5.5V±10%              | 0°C ~ 55°C     | Plastic 42 pin   |  |
| TMP4310APLL   |         |             |          |                               | 10 µs                       | 15 mA        |                       |                |                  |  |

### TLCS-46A (4 BIT SINGLE CHIP CMOS MICROCOMPUTER)

#### TLCS-46A SERIES (CMOS)

| Device Number | RAM     | ROM         | I/O      | Instruction Cycle Time (Min.) | Power Supply Current (Typ.) | Power Supply | Operating Temperature | Package Type          | Alternate Source |  |  |
|---------------|---------|-------------|----------|-------------------------------|-----------------------------|--------------|-----------------------|-----------------------|------------------|--|--|
| TCP4600AC     | 160 × 4 | Without ROM | 34 Lines | 10 µs                         | 0.15 mA at 100kHz           | 4 ~ 6V       | -10°C ~ 70°C          | Ceramic 64 pin        | Toshiba Original |  |  |
| TCP4620AP     | 96 × 4  | 2048 × 8    |          |                               | 0.4 mA at 400kHz            | 4 ~ 6V       | -30°C ~ 85°C          | Plastic 42 pin        |                  |  |  |
| TCP4620BP     |         |             |          |                               |                             |              |                       | Plastic 43 pin (Flat) |                  |  |  |
| TCP4630AP     | 160 × 4 | 3072 × 8    |          |                               |                             |              | -20°C ~ 70°C          | Plastic 42 pin        |                  |  |  |
| TCP4620AF     | 96 × 4  | 2048 × 8    |          |                               |                             |              |                       | Plastic 67 pin (Flat) |                  |  |  |
| TCP4620BF     | 160 × 4 | 3072 × 8    |          |                               |                             |              |                       | Plastic 67 pin (Flat) |                  |  |  |
| TCP4630AF     | 96 × 4  | 2048 × 8    |          |                               |                             |              |                       | Plastic 67 pin (Flat) |                  |  |  |
| TCP4621AP     | 160 × 4 | 3072 × 8    |          |                               |                             |              |                       | Plastic 67 pin (Flat) |                  |  |  |
| TCP4632BF     | 160 × 4 | 3072 × 8    | 57 Lines |                               |                             |              |                       | Plastic 67 pin (Flat) |                  |  |  |

### TLCS-47 (4 BIT SINGLE CHIP NMOS/CMOS MICROCOMPUTER)

#### TLCS-47 SERIES (NMOS/CMOS)

| Device Number | RAM       | ROM     | I/O         | Instruction Cycle Time (Min.) | Power Supply Current (Typ.) | Power Supply | Operating Temperature | Package Type          | Alternate Source |
|---------------|-----------|---------|-------------|-------------------------------|-----------------------------|--------------|-----------------------|-----------------------|------------------|
| NMOS          | TMP4720P  | 128 × 4 | 2048 × 8    | 35 Lines                      | 50 mA                       | 5V±10%       | -30°C ~ 70°C          | Plastic 42 Pin        | Toshiba Original |
|               | TMP4740P  | 256 × 4 | 4096 × 8    |                               |                             |              |                       | QIC 80 Pin            |                  |
|               | TMP4700C  | 256 × 4 | without ROM |                               |                             |              |                       | DIC 42 Pin            |                  |
|               | TMP4799C  | 256 × 4 | without ROM |                               |                             |              |                       | Plastic 67 Pin (Flat) |                  |
| CMOS          | TMP47C20P | 128 × 4 | 2048 × 8    | 4 µs                          | 5 mA                        | 5V±10%       | -30°C ~ 70°C          | Plastic 42 Pin        | Toshiba Original |
|               | TMP47C40P | 256 × 4 | 4096 × 8    |                               |                             |              |                       | Plastic 67 Pin (Flat) |                  |
|               | TMP47C21P | 128 × 4 | 2048 × 8    |                               |                             |              |                       | Plastic 67 Pin (Flat) |                  |
|               | TMP47C41P | 256 × 4 | 4096 × 8    |                               |                             |              |                       | Plastic 67 Pin (Flat) |                  |
|               | TMP47C22F | 192 × 4 | 2048 × 8    | 55 Lines                      |                             |              |                       |                       |                  |

## TLCS-84 (8 BIT SINGLE CHIP NMOS/CMOS MICROCOMPUTER)

### TLCS-84 SERIES (NMOS/CMOS)

|      | Device Number | RAM                                   | ROM      | I/O      | Instruction Cycle Time (Min.) | Power Supply Current (Max.) | Power Supply | Operating Temperature | Package Type   | Alternate Source |  |
|------|---------------|---------------------------------------|----------|----------|-------------------------------|-----------------------------|--------------|-----------------------|----------------|------------------|--|
| NMOS | TMP8048P      | 64 × 8                                | 1024 × 8 | 27 Lines | 2.5 µs                        | 135 mA                      | 5V±10%       | 0°C ~ 70°C            | Plastic 40 pin | 18048            |  |
|      | TMP8035P      | 64 × 8                                | -        |          | 2.5 µs                        | 135 mA                      |              |                       |                | 18035L           |  |
|      | TMP8049P-6    | 128 × 8                               | 2048 × 8 |          | 2.5 µs                        | 170 mA                      |              |                       |                | i8039-6          |  |
|      | TMP8039P-6    | 128 × 8                               | -        |          | 2.5 µs                        | 170 mA                      |              |                       |                | i8049            |  |
|      | TMP8049P      | 128 × 8                               | 2048 × 8 |          | 1.36 µs                       | 170 mA                      |              |                       |                | 18049            |  |
|      | TMP8039P      | 128 × 8                               | -        |          | 1.36 µs                       | 170 mA                      |              |                       |                | 18039            |  |
|      | TMP8048PI     | 64 × 8                                | 1024 × 8 |          | 2.5 µs                        | 145 mA                      |              | -40°C ~ 85°C          | Plastic 24 pin | 1D8048           |  |
|      | TMP8035PI     | 64 × 8                                | -        |          | 2.5 µs                        | 145 mA                      |              |                       |                | 1D8035           |  |
|      | TMP8049PI-6   | 128 × 8                               | 2048 × 8 |          | 2.5 µs                        | 170 mA                      |              |                       |                | 1D8049           |  |
|      | TMP8039PI-6   | 128 × 8                               | -        |          | 2.5 µs                        | 170 mA                      |              |                       |                | 1D8039           |  |
|      | TMP8243P      | I/O Expander for TMP8048P/TMP8049P    |          |          | 20 mA                         | 5V±10%                      |              |                       |                | i8243            |  |
| CMOS | TMP8243PI     | I/O Expander for TMP8048PI-6/8049PI-6 |          |          | 20 mA                         | 5V±10%                      | -40°C ~ 85°C | Plastic 24 pin        | iD8243         | iD8243           |  |
|      | TMP80C49P-6   | 128 × 8                               | 2048 × 8 | 27 Lines | 2.5 µs                        | 10 mA                       | 5V±10%       | -40°C ~ 85°C          |                |                  |  |
|      | TMP80C39P-6   | 128 × 8                               | -        |          | 2.5 µs                        | 10 mA                       |              |                       |                |                  |  |

## TLCS-85A

### • 8 BIT MICROPROCESSOR

| Device Number | Description          | Instruction Cycle Time (Min.) | Power Supply Current (Max.) | Power Supply | Operating Temperature | Package Type   | Alternate Source |
|---------------|----------------------|-------------------------------|-----------------------------|--------------|-----------------------|----------------|------------------|
| TMP8085AP     | 8 Bit Microprocessor | 1.3 µs                        | 170 mA                      | 5V±10%       | 0°C ~ 70°C            | Plastic 40 pin | i8085A           |

### • PERIPHERALS (NMOS)

| Device Number | Description                                             | Power Supply Current (Max.) | Power Supply | Operating Temperature | Package Type   | Alternate Source |
|---------------|---------------------------------------------------------|-----------------------------|--------------|-----------------------|----------------|------------------|
| TMP8155P      | 256 Byte RAM with I/O Ports and Timer (CE: Active Low)  | 180 mA                      | 5V±5%        | 0°C ~ 70°C            | Plastic 40 pin | i8155            |
| TMP8156P      | 256 Byte RAM with I/O Ports and Timer (CE: Active High) | 180 mA                      |              |                       |                | i8156            |
| TMP8355P      | 2K Byte Mask ROM with I/O Ports                         | 180 mA                      |              |                       | Plastic 40 pin | i8355            |
| TMP8755AC     | 2K Byte EPROM with I/O Ports                            | 180 mA                      |              |                       | Ceramic 40 pin | i8755A           |

**4BIT SINGLE CHIP MICROCOMPUTER**

**TLCS-43(NMOS)**



Toshiba

東芝

# INTEGRATED CIRCUIT

## TECHNICAL DATA

TOSHIBA MOS TYPE DIGITAL

INTEGRATED CIRCUIT

TMP4310AP TMP4315BP

TMP4320AP TMP4300C

Silicon Monolithic

N-Channel Silicon Gate Depression Load

### GENERAL DESCRIPTION

TLCS-43 is a complete single chip micro computer series having an internal 4 bit parallel processing function which is suitable for controller applications.

It contains ROM (read only memory) which stores the control programs and the fixed data, RAM (read/write memory) which temporarily stores various data and a plural number of input/output ports.

In order to provide for a variety of applications the TLCS-43 provides short instruction execution time, multiple subroutine nesting, and flexible input/output ports.

By combining index instructions with processing instructions, the same instruction can be executed for all the registers and all the input/output ports enabling highly efficient programmes to be written.

In TLCS-43, there are three versions, TMP4310AP, TMP4315BP and TMP4320AP each of which has different memory capacity and different number of input/output lines, so that the optimum version for a specific application can be selected. Furthermore, TMP4300C is available as the evaluator chip.

Toshiba

東芝

# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4310AP TMP4315BP  
TMP4320AP TMP4300C

### FEATURES

- o TMP4310AP
  - 1024 x 8 ROM
  - 48 x 4 RAM
  - 22 I/O Lines
- o TMP4315BP
  - 1536 x 8 ROM
  - 64 x 8 RAM
  - 35 I/O Lines
- o TMP4320AP
  - 2048 x 8 ROM
  - 128 x 4 RAM
  - 35 I/O Lines
- o TMP4300C
  - Evaluator Chip for TLCS-43
- o 35 Basic Instructions
  - 31 Processing Instructions
  - 4 Index Instructions
- o 4 Level Subroutine Nesting
- o Single Level External Interrupt
- o 4  $\mu$ s Instruction Execution Time
- o Single 5V Supply
- o ROM Data Readout Instructions
- o LED Direct Drive Capability
  - (Except TMP4315BP)

TABLE OF FEATURES

| Feature                             | TMP4310AP                                                        | TMP4315BP               | TMP4320AP               | TMP4300C                                       |
|-------------------------------------|------------------------------------------------------------------|-------------------------|-------------------------|------------------------------------------------|
| ROM Capacity                        | 1,024 Words<br>x 8 Bits                                          | 1,536 Words<br>x 8 Bits | 2,048 Words<br>x 8 Bits | External connection<br>2,048 Words<br>x 8 Bits |
| RAM Capacity                        | 48 Words<br>x 4 Bits                                             | 64 Words<br>x 4 Bits    | 128 Words<br>x 4 Bits   | 128 Words<br>x 4 Bits                          |
| Input Port                          | 1 Port<br>(4 Bits)                                               | 3 Port<br>(12 Bits)     | 3 Port<br>(12 Bits)     | 3 Ports<br>(12 Bits)                           |
| Output Port                         | 2 Port<br>(8 Bits)                                               | 4 Port<br>(15 Bits)     | 4 Port<br>(15 Bits)     | 3 Port<br>(12 Bits)                            |
| Input/Output Port                   | 3 Port<br>(10 Bits)                                              | 2 Port<br>(8 Bits)      | 2 Port<br>(8 Bits)      | 3 Port<br>(11 Bits)                            |
| Subroutine Nesting Level            | 4 Levels (including interrupt)                                   |                         |                         |                                                |
| Interrupt Level                     | 1 Level                                                          |                         |                         |                                                |
| Number of Instructions              | 35 Basic Instructions                                            |                         |                         |                                                |
| Execution Time of Basic Instruction | 4 $\mu$ S (1 Cycle Instruction), 8 $\mu$ S (2 Cycle Instruction) |                         |                         |                                                |
| Input/Output Level                  | TTL Compatible                                                   |                         |                         |                                                |
| Power Supply                        | 5V $\pm$ 10 %                                                    |                         |                         |                                                |
| Power Dissipation                   | 200mW (TYP.)                                                     | 200mW (TYP.)            | 200mW (TYP.)            | 350mW (TYP.)                                   |
| Operating Ambient Temp.             | -10°C to 70°C                                                    |                         |                         |                                                |
| Package                             | 28 Pin Plastic DIP                                               | 42 Pin Plastic DIP      | 42 Pin Plastic DIP      | 64 Pin Ceramic DIP                             |
| Process                             | N-Channel E/D MOS                                                |                         |                         |                                                |



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4310AP      TMP4315BP  
 TMP4320AP      TMP4300C

### PIN CONNECTIONS

Top View

(TMP4310AP)

|                   |    |     |                   |
|-------------------|----|-----|-------------------|
| IN 0 <sub>0</sub> | 1  | 2.8 | V <sub>DD</sub>   |
| IN 0 <sub>1</sub> | 2  | 27  | X <sub>IN</sub>   |
| IN 0 <sub>2</sub> | 3  | 26  | TEST              |
| IN 0 <sub>3</sub> | 4  | 25  | IO 1 <sub>0</sub> |
| OT 0 <sub>0</sub> | 5  | 24  | IO 1 <sub>1</sub> |
| OT 0 <sub>1</sub> | 6  | 23  | IO 1 <sub>2</sub> |
| OT 0 <sub>2</sub> | 7  | 22  | IO 1 <sub>3</sub> |
| OT 0 <sub>3</sub> | 8  | 21  | IO 0 <sub>0</sub> |
| IO 2 <sub>0</sub> | 9  | 20  | IO 0 <sub>1</sub> |
| IO 2 <sub>1</sub> | 10 | 19  | IO 0 <sub>2</sub> |
| OT 1 <sub>0</sub> | 11 | 18  | IO 0 <sub>3</sub> |
| OT 1 <sub>1</sub> | 12 | 17  | INT               |
| OT 1 <sub>2</sub> | 13 | 16  | RST               |
| GND               | 14 | 15  | IO 1 <sub>3</sub> |

(TMP4315BP/TMP4320AP)

|                   |    |    |                   |
|-------------------|----|----|-------------------|
| TEST              | 1  | 42 | V <sub>DD</sub>   |
| IN 0 <sub>0</sub> | 2  | 41 | IN 1 <sub>0</sub> |
| IN 0 <sub>1</sub> | 3  | 40 | IN 1 <sub>1</sub> |
| IN 0 <sub>2</sub> | 4  | 39 | IN 1 <sub>2</sub> |
| IN 0 <sub>3</sub> | 5  | 38 | IN 1 <sub>3</sub> |
| OT 0 <sub>0</sub> | 6  | 37 | IN 2 <sub>0</sub> |
| OT 0 <sub>1</sub> | 7  | 36 | IN 2 <sub>1</sub> |
| OT 0 <sub>2</sub> | 8  | 35 | IN 2 <sub>2</sub> |
| OT 0 <sub>3</sub> | 9  | 34 | IN 2 <sub>3</sub> |
| OT 1 <sub>0</sub> | 10 | 33 | IO 1 <sub>0</sub> |
| OT 1 <sub>1</sub> | 11 | 32 | IO 1 <sub>1</sub> |
| OT 1 <sub>2</sub> | 12 | 31 | IO 1 <sub>2</sub> |
| OT 1 <sub>3</sub> | 13 | 30 | IO 1 <sub>3</sub> |
| OT 2 <sub>0</sub> | 14 | 29 | IO 0 <sub>0</sub> |
| OT 2 <sub>1</sub> | 15 | 28 | IO 0 <sub>1</sub> |
| OT 2 <sub>2</sub> | 16 | 27 | IO 0 <sub>2</sub> |
| OT 2 <sub>3</sub> | 17 | 26 | IO 0 <sub>3</sub> |
| OT 3 <sub>0</sub> | 18 | 25 | X <sub>OUT</sub>  |
| OT 3 <sub>1</sub> | 19 | 24 | X <sub>IN</sub>   |
| OT 3 <sub>2</sub> | 20 | 23 | RST               |
| GND               | 21 | 22 | INT               |

(TMP4300C)

|                   |    |    |                   |
|-------------------|----|----|-------------------|
| GND               | 1  | 64 | NC                |
| RST               | 2  | 63 | INT               |
| X <sub>IN</sub>   | 3  | 62 | ID                |
| X <sub>OUT</sub>  | 4  | 61 | IO 2 <sub>2</sub> |
| IO 0 <sub>3</sub> | 5  | 60 | IO 2 <sub>1</sub> |
| IO 0 <sub>2</sub> | 6  | 59 | IO 2 <sub>0</sub> |
| IO 0 <sub>1</sub> | 7  | 58 | NC                |
| IO 0 <sub>0</sub> | 8  | 57 | OT 0 <sub>3</sub> |
| IO 1 <sub>3</sub> | 9  | 56 | OT 0 <sub>2</sub> |
| IO 1 <sub>2</sub> | 10 | 55 | OT 0 <sub>1</sub> |
| I <sub>7</sub>    | 11 | 54 | OT 0 <sub>0</sub> |
| I <sub>6</sub>    | 12 | 53 | OT 2 <sub>3</sub> |
| I <sub>5</sub>    | 13 | 52 | OT 2 <sub>2</sub> |
| I <sub>4</sub>    | 14 | 51 | OT 2 <sub>1</sub> |
| I <sub>3</sub>    | 15 | 50 | OT 2 <sub>0</sub> |
| I <sub>2</sub>    | 16 | 49 | OT 1 <sub>3</sub> |
| I <sub>1</sub>    | 17 | 48 | OT 1 <sub>2</sub> |
| I <sub>0</sub>    | 18 | 47 | OT 1 <sub>1</sub> |
| IO 1 <sub>1</sub> | 19 | 46 | OT 1 <sub>0</sub> |
| IO 1 <sub>0</sub> | 20 | 45 | IN 0 <sub>3</sub> |
| IN 2 <sub>3</sub> | 21 | 44 | IN 0 <sub>2</sub> |
| IN 2 <sub>2</sub> | 22 | 43 | IN 0 <sub>1</sub> |
| IN 2 <sub>1</sub> | 23 | 42 | IN 0 <sub>0</sub> |
| IN 2 <sub>0</sub> | 24 | 41 | CLK 1             |
| IN 1 <sub>3</sub> | 25 | 40 | A <sub>0</sub>    |
| IN 1 <sub>2</sub> | 26 | 39 | A <sub>1</sub>    |
| IN 1 <sub>1</sub> | 27 | 38 | A <sub>2</sub>    |
| IN 1 <sub>0</sub> | 28 | 37 | A <sub>3</sub>    |
| A <sub>10</sub>   | 29 | 36 | A <sub>4</sub>    |
| A <sub>9</sub>    | 30 | 35 | A <sub>5</sub>    |
| A <sub>8</sub>    | 31 | 34 | A <sub>6</sub>    |
| A <sub>7</sub>    | 32 | 33 | V <sub>DD</sub>   |



## PIN NAMES &amp; PIN DESCRIPTION

| Pin Name                           | Input/<br>output | Function                                                                                                                                                                                                                                                                        | 4310 | 4315/<br>4320 | 4300 |
|------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------|------|
| INO <sub>0</sub> -INO <sub>3</sub> | Input            | 4-bit Input Port IN0                                                                                                                                                                                                                                                            | ○    | ○             | ○    |
| IN1 <sub>0</sub> -IN1 <sub>3</sub> | Input            | 4-bit Input Port IN1                                                                                                                                                                                                                                                            | —    | ○             | ○    |
| IN2 <sub>0</sub> -IN2 <sub>3</sub> | Input            | 4-bit Input Port IN2                                                                                                                                                                                                                                                            | —    | ○             | ○    |
| OT0 <sub>0</sub> -OT0 <sub>3</sub> | Output           | 4-bit Output Port OT0                                                                                                                                                                                                                                                           | ○    | ○             | ○    |
| OT1 <sub>0</sub> -OT1 <sub>3</sub> | Output           | 4-bit Output Port OT1<br>Large sink current (IOL TYP=20mA, VOL=2V)<br>is possible in<br>TMP4310AP/20AP/00C.                                                                                                                                                                     | ○    | ○             | ○    |
| OT2 <sub>0</sub> -OT2 <sub>3</sub> | Output           | 4-bit Output Port OT2<br>Large sink current (IOL TYP=20mA, VOL=2V)<br>is possible in<br>TMP4320AP/00C.                                                                                                                                                                          | —    | ○             | ○    |
| OT3 <sub>0</sub> -OT3 <sub>2</sub> | Output           | 3-bit Output Port OT3<br>IO2 <sub>0</sub> -IO2 <sub>2</sub> of TMP4300C are available<br>in evaluation.                                                                                                                                                                         | —    | ○             | —    |
| IO0 <sub>0</sub> -IO0 <sub>3</sub> | Input/<br>Output | 4-bit Input/Output Port IO0                                                                                                                                                                                                                                                     | ○    | ○             | ○    |
| IO1 <sub>0</sub> -IO1 <sub>3</sub> | Input/<br>Output | 4-bit Input/Output Port IO1                                                                                                                                                                                                                                                     | ○    | ○             | ○    |
| IO2 <sub>0</sub> -IO2 <sub>2</sub> | Input/<br>Output | 3-bit Input/Output Port IO2<br>2-bit Port (IO2 <sub>0</sub> -IO2 <sub>1</sub> ) in TMP4310AP                                                                                                                                                                                    | ○    | —             | ○    |
| RST                                | Input            | Initialize Signal Input<br>The initialize operation is performed<br>by placing RST terminal at low level<br>for more than four clock cycles.                                                                                                                                    | ○    | ○             | ○    |
| INT                                | Input            | Interrupt Request Signal Input<br>The interrupt request is accepted<br>by placing INT terminal at low<br>level for more than our clock<br>cycles. The repetitive interrupt<br>should be requested, after keeping<br>INT terminal at high level for two<br>clock cycles or more. | ○    | ○             | ○    |
| TEST<br>(Note 1)                   | Input            | LSI Test Signal Input<br>TEST should be always kept at high level<br>(open or connect an oscillation resistance<br>in TMP4310AP) except in LSI test mode.                                                                                                                       | ○    | ○             | —    |



## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP4310AP    TMP4315BP  
 TMP4320AP    TMP4300C

|                    |        |                                                                                                                                                 |                       |                       |                       |
|--------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------|-----------------------|
| XIN<br>(Note 1)    | Input  | Basic Clock Terminal<br><br>XIN is used as an external clock input pin, or a oscillator connection pin.                                         | <input type="radio"/> | <input type="radio"/> | <input type="radio"/> |
| XOUT               | Output | Basic Clock Terminal<br><br>XOUT is used as a oscillator connection pin.                                                                        | —                     | <input type="radio"/> | <input type="radio"/> |
| Ao-A <sub>10</sub> | Output | ROM Address Output (MSB:A <sub>10</sub> ,LSB:Ao)                                                                                                | —                     | —                     | <input type="radio"/> |
| Io-I <sub>7</sub>  | Input  | ROM Data Input (MSB:I <sub>7</sub> ,LSB:Io)                                                                                                     | —                     | —                     | <input type="radio"/> |
| CLK1               | Output | Internal Clock Output                                                                                                                           | —                     | —                     | <input type="radio"/> |
| ID                 | Input  | Interrupt Operation Inhibit Input<br>ID is a dedicated terminal only for TDS400/43, and should be always kept at low level except in TDS400/43. | —                     | —                     | <input type="radio"/> |
| V <sub>DD</sub>    |        | +5V (Power Supply)                                                                                                                              | <input type="radio"/> | <input type="radio"/> | <input type="radio"/> |
| GND                |        | OV (Power Supply)                                                                                                                               | <input type="radio"/> | <input type="radio"/> | <input type="radio"/> |

Note 1    The basic clock of TMP4310AP

- o Internal oscillation (with resistance externally installed between X<sub>IN</sub> and TEST) and external clock supply can be available.
- o TEST terminal should be kept open when the basic clock is supplied by an external oscillator circuit.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4310AP      TMP4315BP  
TMP4320AP      TMP4300C

BLOCK DIAGRAM (TMP4310AP)



BLOCK DIAGRAM (TMP4315BP/TMP4320AP)





## FUNCTIONAL DESCRIPTION

## [Block Description]

For all registers and I/O ports, MSB is the High order bit and LSB is the Low order bit.

## 1. Arithmetic and Logical Unit (ALU)

The ALU is the central 4 bit parallel processing function of the TLCS-43.  $S_1$  and  $S_2$  are the two 4 bit input words and C is the carry input from some previous calculation. The ALU processed these and outputs one 4 bit result (D) and a carry bit.



## 2. Accumulator (AC)

The accumulator is a four bit register, which stores the data for arithmetic and logical operations. In addition the accumulator is also used to store the results of arithmetic and logical calculations.

## 3. Status Register (ST)

The status register is a four bit register which contains fields to represent the carry flag (C), branch condition flag (F), interrupt flag (IM) and general purpose flag (G).

|      | ST | MSB | 3 | 2  | 1 | 0 | LSB |
|------|----|-----|---|----|---|---|-----|
| 1) C |    |     | G | IM | F | C |     |

Bit 0 of the status register is called C flag and used to indicate Carry (or Borrow) during arithmetic operation with multiple number of digits.

## 2) F

Bit 1 of the status register is called F flag and set or reset according to the result of logical operation or arithmetic operation just executed. And this bit is referred to during execution of conditional branch instruction in a program.

## 3) IM

Bit 2 of the status register is the interrupt flag called IM flag which is set or reset by program.

IM flag being "1" indicates the interrupt enabled condition and IM flag is cleared to "0" as soon as an interrupt routine is initiated. This is also cleared to "0" by the initialize operation.

## 4) G

Bit 3 of the status register is called G flag and this one bit flag is used generally by programs.

## 4. L Register (LR)

L Register (lower address register) is a four bit register which indicates the lower order 4 bits of RAM address and is used in conjunction with H Register for addressing RAM.

## 5. H Register (HR)

H Register (Higher address register) is a two bit or three bit register which indicates the higher order two or three bits of RAM address, and used in conjunction with L Register for addressing RAM.

When a program reads, the undefined higher order two bits (bit 3 and bit 2) or one bit (bit 3) are always processed to be zero.

(TMP4310AP/TMP4315BP)

MSB 1      0 LSB



(TMP4320AP/TMP4300C)

MSB 2      1      0 LSB



## 6. Input Port (IN0, IN1, IN2)

All of IN0, IN1 and IN2 ports are the dedicated input ports having four bit configuration and read the data sent from outside.

The input ports are non-latch type ports.



# INTEGRATEDCIRCUIT

## TECHNICAL DATA

TMP4310AP    TMP4315BP  
TMP4320AP    TMP4300C



### 7. Output Port (OT0, OT1, OT2, OT3)

OT0, OT1 and OT2 have four bit configuration and OT3 has three bit configuration, all of which are the dedicated output ports. The content of each port is output to outside and retained until replaced with new data. And the content of a port can read by program.

In this case the undefined bit 3 of OT3 port is always processed to be zero. All the bits of all the output ports are set to "1" by the initialize operation.



### 8. Input/Output Port (IO0, IO1, IO2)

IO0 and IO1 have four bit configuration and IO2 has two or three bit configuration, all of which are the input/output ports.

The content of each port is output to outside and retained until replaced with new data. It can also input data from outside. However, the output data must be set to "1" whenever the input operation is performed.

Whenever no data is input from outside, the output data to outside can be read by program. When the output data is read, undefined bit 3 and bit 2 of IO2 port are always processed to be zero.

All bits of the output data are set to "1" by the initialize operation.



#### 9. Program Counter (PC)

The program counter is 11 bit counter which addresses the program stored in ROM (refer to (Note) in the ROM paragraph.)

While the normal instructions are executed, the program counter is incremented by word length of instruction just excuted. However, for branch instructions, subroutine call and interrupt operation, the counter is set to the values designated by the instructions. The counter is reset to "0" by the initialize operation.

#### 10. Stack

The stack is a group of 4 words x 11 bits registers including the data counter.

The stack is used as the save area of the program counter during subroutine call and interrupt operation. If it is already occupied up to level 2, the data counter becomes to be the stack area of level 3.

#### 11. Data Counter (DC)

The data counter is an 11 bit counter which addresses fixed data stored in ROM (refer to (Note) in the ROM paragraph.)

The content of the data counter can be set by program. The data counter is also used as the deepest stack level (level 3) and when nesting has been done up to level 2, if further nesting is performed, the content as the data counter is destroyed.

And when the data counter is being used as stack level 3, if setting operation is performed to the data counter, the content as stack level 3 is destroyed.

#### 12. Read Only Memory (ROM)

The read only memory (ROM) can also store fixed data as well as programs which are required by users.

ROM has a maximum capacity of 2,048 words x 8 bits and is independently addressed by the program counter which addresses the storage area for programs and by the data counter which addresses the storage area for fixed data.

For storing programs the ROM is processed as 8 bit words but for fixed data, 8 bit word is divided into the higher order 4 bits and the lower order 4 bits, namely divided to two 4 bit words of ROM<sub>H</sub> and ROM<sub>L</sub>.



(TMP4310AP).... N=1,023

(TMP4315BP).... N=1,535

(TMP4320AP).... N=2,047

(Note) In the case of TMP4310AP, both of the program counter (PC) and the data counter (DC) are 11 bit counters, and if bit 10 is "1", any contents of ROM are not accessed.

### 13. Read/Write Memory (RAM)

The read/write memory (RAM) can be used as the working area for data processing.

RAM has the maximum configuration of 128 words x 4 bits and is addressed by H Register which designates a page and L Register which designates an address in a page.

In addition to the above, another addressing method of RAM is to access an address in page 0 using the index instructions (M instructions) which will be explained later. This method is effective to save the contents of registers on the interrupt operation.

The configuration of each version is as follows.

(TMP4310AP)



(TMP4315BP)



(TMP4320AP/TMP4300C)





# INTEGRATEDCIRCUIT

## TECHNICAL DATA

TMP4310AP      TMP4315BP  
TMP4320AP      TMP4300C

### 14. Timing Generator (TG) and Instruction Decoder (IDC)

The timing generator produces a clock frequency that is dependant on the oscillator connected externally.

Based on this timing the instruction decoder reads and decodes the fields unique to each instruction.

Timing of interrupts, initialize requests etc. are also synchronized by the Timing Generator.

### 15. Registers Dedicated to Index Instructions (SA, DA and MA)

..... Refer to the paragraph of Index Instructions.

These are 4 bit registers used by the index instructions which are explained later, and there are three kinds, namely SA (Source Address Register), DA (Destination Address Register) and MA (Memory Address Register). Source register code, destination register code and RAM address which are activated by the index instructions are input to SA, DA and MA respectively, and these are temporarily retained until the following one operation instruction is completely executed.

The registers dedicated to the index instructions can not be used by program as additional data registers.

Toshiba

# INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP4310AP      TMP4315BP  
TMP4320AP      TMP4300C

### 1. Features of TLCS-43 Machine Instructions

One of the features of the TLCS-43 Machine Instruction set is the existance of index instructions. In the case of processing instructions, usually the source and destination of data have been inherently defined. The index instructions modify the processing instructions to change the source of data to be processed or/and the destination of the processing results. Therefore, it is much simpler to write programs which require sequential operations through an area of memory. The extensive use of index instructions produces efficient programs in terms of the number of program steps.

Another great feature is that the machine instructions with Data Counter (DC) maintaining ROM address in addition to PC have the instructions which can read out the content of ROM directly, which allows a greater amount of fixed data to be efficiently read.

Furthermore, with the addition of four level subroutine nesting ability, the subroutine call instructions of 1 byte length are available. This is effective in reducing overall program size.

### 2. Format of Machine Instructions

The explanation of each instructions is described according to the following format.



<Symbol  
Instruction >      Mnemonic Operation Code      Operand



## [Machine Instructions]

TLCS-43 series microcomputer is provided with 35 kinds of machine instructions. Unless otherwise mentioned the machine instructions are described as just instructions.

Among the machine instructions of TLCS-43, 30 instructions are of 1-byte length and 5 instructions are of 2-byte length. As regards the execution time of machine instructions, 28 instructions are of 1-machine cycle and 7 instructions are of 2-machine cycle.

Machine Instructions are classified by their functions as follows:



## &lt;Machine Code &gt;

No.1 Byte



No.2 Byte

(Address next to)  
(+1) No.1 Byte

(The correspondence of the operand of symbol instruction and the machine code is recorded, if necessary.)

## &lt;Function &gt;

The logical peration performed by this instruction is explained with symbols.

## &lt;Status Flag &gt;

(F): }      The status after the execution  
(C): }      of status flag is described.

(Dependent on the data when designated to store data in status register.)

## &lt; Execution Cycle &gt;

The number of machine cycles necessary for executing instructions is described.

## &lt; Function Explanation &gt;

The function of instructions is explained.

## &lt; Modifiable Index Instructions &gt;

In processing instructions, modifiable index instructions are described.



## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP4310AP TMP4315BP  
TMP4320AP TMP4300C

In this section, the symbols defined in Table A are used more concisely to express the functions of machine instructions. The storage elements, including input ports, related directly to the operation of instructions are collected in Table B.

Table A. Symbol and their Meanings for Instructions

| Symbol                  | Meaning                                                                             |
|-------------------------|-------------------------------------------------------------------------------------|
| (a)                     | The content of storage element "a".                                                 |
| M[(H,L)]                | The content of RAM address designated by the contents of H register and L register. |
| TEMP                    | Temporary register                                                                  |
| ZR                      | Virtual register of which content is "0".                                           |
| $i_n i_{n-1} \dots i_0$ | Data of $n+1$ bit                                                                   |
| $\bar{b}$               | Values inverted "1" to "0", "0" to "1" every bit of "b".                            |
| $a \leftarrow b$        | "a" is replaced by the value of "b"/                                                |
| $a + 1$                 | Value added 1 to "a".                                                               |
| $a + b$                 | Value added "b" to "a".                                                             |
| $a - b$                 | Value subtracted "b" from "a"/                                                      |
| $a \wedge b$            | Value of logical product of "a" and "b" for every bit.                              |
| $a \vee b$              | Value of logical sum of "a" and "b" for every bit.                                  |
| $a - b$                 | Value of exclusive logical sum of "a" and "b" for every bit.                        |

|                             |                                                                                                  |
|-----------------------------|--------------------------------------------------------------------------------------------------|
| Ones <b>                    | 4-bit data having 1's at bit positions only indicated by "b" and 0's at all other bit positions. |
| $\text{ROM}_H[(\text{DC})]$ | Higher order 4 bits in the content of ROM address indicated by the content of data counter DC.   |
| $\text{ROM}_L[(\text{DC})]$ | Lower order 4 bits in the content of ROM address indicated by the content of data counter DC.    |
| $M[a]$                      | Content of address "a" of RAM.                                                                   |
| $a<_b>$                     | Value of bit position "b" of "a".                                                                |
| $\text{DC}_H$               | Higher order 3 bits of data counter                                                              |
| $\text{DC}_M$               | Intermediate order 4 bits of data counter                                                        |
| $\text{DC}_L$               | Lower order 4 bits of data counter                                                               |
| Carry                       | Carry resulted by operations (overflow)                                                          |
| Borrow                      | Borrow resulted by operations (underflow)                                                        |
| $a = b$                     | "a" equals to "b"                                                                                |
| if a then<br>b else c       | If the condition of "a" is satisfied, "b" is performed; if not, "c" is performed                 |
| \$                          | ROM address in which instructions are stored<br>(No.1 byte address for 2-byte instruction)       |

Table B. Storage Elements Related Directly to Operation of Instructions

| Name        | Mnemonic | Function                               |
|-------------|----------|----------------------------------------|
| Accumulator | AC       | 4-bit register                         |
| Carry flag  | C        | Carry flag of multiple digit operation |
| Branch flag | F        | Condition flag exclusive for branch    |

| Name                 | Mnemonic           | Function                                                                               |
|----------------------|--------------------|----------------------------------------------------------------------------------------|
| Interrupt mask flag  | IM                 | Flag masking interrupt-operation<br>In case of "1", interrupt is permitted.            |
| General purpose flag | G                  | 1 bit flag used by program                                                             |
| L register           | LR                 | Register showing lower order 4 bits of RAM address                                     |
| H register           | HR                 | Register showing higher order 3 bits of RAM address                                    |
| Input port           | INO, IN1, IN2      | Ports for input of external data.                                                      |
| Output port          | OTO, OT1, OT2, OT3 | Ports for output of data                                                               |
| I/O port             | IO0, IO1, IO2      | Ports for input or output of data                                                      |
| Data counter         | DC                 | Counter to read out ROM contents as data                                               |
| Program counter      | PC                 | Counter to read out the instruction under program                                      |
| Stack                | STK                | Stack storing return address from interrupt routine or subroutine (PC evacuation area) |
| Read/Write memory    | RAM                | Memory temporally maintaining data                                                     |
| Read only memory     | ROM                | Memory maintaining program or fixed data                                               |

### 3. Index Instructions

The index instructions indicate source or/and destination of data. The data is processed by the instructions following the index instructions. The fixed data source and destination are designated for the instructions themselves, but if the instructions are modified by the index instructions, the data source and destination become those designated by the index instructions.

Since the index instructions cannot process effective data by themselves, they are invariably used in combination with the processing instructions. Therefore, the interrupt operation cannot be performed after execution of the index instructions, but can be done only after completion of the processing instructions.

One processing instruction can be modified by maximum three index instructions. When sources or destinations have been indicated in duplicate, the initially indicated one becomes effective.

- ① S (Designate Source register) : Source Register Index Instruction

<Symbol Instruction >

S r or = r

<Machine Code >



Operand r = r<sub>3</sub> r<sub>2</sub> r<sub>1</sub> r<sub>0</sub>

<Function > (SA) ← r

< Status Flag > (F) : No change

(C) : No change

< Execution Cycle > 1 Machine Cycle

<Explanation of Function> Write address r of register/port, which becomes data source, in the source address register SA. The source register designated by this instruction is effective until the processing instruction is executed. However, if there are plural numbers of instructions indicating the source register before the processing instruction, the initial index is effective.

- (2) D (Designate Destination register) : Destination Register Index Instruction

< Symbol Instruction >

D    r or = r

< Machine Code >



< Function >

(DA) ← r

< Status Flag >

(F) : No change

(C) : No change

< Executive Cycle >

1 Machine Cycle

< Explanation of Function >

Write address r of register, which becomes a destination as a result of processing, in destination address register DA. The destination register designated by this instruction is effective until the processing instruction is executed. However, if there were plural numbers of instructions indicating the destination register before the processing instruction, the initial index becomes effective.

- (3) SD (Designate Source and Destination register) : Source & Destination Register Index Instruction

< Simbyl Instruction >

SD    r or = r

&lt; Machine Code &gt;

| MSB     | 7                        | 6 | 5 | 4 | 3              | 2              | 1              | LSB            | 0 |
|---------|--------------------------|---|---|---|----------------|----------------|----------------|----------------|---|
|         | 1                        | 0 | 0 | 0 | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> |   |
| Operand | $r = r_3\ r_2\ r_1\ r_0$ |   |   |   |                |                |                |                |   |

&lt; Function &gt;

(SA) ← r      (DA) ← r

&lt; Status Flag &gt;

(F) : No change

(C) : No change

&lt; Executive Cycle &gt;

1 Machine Cycle

&lt; Explanation of Function &gt;

Write address r of the register (same register) becoming data source and destination in source address register SA and destination address register DA. The register designated by this instruction is effective until the processing instruction is executed. However, if the source register or the destination register has been indicated numbers times to one processing instruction in the same way as the instructions of S and D, the index initially made to the respective registers becomes effective.

(4) M (Designate RAM address) : RAM Address Index Instruction

&lt; Symbol Instruction &gt;

M      r or = r

&lt; Machine Code &gt;

| MSB     | 7                        | 6 | 5 | 4 | 3              | 2              | 1              | LSB            | 0 |
|---------|--------------------------|---|---|---|----------------|----------------|----------------|----------------|---|
|         | 1                        | 0 | 1 | 1 | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> |   |
| Operand | $r = r_3\ r_2\ r_1\ r_0$ |   |   |   |                |                |                |                |   |

< Function > (MA) ← r  
< Status Flag > (F) : No change  
(C) : No change  
< Executive Cycle > 1 Machine Cycle  
< Explanation of Function RAM address can be directly designated by this instruction without using H register and L register.  
The RAM address "r" is written in memory address register MA; however, the RAM which can be designated by this instruction is limited to addressed 0 - 15 (16 words in "0" page). These RAM addresses are effective until the processing instruction is executed; that is, the RAM address of the processing instruction modified by this instruction is designated by the memory address register MA regardless of the content of H register and L register.  
There are no changes in the contents of H register and L register.  
If there are numbers of RAM address index instructions before the processing instruction the value initially indicated becomes effective.

#### 4. Decision of Source and Destination by Index Instructions

The way of modifying the processing instruction by index instructions, or the decision of source and destination of the processing instruction, is regulated as follows :

- (O) The elements not modified are unique source and destination for each instruction.



## (1) Instructions related to registers and RAM (9 instructions)

In regard to the nine instructions, such as LDM, SWP, STR, ADD, ADC, SUB, CND, ORM, and EOR, their sources and destinations can be changed by the index instructions (S, D, and SD). When modified by M instruction, RAM data becomes the addresses (0 - 15) designated by M instruction.

## (2) Instructions related to register (13 Instructions)

In regard to the thirteen instructions, such as LDA, LDT, LDI, LLI, CMA, NGT, ADI, ALI, SSB, RSB, LFB, LRL, and LRH, their sources and destinations can be changed by the index instructions (S, D, and SD). When modified by M instruction, the sources and destinations by the S or D instruction become RAM addressed (0 - 15) designated by M instruction.

## (3) As for SDC instruction, the source register can be designated to the intermediate order 4 bits of DC by S Instruction. In this case, the logical sum of the designated source register content and the immediate data is set to the intermediate order 4 bits of DC. When modified by M instructions the intermediate order 4 bits of DC become the contents of RAM addressed (0 - 15) designated by M instruction.

## (4) Subroutine and branch instructions (8 instructions)

In regard to the eight instructions, such as CAL, CLS, RTN, BCF, BCB, JCS, JCC, and JMP, the index instructions cannot be modified. (If they are modified, their operations cannot be guaranteed.)

The following figure shows diagrammatically the relationship between the above mentioned source and destination selection regulation and hardware.



TMP4310AP TMP4315BP

TMP4320AP TMP4300C

The address of source register is stored in source address register SA by S instruction, and the source register is selected by the source selector according to this address.

The data from the selected source register is input into S1 of ALU. Either RAM or ROM is selected by the data selector as data input into S2 of ALU. The selection by this data selector is decided by the instructions.

The address pointer of RAM has HR·LR and memory address register MA. Usually HR·LR is selected, but when modification is made by M instruction, MA is selected. The memory address is stored in MA by M instruction. Since either HR·LR or MA is used as address pointer, if RAM is used as source and destination register, the same address is selected.

The address of destination register is stored in the destination address register DA by D instruction. The destination selector selects destination register according to this address.

The process results output from ALU are stored in the destination register.

By using SD instruction, the same register address is stored into source address register SA and destination address register DA; therefore, the source register of S1 of ALU and the destination of output of ALU become the same.

As shown in the following figure the selector which changes the flow of processing data according to index instructions has the following three kinds of versions:

- (1) Source selector (Selection of source register)
- (2) Destination selector (Selection of destination register)
- (3) RAM address pointer selector

In the case where no modification is made by index instructions, it may be thought that each selector makes the selection of the source or destination.





## INTEGRATEDCIRCUIT

## TECHNICAL DATA

TMP4310AP    TMP4315BP  
TMP4320AP    TMP4300C

Registers can be designated by Index Instructions

| Register code | Symbol   | Name            | TMP4310AP | TMP4315BP | TMP4320AP | TMP4300C |
|---------------|----------|-----------------|-----------|-----------|-----------|----------|
| 0             | AC       | Accumulator     | ○         | ○         | ○         | ○        |
| I             | ST       | Status Register | ○         | ○         | ○         | ○        |
| 2             | LR       | L Register      | ○         | ○         | ○         | ○        |
| 3             | M[(H·L)] | RAM             | ○         | ○         | ○         | ○        |
| 4             | INO      | In. Port 0      | ○         | ○         | ○         | ○        |
| 5             | NULL     | NULL            | ○         | ○         | ○         | ○        |
| 6             | I00      | I/O Port 0      | ○         | ○         | ○         | ○        |
| 7             | I01      | I/O Port 1      | ○         | ○         | ○         | ○        |
| 8             | OT1      | Out. Port 1     | ○         | ○         | ○         | ○        |
| 9             | OT       | Out. Port 0     | ○         | ○         | ○         | ○        |
| A             | HR       | H Register      | ○         | ○         | ○         | ○        |
| B             | -        | -               | Not used  | Not used  | Not used  | Not used |
| C             | OT3      | Out. Port 3     | —         | ○         | ○         | —        |
|               | I02      | I/O Port 2      | ○         | —         | —         | ○        |
| D             | OT2      | Out. Port 2     | Not used  | ○         | ○         | ○        |
| E             | OT2      | In. Port 1      | Not used  | ○         | ○         | ○        |
| F             | IN2      | In. Port 2      | Not used  | ○         | ○         | ○        |

\* Register code C designates I02 for TMP4310AP and TMP4300C and OT3 for TMP4315BP and TMP4320AP. Therefore if it is required to perform evaluation of TMP4315BP and TMP4320AP using TMP4300C, I02 is used as the matching port for OT3.



## 5. Data Processing Instructions

The data processing instructions are classified in four types, data transfer instruction, logical operation instruction, bit processing instruction, and ROM readout instruction.

### 5.1 Data transfer instruction

Data is handled in 4-bit units. The use of these instructions provide the setting of immediate data as well as the data transfer between two registers or between a register and RAM.

#### ⑤) LDM (Load from Memory) : Load from Memory Instruction

< Symbol Instruction >

LDM

< Machine Code >

| MSB | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB | 0 |
|-----|---|---|---|---|---|---|---|-----|---|
|     | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1   | 0 |

< Function >

(AC)  $\leftarrow$  M[(H+L)]

< Status Flag >

(F) : No change

(C) : No change

< Execution Cycle >

1 Machine cycle

< Explanation of >

The content of RAM address designated by H register and L register is loaded into accumulator.

< Modifiable Index Instruction >

D, M

#### ⑥) SWP (Swap) : SWAP Instruction

< Symbol Instruction >

SWP

< Machine Code >

| MSB | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB | 0 |
|-----|---|---|---|---|---|---|---|-----|---|
|     | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0   | 1 |



TMP4310AP TMP4315BP

TMP4320AP TMP4300C

## &lt; Symbol Instruction &gt;

STR

## &lt; Machine Code &gt;

| MSB | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB | 0 |
|-----|---|---|---|---|---|---|---|-----|---|
|     | 0 | 0 | 1 | 0 | 0 | 0 | 1 |     | 0 |

## &lt; Function &gt;

(AC)  $\rightarrow$  M[ (H·L) ]

## &lt; Status Flag &gt;

(F) : No change

(C) : No change

## &lt; Execution Cycle &gt;

1 Machine cycle

## &lt; Explanation of Function &gt;

The content of accumulator is stored in the RAM address designated by H register and L register.

## &lt; Modifiable Index Instruction &gt;

S, M

⑨ LDT (Load and Test) : Load &amp; Test Instruction

## &lt; Symbol Instruction &gt;

LDT

## &lt; Machine Code &gt;

| MSB | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB | 0 |
|-----|---|---|---|---|---|---|---|-----|---|
|     | 0 | 0 | 1 | 0 | 1 | 0 | 1 |     | 0 |

## &lt; Function &gt;

(AC)  $\leftarrow$  (AC)

## &lt; Status Flag &gt;

If (AC) = 0 then (F)  $\leftarrow$  1, else(F)  $\leftarrow$  0

(C) : No change

## &lt; Execution Cycle &gt;

1 Machine cycle

## &lt; Explanation of Function &gt;

The content of accumulator is loaded into the accumulator. If the data is zero, F is set to "1", but if not, F is cleared to "0".

## &lt; Modifiable Index Instruction &gt;

S, D, SD, M

(10) LDI (Load Immediate data) : Load Immediate Data Instruction

&lt; Symbol Instruction &gt;

LDI i (0 ≤ i ≤ 15)

&lt; Machine Code &gt;



&lt; Function &gt;

(AC) ← i

&lt; Status Flag &gt;

(F) : No change

(C) : No change

&lt; Execution Cycle &gt;

1 Machine cycle

&lt; Explanation of Function &gt; Immediate Data i is loaded into accumulator.

&lt; Modifiable Index Instruction &gt;

D, M

(11) LLI (Load Immediate data to L register) : Load Immediate Data to L Register Instruction

&lt; Symbol Instruction &gt;

LLI i (0 ≤ i ≤ 15)

&lt; Machine Code &gt;



&lt; Function &gt;

(LR) ← i

&lt; Status Flag &gt;

(F) : No change

(C) : No change

&lt; Execution Cycle &gt;

1 Machine cycle

&lt; Explanation of Function &gt; Immediate Data i is loaded into L Register

< Modifiable Index Instruction > D, M

## 5.2 Logical operation instruction

The instructions of CMA, CND, ORM and EOR are used for logical operation of every bit of 4-bit data. The others are mainly used for arithmetic operation. For 2-operand instruction one data source is a register and another is RAM.

For the nine instructions except CMA, branch condition flag F is set, and for ADC instruction, carry flag C is set.

### (12) CMA (Complement Accumulator) : Complement Accumulator Instruction

< Symbol Instruction >

CMA

< Machine Code >

| MSB | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB |
|-----|---|---|---|---|---|---|---|-----|
|     | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1   |

< Function >

$(AC) \leftarrow \overline{(AC)}$

< Status Flag >

(F) : No change

(C) : No change

< Execution Cycle >

1 Machine cycle

< Explanation of Function >

The content of accumulator is loaded into the accumulator after inverting "0" to "1" and "1" to "0" every bit.

< Modifiable Index Instruction >

S, D, SD, M

### (13) NGT (Negate) : Negate (2's complement) Instruction

< Symbol Instruction >

NGT

&lt; Machine Code &gt;

| MSB | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB | 0 |
|-----|---|---|---|---|---|---|---|-----|---|
|     | 0 | 0 | 1 | 1 | 1 | 0 | 0 |     | 1 |

&lt; Function &gt;

 $(AC) \leftarrow (\overline{AC}) + 1$ 

&lt; Status Flag &gt;

if Carry then  $(F) \leftarrow 1$ , else  $(F) \leftarrow 0$ 

(C) : No change

&lt; Execution Cycle &gt;

1 Machine cycle

&lt; Explanation of Function &gt;

2's complement of the content of accumulator is loaded into the accumulator. If the original data is 0 ( $(AC)=0$ ), 2's complement is 0. In this case only, F flag is set to "1", but in the other cases, F flag is cleared to "0". In this case F flag is used in both meanings of carry and zero decision.

&lt; Modifiable Index Instruction &gt;

S, D, SD, M

(14) ADD (Add) : Add Instruction

&lt; Symbol Instruction &gt;

ADD

&lt; Machine Code &gt;

| MSB | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB | 0 |
|-----|---|---|---|---|---|---|---|-----|---|
|     | 0 | 0 | 1 | 0 | 1 | 1 | 0 |     | 1 |

&lt; Function &gt;

 $(AC) \leftarrow (AC) + M [(H \cdot L)]$ 

&lt; Status Flag &gt;

if carry then  $(F) \leftarrow 1$ , else  $(F) \leftarrow 0$ 

(C) : No change

&lt; Execution Cycle &gt;

1 Machine cycle



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4310AP      TMP4315BP  
TMP4320AP      TMP4300C

< Explanation of Function >

The content of RAM address designated by the contents of H register and L register is added to the content of the accumulator, and the result is loaded into the accumulator. If the resultant carry is "1", F flag is set to "1", and if it is "0", F flag is cleared to "0".

< Modifiable Index Instruction >      S, D, SD, M

(15) ADC (Add with Carry) : Add with Carry Instruction

< Symbol Instruction >

ADC

< Machine Code >

| MSB | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB | 0 |
|-----|---|---|---|---|---|---|---|-----|---|
|     | 0 | 0 | 1 | 1 | 0 | 1 | 0 |     | 1 |

< Function >

$(AC) \leftarrow (AC) + M [(H \cdot L)] + (C)$

< Status Flag >

if carry then  $(F) \leftarrow 1$ ,  $(C) \leftarrow 1$ , else  $(F) \leftarrow 0$   
 $(C) \leftarrow 0$

< Execution Cycle >

1 Machine cycle

< Explanation of Function >

The content of RAM address designated by H register and L register and the content of C flag are added to the content of accumulator, and the result is loaded into the accumulator. The conditions of Carry cause F flag and C flag to be set/reset.

< Modifiable Index Instruction >      S, D, SD, M



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4310AP    TMP4315BP  
TMP4320AP    TMP4300C

### ⑯ SUB (Subtract) : Subtract Instruction

< Symbol Instruction >

SUB

< Machine Code >

| MSB | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB | 0 |
|-----|---|---|---|---|---|---|---|-----|---|
|     | 0 | 0 | 1 | 1 | 1 | 1 | 0 |     | 1 |

< Function >

(AC)  $\leftarrow$  M[(H·L)] - (AC)

< Status Flag >

if borrow then (F)  $\leftarrow$  0, else (F)  $\leftarrow$  1

(C) : No change

< Execution Cycle >

1 Machine cycle

< Explanation of Function >

The content of accumulator is subtracted from the content of RAM address designated by H register and L register, and the result is loaded into the accumulator. The conditions of underflow cause F flag to be set/reset.

< Modifiable Index Instruction >

S, D, SD, M

### ⑰ CND (Complement & AND) : Complement and AND Instruction

< Symbol Instruction >

CND

< Machine Code >

| MSB | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB | 0 |
|-----|---|---|---|---|---|---|---|-----|---|
|     | 0 | 0 | 1 | 1 | 1 | 1 | 0 |     | 0 |

< Function >

(AC)  $\leftarrow$  (AC) /  $\overline{M[(H \cdot L)]}$

< Status Flag >

if (AC) = 0 then (F)  $\leftarrow$  1, else (F)  $\leftarrow$  0

(C) : No change

&lt; Execution Cycle &gt;

1 Machine cycle

&lt; Explanation of Function &gt;

The logical product of every bit of the content of accumulators and the 1's complement of the content of RAM address designated by the content of H register and L register is loaded into the accumulator. If the result is "0", F flag is set to "1"; in the other cases, F flag is cleared to "0".

&lt; Modifiable Index Instruction &gt;

S, D, SD, M

(18) ORM (OR) : OR Instruction

&lt; Symbol Instruction &gt;

ORM

&lt; Machine Code &gt;

| MSB | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB | 0 |
|-----|---|---|---|---|---|---|---|-----|---|
|     | 0 | 0 | 1 | 0 | 1 | 1 | 1 |     | 0 |

&lt; Function &gt;

 $(AC) \leftarrow (AC) \vee M[(H \cdot L)]$ 

&lt; Status Flag &gt;

if  $(AC)=0$  then  $(F) \leftarrow 1$ , else  $(F) \leftarrow 0$  $(C)$  : No change

&lt; Execution Cycle &gt;

1 Machine cycle

&lt; Explanation of Function &gt;

The logical sum of every bit of the content of accumulator and the content of RAM address designated by H register and L register is loaded into the accumulator. If the result is "0", F flag is set to "1"; in the other cases, F flag is cleared to "0".

&lt; Modifiable Index Instruction &gt;

S, D, SD, M

(19) EOR (Exclusive OR) : Exclusive OR Instruction

&lt; Symbol Instruction &gt;

EOR

&lt; Machine Code &gt;

| MSB | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB | 0 |
|-----|---|---|---|---|---|---|---|-----|---|
|     | 0 | 0 | 1 | 0 | 1 | 1 | 1 |     | 1 |

&lt; Function &gt;

 $(AC) \leftarrow (AC) \nabla M[(H \cdot L)]$ 

&lt; Status Flag &gt;

 if  $(AC)=0$  then  $(F) \leftarrow 1$ , else  $(F) \leftarrow 0$ 

(C) : No change

&lt; Execution Cycle &gt;

1 Machine cycle

&lt; Explanation of Function &gt;

The exclusive logical sum of every bit of the content of accumulator and the content of RAM address designated by H register and L register is loaded into the accumulator.

If the result is "0", F flag is set to "1"; in the other cases, F flag is cleared to "0".

&lt; Modifiable Index Instruction &gt;

S, D, SD, M

(20) ADI (Add Immediate data) : Add Immediate Data Instruction

&lt; Symbol Instruction &gt;

 ADI      i       $(0 \leqq i \leqq 15)$ 

&lt; Machine Code &gt;

| MSB | 7 | 6 | 5 | 4 | 3  | 2  | 1  | LSB | 0  |
|-----|---|---|---|---|----|----|----|-----|----|
|     | 0 | 1 | 1 | 1 | i3 | i2 | i1 |     | i0 |

 Operand     $i = i_3 \ i_2 \ i_1 \ i_0$ 

&lt; Function &gt;

 $(AC) \leftarrow (AC) + i$



# INTEGRATED CIRCUIT

東芝  
TOSHIBA

## TECHNICAL DATA

TMP4310AP      TMP4315BP

TMP4320AP      TMP4300C

< Status Flag >

if Carry then (F)  $\leftarrow 1$ , else (F)  $\leftarrow 0$ ,  
(C) : No change

< Execution Cycle >

1 Machine cycle

< Explanation of Function >

Immediate data "i" is added to the content of accumulator and the result is loaded into the accumulation.

If the resultant carry is generated, F flag is set to "1"; in the other case, F flag is cleared to "0".

< Modifiable Index Instruction >

S, D, SD, M

② ALI (Add Immediate data to L register) :

Add Immediate Data to L Register Instruction

Symbol Instruction

ALI        i        ( $0 \leq i \leq 15$ )

< Machine Code >



< Function >

(LR)  $\leftarrow$  (LR) + i

< Status Flag >

if Carry then (F)  $\leftarrow 1$ , else (F)  $\leftarrow 0$   
(C) : No change

< Execution Cycle >

1 Machine cycle

< Explanation of Function >

Immediate date "i" is added to the content of L register, and the result is loaded into L register. If resultant carry is generated, F flag is set to "1"; in the other cases, F flag is cleared to "0".

< Modifiable Index Instruction >

S, D, SD, M

### 5.3 Bit manipulation instruction

Ordinary data is manipulated as 4-bit units, however the use of these instructions enables the data to be manipulated bit by bit. These instructions are mainly applied to status register ST, but their functions can be extended to arbitrary register, output port and RAM by a combination of index instructions.

#### (22) SSB (Set Status Bit) : Set Status Bit Instruction

< Symbol Instruction >

SSB      b      ( $3 \geq b \geq 0$ )

< Machine Code >



< Function >

$(ST) \leftarrow (ST) \vee \text{Ones} < b >$      $(ST < b > \leftarrow 1)$

< Status Flag >

There may be flags (bits) changed by the execution itself of this instruction, but there are no flags changed by the result of the execution.

< Execution Cycle >

1 Machine cycle

< Explanation of Function >

The bit field of the status register defined by low order 2 bits "b" of the instruction is set to a "1".

< Modifiable Index Instruction >

SD, M

#### (23) RSB (Reset Status Bit) : Reset Status Bit Instruction

< Symbol Instruction >

SRB      b      ( $3 \geq b \geq 0$ )

< Machine Code >

|     |   |   |   |   |   |   |       |     |       |
|-----|---|---|---|---|---|---|-------|-----|-------|
| MSB | 7 | 6 | 5 | 4 | 3 | 2 | 1     | LSB | 0     |
|     | 0 | 0 | 0 | 1 | 1 | 1 | $b_1$ |     | $b_0$ |

Operand     $b = b_1 \ b_0$

< Function >

$(ST) \rightarrow \neg(ST) \wedge \text{Ones} < b \Rightarrow (ST <b>\leftrightarrow 0)$

< Status Flag >

There may be flags (bits) changed by the execution itself of this instruction, but there are no flags changed by the result of the execution.

### < Execution Cycle >

1 Machine cycle

## < Explanation of Function >

The bit field of the status register defined by the low order 2 bits "b" of the instruction is set to a "0".

< Modifiable Index Instruction >

SD, M

24 LFB (Load complemented status Bit to F)

## Load and Complement Status Bit to F Instruction

< Symbol Instruction >

LFB      b      (3 > b > 0)

< Machine Code >

MSB

LSE

Operand       $b = b_1 b_0$

< Function >

(F)  $\rightarrow \cdot \cdot \cdot \overline{ST} <\overline{b}>$

< Status Flag >

(F) : According to condition of ST **< b >**  
(C) : No change

### < Execution Cycle >

1 Machine cycle

TMP4310AP TMP4315BP

TMP4320AP TMP4300C

&lt; Explanation of Function &gt;

If the bit content of status register designated by lower order 2 bits of the instruction is 1, it is inverted to 0, and it is 0, it is inverted to 1, and then it is loaded into F bit.

&lt; Modifiable Index Instruction &gt;

S, M

## 5.4 ROM readout instruction

SDC is the instruction by which the address on ROM of fixed data is set into data counter DC. LRL and LRH are the instructions by which ROM data are readout in the 4-bit unit.

(25) SDC (Set Data Counter) : Set Data Counter Instruction

&lt; Symbol Instruction &gt;

SDC      a       $16 \leq a \leq 2032$ , where "a" is  
 ( integral multiples of 16. )  
 i.e.  $a = 16n, 1 \leq n \leq 127$

&lt; Machine Code &gt;

• Operand  $a = a_{10} a_9 a_8 a_7 a_6 a_5 a_4 0000$ 

&lt; Function &gt;

$$\left. \begin{array}{l} (DC_H) \leftarrow a_{10} a_9 a_8 \\ (DC_M) \leftarrow a_7 a_6 a_5 a_4 \vee (ZR) \\ (DCL) \leftarrow M[(H \cdot L)] \end{array} \right\} \text{i.e. } (DC) \leftarrow a + M[(H \cdot L)]$$

&lt; Status Flag &gt;

(F) : No change

(C) : No change

&lt; Execution Cycle &gt;

2 Machine cycle

&lt; Explanation of Function &gt;

This instruction sets ROM address into the data counter. The higher order 3 bits of ROM address to be set are immediate values, and the intermediate 4 bits are the logical sum of intermediate value and virtual source register ZR, of which content is "0", and the lower order 4 bits are the content of RAM address indicated by H register and L register. When source register is designated by the index instructions, ZR OR-ed to the intermediate 4 bits becomes the content of its source register, being effectively activated.

The content of data counter after the execution of instruction is as follows, if it is not modified by index instructions:



&lt; Modifiable Index Instruction &gt;      S, M

(26) LRL (Load ROM Lower data) : Load ROM Lower Data Instruction

&lt; Symbol Instruction &gt;

LRL

&lt; Machine Code &gt;





# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4310AP      TMP4315BP  
TMP4320AP      TMP4300C

|                                                                    |                                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| < Function >                                                       | (AC) $\leftarrow$ ROM <sub>L</sub> [(DC)]                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| < Status Flag >                                                    | (F) : No change                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|                                                                    | (C) : No change                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| < Execution Cycle >                                                | 2 Machine cycle                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| < Explanation of Function >                                        | This instruction loads the accumulator with the lower order 4 bits of the content of ROM address designated by the content of data counter.                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| < Modifiable Index Instruction >                                   | D, M                                                                                                                                                                                                                                                               |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| (27) RLH (Load ROM Higher data) : Load ROM Higher Data Instruction |                                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| < Symbol Instruction >                                             | LRH                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| < Machine Code >                                                   | MSB <span style="float: right;">LSB</span>                                                                                                                                                                                                                         |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|                                                                    | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td> </tr> <tr> <td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td><td>0</td> </tr> </table> | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 |
| 7                                                                  | 6                                                                                                                                                                                                                                                                  | 5 | 4 | 3 | 2 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |
| 0                                                                  | 0                                                                                                                                                                                                                                                                  | 1 | 1 | 0 | 0 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |
| < Function >                                                       | (AC) $\leftarrow$ ROM <sub>H</sub> [(DC)]                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|                                                                    | (DC) $\leftarrow$ (DC) + 1                                                                                                                                                                                                                                         |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| < Status Flag >                                                    | (F) : No change                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|                                                                    | (C) : No change                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| < Execution Cycle >                                                | 2 Machine cycle                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| < Explanation of Function >                                        | This instruction loads the accumulator with the higher order 4 bits of the content of ROM address designated by the content of data counter; after-ward, the content of data counter is increased by one.                                                          |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| < Modifiable Index Instruction >                                   | D, M                                                                                                                                                                                                                                                               |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |



## 6 Subroutine Instructions

When subroutine call and interrupt operation are performed, the value of PC should be stored in a stack in order to keep return address.

Four levels of PC stacks are provided for the interrupt operation and the subroutine call, enabling four-level nesting to be performed. The 4th stack serves for data counter DC; therefore, when data counter is in use, the operation of nesting should be restricted to three levels. Otherwise, the content of data counter is destroyed, resulting in the deletion of the return address. When the four-level nesting is in operation, no interrupt operation is performed. Also, no storage of PC by call subroutine instruction is performed.

(28) CAL (Call subroutine) : Call Instruction (2 Bytes)

< Symbol Instruction >

CAL a (0 ≤ a ≤ 2047)

### < Machine Code >

lst Byte

|  |   |   |   |   |   |          |       |       |
|--|---|---|---|---|---|----------|-------|-------|
|  | 7 | 6 | 5 | 4 | 3 | 2        | 1     | 0     |
|  | 1 | 1 | 0 | 0 | 1 | $a_{10}$ | $a_9$ | $a_8$ |

| 7               | 6     | 5     | 4     | 3     | 2     | 1     | 0     |       |
|-----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| <b>2nd Byte</b> | $a_7$ | $a_6$ | $a_5$ | $a_4$ | $a_3$ | $a_2$ | $a_1$ | $a_0$ |

## < Function >

Operand       $a = a_{10}a_9a_8a_7a_6a_5a_4a_3a_2a_1a_0$

(PC) —→ (STK) push down

(PC) → a

< Status Flag >

(F) : No change

(C) : No change

### < Execution Cycle >

## 2 Machine cycle

## < Explanation of Function >

This is a subroutine call instruction which directly indicates the entry address of subroutine.



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4310AP TMP4315BP

TMP4320AP TMP4300C

The return address is put into a stack, and the designated value (the entry address of subroutine)  $a=a10a9a8a7a6a5a4a3a2a1a0$  is set to PC.

The stack of return address is a push down stack which can be stacked up to 4 levels. Since the fourth level is a data counter, precautions for use should be taken.

&lt; Modifiable Index &gt;

No instruction

(29) CLS (Call Subroutine by single byte) : Call by Single Byte  
Instruction

&lt; Symbol Instruction &gt;

CLS i (0 ≤ i ≤ 15)

&lt; Machine Code &gt;

MSB LSB

Operand i=i<sub>3</sub>i<sub>2</sub>i<sub>1</sub>i<sub>0</sub>

&lt; Function &gt;

(PC) → (STK) push down

(PC) ← i × 8 + 4

&lt; Status Flag &gt;

(F) : No change

(C) : No change

&lt; Execution Cycle &gt;

1 Machine cycle

&lt; Explanation of Function &gt;

This instruction stores a return address into a stack, calculates (=000 i<sub>3</sub>i<sub>2</sub>i<sub>1</sub>i<sub>0</sub>100) i × 8 + 4 as subroutine entry address from the entry address No. i designated to the operand, and sets the result to PC.

The stack of return address is of push-down stack which can stack as high as 4 levels.

Since the fourth level is a data counter, precautions for use should be taken.

< Modifiable Index Instruction >

### No instruction

(30) RTN (Return) : Return Instruction

## < Symbol Instruction >

RIN

< Machine Code >

A binary number is shown with 32 bits. The most significant bit (MSB) is at the far left, and the least significant bit (LSB) is at the far right. The bits are labeled from 7 down to 0 from left to right.

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 |

### < Function >

(PC) → (STK) last in data

< Status Flag >

(F) : No change

(C) : No change

### < Execution Cycle >

### 1 Machine cycle

## < Explanation of Function >

This instruction causes a return from an interrupt routine and a subroutine to the main program. The newest return address stored in the stack is loaded into the program counter.

## < Modifiable Index Instruction >

### No instruction

7 Branch Instruction

Among the branch instructions, there is an on-condition-set/cleared branch instruction of which condition is decided whether or not branch operation is performed depending upon the value of F flag in the program status register; therefore, it should be considered how the value of F flag is changed by the data processing instruction just before the use of the conditional branch instruction. BRC is limited in branch range, but this instruction can reduce the number of bytes of ROM because of a single byte instruction.

The unconditional jump instruction shifts unconditionally the execution flow of the instruction to the address indicated by the address field of this instruction.

(31) BRC (ranch on Condition set) : Branch on (F) = 1 Forward  
Instruction

(32) BRC (Branch on Condition set) : Branch on (F) = 1 Backward  
Instruction

## Λ Symbol Instruction Υ

BRC      a       $0 \leq a \leq 2047$ ,  
 $(-16 \leq a - \$ \leq 15)$

< Machine Code >

MSB LSE



a-S=j3j2j1j0

$a - \$ \geq 0$ ,  $\overline{S} = 1 \dots$  Branch on  $(F) = 1$  Forward  
Instruction

$a - \$ \leq 0$ ,  $\overline{S} = 0 \dots$  Branch on ( $F = 1$ ) Backward Instruction

< Function >

if ( $F=1$ ) then  $(PC) \leftarrow a$ , else No  
operation  $((PC) \leftarrow (PC) + 1)$

< Status Flag >

(F) : No change

(C) : No change

### < Execution Cycle >

## 1 Machine cycle

## < Explanation of > Function

If F flag of status flag is set to "1", the value of program counter is changed to the absolute address "a" defined by the operand field of the instruction. In the other cases, the program counter advances by one and execution of the next instruction will be initiated without any other operations.



The range of absolute address "a" is -16 - 15 against ROM address "\$" stored by this instruction itself.

< Modifiable Index >  
Instruction

No instruction

(33) JCS (Jump on Condition Set) : Jump on(F)= 1 Instruction

< Symbol Instruction >

JCS      a      ( $0 \leq a \leq 2047$ )

### < Machine Code >

MSB LSP

### 1st Byte



2nd Byte



Operand a=a<sub>10</sub>a<sub>9</sub>a<sub>8</sub>a<sub>7</sub>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>

### < Function >

if (F)=1 then (PC)  $\leftarrow$  a, else No Operation

< Status Flag >

(F) : No change

(C) : No change

### < Execution Cycle >

2 Machine cycle

< Explanation of Function >

If F flag is set to "1", this instruction causes to branch to the address "a" indicated by the lower order 11 bits of this instruction. In the other cases, execution of the next instruction with be initiated without any other operations.

## < Modifiable Index Instruction >

No instruction

(34) JCC (Jump on Condition Cleared) : Jump on (F)=0 Instruction

< Symbol Instruction >

JCC      a            ( $0 \leq a \leq 2047$ )



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4310AP    TMP4315BP  
TMP4320AP    TMP4300C

&lt; Machine Code &gt;

1st Byte

| MSB |   |   |   |   |     |    |    | LSB |    |    |
|-----|---|---|---|---|-----|----|----|-----|----|----|
| 7   | 6 | 5 | 4 | 3 | 2   | 1  | 0  | a10 | a9 | a8 |
| 1   | 1 | 1 | 0 | 1 | a10 | a9 | a8 |     |    |    |

2nd Byte

| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|
| a7 | a6 | a5 | a4 | a3 | a2 | a1 | a0 |

Operand a=a10 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0

&lt; Function &gt;

if (F)=0 then (PC)  $\leftarrow$  a, else No Operation

&lt; Status Flag &gt;

(F) : No change

(C) : No change

&lt; Execution Cycle &gt;

2 Machine cycle

&lt; Explanation of Function &gt;

If F flag is cleared to "0", this instruction causes to branch to the address "a" indicated by the lower order 11 bits of the instruction. In the other cases, execution of the next instruction will be initiated without any other operations.

&lt; Modifiable Index Instruction &gt;

No instruction

(35) JMP (Jump) : Unconditional Jump Instruction

&lt; Symbol Instruction &gt;

JMP a (0  $\leqq$  a  $\leqq$  2047)

&lt; Machine Code &gt;

1st Byte

| MSB |   |   |   |   |   |     |    | LSB |    |    |
|-----|---|---|---|---|---|-----|----|-----|----|----|
| 7   | 6 | 5 | 4 | 3 | 2 | 1   | 0  | a10 | a9 | a8 |
| 1   | 1 | 0 | 0 | 0 |   | a10 | a9 | a8  |    |    |

2nd Byte

| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|
| a7 | a6 | a5 | a4 | a3 | a2 | a1 | a0 |

Operand a=a10 a9 a8 a7 a6 a5 a4 a3 a2 a1 a0

Toshiba

# INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP4310AP TMP4315BP

TMP4320AP TMP4300C

|                                  |                                                                                                                             |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| < Function >                     | (PC) $\leftarrow$ a                                                                                                         |
| < Status Flag >                  | (F) : No change<br>(C) : No change                                                                                          |
| < Executio Cycle >               | 2 Machine cycle                                                                                                             |
| < Explanation of Function >      | This instruciton causes an unconditional branch to the address "a" indicated by the lower order 11 bits of the instruction. |
| < Modifiable Index Instruction > | No instruction                                                                                                              |

**[OPERATION DESCRIPTION]**
**1. Basic Clock**

The basic clock generates the basic timing sequences required for the operations of TLCS-43. There are the following methods of options generating the basic clock.

**(1) Direct Connection of the Oscillator**


When a crystal oscillator, or a ceramic oscillator, or a IFT, is connected as shown at the left, the frequency of TLCS-43 basic clock is equal to that of the oscillator. (Except TMP4310AP)

**(2) Supply of External Clock**


The basic clock of TLCS-43 can also be supplied by an external oscillator circuit as shown at the left.

The external clock input should be sinusoidal or square wave vibrating with levels between 0 volts and 5 volts.

**(3) Internal Oscillation**


The basic clock of TMP4310AP can be obtained by connecting the resistance as shown in the left figure.

(fosc = 250kHz - 450 kHz at R=43kΩ)

(Except TMP4315BP, TMP4320AP, TMP4300C)

**2. Initialize Operation**

The initialize operation of TLCS-43 is performed by placing RST terminal at the low level as shown below. The minimum time period of four basic clock cycle is required for the low level pulse width.



| $0 \leq W < 1.5$ cycles                    | $1.5 \text{ cycles} \leq W < 4$ cycles                   | $4 \text{ cycles} \leq W$              |
|--------------------------------------------|----------------------------------------------------------|----------------------------------------|
| The initialize operation is not performed. | Whether or not the initialize operation is not definite. | The initialize operation is performed. |

One cycle is equal to one cycle of the basic clock.

The initialize operation performs the following functions.

| Block             | Symbol | Initialize Function                 |
|-------------------|--------|-------------------------------------|
| Program counter   | PC     | Cleared to "0"                      |
| Interrupt latch   | IL     | Cleared                             |
| Interrupt flag    | IM     | Cleared to "0" disabling interrupt. |
| Output port       | OT0    | All bits are set to "1".            |
|                   | OT1    | All bits are set to "1".            |
|                   | OT2    | All bits are set to "1".            |
|                   | OT3    | All bits are set to "1".            |
| Input/Output port | IO0    | All output bits are set to "1".     |
|                   | IO1    | All output bits are set to "1".     |
|                   | IO2    | All output bits are set to "1".     |
| Stack             | STK    | Made empty.                         |

While RST terminal is held at the low level, only the above functions are taken place and other operations, such as execution of program are not performed.

When RST terminal is returned to the high level, the program starting from address 0 is executed.

(Note) C, F and G of the status register are not reset.

Therefore, these must be taken care of by the program.

And any index instructions executed prior to the initialization are ignored.

Toshiba

東芝

## INTEGRATED CIRCUIT

## TECHNICAL DATA

 TMP4310AP      TMP4315BP  
 TMP4320AP      TMP4300C


a switch should be connected for this purpose.

If a capacitor is connected to  $\overline{RST}$  terminal as shown at the left, the initialize operation is automatically performed when the power supply is turned on. And if it is required to perform the initialize operation manually,

## 3. Interrupt Operation

## (1) Interrupt Operation

TLCS-43 has the function which allows the interrupt operation to be triggered externally. The interrupt operation is performed by holding  $\overline{INT}$  terminal at the low level for four basic clock cycles or more. However, several conditions must be satisfied to initiate the interrupt operation. Such conditions are as follows.

1. Interrupt flag IM has been set and one or more instructions have been executed after the flag was set.
2. Four levels of subroutine nesting have not been performed.

The interrupt request signal from outside is retained in interrupt latch IL located inside and once an interrupt is accepted, IL and interrupt flag IM are cleared.

If it is desired to trigger an interrupt again,  $\overline{INT}$  terminal must be returned to the high level (for two basic clock cycles or more) and must be placed at the low level again. Repetitive interrupts are not accepted keeping  $\overline{INT}$  terminal at the low level.

Setting and repetitive setting of IL by  $\overline{INT}$  signal are performed in the following timings.

(Setting Timing of IL).



| $0 \leq W < 1$ cycle | $1 \text{ cycle} \leq W < 4$ cycles       | $4 \text{ cycles} \leq W$ |
|----------------------|-------------------------------------------|---------------------------|
| IL is not set.       | Whether or not IL is set is not definite. | IL is set.                |

(Repetitive Setting of II.)



Where one cycle is equal to one cycle of the basic clock.

When an interrupt is accepted, the content of program counter PC is pushed down to stack STK and the entry address (address 2) of the interrupt service routine is set in the program counter.

The accumulator, the status register, L register and H register which are used in the interrupt program must be saved into RAM area in the service routine.

When returning to execution of the main routine after completing the interrupt routine the saved registers are returned and the interrupt flag which has been reset is set to "1". Then, execution of Return instruction causes to return to execution of the main routine.

## (2) Timing of Interrupt Enable/Disable

### ① Interrupt Flag Set/Reset



- ② When stack is used up to the deepest level (level 3)  
 (Assumption: IM flag is set "1" constantly)



Interrupt enable state

Interrupt disable state      Enable      Disable      Enable      Disable      Enable

Even if IL and IM have been set, if the stack is occupied fully up to the deepest level (level 3), any interrupt are not accepted and must wait until level 3 becomes available.

### (3) Relationship between INT Signal and RST Signal

When the interrupt request signal and the initialize signal occur simultaneously, the operation shown in the following examples takes place.



$D' < 1$  cycle ..... The interrupt request is accepted after the initialize operation.

$1 \text{ cycle} \leq D' < 5$  cycles ... Acceptance of the interrupt request is not definite after the initialize operation.

$D' \geq 5$  cycles ..... Only the initialize operation performed and the interrupt request is not accepted.

Where one cycle is equal to one cycle of the basic clock.

#### 4. Types of Output Buffers

For the output buffers of output ports and input/output ports, the following types (A) or (B) can be specified by designating a mask option. Since these types are selected by the same mask as the user program mask, these must be specified based on the mask ROM data type format. (Refer to the mask ROM data tape format.)

When data is input from the input/output ports, the output data must have been set to "1" in advance for both (A) and (B) types.

For the electrical characteristics, refer to the paragraphs of ABSOLUTE MAXIMUM RATINGS and DC CHARACTERISTICS. Since the pull-up resistors are provided by MOS transistors, the characteristics are somewhat different from normal resistors.



$$V_{OH} \geq 2.4V (I_{OH} = -100\text{ A})$$

$$V_{OL} \leq 0.4V (I_{OL} = 1.6\text{mA})$$

(A) With Pull-up Resistance



$$I_{LO} \leq 20\text{ A} (V_{OUT} = V_{DD})$$

$$V_{OL} \leq 0.4V (I_{LO} = 1.6\text{mA})$$

(B) Open Drain

Since all the bits of TMP4300C output ports and input/output ports are the open drain type, the mask option can not be specified.

#### 5. Pull-up Resistors of $\overline{RST}$ Terminal and $\overline{INT}$ Terminal

All versions of TLCS-43 are provided with the pull-up quasi resistors (typical value of 100k ohms) fabricated with MOS transistors for  $\overline{RST}$  and  $\overline{INT}$  terminals. The guaranteed value of general electrical characteristics of these resistors are  $I_{IL2\text{ MAX.}} = -0.1\text{ mA} (V_{IN} = 0.6V)$ . (Refer to DC CHARACTERISTICS.)

## [EVALUATOR CHIP DESCRIPTION]

TMP4300C is the evaluator chip which is used for development of the application systems (or programs) for TLCS-43.

For these purposes, some terminals and functions have been added to TMP4300C in addition to those of other TLCS-43 chips.

The terminals and the functions dedicated to TLCS-43 development tool (TDS400/43) are also provided, and refer to the operation manual of TDS400/43 for details.

## 1. Operation Timing

The normal operation timing of TMP4300C is shown in the figure below.

The timings of the initialize operation and the interrupt operation are exactly same as the operation timings of other TLCS-43 chips.



## 2. Example of TMP4300C Application

The diagram below illustrates an example of connection with an EPROM, which allows the program confirmation before confirming program to ROM.

\* TMM323C is 2716 type EPROM with 16K bits (2,048 words x 8 bits)

TMP4310AP      TMP4315BP  
 TMP4320AP      TMP4300C



### 3 Caution for Using I02 Port

The output port and the input/output port of TLCS-43 have the configurations shown below.



TMP4310AP TMP4315BP

TMP4320AP TMP4300C

Therefore, when a circuit which clamps the output voltage level is directly connected externally to the terminal, and the output data is referenced by the program, it can be correctly read for the output port. However for the input/output ports there is possibility of reading erroneous data if the input voltage level is not secured by the clamp circuit. In order to read the data correctly, the terminals and the clamp circuits are required to be separated by the buffer circuits.

When a system development is conducted for TMP4315BP and TMP4320AP using TMP4300C, the pairing port for the output port OT3 is the input/output port I02. Therefore, when it is required for a program to reference output data in OT3 port in a system using TMP4315BP or TMP4320AP, care should be taken not to directly connect a circuit which clamps the output level to I02 port, during the evaluation stage using TMP4300C.

(Circuit of Actual Application) (Circuit of Evaluation Stage)





## INTEGRATED CIRCUIT



## TECHNICAL DATA

TMP4310AP TMP4315BP

TMP4320AP TMP4300C

## TMP4310AP ELECTRICAL CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS

| Symbol              | Item                                         | Rating         |
|---------------------|----------------------------------------------|----------------|
| V <sub>DD</sub>     | V <sub>DD</sub> Supply Voltage               | -0.5V to 7V    |
| V <sub>DD</sub>     | Input Voltage                                | -0.5 V to 7V   |
| V <sub>OUT1</sub>   | Output Voltage (Except Open Drain Pins)      | -0.5V to 7V    |
| V <sub>OUT2</sub>   | Output Voltage (Open Drain Pins)             | -0.5V to 10V   |
| I <sub>OUT1</sub>   | Average Output Current (Except OT1)          | 4mA            |
| I <sub>OUT2</sub>   | Output Current (OT1)                         | 30mA           |
| P <sub>D</sub>      | Power Dissipation (TA=70°C)                  | 700mA          |
| T <sub>SOLDER</sub> | Soldering Temperature (Soldering Time 10sec) | 260°C          |
| T <sub>STG</sub>    | Storage Temperature                          | -55°C to 125°C |
| T <sub>OPR</sub>    | Operating Temperature                        | -10°C to 70°C  |

## DC CHARACTERISTICS

T<sub>A</sub>=-10°C to 70°C , V<sub>DD</sub>=5V ± 10 %, Unless Otherwise Noted

| Symbol           | Parameter                                                                                        | Test Conditions                  | Min.                             | Typ. | Max.            | Units |
|------------------|--------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------|------|-----------------|-------|
| V <sub>IH1</sub> | Input High Voltage (I <sub>NO</sub> , I <sub>O0</sub> , I <sub>O1</sub> , I <sub>O2</sub> , RST) |                                  | 2.2                              |      | V <sub>DD</sub> | V     |
| V <sub>IH2</sub> | Input High Voltage (INT)                                                                         |                                  | 3.5                              |      | V <sub>DD</sub> | V     |
| V <sub>IL</sub>  | Input Low Voltage                                                                                |                                  | 0                                |      | 0.1             | V     |
| V <sub>CH</sub>  | Clock Input High Voltage (X <sub>IN</sub> )                                                      | External Drive                   | 3.8                              |      | V <sub>DD</sub> | V     |
| V <sub>CL</sub>  | Clock Input Low Voltage (X <sub>IN</sub> )                                                       | External Drive                   | 0                                |      | 0.6             | V     |
| I <sub>IN1</sub> | Input Current (I <sub>NO</sub> )                                                                 | V <sub>IN</sub> =V <sub>DD</sub> |                                  |      | 20              | µA    |
| I <sub>IN2</sub> | Input Current (I <sub>O0</sub> , I <sub>O1</sub> , I <sub>O2</sub> )                             | Open Drain                       | V <sub>IN</sub> =V <sub>DD</sub> |      | 20              | µA    |
|                  |                                                                                                  | Pull Up                          |                                  |      | -               | -     |
| I <sub>ILL</sub> | Input Low Current (I <sub>O0</sub> , I <sub>O1</sub> , I <sub>O2</sub> )                         | Open Drain                       |                                  |      | -               | -     |
|                  |                                                                                                  | Pull Up                          | V <sub>IN</sub> =0.6V            |      | -1.6            | mA    |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4310AP      TMP4315BP  
 TMP4320AP      TMP4300C

| Symbol    | Parameter                                       | Test Condition | Min.               | Typ. | Max. | Unch    |
|-----------|-------------------------------------------------|----------------|--------------------|------|------|---------|
| $I_{IL2}$ | Input Low Current ( $\bar{RST}$ , $\bar{INT}$ ) | $V_{IN}=0.6V$  |                    |      | -0.1 | mA      |
| $I_{LO}$  | Output Lead Current<br>(OT0, OT1)               | Open Drain     | $V_{OUT}=V_{DD}$   |      | 20   | $\mu A$ |
|           |                                                 | Pull Up        |                    |      | -    | -       |
| $V_{OH}$  | Output High Voltage                             | Open Drain     |                    |      | -    | -       |
|           |                                                 | Pull Up        | $I_{OH}=-100\mu A$ | 2.4  |      | V       |
| $V_{OL}$  | Output Low Voltage (Note)                       |                | $I_{OL}=1.6mA$     |      | 0.4  | V       |
| $I_{DD}$  | $V_{DD}$ Supply Current                         |                |                    |      | 40   | 80      |
|           |                                                 |                |                    |      | mA   |         |

Note: Output port OT1 can sink large current. ( $I_{OL}$  TYP.=20mA,  $V_{OL}=2.0V$ )

While sinking large current, the output low voltage ( $V_{OL}$ ) limit is the following value.

$$V_{OL} \text{ Max.}=0.5V \quad (I_{OL}=1.6mA)$$

AC CHARACTERISTICS      Refer to TIMING WAVEFORMS (1).

$T_A=-10^\circ C$  to  $70^\circ C$  ,  $V_{DD}=5V \pm 10\%$  , Unless Otherwise Noted.

| Symbol       | Parameter                         | Test Condition                         | Min. | Typ. | Max. | Units       |
|--------------|-----------------------------------|----------------------------------------|------|------|------|-------------|
| $t_{\phi 0}$ | Clock Cycle Time                  |                                        | 2    |      | 5    | $\mu s$     |
| $t_s$        | Input Set up Time                 |                                        | 0.9  |      |      | $\mu s$     |
| $t_h$        | Input Hold Time                   |                                        | 0.9  |      |      | $\mu s$     |
| $t_D$        | Output Delay Time                 | $C_L=50PF, R(\text{Pull-up})=50k, TTL$ |      |      | 1.8  | $\mu s$     |
| $t_{INT}$    | $\bar{INT}$ Low Level Pulse Width |                                        | 4    |      |      | Clock Cycle |
| $t_{RST}$    | $\bar{RST}$ Low Level Pulse Width |                                        | 4    |      |      | Clock Cycle |
| fosc         | Internal Oscillation Frequency    | $R=43k$                                | 250  |      | 450  | kHz         |

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TOSHIBA INTEGRATED CIRCUITS  
TMP4310AP TMP4315BP

TMP4320AP TMP4300C



## TMP4315BP ELECTRICAL CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS

| Symbol              | Item                                           | Rating         |
|---------------------|------------------------------------------------|----------------|
| V <sub>DD</sub>     | V <sub>DD</sub> Supply Voltage                 | -0.5V to 7V    |
| V <sub>IN</sub>     | Input Voltage                                  | -0.5V to 7V    |
| V <sub>OUT1</sub>   | Output Voltage (Except Open Drain Pins)        | -0.5V to 7V    |
| V <sub>OUT2</sub>   | Output Voltage (Open Drain Pins)               | -0.5V to 10V   |
| I <sub>OUT1</sub>   | Average Output Current                         | 4mA            |
| P <sub>D</sub>      | Power Dissipation (TA=70°C)                    | 700mW          |
| T <sub>SOLDER</sub> | Soldering Temperature (Soldering Time, 10sec.) | 260°C          |
| T <sub>STG</sub>    | Storage Temperature                            | -55°C to 125°C |
| T <sub>OPR</sub>    | Operating Temperature                          | -10°C to 70°C  |

## ELECTRICAL CHARACTERISTICS

TA=-10°C to 70°C, V<sub>DD</sub>=5V ± 10 %, Unless Otherwise Noted.

| Symbol           | Parameter                                                                                                          | Test Condition                   | Min.                              | Typ. | Max.            | Units |    |
|------------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------|------|-----------------|-------|----|
| V <sub>IHI</sub> | Input High Voltage (I <sub>NO</sub> , I <sub>N1</sub> , I <sub>N2</sub> , I <sub>O0</sub> , I <sub>O1</sub> , RST) |                                  | 2.2                               |      | V <sub>DD</sub> | V     |    |
| V <sub>IH2</sub> | Input High Voltage (INT)                                                                                           |                                  | 3.5                               |      | V <sub>DD</sub> | V     |    |
| V <sub>IL</sub>  | Input Low Voltage                                                                                                  |                                  | 0                                 |      | 0.6             | V     |    |
| V <sub>CH</sub>  | Clock Input High Voltage (X <sub>IN</sub> )                                                                        | External Drive                   | 3.8                               |      | V <sub>DD</sub> | V     |    |
| V <sub>CL</sub>  | Clock Input Low Voltage (X <sub>IN</sub> )                                                                         | External Drive                   | 0                                 |      | 0.6             | V     |    |
| I <sub>IN1</sub> | Input Current (I <sub>NO</sub> , I <sub>N1</sub> , I <sub>N2</sub> )                                               | V <sub>IN</sub> =V <sub>DD</sub> |                                   |      | 20              | μA    |    |
| I <sub>IN2</sub> | Input Current(I <sub>O0</sub> , I <sub>O1</sub> )                                                                  | Open Drain                       | V <sub>IN</sub> =V <sub>DD</sub>  |      | 20              | μA    |    |
|                  |                                                                                                                    | Pull up                          |                                   |      | -               | -     |    |
| I <sub>IL1</sub> | Input Low Current (I <sub>O0</sub> , I <sub>O1</sub> )                                                             | Open Drain                       |                                   |      | -               | -     |    |
|                  |                                                                                                                    | Pull Up                          | V <sub>IN</sub> =0.6V             |      | -1.6            | mA    |    |
| I <sub>IL2</sub> | Input Low Current(RST, INT)                                                                                        | V <sub>IN</sub> =0.6V            |                                   |      | -0.1            | mA    |    |
| I <sub>LO</sub>  | Output Lead Current (O <sub>TO</sub> , O <sub>T1</sub> , O <sub>T2</sub> , O <sub>T3</sub> )                       | Open Drain                       | V <sub>OUT</sub> =V <sub>DD</sub> |      | 20              | μA    |    |
|                  |                                                                                                                    | Pull Up                          |                                   |      | -               | -     |    |
| V <sub>OH</sub>  | Output High Voltage (Except X <sub>OUT</sub> )                                                                     | Open Drain                       |                                   |      | -               | -     |    |
|                  |                                                                                                                    | Pull Up                          | I <sub>OH</sub> =-100μA           | 2.4  |                 | V     |    |
| V <sub>OL</sub>  | Low Output Voltage(Except X <sub>OUT</sub> )                                                                       | I <sub>OL</sub> =1.6mA           |                                   |      | 0.4             | V     |    |
| I <sub>DD</sub>  | V <sub>DD</sub> Supply Current                                                                                     |                                  |                                   |      | 40              | 80    | mA |



INTEGRATED CIRCUIT

TECHNICAL DATA

TMP4310AP      TMP4315BP  
TMP4320AP      TMP4300C

## AC CHARACTERISTICS

Refer to TIMING WAVEFORMS (1).

TA=-10°C to 70°C, V<sub>DD</sub>=5V ± 10 %, Unless Otherwise Noted.

| Symbol           | Parameter                 | Test Condition                             | Min. | Typ. | Max. | Units       |
|------------------|---------------------------|--------------------------------------------|------|------|------|-------------|
| t <sub>φ0</sub>  | Clock Cycle Time          |                                            | 2    | 5    |      | μs          |
| t <sub>S</sub>   | Input Set up Time         |                                            | 0.9  |      |      | μs          |
| t <sub>H</sub>   | Input Hold Time           |                                            | 0.9  |      |      | μs          |
| t <sub>D</sub>   | Output Delay Time         | C <sub>L</sub> =50PF,R(Pull up)=50kΩ ,lTTL |      |      | 1.8  | μs          |
| t <sub>INT</sub> | INT Low Level Pulse Width |                                            | 4    |      |      | Clock Cycle |
| t <sub>RST</sub> | RST Low Level Pulse Width |                                            | 4    |      |      | Clock Cycle |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4310AP      TMP4315BP  
 TMP4320AP      TMP4300C

## TMP4320AP ELECTRICAL CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS

| Symbol              | Item                                          | Rating         |
|---------------------|-----------------------------------------------|----------------|
| V <sub>DD</sub>     | V <sub>DD</sub> Supply Voltage                | -0.5V to 7V    |
| V <sub>IN</sub>     | Input Voltage                                 | -0.5V to 7V    |
| V <sub>OUT1</sub>   | Output Voltage (Except Open Drain Pins)       | -0.5V to 7V    |
| V <sub>OUT2</sub>   | Output Voltage (Open Drain Pins)              | -0.5V to 10V   |
| I <sub>OUT1</sub>   | Average Output Current (Except OT1,OT2)       | 4mA            |
| I <sub>OUT2</sub>   | Output Current (OT1, OT2)                     | 30mA           |
| P <sub>D</sub>      | Power Dissipation (TA=70°C)                   | 850mW          |
| T <sub>SOLDER</sub> | Soldering Temperature (Soldering Time 10sec.) | 260°C          |
| T <sub>STG</sub>    | Storage Temperature                           | -55°C to 125°C |
| T <sub>OPR</sub>    | Operating Temperature                         | -10°C to 70°C  |

## DC CHARACTERISTICS

TA=-10°C to 70°C, V<sub>DD</sub>=5V ± 10 %, Unless Otherwise Noted

| Symbol           | Parameter                                                                                                          | Test Conditions                  | Min.                              | Typ. | Max.            | Units |
|------------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------|------|-----------------|-------|
| V <sub>IHL</sub> | Input High Voltage (I <sub>NO</sub> , I <sub>N1</sub> , I <sub>N2</sub> , I <sub>O0</sub> , I <sub>O1</sub> , RST) |                                  | 2.2                               |      | V <sub>DD</sub> | V     |
| V <sub>IH2</sub> | Input High Voltage (INT)                                                                                           |                                  | 3.5                               |      | V <sub>DD</sub> | V     |
| V <sub>IL</sub>  | Input Low Voltage                                                                                                  |                                  | 0                                 |      | 0.6             | V     |
| V <sub>CH</sub>  | Clock Input High Voltage (X <sub>IN</sub> )                                                                        | External Drive                   | 3.8                               |      | V <sub>DD</sub> | V     |
| V <sub>CL</sub>  | Clock Input Low Voltage (X <sub>IN</sub> )                                                                         | External Drive                   | 0                                 |      | 0.6             | V     |
| I <sub>IN1</sub> | Input Current (I <sub>NO</sub> , I <sub>N1</sub> , I <sub>N2</sub> )                                               | V <sub>IN</sub> =V <sub>DD</sub> |                                   | 20   | μA              |       |
| I <sub>IN2</sub> | Input Current (I <sub>O0</sub> , I <sub>O1</sub> )                                                                 | Open Drain                       | V <sub>IN</sub> =V <sub>DD</sub>  |      | 20              | μA    |
|                  |                                                                                                                    | Pull up                          |                                   |      | -               | -     |
| I <sub>IL1</sub> | Input Low Current (I <sub>O0</sub> , I <sub>O1</sub> )                                                             | Open Drain                       |                                   |      | -               | -     |
|                  |                                                                                                                    | Pull Up                          | V <sub>IN</sub> =0.6V             |      | -1.6            | mA    |
| I <sub>IL2</sub> | Input Low Current (RST, INT)                                                                                       | V <sub>IN</sub> =0.6V            |                                   |      | -0.1            | mA    |
| I <sub>LO</sub>  | Output Lead Current (OTO, OT1, OT2, OT3)                                                                           | Open Drain                       | V <sub>OUT</sub> =V <sub>DD</sub> |      | 20              | μA    |
|                  |                                                                                                                    | Pull Up                          |                                   |      | -               | -     |
| V <sub>OH</sub>  | Output High Voltage (Except X <sub>OUT</sub> )                                                                     | Open Drain                       |                                   |      | -               | -     |
|                  |                                                                                                                    | Pull Up                          | I <sub>OH</sub> =-100μA           | 2.4  |                 | V     |
| V <sub>OL</sub>  | Output Low Voltage (Except X <sub>OUT</sub> ) (Note)                                                               | I <sub>OL</sub> =1.6mA           |                                   |      | 0.4             | V     |
| I <sub>DD</sub>  | V <sub>DD</sub> Supply Current                                                                                     |                                  |                                   | 40   | 80              | mA    |



# SEMICONDUCTOR

INTEGRATED CIRCUITS

## TECHNICAL DATA

TMP4310AP TMP4315BP

TMP4320AP TMP4300C



Note: Output port OT1 and OT2 can sink large current. ( $I_{OL\cdot TYP.}=20mA$ ,  
 $V_{OL}=2.0V$ )

While sinking large current, the output low voltage ( $V_{OL}$ ) limit  
is the following value.

$V_{OL\ Max.}=0.5V$  ( $I_{OL}=1.6mA$ )

### AC CHARACTERISTICS

Refer to TIMING WAVEFORMS (1).

TA=-10°C to 70°C,  $V_{DD}=5V \pm 10\%$ , Unless Otherwise Noted.

| SYMBOL       | Parameter                 | Test Conditions                        | Min. | Typ. | Max. | Units       |
|--------------|---------------------------|----------------------------------------|------|------|------|-------------|
| $t_{\phi O}$ | Clock Cycle Time          |                                        | 2    | 5    |      | $\mu s$     |
| $t_s$        | Input Set up Time         |                                        | 0.9  |      |      | $\mu s$     |
| $t_H$        | Input Hold Time           |                                        | 0.9  |      |      | $\mu s$     |
| $t_D$        | Output Delay Time         | $C_L=55pF, R(Pull up)=50K\Omega, ITTL$ |      |      | 1.8  | $\mu s$     |
| $t_{INT}$    | INT Low Level Pulse Width |                                        | 4    |      |      | Clock Cycle |
| $t_{RST}$    | RST Low Level Pulse Width |                                        | 4    |      |      | Clock Cycle |



## INTEGRATEDCIRCUIT

## TECHNICAL DATA

TMP4310AP TMP4315BP  
TMP4320AP TMP4300C

## TMP4300C ELECTRICAL CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS

| Symbol       | Item                                           | Rating         |
|--------------|------------------------------------------------|----------------|
| $V_{DD}$     | $V_{DD}$ Supply Voltage                        | -0.5V to 7V    |
| $V_{IN}$     | Input Voltage                                  | -0.5V to 7V    |
| $V_{OUT1}$   | Output Voltage (Except Open Drain Pins)        | -0.5V to 7V    |
| $V_{OUT2}$   | Output Voltage (Open Drain Pins)               | -0.5V to 10V   |
| $I_{OUT1}$   | Average Output Current (Except OT1, OT2)       | 4mA            |
| $I_{OUT2}$   | Output Current (OT1, OT2)                      | 30mA           |
| $P_D$        | Power Dissipation (TA=70°C)                    | 1W             |
| $T_{SOLDER}$ | Soldering Temperature (Soldering Time 10 sec.) | 260°C          |
| $T_{STG}$    | Storage Temperature                            | -55°C to 125°C |
| $T_{OPR}$    | Operating Temperature                          | -10°C to 70°C  |

## DC CHARACTERISTICS

TA=-10°C to 70°C,  $V_{DD}=5V \pm 10\%$ , Unless Otherwise Noted.

| Symbol    | Parameter                                         | Test Conditions    | Min. | Typ. | Max.     | Units   |    |
|-----------|---------------------------------------------------|--------------------|------|------|----------|---------|----|
| $V_{IH1}$ | Input High Voltage (Except INT, $X_{IN}$ ) (Note) |                    | 2.2  |      | $V_{DD}$ | V       |    |
| $V_{IH2}$ | Input High Voltage (INT)                          |                    | 3.5  |      | $V_{DD}$ | V       |    |
| $V_{IL}$  | Input Low Voltage                                 |                    | 0    |      | 0.6      | V       |    |
| $V_{CH}$  | Clock Input High Voltage ( $X_{IN}$ )             | External Drive     | 3.8  |      | $V_{DD}$ | V       |    |
| $V_{CL}$  | Clock Input Low Voltage ( $X_{IN}$ )              | External Drive     | 0    |      | 0.6      | V       |    |
| $I_{IN}$  | Input Current (Except RST, INT)                   | $V_{IN}=V_{DD}$    |      |      | 20       | $\mu A$ |    |
| $I_{IL2}$ | Input Low Current (RST, INT)                      | $V_{IN}=0.6V$      |      |      | -0.1     | mA      |    |
| $I_{LO}$  | Output Lead Current(OT0,OT1,OT2)                  | $V_{OUT}=V_{DD}$   |      |      | 20       | $\mu A$ |    |
| $V_{OH}$  | Output High Voltage (A0-A10,CLK1)                 | $I_{OH}=-100\mu A$ | 2.4  |      |          | V       |    |
| $V_{OL}$  | Output Low Voltage (Except $X_{OUT}$ ) (Note)     | $I_{OL}=1.6mA$     |      |      | 0.4      | V       |    |
| $I_{DD}$  | $V_{DD}$ Supply Current                           |                    |      |      | 70       | 120     | mA |

Note: Output Port OT1 and OT2 can sink large current. ( $I_{OL}$  TYP.=20mA,  $V_{OL}$ =2.0V) While sinking large current, the Output Low Voltage ( $V_{OL}$ ) limit and the Input High Voltage ( $V_{IH1}$ ) limit are the following values.

$V_{OL}$  Max.=0.5V to 0.6V ( $I_{OL}=1.6mA$ )  
 $V_{IH1}$  Min.=2.3V to 2.4V



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4310AP      TMP4315BP  
TMP4320AP      TMP4300C

## AC CHARACTERISTICS

Refer to TIMING WAVEFORMS (1) (2).

TA=-10°C to 70°C, V<sub>DD</sub>=5V ± 10 %, Unless Otherwise Noted.

| Symbol           | Parameter                     | Test Conditions                              | Min. | Typ. | Max. | Units.      |
|------------------|-------------------------------|----------------------------------------------|------|------|------|-------------|
| t <sub>φO</sub>  | Clock Cycle Time              |                                              | 2    | 5    |      | μs          |
| t <sub>S</sub>   | Input Set up Time             |                                              | 0.9  |      |      | μs          |
| t <sub>H</sub>   | Input Hold Time               |                                              | 0.9  |      |      | μs          |
| t <sub>D</sub>   | Output Delay Time             | C <sub>L</sub> =50PF, R(Pull up)=50kΩ, 1 TTL |      |      | 1.8  | μs          |
| t <sub>INT</sub> | INT Low Level Pulse Width     |                                              | 4    |      |      | Clock Cycle |
| t <sub>RST</sub> | RST Low Level Pulse Width     |                                              | 4    |      |      | Clock Cycle |
| t <sub>CD</sub>  | Clock Output Delay Time       | C <sub>L</sub> =50PF, 1 TIL                  |      |      | 0.4  | μs          |
| t <sub>AD</sub>  | Address Output Delay Time     | C <sub>L</sub> =50PF, 1 TIL                  |      |      | 0.95 | μs          |
| t <sub>IS</sub>  | Instruction Input Set up Time |                                              | 0.4  |      |      | μs          |
| t <sub>IH</sub>  | Instruction Input Hold Time   |                                              | 0    |      |      | μs          |
| t <sub>IDS</sub> | ID Input Set up Time          |                                              | 0.4  |      |      | μs          |
| t <sub>IDH</sub> | ID Input Hold Time            |                                              | 0.95 |      |      | μs          |

## TIMING WAVEFORMS



Toshiba

**INTEGRATED CIRCUIT**  
Surface Mount Technology  
S0005993 S005994  
**TECHNICAL DATA**

東芝

PRODUCTION DATA

TMP4310AP TMP4315BP  
TMP4320AP TMP4300C**OUTLINE DRAWINGS**

(TMP4310AP)



Unit in mm



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. 28 leads.

(TMP4315BP/TMP4320AP)

Unit in mm



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. 42 leads.

(TMP4300C)

TMP4310AP

TMP4315BP

TMP4320AP

TMP4300C

Unit in mm



- 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\text{mm}$  from their theoretical positions with respect to No. 1 and No. 64 leads.
3. The metal on the side of the package is GND Level.



# INTEGRATEDCIRCUIT

## TECHNICAL DATA

TMP4310AP      TMP4315BP  
TMP4320AP      TMP4300C

### MASK ROM DATA TAPE FORMAT

|           |           |                                           |                                                                                                                                                                                                                                                                                       |
|-----------|-----------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .         | .         | Leader                                    | 50 or more characters of "NULL"                                                                                                                                                                                                                                                       |
| 'COMMENT" | (CR) (LF) | Comment                                   | When designated by mask option the characters of "MASK OPTION" are output with apostrophe.                                                                                                                                                                                            |
| (PUNNN1)  | (CR) (LF) |                                           | Outputs symbolic names of bits of output port or input/output port to which pull-up resistors are connected.                                                                                                                                                                          |
| .         | .         |                                           | Outputs symbolic names of bits to which                                                                                                                                                                                                                                               |
| .         | .         |                                           | pull-up resistors are connected PUNNN1                                                                                                                                                                                                                                                |
| .         | .         |                                           | for all the bits of output port                                                                                                                                                                                                                                                       |
| .         | .         |                                           | and input/output port which has                                                                                                                                                                                                                                                       |
| .         | .         |                                           | been designated as mask option.                                                                                                                                                                                                                                                       |
| 'COMMENT" |           | Comment                                   | Outputs six characters starting from the beginning of character train defined by TTL statement of source program and two characters of serial number, with apostrophe.<br>(When no TTL statement exist, six characters of space code and two characters of serial number are output.) |
| N8;       | (CR) (LF) |                                           | Outputs "N8" which indicates that the data pattern is 8 bits long. (The program data follow this code.)                                                                                                                                                                               |
| RXXXX ;   |           |                                           | Outputs the program start address following "R", in four frames of decimal ASCII code.                                                                                                                                                                                                |
| X XX Px;  |           | Data and check sum of the first address.  | X XX Px                                                                                                                                                                                                                                                                               |
| X XX Px;  |           | Data and check sum of the second address. | Check Sum<br>Number of data bits having "1" is output                                                                                                                                                                                                                                 |
| .         |           | .                                         |                                                                                                                                                                                                                                                                                       |
| .         |           | .                                         |                                                                                                                                                                                                                                                                                       |
| .         |           | .                                         |                                                                                                                                                                                                                                                                                       |
| X XX Px;  | (CR) (LF) | Data and check sum of the eighth address. | Data<br>Two characters of eight bit data are output in two frames of hexadecimal ASCII codes.                                                                                                                                                                                         |



# INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP4310AP    TMP4315BP  
TMP4320AP    TMP4300C

|           |                                                                |
|-----------|----------------------------------------------------------------|
| R XXXX ;  | ----- Nineth program address.                                  |
| X XX Px;  | ----- Data and check sum of the nineth address                 |
| .         | Outputs repetitively through the last data.                    |
| .         |                                                                |
| .         |                                                                |
| .         |                                                                |
| (CR) (LF) |                                                                |
| \$        | ----- Outputs symbol "\$" to indicate the end of program data. |
| .         |                                                                |
| .         |                                                                |
| .         |                                                                |
| .         |                                                                |
| .         |                                                                |
|           | Trailer    50 or more characters of "NULL".                    |



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TELEGRAM

TMP4310APL/TMP4310APLL

TECHNICAL DATA

### SPECIFICATION OF TMP4310APL/TMP4310APLL

This specification is applied to TMP4310APL/TMP4310APLL, one of versions of TLCS-43.

TMP4310APL/TMP4310APLL is the low power version of TMP4310AP. There are some differences in electrical characteristics between TMP4310APL/TMP4310APLL and TMP4310AP; however, their functions, instructions and pin connections are compatible. When using and examining TMP4310APL/TMP4310APLL, therefore, it is recommended that this specification be used together with the technical data on TMP4310AP.

Main differences in electrical characteristics between AP and APL/APLL are as follows:

#### 1. Basic clock

Internal oscillation (with resistance externally installed between X<sub>IN</sub> and TEST) and external clock supply can be available.

##### 1.1 Frequency of external supply clock

f=200kHz to 400kHz (APL) (V<sub>DD</sub>=5.5V ± 20%, T<sub>opr</sub>=0°C to 55°C)

f=50kHz to 200kHz (APLL)

##### 1.2 Internal oscillation frequency

f=200kHz to 400kHz (APL, R<sub>X</sub>=56kΩ) (V<sub>DD</sub>=5.5V ± 20%, T<sub>opr</sub>=0°C to 55°C)

f=110kHz to 200kHz (APLL, R<sub>X</sub>=110kΩ)

#### 2. Low input voltage and clock low input voltage (at time of external supply)

V<sub>IL</sub> MAX.=V<sub>CL</sub> MAX.=0.55V (V<sub>DD</sub>=5.5V ± 20%, T<sub>opr</sub>=0°C to 55°C)

#### 3. High output voltage

V<sub>OH</sub> MIN.=2.4V (V<sub>DD</sub>=5.5V ± 20%, T<sub>opr</sub>=0°C to 55°C, I<sub>OH</sub>=-50μA)

#### 4. Supply current

I<sub>DD</sub> TYP.=30mA, I<sub>DD</sub> MAX.=45mA (APL) (V<sub>DD</sub>=6.0V, T<sub>opr</sub>=25°C)

I<sub>DD</sub> TYP.=15mA, I<sub>DD</sub> MAX.=27mA (APLL)

#### 5. Pull up resistance of RST and INT terminals is not contained.

## TMP4310APL/TMP4310APLL BASIC CLOCK

The methods of generating and supplying the basic clock of TMP4310APL/TMP4310APLL are as follows:

## (1) Internal oscillation



The basic clock of TMP4310APL/TMP4310APLL can be obtained by connecting the resistance as shown in the left figure.

(fosc=200kHz to 400kHz at Rx=56kΩ, APL)  
(fosc=110kHz to 200kHz at Rx=110kΩ, APPLL)

## (2) Supply of external clock



The basic clock of TMP4310APL/TMP4310APLL can be supplied from the external oscillation circuit as shown in the left figure.



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4310APL / TMP4310APLL

## TMP4310APL/TMP4310APLL ELECTRICAL CHARACTERISTICS

## ABSOLUTE MAXIMUM RATING

| SYMBOL            | ITEM                                        | RATING         |
|-------------------|---------------------------------------------|----------------|
| V <sub>DD</sub>   | Supply Voltage                              | -0.5V to 7V    |
| V <sub>IN</sub>   | Input Voltage                               | -0.5V to 7V    |
| V <sub>OUT1</sub> | Output Voltage (Except open drain terminal) | -0.5V to 7V    |
| V <sub>OUT2</sub> | Output Voltage (Open drain terminal)        | -0.5V to 10V   |
| T <sub>stg</sub>  | Storage Temperature                         | -55°C to 125°C |
| T <sub>opr</sub>  | Operating Temperature                       | 0°C to 55°C    |
| T <sub>sld</sub>  | Soldering Temperature                       | 260°C (10sec.) |

D.C. CHARACTERISTICS(V<sub>DD</sub>=5.5V+20%, T<sub>opr</sub>=0°C to 55°C) Unless otherwise noted.

| SYMBOL           | PARAMETER                                                                                | TEST CONDITION                    | MIN.                               | TYP. | MAX.            | UNIT |
|------------------|------------------------------------------------------------------------------------------|-----------------------------------|------------------------------------|------|-----------------|------|
| V <sub>IH1</sub> | Input High (I <sub>NO</sub> , I <sub>OO</sub> , I <sub>O1</sub> , I <sub>O2</sub> , RST) | -                                 | 2.2                                | -    | V <sub>DD</sub> | V    |
| V <sub>IH2</sub> | Voltage (INT)                                                                            | -                                 | 3.5                                | -    | V <sub>DD</sub> | V    |
| V <sub>IL</sub>  | Input Low Voltage                                                                        | -                                 | 0                                  | -    | 0.55            | V    |
| V <sub>CH</sub>  | Clock Input High Voltage (X <sub>IN</sub> )                                              | External clock supply             | 3.8                                | -    | V <sub>DD</sub> | V    |
| V <sub>CL</sub>  | Clock Input Low Voltage (X <sub>IN</sub> )                                               |                                   | 0                                  | -    | 0.55            | V    |
| I <sub>IN1</sub> | Input Current (I <sub>NO</sub> , RST, INT)                                               | V <sub>IN</sub> = V <sub>DD</sub> | -                                  | -    | 20              | μA   |
| I <sub>IN2</sub> | Input Current (I <sub>OO</sub> , I <sub>O1</sub> , I <sub>O2</sub> )                     | Open Drain                        | V <sub>IN</sub> = V <sub>DD</sub>  | -    | 20              | μA   |
|                  |                                                                                          | Pull Up                           | -                                  | -    | -               | -    |
| I <sub>IL1</sub> | Input Low Current (I <sub>OO</sub> , I <sub>O1</sub> , I <sub>O2</sub> )                 | Open Drain                        | -                                  | -    | -               | -    |
|                  |                                                                                          | Pull Up                           | V <sub>IN</sub> = 0.55V            | -    | -1.6            | mA   |
| I <sub>LO</sub>  | Output Leak Current (O <sub>TO</sub> , O <sub>T1</sub> )                                 | Open Drain                        | V <sub>OUT</sub> = V <sub>DD</sub> | -    | 20              | μA   |
|                  |                                                                                          | Pull Up                           | -                                  | -    | -               | -    |
| V <sub>OH</sub>  | Output High Voltage                                                                      | Open Drain                        | -                                  | -    | -               | -    |
|                  |                                                                                          | Pull Up                           | I <sub>OH</sub> = -50μA            | 2.4  | -               | V    |
| V <sub>OL</sub>  | Output Low Voltage                                                                       | Pull Up                           | I <sub>OL</sub> = 1.6mA            | -    | 0.4             | V    |
| I <sub>DD</sub>  | Supply Current                                                                           | APL                               | V <sub>DD</sub> =6.0V, Ta=25°C     | -    | 30              | mA   |
|                  |                                                                                          | APLL                              |                                    | -    | 15              | mA   |

Pull-Up resistance of RST and INT terminals is not contained.

Low output voltage: It is possible that output port OT1 sinks large output current I<sub>OL</sub> Typ.=20mA (V<sub>OL</sub>=2V) for each pins. At the time when OT1 sinks large output current, low output voltage (V<sub>OL</sub>) becomes V<sub>OL</sub> Max.≈0.5V (I<sub>OL</sub>=1.6mA).

A.C. CHARACTERISTICS ( $V_{DD}=5.5V \pm 20\%$ ,  $T_{OPR}=0^{\circ}C$  to  $55^{\circ}C$ )

| SYMBOL       | PARAMETER                      | TEST CONDITION                           | MIN. | TYP. | MAX. | UNIT        |
|--------------|--------------------------------|------------------------------------------|------|------|------|-------------|
| $t_{\phi 0}$ | Clock Cycle Time               | External clock supply                    | APL  | 2.5  | -    | 5.0 $\mu s$ |
|              |                                |                                          | APLL | 5    | -    | 20 $\mu s$  |
| $t_S$        | Input Set Up Time              | -                                        | APL  | 0.9  | -    | - $\mu s$   |
|              |                                |                                          | APLL | 1.8  | -    | - $\mu s$   |
| $t_H$        | Input Hold Time                | -                                        | APL  | 0.9  | -    | - $\mu s$   |
|              |                                |                                          | APLL | 1.8  | -    | - $\mu s$   |
| $t_D$        | Output Delay Time              | $CL=50pF$ , $R(Pull up)=50k\Omega$ , TTL | APL  | -    | -    | 1.8 $\mu s$ |
|              |                                |                                          | APLL | -    | -    | 3.6 $\mu s$ |
| $t_{INT}$    | INT Low Level Pulse Width      | -                                        |      | 4    | -    | - Cycle     |
| $t_{RST}$    | RST Low Level Pulse Width      | -                                        |      | 4    | -    | - Cycle     |
| $f_{osc}$    | Internal Oscillation Frequency | $R = 56k\Omega$                          | APL  | 200  | -    | 400 kHz     |
|              |                                | $R = 110k\Omega$                         | APLL | 110  | -    | 200 kHz     |


**TYPICAL CHARACTERISTICS**


## PIN CONNECTIONS

TOP View



## OUTLINE DRAWINGS

Unit in mm



- 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\text{mm}$  from their theoretical position with respect to No.1 and No.28 leads.

Toshiba

東芝

## INTEGRATED CIRCUIT

## TECHNICAL DATA

## TMP 4321AP

TOSHIBA MOS Digital Integrated Circuit  
 Silicon Monolithic  
 N-channel Silicon Gate Depression Load

## GENERAL DESCRIPTION

TMP4321AP is one version of single-chip microcomputer TLCS43 series processed with NMOS.

Since TMP4321AP can make periodic interrupt gained by dividing the CPU clock to 512 or 1024 using the built-in prescaler, it is most appropriate for computer control, such as sequence control.

Refer to the technical data of TLCS43 when using or considering TMP4321AP.

## FEATURES

- o Software compatible with TLCS43 series
- o ROM capacity: 2048W x 8 Bits
- o RAM capacity: 128W x 4 Bits
- o Instruction executing rate: 4  $\mu$ s
- o Input ports: 3 x 4 Bits
- o Input/output ports: 2 x 4 Bits
- o Output ports: 3 x 4 Bits  
1 x 3 Bits

## PIN CONNECTIONS

- o Interrupt level: 1 level (Interrupt by timer)
- o Subroutine nesting: 4 levels (including interrupt level)
- o ROM data readout instructions
- o I/O level: TTL compatible
- o Ports available for large current output: 2 x 4 Bits
- o +5V single power operating (operating voltage margin: 5V  $\pm$  10%)
- o Operating temperature range: -10 ~ 70°C



### TIMER INTERRUPT

The following figure shows the configuration of timer interrupt circuit of TMP4321AP.



As shown in the above figure, interrupt is not caused by external source via INT pin, but it is only caused by the output divided by the built-in prescaler. The INT pin is usually set to "H" level (open) by the pull-up resistor, but it is not connected with the internal circuit.

Assignment of selective timer option is as follows :

- (1) Option INTDV7 is interrupted at  $\frac{1}{f_{osc}} \times 512(S)$  cycle ( $\overline{Q7}$ ).
- (2) Option INTDV8 is interrupted at  $\frac{1}{f_{osc}} \times 1024(S)$  cycle ( $\overline{Q8}$ ).

(Refer to "Mask Option Assignment" in the technical data of TLCS43 for further details.)

The relation between timer interrupt and reset is shown in the following figure.

MASK ROM DATA TAPE FORMAT



Initial interrupt occurs at  $T/2$  interval after the RST input is released, and then repeatedly occurs by every T cycle.



## BASIC CLOCK

The following are four methods to generate and supply the basic clock pulse in the TMP4321AP.

## (1) Direct connection of crystal oscillator



When a crystal oscillator has been connected to TMP4321AP as shown in the left figure, the basic clock pulse is generated at the frequency inherent in the crystal oscillator.  
Recommendations for  $C_{IN}$  and  $C_{OUT}$   
 $C_{IN}=C_{OUT}=60\text{pF}$  ( $f_{OSC} \approx 500\text{KHz}$ )

## (2) Direct connection of ceramic oscillator



When a ceramic oscillator has been connected to TMP4321AP as shown in the left figure, the basic clock pulse is generated at the frequency inherent in the ceramic oscillator.  
Recommendations for  $C_{IN}$  and  $C_{OUT}$   
 $C_{IN}=C_{OUT}=100\text{pF}$  ( $f_{OSC} \approx 500\text{KHz}$ )

## (3) Direct connection of IFT



When a IFT has been connected to TMP4321AP as shown in the left figure, the basic clock pulse is determined according to the circuit constant.  
Recommendations for  $C_{IN}$  and  $C_{OUT}$   
 $C_{IN}=C_{OUT}=100\text{pF}$  ( $f_{OSC} \approx 500\text{KHz}$ )

## (4) Supply of external clock



The basic clock pulse of TMP4321AP can be supplied by an external oscillating circuit as shown in the left figure.

## MAXIMUM RATINGS

| SYMBOL | ITEM                                        | RATING        | UNIT |
|--------|---------------------------------------------|---------------|------|
| VDD    | Supply Voltage                              | -0.5 ~ 7      | V    |
| VIN    | Input Voltage                               | -0.5 ~ 7      | V    |
| VOUT1  | Output Voltage (except open drain terminal) | -0.5 ~ 7      | V    |
| VOUT2  | Output Voltage (open drain terminal)        | -0.5 ~ 10     | V    |
| IOUT1  | Output Current (except OT1, OT2)            | 4             | mA   |
| IOUT2  | Output Current (OT1, OT2)                   | 30            | mA   |
| Tstg   | Storage Temperature                         | -55 ~ 125     | °C   |
| Topr   | Operating Temperature                       | -10 ~ 70      | °C   |
| Tsld   | Solder Temperature                          | 260 (10 sec.) | °C   |
| PW     | Power Dissipation (Ta = 70°C)               | 850           | mW   |

D.C. ELECTRICAL CHARACTERISTICS ( $V_{DD} = 5V \pm 10\%$ ,  $Topr = -10 \sim 70^\circ C$ )

| SYMBOL | PARAMETER                                         | TEST CONDITION        | MIN.                    | TYP. | MAX. | UNIT    |
|--------|---------------------------------------------------|-----------------------|-------------------------|------|------|---------|
| VIH1   | Input High Voltage (IN0, IN1, IN2, IO0, IO1, RST) | -                     | 2.2                     | -    | VDD  | V       |
| VIH2   | Input High Voltage (INT)                          | -                     | 3.5                     | -    | VDD  | V       |
| VIL    | Input Low Voltage                                 | -                     | 0                       | -    | 0.6  | V       |
| VCH    | Input High Clock Voltage (XIN)                    | -                     | 3.8                     | -    | VDD  | V       |
| VCL    | Input Low Clock Voltage (XIN)                     | -                     | 0                       | -    | 0.6  | V       |
| IIN1   | Input Current (IN0, IN1, IN2)                     | $V_{IN} = V_{DD}$     | -                       | -    | 20   | μA      |
| IIN2   | Input Current (IO0, IO1)                          | Open Drain<br>Pull Up | VIN = VDD<br>-          | -    | 20   | μA      |
| IIL1   | Input Low Current (IO0, IO1)                      | Open Drain<br>Pull Up | -                       | -    | -    | -       |
| IIL2   | Input Low Current (RST, INT)                      | -                     | $V_{IN} = 0.6V$         | -    | -    | -1.6 mA |
| ILO    | Output Leak Current (OT0, OT1)<br>(OT2, OT3)      | Open Drain<br>Pull Up | $V_{OUT} = V_{DD}$<br>- | -    | 20   | μA      |
| VOH    | Output High Voltage<br>(except XOUT)              | Open Drain<br>Pull Up | -                       | -    | -    | -       |
| VOL    | Output Low Voltage (except XOUT)                  | -                     | $I_{OH} = -100\mu A$    | 2.4  | -    | -       |
| IDD    | Supply Current                                    | -                     | -                       | 40   | 80   | mA      |

Output Low Voltage: Output large current  $I_{OL}$  TYP.=20mA ( $V_{OL}=2V$ ) is made possible by output ports OT1, OT2. When output large current sinks, output low voltage becomes  $V_{OL}$  MAX. $\approx 0.5V$  ( $I_{OL}=1.6mA$ ).

A.C. ELECTRICAL CHARACTERISTICS ( $V_{DD} = 5V \pm 10\%$ ,  $Topr = -10 \sim 70^\circ C$ ) Refer to Timing Chart.

| SYMBOL           | PARAMETER             | TEST CONDITION                         | MIN. | TYP. | MAX. | UNIT  |
|------------------|-----------------------|----------------------------------------|------|------|------|-------|
| t <sub>0</sub>   | Clock Cycle Time      | -                                      | 2    | -    | 5    | μS    |
| t <sub>S</sub>   | Input Setup Time      | -                                      | 0.9  | -    | -    | μS    |
| t <sub>H</sub>   | Input Hold Time       | -                                      | 0.9  | -    | -    | μS    |
| t <sub>D</sub>   | Output Delay Time     | $C_L=50pF, R(Pull Up)=50k\Omega, 1TTL$ | -    | -    | 1.8  | μS    |
| t <sub>INT</sub> | INT (Low Level Width) | -                                      | 4    | -    | -    | Cycle |
| t <sub>RST</sub> | RST (Low Level Width) | -                                      | 4    | -    | -    | Cycle |

**TIMING CHART**

**EXTERNAL VIEW OF PACKAGE (Plastic Package)**


Note 1. The dimension of this external view indicates the lead bending center.

Note 2. 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.42 leads.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4399C

TOSHIBA MOS Digital Integrated Circuit  
Silicon Monolithic  
N-channel Silicon Gate Depletion Load

### DESCRIPTION

TMP4399C is a single-chip microcomputer for evaluation, provided with the general purpose 16K EPROM (TMM323D) inserting socket, being capable of developing and checking hardware and software of TLCS-43 Application System by use of the EPROM.

TMP4399C is equipped with a 24-pin socket which may directly mount the general purpose 16K EPROM (TMM323D) on the surface of the package. Therefore, when the fixed program written in the general purpose 16K EPROM is mounted on the package, TMP4399C becomes pin-compatible with TMP4315BP/TMP4320AP as the end product which the program has been written in the mask ROM. The former operates the same as the latter.

TMP4399C can be used within the range of a microcomputer for evaluating the TLCS-43 system as well as for mounting an equipment made on an experimental basis.

### FEATURES

- o General purpose 16K EPROM TMM323D (equivalent to INTEL2716) can be used.
- o Compatible with TLCS-43 single-chip microcomputer family TMP4315BP/4320AP in pin.
- o Compatible with TLCS-43 Series in software.
- o ROM 2KW x 8 BIT RAM 128W x 4 BIT
- o Can be operated by +5V single power supply. Voltage margin is  $\pm 10\%$  equal to that of mass-produced products.
- o Operating temperature range is -10 ~ 70°C equal to that of mass-produced products.

### PIN CONNECTIONS



(Note) ○ mark: Socket for TMM323D

## PRECAUTIONS FOR USING TMP4399C

## 1. Precautions for using OT3 Output Port

The output port and input/output port of TLCS-43 are composed as shown in the following figures.

(OUTPUT PORT)



(INPUT/OUTPUT PORT)



Therefore, when the circuit which clamps the output voltage level is connected directly to the outside of terminal, if the output data is referred to by the program, for the output port such data can be normally read, but for the input/output port erroneous data may be read unless the voltage level can be ensured as an input signal by the clamp circuit. For the purpose of reading correct data, it is necessary to separate the terminal from the clamp circuit by the buffer circuit.

The output port OT3 of TMP4399C serves as an input/output port owing to the configuration of the chip. In case of the system using TMP4315BP or TMP4320AP, therefore, if the output data of OT3 Port must be referred to by the program, care should be taken that the circuit which clamps the output level may not be connected directly to OT3 Port at the stage of development where TMP4399C is used.

(ACTUAL APPLICATION CIRCUIT)



( BUFFER CIRCUIT )



## 2. Precautions for using large output current

In case of TMP4399C, each terminal of the output port OT1 and OT2 may sink large output current  $I_{OL} = 20\text{mA TYP}$ . ( $V_{OL} = 2\text{V}$ ) when there ports sink large output current, a part of the DC electrical characteristics is changed. Attention should be paid to the main characteristics that the high input voltage of  $V_{IH1}$  and the low output voltage of  $V_{OL}$  at every terminal to be applied will become the valurs shown as follows:

$$V_{IH1} \text{ MIN. } \approx 2.3 \sim 2.4\text{V}$$

$$V_{OL} \text{ MAX. } \approx 0.5 \sim 0.6\text{V } (I_{OL} = 1.6\text{mA.})$$

The maximum rating of large output current is 30 mA.



## INTEGRATED CIRCUIT

TMP4399C

## TECHNICAL DATA

## ELECTRICAL CHARACTERISTICS

## MAXIMUM RATINGS

| Symbol            | CHARACTERISTICS                               | RATING       | UNIT |
|-------------------|-----------------------------------------------|--------------|------|
| V <sub>DD</sub>   | Supply Voltage                                | -0.5 ~ 7     | V    |
| V <sub>IN</sub>   | Input Voltage                                 | -0.5 ~ 7     | V    |
| V <sub>OUT1</sub> | Output Voltage(excepting open drain terminal) | -0.5 ~ 7     | V    |
| V <sub>OUT2</sub> | Output Voltage(Open drain terminal)           | -0.5 ~ 10    | V    |
| I <sub>OUT1</sub> | Output Current(Excepting OT1, OT2)            | 4            | mA   |
| I <sub>OUT2</sub> | Output Current (OT1, OT2)                     | 30           | mA   |
| T <sub>stg</sub>  | Storage Temperature                           | -55 ~ 125    | °C   |
| T <sub>opr</sub>  | Operating Temperature                         | -10 ~ 70     | °C   |
| T <sub>sld</sub>  | Soldering Temperature                         | 260(10 sec.) | °C   |
| P <sub>W</sub>    | Power Consumption (Ta = 70°C)                 | 1            | W    |

D.C. ELECTRICAL CHARACTERISTICS (V<sub>DD</sub> = 5V ± 10%, T<sub>opr</sub> = -10 ~ 70°C)

| Symbol           | CHARACTERISTICS                   | TEST CONDITION                     | MIN. | TYP. | MAX.            | UNIT |
|------------------|-----------------------------------|------------------------------------|------|------|-----------------|------|
| V <sub>IH1</sub> | Input High V.(excepting INT,XIN)  | -                                  | 2.2  | -    | V <sub>DD</sub> | V    |
| V <sub>IH2</sub> | Input High Voltage (INT)          | -                                  | 3.5  | -    | V <sub>DD</sub> | V    |
| V <sub>IL</sub>  | Input Low Voltage                 | -                                  | 0    | -    | 0.6             | V    |
| V <sub>CH</sub>  | Clock Input High Voltage (XIN)    | -                                  | 3.8  | -    | V <sub>DD</sub> | V    |
| V <sub>CL</sub>  | Clock Input Low Voltage (XIN)     | -                                  | 0    | -    | 0.6             | V    |
| I <sub>IN</sub>  | Input Current(excepting RST, INT) | V <sub>IN</sub> = V <sub>DD</sub>  | -    | -    | 20              | μA   |
| I <sub>IL2</sub> | Input Low Current (RST, INT)      | V <sub>IN</sub> = 0.6V             | -    | -    | -0.1            | mA   |
| I <sub>LO</sub>  | Output Leak Current(OT0,OT1,OT2)  | V <sub>OUT</sub> = V <sub>DD</sub> | -    | -    | 20              | μA   |
| V <sub>OH</sub>  | Output High Voltage (A0 ~ A10)    | I <sub>OH</sub> = -100μA           | 24   | -    | -               | V    |
| V <sub>OL</sub>  | Output Low V. (excepting XOUT)    | I <sub>OL</sub> = 1.6 mA           | -    | -    | 0.4             | V    |
| I <sub>DD</sub>  | Supply Voltage                    | -                                  | -    | 70   | 120             | mA   |

[Operation of Evaluator Chip] Refer to the paragraph entitled "Precautions for Using Large Output Current".

Refer to timing charts (1) and (2).

A.C. ELECTRICAL CHARACTERISTICS (V<sub>DD</sub> = 5V ± 10%, T<sub>opr</sub> = -10 ~ 70°C)

| Symbol           | CHARACTERISTIC               | TEST CONDITION                                  | MIN. | TYP. | MAX. | UNIT  |
|------------------|------------------------------|-------------------------------------------------|------|------|------|-------|
| t <sub>fo</sub>  | Clock Cycle Time             | -                                               | 2    | -    | 5    | μs    |
| t <sub>S</sub>   | Input Setup Time             | -                                               | 0.9  | -    | -    | μs    |
| t <sub>H</sub>   | Input Hold Time              | -                                               | 0.9  | -    | -    | μs    |
| t <sub>D</sub>   | Output Delay Time            | C <sub>L</sub> =50PF<br>R(Pull UP) = 50kΩ, 1TTL | -    | -    | 1.8  | μs    |
| t <sub>INT</sub> | INT Low Level Width          | -                                               | 4    | -    | -    | Cycle |
| t <sub>RST</sub> | RST Low Level Width          | -                                               | 4    | -    | -    | Cycle |
| t <sub>CD</sub>  | Clock Output Delay Time      | C <sub>L</sub> = 50PF, 1TTL                     | -    | -    | 0.4  | μs    |
| t <sub>AD</sub>  | Address Output Delay Time    | C <sub>L</sub> = 50PF, 1TTL                     | -    | -    | 0.95 | μs    |
| t <sub>IS</sub>  | Instruction Input Setup Time | -                                               | 0.4  | -    | -    | μs    |
| t <sub>IH</sub>  | Instruction Input Hold Time  | -                                               | 0    | -    | -    | μs    |

**TIMING CHART**

(1)



(2)



(Note) Since internal clock (CLK<sub>1</sub>) is not output, it cannot be seen from the outside.



# INTEGRATED CIRCUIT

TMP4399C

## TECHNICAL DATA

Unit: mm

EXTERNAL SHAPE OF PACKAGE



$$2.54 \times 20 = 50.8 \pm 0.3$$



**4BIT SINGLE CHIP MICROCOMPUTER**

**TLCS-46A(CMOS)**



Toshiba

東芝

# INTEGRATEDCIRCUIT

## TECHNICAL DATA

"C<sup>2</sup>MOS" DIGITAL INTEGRATED CIRCUIT

TCP4620AP

TCP4630AP

SILICON MONOLITHIC

CMOS 4-BIT SINGLE CHIP MICROCOMPUTER

### GENERAL DESCRIPTION

TLCS-46A is a C<sup>2</sup>MOS high speed and low power 4-bit single chip micro-computer for consumer applications.

A single and integral microcomputer has been composed of a 4-bit parallel arithmetic and logical unit (ALU), accumulator (AC), program memory (ROM), data memory (RAM), input/output ports, clock generator, and divider incorporated.

TLCS-46A Family consists of two kinds of chips having different ROM/RAM capacities for mass production and evaluator for system development.

## FEATURES

- o TCP4620AP
    - 2048 x 8 ROM
    - 96 x 4 RAM
    - 34 I/O Lines
  - o TCP4630AP
    - 3072 x 8 ROM
    - 160 x 4 RAM
    - 34 I/O Lines
  - o TCP4600AP
    - Evaluator Chip  
for TLCS-46A
- o Low Power Dissipation by Employment of C<sup>2</sup>MOS Process
    - Typical Supply Current : 400µA  
(at 400 kHz Basic Clock)
  - o Single 5V Supply
    - Wide Operating Range : 3V to 6V
  - o Wide Operating Temperature Range: -30°C to 85°C
  - o 52 Instructions
    - 46 One Cycle Instructions
    - 6 Two Cycle Instructions
  - o Single Level Subroutine Nesting
  - o Single Level External Interrupt
  - o 10µs Instruction Execution Time
  - o PLA and Decode Matrix for Display Operation
  - o Many Kinds of Mask Options for Optimum Application Systems

## PIN CONNECTIONS (TOP VIEW)



## PIN NAMES &amp; PIN DESCRIPTION

| Pin Name                            | Input/Output    | Function                                                                                |
|-------------------------------------|-----------------|-----------------------------------------------------------------------------------------|
| P <sub>03</sub> - P <sub>00</sub>   | Input/Output    | 4-bit general purpose I/O port (I/O is designated by a program).                        |
| P <sub>13</sub> - P <sub>10</sub>   | Output          | 4-bit general purpose output port.                                                      |
| P <sub>23</sub> - P <sub>20</sub>   | Input or Output | 4-bit general purpose Input/Output port                                                 |
| P <sub>43</sub> - P <sub>40</sub>   | Input or Output | 4-bit general purpose Input/Output port                                                 |
| PO <sub>54</sub> - PO <sub>50</sub> | Output          | 5-digit output port for display. (Can be used as the general purpose 5-bit output port) |

| Pin Name                           | Input/Output | Function                                                                                 |
|------------------------------------|--------------|------------------------------------------------------------------------------------------|
| P0 <sub>67</sub> -P0 <sub>60</sub> | Output       | 8-segment output port for display (can be used as the general purpose 8-bit output port) |
| PI <sub>53</sub> -PI <sub>50</sub> | Input        | 4-bit general purpose input port.                                                        |
| PI <sub>60</sub>                   | Input        | 1-bit general purpose input port (with a internal Schmitt circuit).                      |
| <u>RESET</u>                       | Input        | Initialize signal input (with a internal Schmitt circuit).                               |
| <u>INT</u>                         | Input        | Interrupt request signal input (with a internal Schmitt circuit).                        |
| X <sub>IN</sub>                    | Input        | Oscillator connecting terminal                                                           |
| X <sub>OUT</sub>                   | Output       | Oscillator connecting terminal                                                           |
| CK                                 | Output       | External timing output                                                                   |
| TEST                               | Input        | LSI test signal input, used by connecting to GND                                         |
| V <sub>DD</sub>                    |              | Power supply                                                                             |
| GND                                |              | GND                                                                                      |

**BLOCK DIAGRAM**


$\overline{\circ}$  denotes mask option.

TEST V<sub>DD</sub> GND

RESET INT



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4620AP

TCP4630AP

### FUNCTIONAL DESCRIPTION

#### [SYSTEM CONFIGURATION]

TLCS-46A consists of the following elements.

#### 1. BASIC ELEMENTS

- (1) Arithmetic and Logical Unit (ALU)
- (2) Accumulator (AC)
- (3) Status Register (ST)
- (4) H Register (HR), L Register (LR), Y Register (YR), Y Register Flag (EYR)
- (5) Port (P), Port Register (Register)
- (6) Internal Bus (IBUS)
- (7) Data Memory (RAM)
- (8) Program Memory (ROM)
- (9) Program Counter (PC)
- (10) Stack (STK), Stack Flag (FSTK)
- (11) Instruction Register (IR), Instruction Decoder (IDEC)
- (12) Clock Generator (OSC)
- (13) Divider
- (14) Timing Generator (TG)

- (1) Arithmetic and Logical Unit (ALU)

ALU performs the principal function involved in the data processing of TLCS-46A, and consists of 4-bit binary parallel arithmetic circuit.

One of the inputs of the arithmetic and logical unit is the accumulator or the status register, and another input is the internal bus, and the result of operation is output to the internal bus and at the same time, carry (barrow) and zero are detected.



## (2) Accumulator (AC)

The accumulator is a 4-bit register that temporarily stores data for arithmetic process, arithmetic result and data from/to the input/output ports.

### (3) Status Register (ST)

The status register is a 4-bit register having a meaning per bit, and is called H flag, D flag, C flag and Z flag in that order from LSB side.



### ① Zero Flag (Z)

The zero flag (Z) is set to "1", if the result generated by certain instructions is zero.

The zero flag is cleared, if the result is not zero.

Further, z flag is used not only for judgement of zero but also as a branch condition for program flow.

② C Flag

When an instruction indicating update is executed, C flag is set at "1" if carry is resulted at time of addition and increment, and at "0" if no carry is resulted.

Further C flag is also set at "0" when borrow is resulted at time of subtraction and at "1" when no borrow is resulted.

C flag is used for judging size of data and for multiple digit arithmetic operation.



## (3) D Flag

D flag is used by a program as an input/output designating signal of the input/output port (Po). When D flag is "0", the input/output port serves as the input port and when D flag is "1", it serves as the output port.

When the input/output port is used exclusively as the output port (specified by mask option), D flag becomes the general purpose flag bit that can be optionally used by user.

D flag is reset at "0" by the initialize operation.

## (4) H Flag

H flag is used as a control signal for hold operation. When "1" is set on H flag, the timing generator is placed in hold mode and the operation is held suspended. The restart from the hold mode is accomplished by resetting H flag at "0" in the hardware processing, and after released from the hold mode, the process that was held suspended prior to the hold operation is resumed. However, interrupt request is not accepted under the hold operation.

When the hold operation is not used (specified by mask option), H flag becomes a general purpose flag bit that can be optionally used by user.

H flag is reset at "0" by the initialize operation.

## (4) H Register (HR), L Register (LR), Y Register (YR), Y Register Flag (EYR)

H register and L register are 4-bit registers and function as an address pointer of the data memory (RAM) or a general purpose register.

When H register and L register are used as an address pointer of the data memory, H register represents high order 4 bits of an address and L register represents low order 4 bits, and they designate an address space of total 8 bits (256 words). Therefore, when 16 words in the address space of the data memory are expressed as one page, H register designates a page address and L register designates an address in the page.

When an undefined region without data memory is read with H register and L register used as address pointers of the data memory, the data memory contents are regarded as being undefined. Further, data write into an undefined region should be avoided.

Y register is a 4-bit register and functions as an address pointer in page 0 of the data memory or a general purpose register.

Y register flag is an 1-bit flag that shows as to whether H register or L register is used as an address pointer of the data memory. When Y register flag is "1" (EYR=1), Y register is selected as an address pointer of the data memory, and when Y register flag is "0" (EYR=0), H register and L register are selected as address pointers.

Y register flag is set at "1" by the execution of Y register data setting instruction. And Y register flag is cleared at "0" by the execution of the instruction which does not set data to data memory. Further, while Y register flag is set at "1", it is kept in interrupt disabled (waiting) state.

Y register flag is reset at "0" by the initialize operation.

#### (5) Port (P), Port Register (Register)

TCP4620AP/TCP4630AP is provided with a total 34 ports; input port, output port, input output port, and input/output port.

When a port is used as input, it is processed as non-latch input, and therefore, it is necessary to hold external input data till completion of read-in.

When a port is used as output, output data is set in the port register by an instruction and contents of this port register are output. On some ports it is possible to read contents of the port registers by an instruction.

Further, the port register is reset at "0" by initialize operation. In addition, the input level is compatible with CMOS, and the output level is compatible with CMOS/TTL.



Port Configuration

| Port Name         | Symbol         | Pin Name                          | Register Number | Port Function     | Remarks                                                                                                             |
|-------------------|----------------|-----------------------------------|-----------------|-------------------|---------------------------------------------------------------------------------------------------------------------|
| Input Output port | P <sub>0</sub> | P <sub>03</sub> - P <sub>00</sub> | 0               | Input output port | Control designating of I/O by D flag.<br>This port can be specified as an exclusive use output port by mask option. |

| Port Name           | Symbol          | Pin Name                            | Register Number | Port Function | Remarks                                                                                                        |
|---------------------|-----------------|-------------------------------------|-----------------|---------------|----------------------------------------------------------------------------------------------------------------|
| Output Port         | P <sub>1</sub>  | P <sub>13</sub> - P <sub>10</sub>   | 1               | Output port   | General purpose output port. Contents of registers can be read by an instruction.                              |
| I/O Port            | P <sub>2</sub>  | P <sub>23</sub> - P <sub>20</sub>   | 2               | I/O port      | Input/output is specified by mask option. Contents of registers can be read by instruction at the output mode. |
| I/O Port            | P <sub>4</sub>  | P <sub>43</sub> - P <sub>40</sub>   | 4               | I/O port      |                                                                                                                |
| Key Input Port      | P <sub>15</sub> | P <sub>153</sub> - P <sub>150</sub> | 5               | Input port    | General purpose input port with a 150KΩ(Typical) resistor. (Pull-up/down can be specified by mask options).    |
| Digit Output Port   | P <sub>05</sub> | P <sub>054</sub> - P <sub>050</sub> |                 | Output port   | Digit output port for dynamic display. Can be specified as a general purpose output port by mask options.      |
| Input Port          | P <sub>16</sub> | P <sub>160</sub>                    | 6               | Input port    | General purpose input port.                                                                                    |
| Segment Output Port | P <sub>06</sub> | P <sub>067</sub> - P <sub>060</sub> |                 | Output port   | 8-segment output port for dynamic display. Can be specified as a general purpose output port by mask options.  |

## Generalization of Segment Output Port (Specified by Mask Options)

| Port Name   | Symbol          | Pin Name                            | Register Number | Port Function | Remarks                      |
|-------------|-----------------|-------------------------------------|-----------------|---------------|------------------------------|
| Output Port | PO <sub>6</sub> | PO <sub>63</sub> - PO <sub>60</sub> | 6               | Output port   | General purpose output port. |
| Output Port | PO <sub>7</sub> | PO <sub>73</sub> - PO <sub>70</sub> | 7               | Output port   | General purpose output port. |

## (1) Port 0 (Po)

Port 0 is a 4-bit general purpose input/output port. This port is selected when Register 0 is specified in an instruction.

Input/output designation is made by D flag of the status register. When D flag is "0", this port becomes the input and when D flag is "1", it becomes the output and output the content of Register 0.

Port 0 can be used as an exclusive output port by mask options.

(2) Port 1 (P<sub>1</sub>)

Port 1 is a 4-bit general purpose output port. This port is selected when Register 1 is specified in an instruction and the content of Register 1 is output.

Further, the content of Register 1 can be read by an instruction.

(3) Port 2 (P<sub>2</sub>), Port 4 (P<sub>4</sub>)

Port 2 and Port 4 are 4-bit input/output ports that can be specified as either input or output by mask options. When Register 2 and Register 4 are specified in an instruction, Port 2 and Port 4 are selected, respectively.



In specifying input or output in a mask option, the following combination is possible.

- (a) p2/F/, P4/F/-Port 2 and Port 4 as output.
- (b) P2/F/, P4/3/-Port 2 as output.  
High order 2 bits (P43,P42) of Port 4 as input, low order 2 bits (P41, P40) as output.
- (c) P2/0/, P4/F/-Port 2 as input.  
Port 4 as output.
- (d) Specify P2/0/, P4/3/-Port 2 as input.  
High order 2 bits (P43,P42) of Port 4 as input low order 2 bits (P41, P40) of Port 4 as output.
- (e) Specify P2/0/, P4/0/-Port 2 and P4 as input.

Further, in case of input bits these ports operate as non-latch inputs, and in case of output bits they operate functionally same as in Port 1.

#### ④ Output Port 5 (P05)

Output Port 5 is a 5-bit output port with the purpose of digit data output in dynamic display.

When an instruction for writing data in Register 5 is executed, 4-bit data on the internal bus is converted into 5-bit data by the decoder matrix, this data is written into the 5-bit Register 5 and further, output to Port 5.

User is able to specify the content of the decode matrix optionally by mask options.

Further, the content of Register 5 cannot be read by an instruction.



#### ⑤ Input Port 5 (PI5)

Input Port 5 is a 4-bit input port. This port is selected by a Read Register 5 instruction.

Input Port 5 is equipped with a  $150\text{k}\Omega$  (Typ.) input resistor, and the pull-up/down is specified by mask options.

#### ⑥ Output Port 6 (P06), Output Port 7 (P07)

Output Port 6 is a 8-bit output port for segment data output in dynamic display.

When an instruction for writing data in Register 6 is executed, a output data is read from 16 words x 8 bits PLA with a 4-bit data on the internal bus used as an address, this output data is written into the 8-bit Register 6, and output to Port 6.

User is able to specify the content of PLA optionally by mask options.

Further, it is possible to specify and use output Port 6 as two 4-bit general purpose output ports by mask options. In this case, the 8-bit output port is split into high order 4 bits and low order 4 bits, and the high order 4 bits are assigned to output Port 7 (Register 7) and low order 4 bits to Output Port 6 (Register 6).

The contents of Register 6 (and Register 7) cannot be read by an instruction.

Internal bus



#### ⑦ Input Port 6 (PI<sub>6</sub>), Counter Buffer

Input Port 6 is the input port of 1 terminal (PI<sub>60</sub>), but internally it is treated as a 4-bit data in combination with 3-bit data that are output from the divider (refer to Item for Divider).



The read circuit which reads this 4-bit data is called Counter Buffer/Input Port 6 or Counter Buffer simply. This counter buffer is selected by a Read Register 6 instruction and processed as 4-bit parallel non-latch input as in other input ports.

The bit configuration of the counter buffer is such that external input from PI60 terminal is connected to LSB side 1 bit and output from the divider is connected to MSB side 3 bits.

Further, the output stage of the divider to be connected is specified by mask options, but is fixed by a combination of an oscillator to be used and internal basic frequency. (Refer to Item for Divider.)

A Schmitt circuit and a timing shaping shift register are connected to PI60 terminal, which therefore cannot be operated at frequency above the internal basic clock frequency. The internal signal from the input terminal is subject to a time delay of maximum.

$$\frac{3}{\text{Internal basic frequency} \times 2} \text{ (sec.)}$$

#### (6) Internal Bus (IBUS)

The internal bus consists of 4 bits, connects various registers and blocks such as the accumulator, status register, data memory, H register, L register, Y register, port register, ALU, etc., and data to be processed and data of process result are transferred through the internal bus.

#### (7) Data Memory (RAM)

TLCS-46A Family has the following internal data memories in order to store user's process data.

| Type       | Capacity            |
|------------|---------------------|
| TCP4620AP  | 96 words x 4 bits   |
| TCP4630AP  | 160 words x 4 bits  |
| (TCP4600AC | 160 words x 4 bits) |

The data memory consists of the static memory cells.

Addressing of the data memory is executed by contents of H register/L register or Y register.



portion can be referred by Y register.

#### Addressing of Data Memory



INTEGRATED CIRCUIT

TECHNICAL DATA

TCP4620AP  
TCP4630AP

## (8) Program Memory (ROM)

TLCS-46A Family has the following internal program memory in order to store user's process programs.

| Type        | Capacity            |
|-------------|---------------------|
| TCP4620AP   | 2048 words x 8 bits |
| TCP4630AP   | 3072 words x 8 bits |
| (TCP4600AC) | No internal ROM)    |

The program memory addressing is executed by the program counter (PC). Inherent meaning is given to Addresses 0 and 2 by the hardware, normal user process programs are place in Address 4 and subsequent addresses.

Further, the program counter consists of 12 bits and is capable of directly specifying addresses up to 4095, however, data in an undefined region having no program memory loaded becomes unstable.

T C P 4 6 2 0 A P



T C P 4 6 3 0 A P





## (9) Program Counter (PC)

The program counter consists of a 12-bit binary counter, adds count increment at every instruction fetch, and makes the addressing of a program memory in which an instruction to be executed.

When a branch instruction, an interrupt operation, or subroutine instruction is executed, the contents of the program counter are changed.

Addresses 0 and 2 are compulsorily set in the program counter by a initialize signal and an interrupt request signal, respectively.

## (10) Stack (STK), Stack Flag (FSTK)

The stack is used for temporary evacuation of the contents of the program counter when an interrupt request is accepted or a subroutine is to be executed.

The stack flag is a flag indicating whether the contents of the program counter have been evacuated in the stack.

When the contents of the program counter are pushed down in the stack, the stack flag is set at "1" (FSTK=1). And when the contents of the stack are popped up by a RTN instruction and returned to the original program flow, the stack flag is set at "0" (FSTK=0). At time of FSTK=1, the interrupt request becomes the disable (waiting) state.

Further, the stack flag is set at FSTK=1 by the initialize operation.

## (11) Instruction Register (IR), Instruction Decoder (IDEC)

The instruction register latches a 8-bit data from the program memory and outputs it to the instruction decoder. (Program memory data may be used for direct internal control.)



INTEGRATEDCIRCUIT

TECHNICAL DATA

TCP4620AP  
TCP4630AP

The instruction decoder receives data from the instruction register and outputs a control signal required for processing.

(12) Clock Generator (OSC)

TCP4620AP/TCP4630AP has a internal clock generator. By externally installing a crystal oscillator/ceramic oscillator or a LC oscillator, required clock is easily obtained. Furhter, clock can be supplied externally, however, in this case, the clock is input through X<sub>IN</sub> terminal and X<sub>OUT</sub> terminal is kept open. While TCP4620AP/TCP4630AP starts by  $\overline{\text{RESET}}$ , the clock should be always continuously supplied.

Oscillation frequency shall be selected from several frequencies ranging from 20KHz to 4.2MHz by mask options.

The clock generator has a internal 6-stage clock divider and specifies the optimum divide ratio to obtain internal basic clock (CP) on the basis of oscillation frequency by mask options.

The clock generator is provided with the output terminal CK for external timing, and output frequency is specified by mask options.

Further, a divide ratio for obtaining internal basic clock and external timing output frequency specified by mask options (refer to Item for Divider) are determined by an oscillator (oscillation frequency) to be used and internal basic clock frequency.



## Clock Generator Circuit Configuration

(13) Divider

The divider is a binary 16-stage divider provided for a clock counter, timer, etc., and makes the count of internal basic clock (CP).



## Divider Configuration

Of output from the 16-stage divider, 3 bits are connected to the counter buffer by mask options and can be read by a program as the counter buffer contents.

The relation between output 3 bits that can be specified by mask options and the divider output stage is determined by an oscillator (oscillation frequency) to be used and internal basic frequency as shown below.

| Oscillator                 | 32.76K<br>Xtal | 100K<br>Xtal | 400 -<br>500K<br>Ceramic<br>/IFT | 400K<br>ce-<br>ramic<br>/IFT | 3 -<br>4.2M<br>Xtal | 3 -<br>4.2M<br>Xtal |     |
|----------------------------|----------------|--------------|----------------------------------|------------------------------|---------------------|---------------------|-----|
| Internal basic<br>clock CP | 00             | 00           | 04                               | 02                           | 64                  | 32                  |     |
| External timing CK         | 32             | 64           | CP                               | CP                           | CP                  | CP                  |     |
| Counter<br>buffer          | C1             | RD9          | RDB                              | RDB                          | RD7                 | RDA                 | RD7 |
|                            | C2             | RDA          | RDC                              | RDC                          | RDA                 | RDB                 | RDA |
|                            | C3             | RDB          | RDD                              | RDD                          | RDD                 | RDC                 | RDD |

Further, the most significant bit (C3) of the counter buffer is used as a hold release signal (H flag reset enable signal of the status register) when the hold operation is used.

In addition, only when a 100K Xtal is used as an oscillator, the divider (2) is reset when the count value of the divider (2) reaches "12500" and the count value is reset to zero and then the count is resumed.

#### (14) Timing Generator (TG)

The timing generator consists of the internal timing signal generation circuit, initialize control circuit and interrupt control circuit.

① Internal Timing Signal Generation Circuit

This circuit receives the internal basic clock (CP) from the clock generator and generates two internal basic timing signals  $\phi$  and  $\phi_S$ .



② Initialize Control Circuit

This circuit shapes the timing of external RESET signal and generates an internal initialize signal. This initialize signal is used for internal initialization. (For details of the initialize operation refer to "Operation Description".)

③ Interrupt Control Circuit

This circuit shapes the timing of external interrupt request signal INT, store it in the internal interrupt latch, and makes a judgement as to if the internal state is interrupt enable. When it is in evalable state, this circuit generates an interrupt request signal internally and starts an interrupt operation, but if it is in disable state, controls the interrupt request to wait till it becomes enables.

(For details of the interrupt operation refer to "Operation Description".)

## [MACHINE INSTRUCTION]

## 1. Symbol Meaning

The explanation of symbols used for the following description is collected in the following table.

| Symbol          | Meaning                                                          |
|-----------------|------------------------------------------------------------------|
| PC              | Program counter                                                  |
| AC              | Accumulator                                                      |
| ST              | Status register                                                  |
| M               | Data memory                                                      |
| LR              | L register                                                       |
| HR              | H register                                                       |
| YR              | Y register                                                       |
| EYR             | Y register flag                                                  |
| C               | C flag of status register                                        |
| Z               | Z flag of status register                                        |
| R               | Port register, Field designating register under instructions     |
| I               | Value of immediate data field                                    |
| G               | Field designating bit position under bit processing instructions |
| AP              | Address branched by branch instructions                          |
| AP <sub>H</sub> | Field showing higher order 4 bits of AP                          |
| AP <sub>M</sub> | Field showing intermediate order 4 bits of AP                    |
| AP <sub>L</sub> | Field showing lower order 4 bits of AP                           |
| (A)             | Content of A                                                     |
| (A̅)            | Values that contents of A are inverted every bit                 |
| +               | Binary addition                                                  |
| -               | Binary subtraction                                               |
| ^               | Logical AND for every bit                                        |
| ∨               | Logical OR for every bit                                         |

| Symbol       | Meaning                                               |
|--------------|-------------------------------------------------------|
| $\vee$       | Exclusive OR for every bit                            |
| $\leftarrow$ | Value of left side is equalized to that of right side |
| $A[a : b]$   | Content from b bitth to a bitth of A                  |
| $\circ$      | Value is made into one by connecting two fields       |
| $*$          | Value is updated by operation result                  |
| $-$          | Value is not changed by operation result              |
| Push PC      | Content of program counter is saved in stack          |
| Pop PC       | Content of stack is returned to program counter       |
| Null         | No operation                                          |

## 2. Instruction Description

The machine instruction of TLCS-46A consists of 52 kinds of instruction, being divided roughly into 6 kinds as follows:



In this paragraph, the function of each instruction is described according to the following instruction description format.

|                       |                           |  |                                   |                                   |
|-----------------------|---------------------------|--|-----------------------------------|-----------------------------------|
| Assembler<br>mnemonic | Instruction name          |  |                                   |                                   |
|                       | Machine code              |  |                                   |                                   |
|                       | Function                  |  | Z flag<br>after<br>execu-<br>tion | C flag<br>after<br>execu-<br>tion |
|                       | EYR<br>after<br>execution |  |                                   |                                   |
| Operation description |                           |  |                                   |                                   |

## Instruction Description Format

## (1) Data Transfer Instruction

The data transfer instruction mainly provides the data transfer among accumulator, status register, memory (RAM), and registers.

|                                                                                       |                                |   |   |       |           |
|---------------------------------------------------------------------------------------|--------------------------------|---|---|-------|-----------|
| LAR R                                                                                 | Load Accumulator from Register |   |   |       | 1         |
|                                                                                       | 7                              | 0 | 0 | 1     |           |
|                                                                                       | 0                              | 0 | 0 | 1 0 R | 0 ≤ R ≤ 7 |
|                                                                                       | (AC) ← (R)                     |   |   |       | - - 0     |
| The content of register or input port designated by R field is loaded in accumulator. |                                |   |   |       |           |

|                                                                                                                          |       |                                         |   |   |   |   |   |   |           |
|--------------------------------------------------------------------------------------------------------------------------|-------|-----------------------------------------|---|---|---|---|---|---|-----------|
|                                                                                                                          |       | Load Accumulator from Register and Test |   |   |   |   |   |   |           |
| LTR                                                                                                                      | R     | 7                                       | 0 | 0 | 0 | 1 | 1 | R | 0 ≤ R ≤ 7 |
| (AC)                                                                                                                     | ← (R) | *                                       | - | 0 |   |   |   |   |           |
| The content of register or input port designated by R field is loaded in accumulator. After execution Z flag is updated. |       |                                         |   |   |   |   |   |   |           |
|                                                                                                                          |       | Load Accumulator from Memory            |   |   |   |   |   |   |           |
| L A M                                                                                                                    |       | 7                                       | 0 | 0 | 0 | 0 | 0 | 1 | 0         |
| (AC)                                                                                                                     | ← (M) | -                                       | - | 0 |   |   |   |   |           |
| The content of memory is loaded in accumulator                                                                           |       |                                         |   |   |   |   |   |   |           |
| Note 1                                                                                                                   |       |                                         |   |   |   |   |   |   |           |
|                                                                                                                          |       | Load Accumulator from Memory and Test   |   |   |   |   |   |   |           |
| L T M                                                                                                                    |       | 7                                       | 0 | 1 | 0 | 0 | 0 | 0 | 1         |
| (AC)                                                                                                                     | ← (M) | *                                       | - | 0 |   |   |   |   |           |
| The content of memory is loaded in accumulator.                                                                          |       |                                         |   |   |   |   |   |   |           |
| After execution Z flag is updated.                                                                                       |       |                                         |   |   |   |   |   |   |           |
| Note 1                                                                                                                   |       |                                         |   |   |   |   |   |   |           |

|                                                     |                                  |   |             |             |
|-----------------------------------------------------|----------------------------------|---|-------------|-------------|
|                                                     | Load Status-register from Memory |   |             |             |
| L S M                                               | 7<br>0<br>0 0 0 0 0 1 0 1        | 0 |             | 1           |
|                                                     | (ST) ← (M)                       |   | Note 3<br>* | Note 3<br>* |
| The content of memory is loaded in status register. |                                  |   |             |             |
| Note 1                                              |                                  |   |             |             |
|                                                     | Load Accumulator from L-register |   |             |             |
| L A L                                               | 7<br>0<br>0 0 0 0 0 1 1 0        | 0 |             | 1           |
|                                                     | (AC) ← (LR)                      | - | -           | 0           |
| The content of L register is loaded in accumulator. |                                  |   |             |             |
|                                                     | Load Accumulator from H-register |   |             |             |
| L A H                                               | 7<br>0<br>0 0 0 0 0 1 1 1        | 0 |             | 1           |
|                                                     | (AC) ← (HR)                      | - | -           | 0           |
| The content of H register is loaded in accumulator. |                                  |   |             |             |
|                                                     | Load Accumulator Immediate       |   |             |             |
| LAI I                                               | 7<br>0 1 0 0<br>I                | 0 | 0 ≤ I ≤ 15  | 1           |
|                                                     | (AC) ← I                         | - | -           | 0           |
| The value of I field is set to accumulator.         |                                  |   |             |             |



## INTEGRATEDCIRCUIT

## TECHNICAL DATA

TCP4620AP

TCP4630AP

|                                                                                               |  |                               |   |   |   |   |   |            |           |
|-----------------------------------------------------------------------------------------------|--|-------------------------------|---|---|---|---|---|------------|-----------|
|                                                                                               |  | Load L-register Immediate     |   |   |   |   |   |            |           |
| LLI I                                                                                         |  | 7                             | 0 | 1 | 1 | 0 | I | 0 ≤ I ≤ 15 |           |
| (LR) ← I                                                                                      |  |                               |   |   |   |   |   | -          | -         |
| The value of I field is set to L register.                                                    |  |                               |   |   |   |   |   |            |           |
|                                                                                               |  | Load H-register Immediate     |   |   |   |   |   |            |           |
| LHI I                                                                                         |  | 7                             | 0 | 1 | 1 | 1 | I | 0 ≤ I ≤ 15 |           |
| (HR) ← I                                                                                      |  |                               |   |   |   |   |   | -          | -         |
| The value of I field is set to H register.                                                    |  |                               |   |   |   |   |   |            |           |
|                                                                                               |  | Load Y-register Immediate     |   |   |   |   |   |            |           |
| LYI I                                                                                         |  | 7                             | 0 | 1 | 0 | 1 | I | 0 ≤ I ≤ 15 |           |
| (YR) ← I                                                                                      |  |                               |   |   |   |   |   | -          | -         |
| The value of I field is set to Y register.<br>After execution, Y register flag is set to "1". |  |                               |   |   |   |   |   |            |           |
|                                                                                               |  | Store Accumulator to Register |   |   |   |   |   |            |           |
| SAR R                                                                                         |  | 7                             | 0 | 0 | 1 | 0 | 1 | R          | 0 ≤ R ≤ 7 |
| (R) ← (AC)                                                                                    |  |                               |   |   |   |   |   | -          | -         |
| The content of accumulator is stored in the register designated by R field.                   |  |                               |   |   |   |   |   |            |           |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4620AP

TCP4630AP

|       |                                                                      |   |   |   |   |   |   |   |
|-------|----------------------------------------------------------------------|---|---|---|---|---|---|---|
| S A M | Store Accumulator to Memory                                          |   |   |   |   |   |   |   |
|       | 7                                                                    | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
|       | (M) ← (AC)                                                           | - | - | - | - |   |   |   |
|       | The content of accumulator is stored in memory.<br>Note 1, Note 2    |   |   |   |   |   |   |   |
| S S M | Store Status-register to Memory                                      |   |   |   |   |   |   |   |
|       | 7                                                                    | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
|       | (M) ← (ST)                                                           | - | - | - | - |   |   |   |
|       | The content of status register is stored in memory<br>Note 1, Note 2 |   |   |   |   |   |   |   |
| S A L | Store Accumulator to L-register                                      |   |   |   |   |   |   |   |
|       | 7                                                                    | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
|       | (LR) ← (AC)                                                          | - | - | - | - |   |   |   |
|       | The content of accumulator is stored in L register                   |   |   |   |   |   |   |   |
| S A H | Store Accumulator to H-register                                      |   |   |   |   |   |   |   |
|       | 7                                                                    | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
|       | (HR) ← (AC)                                                          | - | - | - | - |   |   |   |
|       | The content of accumulator is stored in H register.                  |   |   |   |   |   |   |   |



## INTEGRATEDCIRCUIT

## TECHNICAL DATA

TCP4620AP  
TCP4630AP

|                                                                                                                                                                                                 |   |                                                                                                                                                                                               |   |   |   |   |   |  |  |   |   |   |   |   |   |   |   |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|--|---|---|---|---|---|---|---|---|
|                                                                                                                                                                                                 |   | Store Accumulator to Y-register                                                                                                                                                               |   |   |   |   |   |  |  |   |   |   |   |   |   |   |   |
| S A Y                                                                                                                                                                                           |   | 7 0<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td></tr> </table> 0                 |   |   |   |   |   |  |  | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0                                                                                                                                                                                               | 0 | 0                                                                                                                                                                                             | 0 | 1 | 0 | 0 | 0 |  |  |   |   |   |   |   |   |   |   |
|                                                                                                                                                                                                 |   | (YR) $\leftarrow$ (AC)                                                                                                                                                                        |   |   |   |   |   |  |  |   |   |   |   |   |   |   |   |
| The content of accumulator is stored in Y register.<br>After execution, Y register flag is set to "1".                                                                                          |   |                                                                                                                                                                                               |   |   |   |   |   |  |  |   |   |   |   |   |   |   |   |
|                                                                                                                                                                                                 |   | Store Y-register to Register                                                                                                                                                                  |   |   |   |   |   |  |  |   |   |   |   |   |   |   |   |
| SYR R                                                                                                                                                                                           |   | 7 0<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>R</td><td></td><td></td></tr> </table> 0 $4 \leq R \leq 7$ |   |   |   |   |   |  |  | 0 | 0 | 1 | 1 | 0 | R |   |   |
| 0                                                                                                                                                                                               | 0 | 1                                                                                                                                                                                             | 1 | 0 | R |   |   |  |  |   |   |   |   |   |   |   |   |
|                                                                                                                                                                                                 |   | (R) $\leftarrow$ (YR)                                                                                                                                                                         |   |   |   |   |   |  |  |   |   |   |   |   |   |   |   |
| The content of Y register is stored in register designated by R field.                                                                                                                          |   |                                                                                                                                                                                               |   |   |   |   |   |  |  |   |   |   |   |   |   |   |   |
|                                                                                                                                                                                                 |   | Clear Register                                                                                                                                                                                |   |   |   |   |   |  |  |   |   |   |   |   |   |   |   |
| CLR R                                                                                                                                                                                           |   | 7 0<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>R</td><td></td><td></td></tr> </table> 0 $0 \leq R \leq 7$ |   |   |   |   |   |  |  | 0 | 0 | 1 | 0 | 0 | R |   |   |
| 0                                                                                                                                                                                               | 0 | 1                                                                                                                                                                                             | 0 | 0 | R |   |   |  |  |   |   |   |   |   |   |   |   |
|                                                                                                                                                                                                 |   | (R) $\leftarrow$ 0 $(0 \leq R \leq 4)$                                                                                                                                                        |   |   |   |   |   |  |  |   |   |   |   |   |   |   |   |
| "0" is written in the register designated by R field ( $0 \leq R \leq 4$ ).<br>For $5 \leq R \leq 7$ , decode matrix output or PLA output corresponding to data "0" is written in the register. |   |                                                                                                                                                                                               |   |   |   |   |   |  |  |   |   |   |   |   |   |   |   |



## INTEGRATEDCIRCUIT

## TECHNICAL DATA

TCP4620AP

TCP4630AP

## (2) Operation Instruction

Operation instruction has 2 operand instruction and 1 operand instruction, and performs arithmetic operation and logical operation.

|                                                                                                                                                                                                         |                                                                                                                                    |   |   |       |   |   |   |   |                    |   |   |  |   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|---|---|-------|---|---|---|---|--------------------|---|---|--|---|
|                                                                                                                                                                                                         | Add Accumulator Immediate                                                                                                          |   |   |       |   |   |   |   |                    |   |   |  |   |
| ADI I                                                                                                                                                                                                   | 7<br><table border="1"><tr><td>1</td><td>0</td><td>0</td><td>1</td><td>I</td><td>0</td></tr></table>                               | 1 | 0 | 0     | 1 | I | 0 | 0 | $0 \leq I \leq 15$ | 1 |   |  |   |
| 1                                                                                                                                                                                                       | 0                                                                                                                                  | 0 | 1 | I     | 0 |   |   |   |                    |   |   |  |   |
|                                                                                                                                                                                                         | $(AC) \leftarrow (AC) + I$                                                                                                         |   |   | * * 0 |   |   |   |   |                    |   |   |  |   |
| The value of I field is added to the content of accumulator. After execution of instruction, Z flag and C flag are updated.                                                                             |                                                                                                                                    |   |   |       |   |   |   |   |                    |   |   |  |   |
| A D A                                                                                                                                                                                                   | Add and Store to Accumulator                                                                                                       |   |   |       |   |   |   |   |                    |   |   |  |   |
|                                                                                                                                                                                                         | 7<br><table border="1"><tr><td>1</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td></tr></table> | 1 | 0 | 0     | 0 | 0 | 0 | 0 | 0                  | 0 | 0 |  | 1 |
| 1                                                                                                                                                                                                       | 0                                                                                                                                  | 0 | 0 | 0     | 0 | 0 | 0 | 0 |                    |   |   |  |   |
|                                                                                                                                                                                                         | $(AC) \leftarrow (M) + (AC)$                                                                                                       |   |   | * * 0 |   |   |   |   |                    |   |   |  |   |
| The content of accumulator is added to the content of memory, and the result is loaded in accumulator. After execution of instruction, Z flag and C flag are updated.                                   |                                                                                                                                    |   |   |       |   |   |   |   |                    |   |   |  |   |
| A D M                                                                                                                                                                                                   | Add and Store to Memory                                                                                                            |   |   |       |   |   |   |   |                    |   |   |  |   |
|                                                                                                                                                                                                         | 7<br><table border="1"><tr><td>1</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td><td>0</td></tr></table> | 1 | 0 | 0     | 0 | 1 | 0 | 0 | 0                  | 0 | 0 |  | 1 |
| 1                                                                                                                                                                                                       | 0                                                                                                                                  | 0 | 0 | 1     | 0 | 0 | 0 | 0 |                    |   |   |  |   |
|                                                                                                                                                                                                         | $(M) \leftarrow (M) + (AC)$                                                                                                        |   |   | * * - |   |   |   |   |                    |   |   |  |   |
| The content of accumulator is added to the content of memory, and the result is stored in memory. After execution of instruction, Z flag and C flag are updated. Note 1, Note 2                         |                                                                                                                                    |   |   |       |   |   |   |   |                    |   |   |  |   |
| A C A                                                                                                                                                                                                   | Add with Carry and Store to Accumulator                                                                                            |   |   |       |   |   |   |   |                    |   |   |  |   |
|                                                                                                                                                                                                         | 7<br><table border="1"><tr><td>1</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td></tr></table> | 1 | 0 | 0     | 0 | 0 | 0 | 0 | 1                  | 0 | 0 |  | 1 |
| 1                                                                                                                                                                                                       | 0                                                                                                                                  | 0 | 0 | 0     | 0 | 0 | 1 | 0 |                    |   |   |  |   |
|                                                                                                                                                                                                         | $(AC) \leftarrow (M) + (AC) + (C)$                                                                                                 |   |   | * * 0 |   |   |   |   |                    |   |   |  |   |
| The content of accumulator and the content of C flag are added to the content of memory, and the result is loaded in accumulator. After execution of instruction, Z flag and C flag are updated. Note 1 |                                                                                                                                    |   |   |       |   |   |   |   |                    |   |   |  |   |

|       |                                                                                                                                                                                                            |   |   |   |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|
| A C M | Add with Carry and Store to Memory                                                                                                                                                                         |   |   |   |
|       | 7                                                   0<br>                                                                 |   |   |   |
|       | (M) + (M) + (AC) + (C)                                                                                                                                                                                     | * | * | - |
|       | The content of accumulator and the content of C flag are added to the content of memory, and the result is stored in memory. After execution of instruction, Z flag and C flag are updated. Note 1, Note 2 |   |   |   |
| S U A | Subtract and Store to Accumulator                                                                                                                                                                          |   |   |   |
|       | 7                                                   0<br>                                                                 |   |   |   |
|       | (AC) - (M) - (AC)                                                                                                                                                                                          | * | * | 0 |
|       | The content of accumulator is subtracted from the content of memory, and the result is loaded in accumulator. After execution of instruction, Z flag and C flag are updated. Note 1                        |   |   |   |
| S U M | Subtract and Store to Memory                                                                                                                                                                               |   |   |   |
|       | 7                                                   0<br>                                                                 |   |   |   |
|       | (M) - (M) - (AC)                                                                                                                                                                                           | * | * | - |
|       | The content of accumulator is subtracted from the content of memory, and the result is stored in memory. After execution of instruction, Z flag and C flag are updated. Note 1, Note 2                     |   |   |   |
| O R A | Or and Store to Accumulator                                                                                                                                                                                |   |   |   |
|       | 7                                                   0<br>                                                               |   |   |   |
|       | (AC) + (M) v (AC)                                                                                                                                                                                          | * | - | 0 |
|       | The logical sum of every bit of the content of memory and the content of accumulator is loaded in accumulator. After execution of instruction, Z flag is updated. Note 1                                   |   |   |   |



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4620AP

TCP4630AP

|       |                                                                                                                                                                                 |   |   |   |   |   |   |   |   |  |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--|--|
| O R M | Or and Store to Memory                                                                                                                                                          |   |   |   |   |   |   |   |   |  |  |
|       | 7<br><table border="1"><tr><td>1</td><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td></tr></table> 0                                                      | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 |  |  |
| 1     | 0                                                                                                                                                                               | 0 | 0 | 1 | 1 | 0 | 0 |   |   |  |  |
| E O A | (M) $\leftarrow$ (M) $\vee$ (AC)                                                                                                                                                | * | - | - |   |   |   |   |   |  |  |
|       | The logical sum of every bit of the content of memory and the content of accumulator is stored in memory. After the execution of instruction, Z flag is updated. Note 1, Note 2 |   |   |   |   |   |   |   |   |  |  |
| E O M | Exclusive-or and Store to Accumulator                                                                                                                                           |   |   |   |   |   |   |   |   |  |  |
|       | 7<br><table border="1"><tr><td>1</td><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td></tr></table> 0                                                      | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 |  |  |
| 1     | 0                                                                                                                                                                               | 0 | 0 | 0 | 1 | 0 | 1 |   |   |  |  |
| C M A | (AC) $\leftarrow$ (M) $\vee\!\!v$ (AC)                                                                                                                                          | * | - | 0 |   |   |   |   |   |  |  |
|       | The exclusive OR of every bit of the content of memory and the content of accumulator is loaded in accumulator. After execution of instruction, Z flag is updated. Note 1       |   |   |   |   |   |   |   |   |  |  |
| C M A | Exclusive-or and Store to Memory                                                                                                                                                |   |   |   |   |   |   |   |   |  |  |
|       | 7<br><table border="1"><tr><td>1</td><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>1</td></tr></table> 0                                                      | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 |  |  |
| 1     | 0                                                                                                                                                                               | 0 | 0 | 1 | 1 | 0 | 1 |   |   |  |  |
| C M A | (M) $\leftarrow$ (M) $\vee\!\!v$ (AC)                                                                                                                                           | * | - | - |   |   |   |   |   |  |  |
|       | The exclusive OR of every bit of the content of memory and the content of accumulator is stored in memory. After execution of instruction, Z flag is updated. Note 1, Note 2    |   |   |   |   |   |   |   |   |  |  |
| C M A | Complement Accumulator                                                                                                                                                          |   |   |   |   |   |   |   |   |  |  |
|       | 7<br><table border="1"><tr><td>1</td><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td></tr></table> 0                                                      | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 |  |  |
| 1     | 0                                                                                                                                                                               | 0 | 0 | 0 | 1 | 1 | 0 |   |   |  |  |
| C M A | (AC) $\leftarrow \overline{(AC)}$                                                                                                                                               | * | - | 0 |   |   |   |   |   |  |  |
|       | The content of accumulator is inverted every bit. After execution of instruction, Z flag is updated.                                                                            |   |   |   |   |   |   |   |   |  |  |

|                                                                                                                                                         |                                                                                                                                                   |   |   |   |   |   |   |   |   |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--|--|--|
|                                                                                                                                                         | Complement Accumulator and Store to Memory                                                                                                        |   |   |   |   |   |   |   |   |  |  |  |
| C M M                                                                                                                                                   | 7                                                                                                                                                 | 0 |   | 1 |   |   |   |   |   |  |  |  |
|                                                                                                                                                         | <table border="1" data-bbox="323 310 606 347"><tr><td>1</td><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>0</td></tr></table>   | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 |  |  |  |
| 1                                                                                                                                                       | 0                                                                                                                                                 | 0 | 0 | 1 | 1 | 1 | 0 |   |   |  |  |  |
| (M) $\leftarrow \overline{(AC)}$                                                                                                                        |                                                                                                                                                   |   |   |   |   |   |   |   |   |  |  |  |
|                                                                                                                                                         | *                                                                                                                                                 | - | - |   |   |   |   |   |   |  |  |  |
| The content of accumulator is inverted every bit, and the result is stored in memory. After execution of instruction, Z flag is updated. Note 1, Note 2 |                                                                                                                                                   |   |   |   |   |   |   |   |   |  |  |  |
|                                                                                                                                                         | Load Accumulator and Increment                                                                                                                    |   |   |   |   |   |   |   |   |  |  |  |
| I C A                                                                                                                                                   | 7                                                                                                                                                 | 0 |   | 1 |   |   |   |   |   |  |  |  |
|                                                                                                                                                         | <table border="1" data-bbox="323 569 606 606"><tr><td>1</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td></tr></table>   | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |  |  |  |
| 1                                                                                                                                                       | 0                                                                                                                                                 | 0 | 0 | 0 | 0 | 1 | 1 |   |   |  |  |  |
|                                                                                                                                                         | (AC) $\leftarrow (M) + 1$                                                                                                                         |   |   |   |   |   |   |   |   |  |  |  |
|                                                                                                                                                         | *                                                                                                                                                 | * | 0 |   |   |   |   |   |   |  |  |  |
| "1" is added to the content of memory, and the result is loaded in accumulator. After execution of instruction, Z flag and C flag are updated. Note 1.  |                                                                                                                                                   |   |   |   |   |   |   |   |   |  |  |  |
|                                                                                                                                                         | Increment Memory                                                                                                                                  |   |   |   |   |   |   |   |   |  |  |  |
| I C M                                                                                                                                                   | 7                                                                                                                                                 | 0 |   | 1 |   |   |   |   |   |  |  |  |
|                                                                                                                                                         | <table border="1" data-bbox="323 843 606 880"><tr><td>1</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td></tr></table>   | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 |  |  |  |
| 1                                                                                                                                                       | 0                                                                                                                                                 | 0 | 0 | 1 | 0 | 1 | 1 |   |   |  |  |  |
|                                                                                                                                                         | (M) $\leftarrow (M) + 1$                                                                                                                          |   |   |   |   |   |   |   |   |  |  |  |
|                                                                                                                                                         | *                                                                                                                                                 | * | - |   |   |   |   |   |   |  |  |  |
| "1" is added to the content of memory. After execution of instruction, Z flag and C flag are updated.<br>Note 1, Note 2                                 |                                                                                                                                                   |   |   |   |   |   |   |   |   |  |  |  |
|                                                                                                                                                         | Increment L-register                                                                                                                              |   |   |   |   |   |   |   |   |  |  |  |
| I C L                                                                                                                                                   | 7                                                                                                                                                 | 0 |   | 1 |   |   |   |   |   |  |  |  |
|                                                                                                                                                         | <table border="1" data-bbox="323 1095 606 1132"><tr><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td></tr></table> | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |  |  |  |
| 0                                                                                                                                                       | 0                                                                                                                                                 | 0 | 0 | 0 | 0 | 1 | 0 |   |   |  |  |  |
|                                                                                                                                                         | (LR) $\leftarrow (LR) + 1$                                                                                                                        |   |   |   |   |   |   |   |   |  |  |  |
|                                                                                                                                                         | -                                                                                                                                                 | - | 0 |   |   |   |   |   |   |  |  |  |
| "1" is added to the content of L register.                                                                                                              |                                                                                                                                                   |   |   |   |   |   |   |   |   |  |  |  |

|                                                                     |                                            |   |  |  |  |  |  |   |   |   |
|---------------------------------------------------------------------|--------------------------------------------|---|--|--|--|--|--|---|---|---|
| I C H                                                               | Increment H-register                       |   |  |  |  |  |  |   |   |   |
|                                                                     | 7                                          | 0 |  |  |  |  |  |   |   |   |
|                                                                     | 0   0   0   0   0   0   1   1              |   |  |  |  |  |  |   |   |   |
| (HR) ← (HR) + 1                                                     |                                            |   |  |  |  |  |  | - | - | 0 |
| T S M                                                               | "1" is added to the content of H register. |   |  |  |  |  |  |   |   |   |
|                                                                     | Test Memory                                |   |  |  |  |  |  |   |   |   |
|                                                                     | 7                                          | 0 |  |  |  |  |  |   |   |   |
| 1   0   0   0   1   1   1   1                                       |                                            |   |  |  |  |  |  | * | - | - |
| (M) ← (M)                                                           |                                            |   |  |  |  |  |  | * | - | - |
| Z flag is set according to the content of memory.<br>Note 1, Note 2 |                                            |   |  |  |  |  |  |   |   |   |

### (3) Bit Manipulation Instruction

The bit manipulation instruction is performed to each bit of accumulator or status register.

|           |                                                                                   |   |           |  |  |  |  |  |   |   |   |  |
|-----------|-----------------------------------------------------------------------------------|---|-----------|--|--|--|--|--|---|---|---|--|
| T B A   G | Test a bit for Accumulator                                                        |   |           |  |  |  |  |  |   |   |   |  |
|           | 7                                                                                 | 0 |           |  |  |  |  |  |   |   |   |  |
|           | 1   0   1   0   0   0   G                                                         |   | 0 ≤ G ≤ 3 |  |  |  |  |  |   |   |   |  |
|           | Null ← (AC) $\wedge$ $2^G$                                                        |   |           |  |  |  |  |  | * | - | 0 |  |
|           | The Z flag is updated, according to the bit of accumulator designated by G field. |   |           |  |  |  |  |  |   |   |   |  |
|           |                                                                                   |   |           |  |  |  |  |  |   |   |   |  |

|                                                                                                                                                            |   |                                |   |                   |             |   |   |   |   |   |   |   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------------------------------|---|-------------------|-------------|---|---|---|---|---|---|---|
|                                                                                                                                                            |   | Test a bit for Status-register |   |                   |             |   |   |   |   |   |   |   |
| TBS G                                                                                                                                                      |   | 7                              | 0 | $0 \leq G \leq 3$ |             |   |   |   |   |   |   |   |
| <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td><td>G</td></tr> </table> |   |                                |   |                   |             | 1 | 0 | 1 | 1 | 0 | 0 | G |
| 1                                                                                                                                                          | 0 | 1                              | 1 | 0                 | 0           | G |   |   |   |   |   |   |
| The Z flag is updated, according to the bit of status register designated by G field.                                                                      |   |                                |   |                   |             |   |   |   |   |   |   |   |
|                                                                                                                                                            |   | Set a bit for Accumulator      |   |                   |             |   |   |   |   |   |   |   |
| SBA G                                                                                                                                                      |   | 7                              | 0 | $0 \leq G \leq 3$ |             |   |   |   |   |   |   |   |
| <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td><td>G</td></tr> </table> |   |                                |   |                   |             | 1 | 0 | 1 | 0 | 0 | 1 | G |
| 1                                                                                                                                                          | 0 | 1                              | 0 | 0                 | 1           | G |   |   |   |   |   |   |
| $(AC) \leftarrow (AC) \vee 2^G$                                                                                                                            |   |                                |   | -                 | -           |   |   |   |   |   |   |   |
| The bit of accumulator designated by G field is set to "1".                                                                                                |   |                                |   |                   |             |   |   |   |   |   |   |   |
|                                                                                                                                                            |   | Set a bit for Status-register  |   |                   |             |   |   |   |   |   |   |   |
| SBS G                                                                                                                                                      |   | 7                              | 0 | $0 \leq G \leq 3$ |             |   |   |   |   |   |   |   |
| <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>0</td><td>1</td><td>1</td><td>0</td><td>1</td><td>G</td></tr> </table> |   |                                |   |                   |             | 1 | 0 | 1 | 1 | 0 | 1 | G |
| 1                                                                                                                                                          | 0 | 1                              | 1 | 0                 | 1           | G |   |   |   |   |   |   |
| $(ST) \leftarrow (ST) \vee 2^G$                                                                                                                            |   |                                |   | Note 3<br>*       | Note 3<br>* |   |   |   |   |   |   |   |
| The bit of status-register designated by G field is set to "1".                                                                                            |   |                                |   |                   |             |   |   |   |   |   |   |   |
|                                                                                                                                                            |   | Clear a bit for Accumulator    |   |                   |             |   |   |   |   |   |   |   |
| CBA G                                                                                                                                                      |   | 7                              | 0 | $0 \leq G \leq 3$ |             |   |   |   |   |   |   |   |
| <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td><td>G</td></tr> </table> |   |                                |   |                   |             | 1 | 0 | 1 | 0 | 1 | 0 | G |
| 1                                                                                                                                                          | 0 | 1                              | 0 | 1                 | 0           | G |   |   |   |   |   |   |
| $(AC) \leftarrow (AC) \wedge \bar{2^G}$                                                                                                                    |   |                                |   | -                 | -           |   |   |   |   |   |   |   |
| The bit of accumulator designated by G field is cleared to "0".                                                                                            |   |                                |   |                   |             |   |   |   |   |   |   |   |



## INTEGRATEDCIRCUIT

## TECHNICAL DATA

TCP4E20AP  
TCP4E30AP

|                                                                     |  |                                              |   |                                                                    |  |             |             |   |
|---------------------------------------------------------------------|--|----------------------------------------------|---|--------------------------------------------------------------------|--|-------------|-------------|---|
|                                                                     |  | Clear a bit for Status register              |   |                                                                    |  |             |             |   |
| CBS G                                                               |  | 7                                            | 0 | $1 \mid 0 \mid 1 \mid 1 \mid 1 \mid 0 \mid G$<br>$0 \leq G \leq 3$ |  |             |             | 1 |
|                                                                     |  | $(ST) \leftarrow (ST) \wedge \overline{2^G}$ |   |                                                                    |  | Note 3<br>* | Note 3<br>* | 0 |
| The bit of status register designated by G field is cleared to "0". |  |                                              |   |                                                                    |  |             |             |   |
|                                                                     |  | Invert a bit for Accumulator                 |   |                                                                    |  |             |             |   |
| IBA G                                                               |  | 7                                            | 0 | $1 \mid 0 \mid 1 \mid 0 \mid 1 \mid 1 \mid G$<br>$0 \leq G \leq 3$ |  |             |             | 1 |
|                                                                     |  | $(AC) \leftarrow (AC) \vee 2^G$              |   |                                                                    |  | -           | -           | 0 |
| The bit of accumulator designated by G field is inverted.           |  |                                              |   |                                                                    |  |             |             |   |
|                                                                     |  | Invert a bit for Status register             |   |                                                                    |  |             |             |   |
| IBS G                                                               |  | 7                                            | 0 | $1 \mid 0 \mid 1 \mid 1 \mid 1 \mid 1 \mid G$<br>$0 \leq G \leq 3$ |  |             |             | 1 |
|                                                                     |  | $(ST) \leftarrow (ST) \vee 2^G$              |   |                                                                    |  | Note 3<br>* | Note 3<br>* | 0 |
| The bit of status register designated by G field is inverted.       |  |                                              |   |                                                                    |  |             |             |   |

## (4) Branch instruction

The branch instruction performs unconditional or conditional branch.

|                                                                                                                                                                                                                                                                                |    |                                                                                                                                                                                                        |     |                 |                 |                 |                 |                 |                 |                       |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------------|--|
| JMP                                                                                                                                                                                                                                                                            | AP | Jump                                                                                                                                                                                                   |     |                 |                 |                 |                 |                 |                 |                       |  |
|                                                                                                                                                                                                                                                                                |    | 7                                                                                                                                                                                                      | 015 |                 | 8               |                 |                 |                 |                 |                       |  |
|                                                                                                                                                                                                                                                                                |    | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>1</td><td>1</td><td>1</td><td>0</td> <td>AP<sub>L</sub></td> <td>AP<sub>H</sub></td> <td>AP<sub>M</sub></td> </tr> </table> | 1   | 1               | 1               | 0               | AP <sub>L</sub> | AP <sub>H</sub> | AP <sub>M</sub> | $0 \leq AP \leq 4095$ |  |
| 1                                                                                                                                                                                                                                                                              | 1  | 1                                                                                                                                                                                                      | 0   | AP <sub>L</sub> | AP <sub>H</sub> | AP <sub>M</sub> |                 |                 |                 |                       |  |
| (PC) $\leftarrow$ AP                                                                                                                                                                                                                                                           |    |                                                                                                                                                                                                        |     |                 |                 | -               | -               |                 |                 |                       |  |
| The value of AP field is set to program counter. After execution of instruction, therefore, program sequence changes to the AP address.                                                                                                                                        |    |                                                                                                                                                                                                        |     |                 |                 |                 |                 |                 |                 |                       |  |
| BCS                                                                                                                                                                                                                                                                            | AP | Branch on Condition Set                                                                                                                                                                                |     |                 |                 |                 |                 |                 |                 |                       |  |
|                                                                                                                                                                                                                                                                                |    | 7                                                                                                                                                                                                      | 015 |                 | 8               |                 |                 |                 |                 |                       |  |
|                                                                                                                                                                                                                                                                                |    | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>1</td><td>1</td><td>0</td><td>0</td> <td>AP<sub>L</sub></td> <td>AP<sub>H</sub></td> <td>AP<sub>M</sub></td> </tr> </table> | 1   | 1               | 0               | 0               | AP <sub>L</sub> | AP <sub>H</sub> | AP <sub>M</sub> | $0 \leq AP \leq 4095$ |  |
| 1                                                                                                                                                                                                                                                                              | 1  | 0                                                                                                                                                                                                      | 0   | AP <sub>L</sub> | AP <sub>H</sub> | AP <sub>M</sub> |                 |                 |                 |                       |  |
| If Z = 1 then (PC) $\leftarrow$ AP, else Null                                                                                                                                                                                                                                  |    |                                                                                                                                                                                                        |     |                 |                 | -               | -               |                 |                 |                       |  |
| The content of Z flag is "1", the value of AP field is set to program counter. After execution of instruction, therefore, program sequence changes to the AP address.<br>If the content of Z flag is "0", the program sequence follows the next address without any operation. |    |                                                                                                                                                                                                        |     |                 |                 |                 |                 |                 |                 |                       |  |
| BCC                                                                                                                                                                                                                                                                            | AP | Branch on Condition Clear                                                                                                                                                                              |     |                 |                 |                 |                 |                 |                 |                       |  |
|                                                                                                                                                                                                                                                                                |    | 7                                                                                                                                                                                                      | 015 |                 | 8               |                 |                 |                 |                 |                       |  |
|                                                                                                                                                                                                                                                                                |    | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>1</td><td>1</td><td>0</td><td>1</td> <td>AP<sub>L</sub></td> <td>AP<sub>H</sub></td> <td>AP<sub>M</sub></td> </tr> </table> | 1   | 1               | 0               | 1               | AP <sub>L</sub> | AP <sub>H</sub> | AP <sub>M</sub> | $0 \leq AP \leq 4095$ |  |
| 1                                                                                                                                                                                                                                                                              | 1  | 0                                                                                                                                                                                                      | 1   | AP <sub>L</sub> | AP <sub>H</sub> | AP <sub>M</sub> |                 |                 |                 |                       |  |
| If Z = 0 then (PC) $\leftarrow$ AP, else Null                                                                                                                                                                                                                                  |    |                                                                                                                                                                                                        |     |                 |                 | -               | -               |                 |                 |                       |  |
| The content of Z flag is "0", the value of AP field is set to program counter. After execution of instruction, therefore, program sequence changes to the AP address.<br>If the content of Z flag is "1", the program sequence follows the next address without any operation. |    |                                                                                                                                                                                                        |     |                 |                 |                 |                 |                 |                 |                       |  |

## (5) Interrupt/Subroutine Instruction

The interrupt/subroutine instruction is used for performing a call of subroutine and a return from interrupt routine or subroutine.

In addition NOP instruction is available as one other instruction.

|        |                                                                                                                                                                                                                                                                                          |     |   |   |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---|---|
|        | Call Subroutine                                                                                                                                                                                                                                                                          |     |   |   |
| CAL AP | <br>push (PC), and (PC) ← AP                                                                                                                                                                                                                                                             | 015 | 8 | 2 |
|        | The content (the next address) of program counter is stored in the stack, and the value of AP field is set to the program counter. The interrupt is placed in disable (queued) state during execution of subroutine.                                                                     | -   | - | 0 |
|        | Return                                                                                                                                                                                                                                                                                   |     |   |   |
| R T N  | <br>POP (PC)                                                                                                                                                                                                                                                                             | 0   |   | 2 |
|        | The content of the stack is restored to program counter. After execution of instruction, the interrupt is placed in enable state.                                                                                                                                                        | -   | - | 0 |
|        | Jump by Accumulator                                                                                                                                                                                                                                                                      |     |   |   |
| J A C  | <br>(PC) ← (PC)+1, and (PC) < 11:4> (AC)                                                                                                                                                                                                                                                 | 0   |   | 2 |
|        | The content (address where JAC instruction is stored, plus 2) of the incremented program counter is taken as the higher 8 bits, and the content of AC is taken as the lower 4 bits; then, the value of 12 bits in total that these contents are connected is set to the program counter. | -   | - | 0 |
|        | No Operation                                                                                                                                                                                                                                                                             |     |   |   |
| N O P  | <br>Null                                                                                                                                                                                                                                                                                 | 0   |   | 1 |
|        | This is an instruction by which nothing is executed. However, Y register flag is reset to "0".                                                                                                                                                                                           | -   | - | 0 |



INTEGRATEDCIRCUIT

TECHNICAL DATA

TCP4620AP

TCP4630AP

Note 1: The address of data memory becomes as follows;

EYR = 0 , (HR<sup>o</sup>LR)

EYR = 1 , (0<sup>o</sup>YR).

Note 2: Care should be taken to the fact that, even after this instruction is eexecuted, Y register flag does not change.

Note 3: A flag may be updated as a result of processing.

Toshiba

東芝

## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4620AP

TCP4630AP

## 3. LIST OF INSTRUCTIONS

|                           | Mne-monic    | Machine code |           | Operation                                          | Update of flag | Remarks    |
|---------------------------|--------------|--------------|-----------|----------------------------------------------------|----------------|------------|
|                           | Hexa-decimal | Binary       |           |                                                    |                |            |
| Data Transfer Instruction | LAR          | 1i           | 00010iii  | (AC) <- (Register iii)                             |                |            |
|                           | LTR          | 1i           | 00011iii  | (AC) <- (Register iii)                             | Z              |            |
|                           | LAM          | 04           | 00000100  | (AC) <- (M)                                        |                |            |
|                           | LTM          | 87           | 10000111  | (AC) <- (M)                                        | Z              |            |
|                           | LSM          | 05           | 00000101  | (ST) <- (M)                                        | ZC             |            |
|                           | LAL          | 06           | 00000110  | (AC) <- (LR)                                       |                |            |
|                           | LAH          | 07           | 00000111  | (AC) <- (HR)                                       |                |            |
|                           | LAI          | 4i           | 0100iiii  | (AC) <- iiii                                       |                |            |
|                           | LLI          | 6i           | 0110iiii  | (LR) <- iiii                                       |                |            |
|                           | LHI          | 7i           | 0111iiii  | (HR) <- iiii                                       |                |            |
|                           | LYI          | 5i           | 0101iiii  | (YR) <- iiii                                       |                |            |
|                           | SAR          | 2i           | 00101iii  | (Register iii) <- (AC)                             |                | EYR is set |
|                           | SAM          | 0C           | 00000100  | (M) <- (AC)                                        |                |            |
|                           | SSM          | 0D           | 00000101  | (M) <- (ST)                                        |                |            |
|                           | SAL          | 0E           | 00000110  | (LR) <- (AC)                                       |                |            |
|                           | SAH          | 0F           | 00000111  | (HR) <- (AC)                                       |                |            |
|                           | SAY          | 08           | 000001000 | (YR) <- (AC)                                       |                |            |
| Operation Instruction     | SYR          | 3i           | 001101ii  | (Register 1ii) <- (YR)                             |                | EYR is set |
|                           | CLR          | 2i           | 00100iii  | (Register iii) <- 0                                |                |            |
|                           | ADI          | 9i           | 1001iiii  | (AC) <- (AC)+iiii                                  | ZC             |            |
|                           | ADA          | 80           | 10000000  | (AC) <- (M)+(AC)                                   | ZC             |            |
|                           | ADM          | 88           | 10001000  | (M) <- (M)+(AC)                                    | ZC             |            |
|                           | ACA          | 81           | 10000001  | (AC) <- (M)+(AC)+(C)                               | ZC             |            |
|                           | ACM          | 89           | 100001001 | (M) <- (M)+(AC)+(C)                                | ZC             |            |
|                           | SUA          | 82           | 100000010 | (AC) <- (M)-(AC)                                   | ZC             |            |
|                           | SUM          | 8A           | 100001010 | (M) <- (M)-(AC)                                    | ZC             |            |
|                           | ORA          | 84           | 100000100 | (AC) <- (M)∨(AC)                                   | Z              |            |
|                           | ORM          | 8C           | 100001100 | (M) <- (M)∨(AC)                                    | Z              |            |
|                           | EOA          | 85           | 100000101 | (AC) <- (M)∨(AC)                                   | Z              |            |
|                           | EOM          | 8D           | 100001101 | (M) <- (M)∨(AC)                                    | Z              |            |
|                           | CMA          | 86           | 100000110 | (AC) <- (AC)                                       | Z              |            |
|                           | CMM          | 8E           | 100001110 | (M) <- (AC)                                        | Z              |            |
|                           | ICA          | 83           | 100000011 | (AC) <- (M)+1                                      | ZC             |            |
|                           | ICM          | 8B           | 100001011 | (M) <- (M)+1                                       | ZC             |            |
|                           | ICL          | 02           | 000000010 | (LR) <- (LR)+1                                     |                |            |
|                           | ICH          | 03           | 000000011 | (HR) <- (HR)+1                                     |                |            |
|                           | TSM          | 8F           | 100001111 | (M) <- (M), if (M)=0<br>then Z <- 1<br>else Z <- 0 | Z              |            |

|                                  | Mne-<br>monic | Machine code                    |                      | Operation                              | Update<br>of flag | Remarks                                                                                |
|----------------------------------|---------------|---------------------------------|----------------------|----------------------------------------|-------------------|----------------------------------------------------------------------------------------|
|                                  |               | Hexa-<br>decimal                | Binary               |                                        |                   |                                                                                        |
| Bit Manipulation<br>Instruction  | TBA           | A <u>i</u>                      | 101000ii             | if (AC)<ii>=0 then Z + 1<br>eles Z + 0 | Z                 | Asteris (*) denotes that, when Z flag and C flag are designated, the fags are updated. |
|                                  | TBS           | B <u>i</u>                      | 101100ii             | if (ST)<ii>=0 then Z + 1<br>eles Z + 0 | Z                 |                                                                                        |
|                                  | SBA           | A <u>i</u>                      | 101001ii             | (AC)<ii><1                             | **                |                                                                                        |
|                                  | SBS           | B <u>i</u>                      | 101101ii             | (ST)<ii><1                             | **                |                                                                                        |
|                                  | CBA           | A <u>i</u>                      | 101010ii             | (AC)<ii><0                             | **                |                                                                                        |
|                                  | CBS           | B <u>i</u>                      | 101110ii             | (ST)<ii><0                             | **                |                                                                                        |
|                                  | IBA           | A <u>i</u>                      | 101011ii             | (AC)<ii>+(AC)<ii>                      | **                |                                                                                        |
|                                  | IBS           | B <u>i</u>                      | 101111ii             | (ST)<ii>+(ST)<ii>                      | **                |                                                                                        |
| Branch Instruction<br>and Others | JMP           | E <u>k</u><br><u>i</u> <u>j</u> | 1110kkkk<br>iiiijjjj | (PC)<iiiijjjjkkkk                      |                   | 2-byte, 2-cycle instruction                                                            |
|                                  | BCS           | C <u>k</u><br><u>i</u> <u>j</u> | 1100kkkk<br>iiiijjjj | if Z=1 then (PC)<iiiijjjjkkkk          |                   | "                                                                                      |
|                                  | BCC           | D <u>k</u><br><u>i</u> <u>j</u> | 1101kkkk<br>iiiijjjj | if Z=0 then (PC)<iiiijjjjkkkk          |                   | "                                                                                      |
|                                  | CAL           | F <u>k</u><br><u>i</u> <u>j</u> | 1111kkkk<br>iiiijjjj | (PC)+, (PC)<iiiijjjjkkkk               |                   | "                                                                                      |
|                                  | RTN           | O <u>1</u>                      | 00000001             | (PC)↑                                  |                   | 1-byte, 2-cycle instruction                                                            |
|                                  | JAC           | O <u>9</u>                      | 00001001             | (PC)<((PC)+1)<11:4>•(AC)               |                   | "                                                                                      |
|                                  | NOP           | O <u>0</u>                      | 00000000             | No Operation                           |                   | EYR is reset.                                                                          |

Note: Pay attention to the conversion of the underlined machine codes.

## 4. TLCS-46A Instruction map

| L<br>H | 0   | 1         | 2     | 3     | 4     | 5     | 6     | 7     | 8   | 9         | A   | B   | C     | D   | E   | F   |
|--------|-----|-----------|-------|-------|-------|-------|-------|-------|-----|-----------|-----|-----|-------|-----|-----|-----|
| 0      | NOP | *1<br>RTN | ICL   | ICH   | LAM   | LSM   | LAL   | LAH   | SAY | *1<br>JAC |     |     | SAM   | SSM | SAL | SAH |
| 1      |     |           | L A R |       |       |       |       |       |     |           |     |     | L T R |     |     |     |
| 2      |     |           | C L R |       |       |       |       |       |     |           |     |     | S A R |     |     |     |
| 3      |     |           |       | S Y R |       |       |       |       |     |           |     |     |       |     |     |     |
| 4      |     |           |       |       | L A I |       |       |       |     |           |     |     |       |     |     |     |
| 5      |     |           |       |       | L Y I |       |       |       |     |           |     |     |       |     |     |     |
| 6      |     |           |       |       | L L I |       |       |       |     |           |     |     |       |     |     |     |
| 7      |     |           |       |       | L H I |       |       |       |     |           |     |     |       |     |     |     |
| 8      | ADA | ACA       | SUA   | ICA   | ORA   | EOA   | CMA   | LTM   | ADM | ACM       | SUM | ICM | ORM   | EOM | CMM | TSM |
| 9      |     |           |       |       |       |       |       |       |     |           |     |     |       |     |     |     |
| A      |     | T B A     |       |       | S B A |       |       |       |     | C B A     |     |     | I B A |     |     |     |
| B      |     | T B S     |       |       | S B S |       |       |       |     | C B S     |     |     | I B S |     |     |     |
| C      |     |           |       |       |       | B C S |       |       |     |           |     |     |       |     |     |     |
| D      |     |           |       |       |       |       | B C C |       |     |           |     |     |       |     |     |     |
| E      |     |           |       |       |       |       | J M P |       |     |           |     |     |       |     |     |     |
| F      |     |           |       |       |       |       |       | C A L |     |           |     |     |       |     |     |     |

\*1 - 1 byte, 2-cycle instruction

\*2 - 2 byte, 2-cycle instruction

## [OPERATION DESCRIPTION]

## 1. Basic Clock

The basic clock is used to generate the basic timing signals for the operation of TLCS-46A and as the clock for the divider.

For the generation and supply of basic clock, there are following methods:

## (1) Connecting crystal oscillator/ceramic oscillator



In case the crystal oscillator/ceramic oscillator is connected as shown in the left figure, it is possible to obtain the oscillation frequency characteristic to crystal oscillator/ceramic oscillator.

## (2) Connecting IFT



In case the IFT is connected as shown in the left figure, it is possible to obtain the oscillation frequency characteristic to IFT.

## (3) Suppling the external clock



If the external oscillator is connected to XIN terminal as shown in the left figure, it is possible to supply the clock from the external.

In this case, XOUT terminal shall be kept open.

## 2. Instruction Execute Cycle

The instruction execute cycle consists of two internal timing signals,  $\phi_S$  and  $\phi$ , supplied by the timing generator.

$\phi_S$  is the signal expressing the instruction execute cycle, while  $\phi$  is the signal which comes to the set timing of data memory, register, etc.



Instruction Execution Timing Chart

## 3. Initialize operation (System initialization)

The initialize operation is carried out without fail after impressing power source on TLCS-46A, which is returned to the initial state in the interior.

By keeping the RESET terminal to "L" level, the internal initialize signal is formed, whereby the initialize operation of TLCS-46A is executed. At this time, more than 2 cycles are required for the time of "L" level.

RESET

| $W < 2$ cycles                                                   | $W \geq 2$ cycles                 |
|------------------------------------------------------------------|-----------------------------------|
| Whether or not initialize operation is executed is not definite. | Initialize operation is executed. |

However, 1 cycle corresponds to 2 period of internal basic clock (CP).

By the initialize operation, the interior of TLCS-46A comes to the conditions as given below:

- ① Resetting H flag and D flag of status register to "0".
- ② Resetting the interrupt latch to "0".
- ③ Resetting the port register "0".  
(All output pins come to "L" level.)
- ④ Setting the stack flag to "1".
- ⑤ Setting the program counter to 0 address.

There is no influence on accumulator, data memory, H register, L register, Y register, C flag and Z flag of status register, etc.

The program is executed from 0 address when RESET signal comes to "H" level and the internal initialize signal comes to "L" level.



#### 4. Interrupt Operation

TLCS-46A is provided with the function permitting the external interrupt operation. The interruption is an operation enabling other processing to be preferentially made by suspending the processing underway.

The request for interrupt operation is made by changing INT terminal from "H" level to "L" level and by holding the terminal on "L" level for more than 2 cycles.

There are several conditions enabling TLCS-46A to start the interrupt operation. If the interrupt operation request is made before the conditions are satisfied, the interrupt operation is in standby state to wait until the conditions are satisfied.

The conditions are as follows:

- ① Data memory is not made reference with Y register.  
(EYR = 0)
- ② Stack is empty. (FSTK = 0)
- ③ No hold operation (Interrupt request is ignored in hold operation.)

The external interrupt request signal is preserved in the internal interrupt latch, and the interrupt latch is cleared when the interrupt is accepted.

In case of repetitive interrupt request, it is required to make  $\overline{\text{INT}}$  terminal "H" level (more than 2 cycles) and to make  $\overline{\text{INT}}$  terminal "L" level. Repetitive interrupt request is not accepted when  $\overline{\text{INT}}$  terminal is "L" level without making it "H" level.

#### ① Internal latch set timing



| $W < 2$ cycles                                            | $W \geq 2$ cycles         |
|-----------------------------------------------------------|---------------------------|
| Whether or not interruption latch is set is not definite. | Interruption latch is set |

However, 1 cycle corresponds to 2 period of internal basic clock (CP).

#### ② Internal latch repetitive set timing



| $W' = 0$                             | $0 < W' < 2$ cycles                                             | $W' \geq 2$ cycles              |
|--------------------------------------|-----------------------------------------------------------------|---------------------------------|
| Interruption latch is not set again. | Whether or not interruption latch is set again is not definite. | Interruption latch is set again |

However, 1 cycle corresponds to 2 period of internal basic clock (CP).

When TLCS-46A accepts the interrupt, the following processings are made:

- 1 The content of program counter is stored in a save register (stack).
- 2 The entry address (address 2) is set in the program counter.
- 3 The interrupt latch is cleared.

Therefore, the interrupt service routine defines 2 address of program memory as the top address.

When TLCS-46A returns to the main program by completing the interrupt process, it follows the execution of RTN instruction.



Interrupt Acceptance Timing Chart

## 5. Hold Operation

In case the hold operation is designated by mask options, the operation state (normal/hold) of TLCS-46A is controlled by the H flag of status register.



When each instruction of SBS, LBS and LSM is executed, and "1" is set to the H flag, the internal timing signals of  $\phi_S$  and  $\phi$  stop after the completion of the execution of the instruction, whereby the hold operation begins. At this time, the program counter, instruction register and other internal registers are held in the state which was before the hold operation, but the interrupt request under waiting is ignored because the interrupt latch is cleared.

As the clock generator does not stop, there is no influence on the internal basic clock and the count function of divider.

Restart from the hold operation is made by resetting H flag to "0" in hardware. For the signal for resetting H flag, the output of divider (the MSB input (C3) of counter buffer) is used, and the resetting is made by detecting the trailing edge of the bit input (C3).

At the input of divider is the internal clock (CP), restart is made at constant intervals.

When H flag is reset, the internal timing signals of  $\phi_S$  and  $\phi$  start, whereby the execution is continued to start from the condition which is the same as that just before starting the hold operation.



Restart Timing from Hold Operation



# INTEGRATEDCIRCUIT

## TECHNICAL DATA

TCP4620AP  
TCP4E30AP

### 6. Reference to Data Memory

There are two methods of making reference to data memory.

- (1) The page of data memory is designated by H register, while the address in the page is designated by L register.

In the case of access to data memory, it is so arranged as to make access to the address designated by L register in the page designated by the contents of H register.

(1 page consists of 16 words.)



- (2) The address in 0 page is designated by Y register. In the case of access to data memory immediately after writing data in Y register by the instruction of LYI or SAY, the access is made to the address designated by the contents of Y register in 0 page.



At the time of making reference to data memory, it depends on the value of internal Y register flag (EYR) to select H register/L register or Y register for designating address. When EYR=0, the method (1) above is adopted. When EYR = 1, the method (2) above is adopted. When data are written in Y register by SAY instruction or LYI instruction, "1" is set to EYR. At the time of instruction execution when data are not set to data memory, EYR is reset to "0".

## 7. Input and Output Timing for Port

The input of data from the input port of TLCS-46A and the output of data to the output port are made by the data transfer instruction between accumulator and each port.

### Port Input

As the input ports of TLCS-46A are all non-latch inputs, the input data is required to be stable until the completion of reading.

At the instruction cycle of LAR or LTR instruction, input data is set to the accumulator.

### Port Output

The output ports of TLCS-46A output the content of port register. Data are written in the port register when SAR, SYR and CLR instructions are executed.

The digit output port (PO5) and segment output port (PO6) for display are different in output timing from other output ports.



Output Timing (Port5, Port6)



Output Timing (except Port5, Port6)

#### 8. Input/Output Switching of Port 0

The switching of input/output of port 0 is made by the D flag of status register. By each instruction of SBS, CBS, IBS and LSM, the value of D flag is changed, whereby the switching of input/output is carried out.



Input/Output Switching Timing of Port 0

#### 9. Output Terminal for External Timing

CK terminal is equipped for taking out the output of the divider of clock generator.

The output frequency is designated by the mask options but is decided by the oscillator (oscillation frequency) used. The output frequency is either 1/32 or 1/64 of oscillation frequency or internal basic clock (CP).

The output signal on CK terminal is generated after inverting the phase of the output of divider.



Example of the internal basic clock and external timing waveform.

The internal basic clock (CP) is 1/4 of the oscillation frequency. The external timing signal is CP.

#### [Mask Options]

TCP4620AP/TCP4630AP have many kinds of mask options on the clock generator, input output ports, etc. so as to meet the extensive requirements from the users.

| Option Name | Function                                                               |
|-------------|------------------------------------------------------------------------|
| O S C       | Prescribing the oscillator and oscillation frequency.                  |
| C P         | Prescribing the dividing ratio for obtaining the internal basic clock. |

| Option Name    | Function                                                  |
|----------------|-----------------------------------------------------------|
| C K            | Prescribing the output frequency for the external timing. |
| COUNTER        | Prescribing the reset timing of divider.                  |
| COUNTER BUFFER | Prescribing the input of counter buffer.                  |
| HOLD           | Prescribing the function of H flag.                       |
| RSTH           | Prescribing the restart signal from hold operation.       |
| STD            | Prescribing the function of port 0.                       |
| P 2            | Prescribing the function of port 2.                       |
| P 4            | Prescribing the function of port 4.                       |
| P I 5          | Prescribing the function of input resistance of port 5.   |
| DECODER        | Prescribing the contents of decode matrix.                |
| P O 6          | Prescribing the function of port 6.                       |
| PLA            | Prescribing the contents of PLA.                          |

- (Note) o The mask options of OSC-RSTH are decided by the oscillator (oscillation frequency) used.
- o Use the designation paper for mask options which is attached to the ES order sheet.
  - o Submit to us the designation paper for mask options together with the ES order sheet by the date two weeks prior to the date of submitting the mask tape.



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4620AP

TCP4630AP

## 1. Designation of Mask Options

| Option Item                       | Option Name     | TYP001                | TYP002              | TYP003                          | TYP004                      | TYP005                  | TYP006                  |
|-----------------------------------|-----------------|-----------------------|---------------------|---------------------------------|-----------------------------|-------------------------|-------------------------|
| Oscillation frequency             | OSC             | 003<br>32.76K<br>Xtal | 012<br>100K<br>Xtal | 050<br>400-500K<br>ceramic /IFT | 050<br>400K<br>ceramic /IFT | 400<br>3 - 4.2K<br>Xtal | 400<br>3 - 4.2K<br>Xtal |
| Dividing ratio for internal clock | CP              | 00                    | 00                  | 04                              | 02                          | 64                      | 32                      |
| External timing output            | CK              | 32                    | 64                  | CP                              | CP                          | CP                      | CP                      |
| Counter Counter                   | PD              | CP                    | CP                  | CP                              | CP                          | CP                      | CP                      |
| Count-er                          | Divider 1 Input | PDR                   | PD2                 | PD2                             | PD2                         | PD2                     | PD2                     |
| Counter Counter                   | Divider 3 Input | PDR                   | N                   | /12500/                         | N                           | N                       | N                       |
| Count-er                          | Reset timing    | CO                    | PI <sub>60</sub>    | PI <sub>60</sub>                | PI <sub>60</sub>            | PI <sub>60</sub>        | PI <sub>60</sub>        |
| Counter Buffer                    | Buffer 0 Input  | C1                    | RD9                 | RDB                             | RDB                         | RDA                     | RD7                     |
| Counter Buffer                    | Buffer 1 Input  | C2                    | RDA                 | RDC                             | RDC                         | RDB                     | RDA                     |
| Counter Buffer                    | Buffer 2 Input  | C3                    | RDB                 | RDD                             | RDD                         | RDC                     | RDD                     |
| Counter Buffer                    | Buffer 3 Input  | HOLD                  | H                   | H                               | 0                           | 0                       | 0                       |
| H flag                            |                 |                       |                     |                                 |                             |                         |                         |
| Restart condition                 | RSTH            | C3                    | C3                  | C3                              | 0                           | 0                       | 0                       |
| Input/Output port                 | Port 0          | STD                   | D(PROG)             | 1(OUT)                          |                             |                         |                         |
| I/O port                          | Port 2          | P2                    | /F/(OUT)            | /F/(OUT)                        | /0/(IN)                     | /0/(IN)                 | /0/(IN)                 |
|                                   | Port 4          | P4                    | /F/(OUT)            | /3(IN/OUT)                      | /F/(OUT)                    | /3(IN/OUT)              | /0/(IN)                 |
| Input resistance (Input port 5)   |                 | PI5                   | 0(UP)               | 1(DOWN)                         |                             |                         |                         |
| Decode matrix                     | Line 0          | DEC0                  | /                   | /                               |                             |                         |                         |
|                                   | Line 1          | DEC1                  | /                   | /                               |                             |                         |                         |
|                                   | Line 2          | DECODER               | DEC2                | /                               |                             |                         |                         |
|                                   | Line 3          |                       | DEC3                | /                               |                             |                         |                         |
|                                   | Line 4          |                       | DEC4                | /                               |                             |                         |                         |
| Output port                       | 6/7             | PO6                   | 1(P6/P7)            | 0(P6)                           |                             |                         |                         |
| PLA                               | Line 0          | PLA0                  | /00                 | /                               | /                           |                         |                         |
|                                   | Line 1          | PLA1                  | /11                 | /                               | /                           |                         |                         |
|                                   | Line 2          | PLA2                  | /22                 | /                               | /                           |                         |                         |
|                                   | Line 3          | PLA3                  | /33                 | /                               | /                           |                         |                         |
|                                   | Line 4          | PLA4                  | /44                 | /                               | /                           |                         |                         |
|                                   | Line 5          | PLA5                  | /55                 | /                               | /                           |                         |                         |
|                                   | Line 6          | PLA6                  | /66                 | /                               | /                           |                         |                         |
|                                   | Line 7          | PLA7                  | /77                 | /                               | /                           |                         |                         |
|                                   | Line 8          | PLA8                  | /88                 | /                               | /                           |                         |                         |
|                                   | Line 9          | PLA9                  | /99                 | /                               | /                           |                         |                         |
|                                   | Line A          | PLAA                  | /AA                 | /                               | /                           |                         |                         |
|                                   | Line B          | PLAB                  | /BB                 | /                               | /                           |                         |                         |
|                                   | Line C          | PLAC                  | /CC                 | /                               | /                           |                         |                         |
|                                   | Line D          | PLAD                  | /DD                 | /                               | /                           |                         |                         |
|                                   | Line E          | PLAE                  | /EE                 | /                               | /                           |                         |                         |
|                                   | Line F          | PLAF                  | /FF                 | /                               | /                           |                         |                         |

Note 1: As to each option item, one of the thick frames horizontally lined shall be selected. (The whole thick frame is enclosed with a circule.)

Note 2: Please enter the data entry mode (decode matrix, PLA) by yourself.

Note 3: The formal name of option is that naming continuously the option name and the data in the designation column of option.



## (1) OSC - RSTH Options

OSC-RSTH options can construct six kinds of combination.  
However, it is impossible to use the options by changing  
the combinations.

| Name of Option | TYP 001 | TYP002           | TYP 003          | TYP 004          | TYP 005          | TYP 006          |
|----------------|---------|------------------|------------------|------------------|------------------|------------------|
| OSC            | 003     | 012              | 050              | 050              | 400              | 400              |
| CP             | 00      | 00               | 04               | 02               | 64               | 32               |
| CK             | 32      | 64               | CP               | CP               | CP               | CP               |
| PD             | CP      | CP               | CP               | CP               | CP               | CP               |
| COUNTER        | PDR     | PD2              | PD2              | PD2              | PD2              | PD2              |
|                | PDR     | N                | /12500/          | N                | N                | N                |
| COUNTER        | CO      | PI <sub>60</sub> |
|                | C1      | RD9              | RDB              | RDB              | RD7              | RDA              |
| BUFFER         | C2      | RDA              | RDC              | RDC              | RDA              | RDB              |
|                | C3      | RDB              | RDD              | RDD              | RDD              | RDC              |
|                | HOLD    | H                | H                | 0                | 0                | 0                |
|                | RSTH    | C3               | C3               | C3               | 0                | 0                |

## ① OSC: Prescribing the oscillator and oscillation frequency.

- o OSC003 - 32.768 KHz oscillation by Xtal oscillator.
- o OSC012 - 100 KHz oscillation by Xtal oscillator.
- o OSC050 - 400 KHz (400K~500KHz) oscillation by ceramic oscillator or IFT.
- o OSC400 - 4194.304 KHz oscillation by Xtal oscillator.

Note (1): It is possible to make driving from the external oscillator by opening XOUT terminal and by arranging XIN terminal for input.

Note (2): The formal name of option is that naming continuously the option name and the data in the designation column of option.

- ② CP: Prescribing the frequency dividing ratio for obtaining the internal basic clock.
  - o CP00 - Oscillation signal is made to clock.
  - o CP02 - Signal of dividing oscillation frequency into 2.
  - o CP04 - Signal of dividing oscillation frequency into 4.
  - o CP32 - Signal of dividing oscillation frequency into 32.
  - o CP64 - Signal of dividing oscillation frequency into 64.
  
- ③ CK: Prescribing the output frequency for external timing
  - o CK32 - Signal of dividing oscillation frequency into 32.
  - o CK64 - Signal of dividing oscillation frequency into 64.
  - o CKCP - Signal of the internal basic clock frequency.
  
- ④ COUNTER: Dividers

The divider consists of 16-stage divider and can be disassembled into the basic construction of the front 2 stages [divider (1)] and the rear 14 stages [divider (2)].





- o PDCP - Setting the input of divider (1) to the internal basic clock (CP).
- o PDRPD2 - Setting the input of divider (2) to the output of divider (1).
- o PDRN - Setting the function of divider (1) and divider (2) as the usual binary counters.
- o PDR/12500/ - This is the designation only at the time of use of 100K Xtal. When the count value of divider (2) is "12500", the divider (2) is reset to return the count value to "0".

⑤ COUNTER BUFFER Prescribing the input of counter buffer

The counter buffer is composed of 4 bits, which are marked C0, C1, C2 and C3 from LSB side (Bit 0).

- o COPI60 - PI60 terminal input to Bit 0.
- o ClRD7 - The output of divider 10 to Bit 1.
- o ClRD9 - The output of divider 12 to Bit 1.
- o ClRDA - The output of divider 13 to Bit 1.
- o ClRDB - The output of divider 14 to Bit 1.
- o C2RDA - The output of divider 13 to Bit 2.
- o C2RDB - The output of divider 14 to Bit 2.
- o C2RDC - The output of divider 15 to Bit 2.
- o C3RDB - The output of divider 14 to Bit 3.
- o C3RDC - The output of divider 15 to Bit 3.
- o C3RDD - The output of divider 16 to Bit 3.

⑥ HOLD, RSTH: Prescribing the function of H flag and the signal for restart from the hold state.

- o HOLDH - Hold control is carried out by H flag.
- o HOLDO - No hold is maintained. H flag is capable of being used as the general flag.
- o RSTHC3 - Interlocking with HOLDH. Counter buffer bit 3 is used as the hold restart signal.
- o RSTHO - Interlocking with HOLDO. No hold is maintained.

(2) STD - P15 Options

STL - P15 options prescribe the state of input/output of port. It is possible to independently designate STD and P15 options respectively.

| Option names | Designation of option |             |          |             |         |
|--------------|-----------------------|-------------|----------|-------------|---------|
| STD          | D(PROG)               | 1 (OUT)     |          |             |         |
| P2           | /F/(OUT)              | /F/(OUT)    | /0/(IN)  | /0/(IN)     | /0/(IN) |
| P4           | /F/(OUT)              | /3/(IN/OUT) | /F/(OUT) | /3/(IN/OUT) | /0/(IN) |
| P15          | 0(UP)                 | 1(DOWN)     |          |             |         |

- ① STD: Prescribing the function of port 0.
- o STDD - Switching input/output of port 0 is made according to the contents of D flag.
  - o STD1 - Using as the output of port 0. In this case, D flag can be used as the general flag.

- ② P2, P4: Prescribing the function of port 2 and port 4.

Port 2 and port 4 are the 4-bit ports to which the input or the output can be designated.

The 4-bit ports are expressed by the one-figure numeric characters of hexadecimal digit by defining the input as "0" and the output as "1" for each bit.

(Example)

(MSB)

Bit 3 2 1 0 (LSB)

|   |   |   |   |
|---|---|---|---|
| 0 | 0 | 1 | 1 |
|---|---|---|---|

(0 : Input)  
(1 : Output) Hexadecimal = 3

- o P2/F/, P4/F/ - Prescribing both port 2 and port 4 as the output.
- o P2/F/, P4/3/ - Prescribing the upper 2 bits of port 4 as the input, with the others being the output.
- o P2/0/, P4/F/ - Prescribing port 2 as the input and port 4 as the output.
- o P2/0/, P4/3/ - Prescribing the lower 2 bits of port 4 as the output, with the others being the input.
- o P2/0/, P4/0/ - Prescribing both port 2 and port 4 as the input.

③ P15: Prescribing the function of the input resistance at port 5.

- o PI50 - Input port 5 comes to the input with pull-up resistance.
- o PI51 - Input port 5 comes to the input with pull-down resistance.

### (3) DECODER - PLA Options

The decoder and PLA options are the data writing mode in which user designates the data. P06 option is used according to the function of PLA.

| Option Names | Designation of Options |                   |
|--------------|------------------------|-------------------|
| DECODER      | Data writing mode      |                   |
| P06          | 1 (P6/P7)              | 0 (P6)            |
| PLA          | General output port    | Data writing mode |

1 DECODER: Prescribing the contents of decode matrix.

Operation processing and internal data are processed with 4 bits. However, at the output port 5, 5-bit data are produced as the output after the conversion into 5 lines by the decode matrix.



The following explanation is made for the purpose of explaining the contents of decode matrix and has no direct relations with the design patterning in the actual LSI. Give your kind attention to this point.

The logic of decode matrix can be expressed by the following formula. (See the above diagram.)

$$\left. \begin{aligned} \text{DEC}_i &= D_3 \cdot D_2 \cdot D_1 \cdot D_0 \quad (i = 0 - 4) \\ \text{Where, the selection is practicable as to} \\ D_j \quad (j = 0 - 3) &= d_j \text{ or } \bar{d}_j \text{ or } 1 \end{aligned} \right\}$$

As to the designation of decode matrix, it is possible to define the selection as "1", to define non-selection as "0", and to express  $\bar{d}_3$ ,  $d_3$ ,  $\bar{d}_2$ ,  $d_2$ ,  $\bar{d}_1$ ,  $d_1$ ,  $\bar{d}_0$ , and  $d_0$  as the continuous 8-bit data ( $d_3$  shall be MSB) with the figures of hexadecimal two digits.



## INTEGRATEDCIRCUIT

## TECHNICAL DATA

TCP4620AP

TCP4630AP

| $\overline{d_3}, d_3$ | $\overline{d_2}, d_2$ | $\overline{d_1}, d_1$ | $\overline{d_0}, d_0$ |
|-----------------------|-----------------------|-----------------------|-----------------------|
| x                     | x                     | x                     | x                     |

$x = 1$  (Selection) or  
 $0$  (Non-selection)

Hexadecimal two digits

Note:  $D_j = \overline{d}_j \rightarrow (\overline{d}_j, d_j) = (\text{Selection}, \text{Non-selection}) = (1, 0)$

$D_j = d_j \rightarrow (\overline{d}_j, d_j) = (\text{Non-selection}, \text{Selection}) = (0, 1)$

$D_j = 1 \rightarrow (\overline{d}_j, d_j) = (\text{Non-selection}, \text{Non-selection}) = (0, 0)$

It is meaningless to select both  $\overline{d}_j$  and  $d_j$

Attention shall be given to the fact that the output comes to "1" except initialization in case where the designation of (Non-selection, Non-selection) is made to all bits (DECi = 1).

- o In case where P050 terminal output is "H" when the data "1" are written in the output port 5, and the output is "L" when other data are written:

Logic:  $DEC0 = \overline{d_3} \cdot \overline{d_2} \cdot \overline{d_1} \cdot d_0$

Designation:  $DEC0 = [\overline{d_3} \ \overline{d_3} \ \overline{d_2} \ d_2 \ \overline{d_1} \ d_1 \ \overline{d_0} \ d_0]$   
 $= [1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 0 \ 1] = X' A9'$

- o In case where P054 terminal output is "H" when the data "C" - "F" are written in the output port 5, and the output is "L" when other data are written:

Logic:  $DEC4 = d_3 \cdot d_2$

Designation:  $DEC4 = [\overline{d_3} \ d_3 \ \overline{d_2} \ d_2 \ \overline{d_1} \ d_1 \ \overline{d_0} \ d_0]$   
 $= [0 \ 1 \ 0 \ 1 \ 0 \ 0 \ 0 \ 0] = X' 50'$

- o In the case of P051 terminal when the output of data written in the output port 5 is desired:



\* Refer to the examples of data designation.

- (2) P06: Prescribing the function of port 6.
  - o P060 - Port 6 is used as the 8-bit PLA data output port.
  - o P061 - Port 6 is used as the two 4-bit general output port.  
(No designation can be made as to the contents of PLA.)
- (3) PLA: Prescribing the contents of PLA.

Operation processing and internal data are processed with 4 bits. However, at the output port 6, 8-bit data are produced as the output after the conversion into 8 lines by PLA.



The following explanation is made for the purpose of explaining the contents of PLA and has no direct relations with the design patterning in the actual LSI.  
Give your kind attention to this point.

PLA can be expressed as the 16 words x 8 bits memory. (Refer to the above diagram.) Namely, the 4-bit write data is the address of PLA, and the 8-bit data read out from PLA comes to the output data on the output port terminals.

| Write data | Address |
|------------|---------|------------|---------|------------|---------|------------|---------|
| 0          | PLA0    | 4          | PLA4    | 8          | PLA8    | 12         | PLAC    |
| 1          | PLA1    | 5          | PLA5    | 9          | PLA9    | 13         | PLAD    |
| 2          | PLA2    | 6          | PLA6    | 10         | PLAA    | 14         | PLAE    |
| 3          | PLA3    | 7          | PLA7    | 11         | PLAB    | 15         | PLAF    |

The designation of PLA data is made to addresses by expressing the 8-bit data, which are MSB in P0<sub>67</sub> terminal output and LSB in P0<sub>60</sub> terminal output, with 2-figure numeric characters of hexadecimal digit.

- In case each output between P0<sub>67</sub> terminal and P0<sub>60</sub> terminal comes to H, L, H, H, L, H, H, and L when data "5" are written in the 8-bit output port 6,



- In case data "3" are written in output port 6 or output port 7 to use it as the 4-bit general output port,



Therefore, if data "3" are written in output port 7, each output between P067 terminal and P064 terminal comes to L, L, H, and H. At this time, each input to register 6 (connected to P063 terminal- P060 terminal) comes likewise to 0, 0, 1, and 1, but each output does not change because no setting is made to the register. This applies to the reverse case comes likewise.

- o Refer to the examples of the designation of data.

Examples of the Designation of Data for Decode Matrix and PLA

|                 | Examples of General port    | Examples of 5-1 Fig. dynamic indication                         |  | General port | Examples of segment display |  |
|-----------------|-----------------------------|-----------------------------------------------------------------|--|--------------|-----------------------------|--|
| Logic           | DEC0 = d0                   | DEC0 = $\overline{d_3} \ \overline{d_2} \ \overline{d_1} \ d_0$ |  | PLA 0 = /00/ | PLA 0 = /FC/                |  |
|                 | DEC1 = d1                   | DEC1 = $\overline{d_3} \ \overline{d_2} \ d_1 \ \overline{d_0}$ |  | PLA 1 = /11/ | PLA 1 = /60/                |  |
|                 | DEC2 = d2                   | DEC2 = $\overline{d_3} \ \overline{d_2} \ d_1 \ d_0$            |  | PLA 2 = /22/ | PLA 2 = /DA/                |  |
|                 | DEC3 = d3                   | DEC3 = $\overline{d_3} \ d_2 \ \overline{d_1} \ \overline{d_0}$ |  | PLA 3 = /33/ | PLA 3 = /F2/                |  |
|                 | DEC4 = $\overline{d_3}$     | DEC4 = $d_3 \ d_2 \ \overline{d_1} \ d_0$                       |  | PLA 4 = /44/ | PLA 4 = /66/                |  |
| Designated Data | DEC0 = /01/                 | DEC0 = /A9/                                                     |  | PLA 5 = /55/ | PLA 5 = /B6/                |  |
|                 | DEC1 = /04/                 | DEC1 = /A6/                                                     |  | PLA 6 = /66/ | PLA 6 = /BE/                |  |
|                 | DEC2 = /10/                 | DEC2 = /A5/                                                     |  | PLA 7 = /77/ | PLA 7 = /E4/                |  |
|                 | DEC3 = /40/                 | DEC3 = /9A/                                                     |  | PLA 8 = /88/ | PLA 8 = /FE/                |  |
|                 | DEC4 = /80/                 | DEC4 = /99/                                                     |  | PLA 9 = /99/ | PLA 9 = /F6/                |  |
|                 | (Evaluator built-in option) |                                                                 |  | PLA A = /AA/ | PLA A = /FD/                |  |
|                 | (Evaluator built-in option) |                                                                 |  | PLA B = /BB/ | PLA B = /00/ (blank)        |  |
|                 | (Evaluator built-in option) |                                                                 |  | PLA C = /CC/ | PLA C = /02/                |  |
|                 | (Evaluator built-in option) |                                                                 |  | PLA D = /DD/ | PLA D = /CE/                |  |
|                 | (Evaluator built-in option) |                                                                 |  | PLA E = /EE/ | PLA E = /9E/                |  |
|                 | (Evaluator built-in option) |                                                                 |  | PLA F = /FF/ | PLA F = /8E/                |  |
|                 | (Evaluator built-in option) |                                                                 |  |              |                             |  |
|                 | (Evaluator built-in option) |                                                                 |  |              |                             |  |

(Evaluator built-in option)

## MASK ROM DATA TAPE FORMAT

|           |  |                                                                                                               |                                                                                                                                                                                                                                                                                                       |
|-----------|--|---------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |  | ..... Leader                                                                                                  | Output of more than 50 characters of "NULL"<br>(No other symbols than "NULL" should be<br>existent.)                                                                                                                                                                                                  |
| 'COMMENT' |  | ..... Comment                                                                                                 | Output of six characters starting from the<br>beginning of character train defined by TTL<br>statement of source program and two characters<br>of serial number, with apostrophe. (when no<br>TTL statement exist, output of six characters<br>of space code and two characters of serial<br>number.) |
| (CR) (LF) |  |                                                                                                               |                                                                                                                                                                                                                                                                                                       |
| N8 ;      |  | ..... Output of "N8" indicating that the date pattern is 8<br>bits long. (The program data follow this code.) |                                                                                                                                                                                                                                                                                                       |
| (CR) (LF) |  |                                                                                                               |                                                                                                                                                                                                                                                                                                       |
| RXXXX ;   |  | ..... Output of the program start address following "R" in<br>four frames of decimal ASCII code.              |                                                                                                                                                                                                                                                                                                       |
| XXX PX ;  |  | ..... 1st address data<br>and check sum                                                                       |                                                                                                                                                                                                                                                                                                       |
| XXX PX ;  |  | 2nd address data<br>and check sum                                                                             |                                                                                                                                                                                                                                                                                                       |
| XXX PX ;  |  | 8th address data<br>and check sum                                                                             |                                                                                                                                                                                                                                                                                                       |
| (CR) (LF) |  |                                                                                                               |                                                                                                                                                                                                                                                                                                       |
| RXXXX ;   |  | ..... 9th program address                                                                                     |                                                                                                                                                                                                                                                                                                       |
| XXX PX ;  |  | 9th address data and check sum                                                                                |                                                                                                                                                                                                                                                                                                       |
|           |  | Repeated output through the last data                                                                         |                                                                                                                                                                                                                                                                                                       |
| (CR) (LF) |  |                                                                                                               |                                                                                                                                                                                                                                                                                                       |
| \$        |  | ..... Output of indicating the end of program data                                                            |                                                                                                                                                                                                                                                                                                       |
|           |  |                                                                                                               |                                                                                                                                                                                                                                                                                                       |
|           |  | Trailer: Output of more than 50 characters of "NULL".                                                         |                                                                                                                                                                                                                                                                                                       |

Toshiba

## INTEGRATEDCIRCUIT



## TECHNICAL DATA

TCP4620AP

TCP4630AP

## ELECTRICAL CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL           | ITEM                  | RATING                           |
|------------------|-----------------------|----------------------------------|
| VDD              | Supply Voltage        | -0.3V to + 7.0V                  |
| V <sub>IN</sub>  | Input Voltage         | -0.3V to V <sub>D</sub> D + 0.3V |
| V <sub>OUT</sub> | Output Voltage        | -0.3V to V <sub>D</sub> D + 0.3V |
| P <sub>D</sub>   | Power Dissipation     | 600 mW                           |
| T <sub>SOL</sub> | Soldering Temperature | 260°C (10 SEC)                   |
| T <sub>STG</sub> | Storage Temperature   | -55°C to + 125°C                 |
| T <sub>OPR</sub> | Operating Temperature | -30°C to + 85°C                  |

## ALLOWABLE OPERATING CONDITIONS

| SYMBOL           | ITEM                     | Condition                                 |                                           |
|------------------|--------------------------|-------------------------------------------|-------------------------------------------|
|                  |                          | V <sub>D</sub> D = 3V to 6V               | V <sub>D</sub> D = 4V to 6V               |
| T <sub>A</sub>   | Ambient Temeprature      | -30°C to + 85°C                           | -30°C to 85°C                             |
| V <sub>O</sub> H | Output High Voltage      | Min. V <sub>D</sub> D -3.5V( $\geq$ 1.5V) | Min.V <sub>D</sub> D -3.5V ( $\geq$ 1.5V) |
| V <sub>O</sub> L | Output Low Voltage       | Max. 3V                                   | Max. 3V                                   |
| f <sub>X</sub>   | Xtal Operating Frequency | 20KHz to 2MHz                             | 20KHz to 4.2MHz                           |
| t <sub>cy</sub>  | Cycle Time               | 40 $\mu$ s to 100 $\mu$ s                 | 10 $\mu$ s to 100 $\mu$ s                 |

TCP4E20AP

TCP4E30AP

## DC CHARACTERISTICS (Ta=-30°C to +85°C, VDD=3V to 6V)

| SYMBOL            | PARAMETER                                                        | TEST CONDITION                                                              | MIN.     | TYP.<br>(Note 1) | MAX.     | UNIT |
|-------------------|------------------------------------------------------------------|-----------------------------------------------------------------------------|----------|------------------|----------|------|
| VIH               | Input High Voltage                                               |                                                                             | VDDx0.75 | -                | VDD      | V    |
|                   |                                                                  | VDD $\geq$ 4V                                                               | VDDx0.7  | VDDx0.55         | VDD      |      |
| VIHS              | Input High Voltage<br>(Schmitt)                                  |                                                                             | VDDx0.9  | VDDx0.75         | VDD      |      |
|                   |                                                                  | VDD $\geq$ 4V                                                               | VDDx0.85 | -                | VDD      |      |
| VIHC              | Input High Voltage(XIN Input)                                    |                                                                             | VDDx0.75 | -                | VDD      |      |
| VIL               | Input Low Voltage                                                |                                                                             | 0        | VDDx0.45         | VDDx0.3  |      |
| VILS              | Input Low Voltage<br>(Schmitt)                                   |                                                                             | 0        | VDDx0.35         | VDDx0.1  |      |
|                   |                                                                  | VDD $\geq$ 4V                                                               | 0        | -                | VDDx0.15 |      |
| VILC              | Input Low Voltage (XIN Input)                                    |                                                                             | 0        | -                | VDDx0.25 |      |
| I <sub>IH</sub>   | Input High Current                                               | VDD=6V, VIN=6V                                                              | -        | -                | 20       | μA   |
| I <sub>IL</sub>   | Input Low Current                                                | VDD=6V, VIN=0V                                                              | -        | -                | -20      |      |
| R <sub>IN</sub>   | Input Resistance (PI5)                                           | VDD=5V                                                                      | 75       | 150              | 350      | kΩ   |
| V <sub>OH</sub>   | Output High Voltage                                              | VDD=5V, Output Open                                                         | 4.7      | 4.9              | -        | V    |
| V <sub>OL</sub>   | Output Low Voltage                                               | VDD=5V, Open                                                                | -        | 0.1              | 0.3      |      |
| I <sub>OH</sub>   | Output High Current                                              | VDD=4.5V, V <sub>OH</sub> =2.4V                                             | -0.7     | -2               | -        | mA   |
| I <sub>OHL</sub>  | Output High Current (P05, P06)                                   |                                                                             | -2.5     | -6               | -        |      |
| I <sub>OL</sub>   | Output Low Current                                               | VDD=5V, V <sub>OH</sub> =4.2V                                               | -1.1     | -2.5             | -        |      |
| I <sub>OLL</sub>  | Output Low Current (P05, P06)                                    |                                                                             | 1.6      | 4                | -        |      |
| I <sub>IDDO</sub> | V <sub>DD</sub> Supply Current in Normal Operation (fx=32.8 KHz) | VDD=6V<br>VIN=5.9V/0.1V<br>(All valid)<br>PI5 Open<br>C <sub>L</sub> = 50pF | -        | 50               | 300      | μA   |
|                   | Current in (fx=100 KHz)                                          |                                                                             | -        | 150              | 450      |      |
|                   | Normal (fx=400 KHz)                                              |                                                                             | -        | 400              | 1200     |      |
|                   | Operation (fx=4.19 MHz)                                          |                                                                             | -        | 1000             | 3000     |      |
| I <sub>IDIH</sub> | V <sub>DD</sub> Supply Current in Hold Operation (fx=32.8 KHz)   | (Note 3)                                                                    | -        | 15               | 80       |      |
|                   | Current in (fx=100 KHz)                                          |                                                                             | -        | 40               | 120      |      |
|                   | (fx=400 KHz)                                                     |                                                                             | -        | 150              | 450      |      |

Note 1: Typical values are at Ta=25°C and VDD=5V.

Note 2: Output characteristic excludes XOUT terminal.

Note 3: XIN input waveform at the time of measuring VDD supply current.



Toshiba

東芝

## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4E20AP

TCP4E30AP

AC CHARACTERISTICS ( $T_a = -30^\circ\text{C}$  to  $+85^\circ\text{C}$ ,  $V_{DD} = 3\text{V}$  to  $6\text{V}$ )

| SYMBOL       | PARAMETER                             | TEST CONDITION                               | MIN.       | TYP. | MAX.       | UNIT          |
|--------------|---------------------------------------|----------------------------------------------|------------|------|------------|---------------|
| $t_{WXIN}$   | XIN Pulse Width                       | External Input<br>$V_{IN} = V_{IHC}/V_{ILC}$ | 0.4/ $f_x$ | -    | 0.6/ $f_x$ | SEC           |
| $t_{WRESET}$ | $\overline{\text{RESET}}$ Pulse Width | $V_{IN} = V_{IHS}/V_{ILS}$                   | 2 tcy      | -    | -          | $\mu\text{s}$ |
| $t_{WINT}$   | $\overline{\text{INT}}$ Pulse Width   |                                              | 2 tcy      | -    | -          |               |
| $t_{WP160}$  | PI60 Pulse Width                      |                                              | 2 tcy      | -    | -          |               |

TCP4620AP

TCP4630AP

## OUTLINE DRAWINGS

Unit in 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 ±0.25mm from their theoretical positions with respect to No.1 and No.42 leads.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

"C<sup>2</sup>MOS" DIGITAL INTEGRATED CIRCUIT

TCP4620AF

TCP4630AF

SILICON MONOLITHIC

### CMOS 4-BIT SINGLE CHIP MICROCOMPUTER

This is the specification for TCP4620AF/TCP4630AF in the TLCS-46A family.

TCP4620AF/TCP4630AF is a flat package version of TCP4620AP/TCP4630AP. There are some differences in electrical characteristics between TCP4620AF/TCP4630AF and TCP4620AP/TCP4630AP; however, their function, instruction, and pin description are compatible.

When using and examining TCP4620AF/TCP4630AF, therefore, it is recommended that this specification be used together with the technical data on TCP4620AP/TCP4630AP.

The differences in electrical characteristics between the two are as follows:

#### 1. Power Dissipation

$$P_D = 400 \text{ mW MAX}$$

#### 2. Operating Temperature and Ambient Temperature

$$T_{opr} = -20 \text{ to } 70^\circ\text{C}$$

$$T_a = -20 \text{ to } 70^\circ\text{C}$$



## INTEGRATEDCIRCUIT

## TECHNICAL DATA

TCP4620AF  
TCP4630AF

## TCP4620AF /TCP4630AF ELECTRICAL CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL           | ITEM                  | Rating                         |
|------------------|-----------------------|--------------------------------|
| V <sub>DD</sub>  | Supply Voltage        | -0.3V to +7.0V                 |
| V <sub>IN</sub>  | Input Voltage         | -0.3V to V <sub>DD</sub> +0.3V |
| V <sub>OUT</sub> | Output Voltage        | -0.3V to V <sub>DD</sub> +0.3V |
| P <sub>D</sub>   | Power Dissipation     | 400mW                          |
| T <sub>SOL</sub> | Soldering Temperature | 260°C (10 SEC)                 |
| T <sub>STG</sub> | Storage Temperature   | -55°C to +125°C                |
| T <sub>OPR</sub> | Operating Temperature | -20°C to +70°C                 |

## ALLOWABLE OPERATING CONDITION

| SYMBOL          | ITEM                     | Condition                         |                                   |
|-----------------|--------------------------|-----------------------------------|-----------------------------------|
|                 |                          | V <sub>DD</sub> =3V to 6V         | V <sub>DD</sub> =4V to 6V         |
| T <sub>A</sub>  | Ambient Temperature      | -20°C to +70°C                    | -20°C to +70°C                    |
| V <sub>OH</sub> | Output High Voltage      | Min. V <sub>DD</sub> -3.5V(>1.5V) | Min. V <sub>DD</sub> -3.5V(>1.5V) |
| V <sub>OL</sub> | Output Low Voltage       | Max. 3V                           | Max. 3V                           |
| f <sub>X</sub>  | Xtal Operating Frequency | 20KHz to 2MHz                     | 20KHz to 4.2MHz                   |
| t <sub>cy</sub> | Cycle Time               | 40μs to 100μs                     | 10μs to 100μs                     |

DC CHARACTERISTICS (Ta=-20°C to 70°C, V<sub>DD</sub>=3V to 6V)

| SYMBOL           | PARAMETER                                                                                                            | TEST CONDITION                                | MIN.                  | TYP. (Note 1)         | MAX.                  | UNIT |
|------------------|----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|-----------------------|-----------------------|-----------------------|------|
| V <sub>IH</sub>  | Input High Voltage                                                                                                   |                                               | V <sub>DD</sub> x0.75 | -                     | V <sub>DD</sub>       | V    |
|                  |                                                                                                                      | V <sub>DD</sub> ≥ 4V                          | V <sub>DD</sub> x0.7  | V <sub>DD</sub> x0.55 | V <sub>DD</sub>       |      |
| V <sub>IHS</sub> | Input High Voltage (Schmitt)                                                                                         |                                               | V <sub>DD</sub> x0.9  | V <sub>DD</sub> x0.75 | V <sub>DD</sub>       | V    |
|                  |                                                                                                                      | V <sub>DD</sub> ≥ 4V                          | V <sub>DD</sub> x0.85 | -                     | V <sub>DD</sub>       |      |
| V <sub>IHC</sub> | Input High Voltage (X <sub>IN</sub> Input)                                                                           |                                               | V <sub>DD</sub> x0.75 | -                     | V <sub>DD</sub>       |      |
| V <sub>IL</sub>  | Input Low Voltage                                                                                                    |                                               | 0                     | V <sub>DD</sub> x0.45 | V <sub>DD</sub> x0.3  |      |
| V <sub>ILS</sub> | Input Low Voltage (Schmitt)                                                                                          |                                               | 0                     | V <sub>DD</sub> x0.35 | V <sub>DD</sub> x0.1  | V    |
|                  |                                                                                                                      | V <sub>DD</sub> ≥ 4V                          | 0                     | -                     | V <sub>DD</sub> x0.15 |      |
| V <sub>ILC</sub> | Input Low Voltage (X <sub>IN</sub> Input)                                                                            |                                               | 0                     | -                     | V <sub>DD</sub> x0.25 |      |
| I <sub>IH</sub>  | Input High Current                                                                                                   | V <sub>DD</sub> =6V, V <sub>IN</sub> =6V      | -                     | -                     | 20                    | μA   |
| I <sub>IL</sub>  | Input Low Current                                                                                                    | V <sub>DD</sub> =6V, V <sub>IN</sub> =0V      | -                     | -                     | -20                   |      |
| R <sub>IN</sub>  | Input Resistance (P15)                                                                                               | V <sub>DD</sub> =5V                           | 75                    | 150                   | 350                   | KΩ   |
| V <sub>OH</sub>  | Output High Voltage                                                                                                  |                                               | 4.7                   | 4.9                   | -                     |      |
| V <sub>OL</sub>  | Output Low Voltage                                                                                                   | V <sub>DD</sub> =5V, Output Open              | -                     | 0.1                   | 0.3                   | V    |
| I <sub>OH</sub>  | Output High Current                                                                                                  |                                               | -0.7                  | -2                    | -                     |      |
| I <sub>OH1</sub> | Output High Current (P05, P06)                                                                                       | V <sub>DD</sub> =4.5V, V <sub>OH</sub> =2.4V  | -2.5                  | -6                    | -                     | mA   |
|                  |                                                                                                                      | V <sub>DD</sub> =5V, V <sub>OH</sub> =4.2V    | -1.1                  | -2.5                  | -                     |      |
| I <sub>OL</sub>  | Output Low Current                                                                                                   | V <sub>DD</sub> =4.5V, V <sub>OL</sub> =0.45V | 1.6                   | 4                     | -                     |      |
| I <sub>OL1</sub> | Output Low Current (P05, P06)                                                                                        | V <sub>DD</sub> =4.5V, V <sub>OL</sub> =0.45V | 3.5                   | 8                     | -                     |      |
| I <sub>DDO</sub> | V <sub>DD</sub> Supply Current in Normal Operation<br>(fx=32.8 KHz)<br>(fx=100 KHz)<br>(fx=400 KHz)<br>(fx=4.19 MHz) | V <sub>DD</sub> =6V                           | -                     | 50                    | 300                   | μA   |
|                  |                                                                                                                      | V <sub>IN</sub> =5.9V/0.1V<br>(all valid)     | -                     | 150                   | 450                   |      |
|                  |                                                                                                                      | -                                             | -                     | 400                   | 1200                  |      |
|                  |                                                                                                                      | PI5 Open                                      | -                     | 1000                  | 3000                  |      |
| I <sub>DDH</sub> | V <sub>DD</sub> Supply Current in Hold Operation<br>(fx=32.8 KHz)<br>(fx=100 KHz)<br>(fx=400 KHz)                    | C <sub>L</sub> = 50pF                         | -                     | 15                    | 80                    |      |
|                  |                                                                                                                      | (Note 3)                                      | -                     | 40                    | 120                   |      |
|                  |                                                                                                                      |                                               | -                     | 150                   | 450                   |      |

Note 1: Typical values are at Ta=25°C and V<sub>DD</sub>=5V.Note 2: Output characteristic excludes X<sub>OUT</sub> terminal.Note 3: X<sub>IN</sub> input waveform at the time of measuring V<sub>DD</sub> Supply Current.



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4630AF

TCP4630AF

AC CHARACTERISTICS ( $T_a = -20^\circ\text{C}$  to  $+70^\circ\text{C}$ ,  $V_{DD} = 3\text{V}$  to  $6\text{V}$ )

| SYMBOL       | PARAMETER                             | TEST CONDITION                               | MIN.               | TYP. | MAX.               | UNIT          |
|--------------|---------------------------------------|----------------------------------------------|--------------------|------|--------------------|---------------|
| $t_{WXIN}$   | XIN Pulse Width                       | External Input<br>$V_{IN} = V_{IHC}/V_{ILC}$ | 0.4/f <sub>x</sub> | -    | 0.6/f <sub>x</sub> | SEC           |
| $t_{WRESET}$ | $\overline{\text{RESET}}$ Pulse Width | $V_{IN} = V_{IHS}/V_{ILS}$                   | 2 t <sub>c</sub> y | -    | -                  | $\mu\text{s}$ |
| $t_{WINT}$   | $\overline{\text{INT}}$ Pulse Width   |                                              | 2 t <sub>c</sub> y | -    | -                  |               |
| $t_{WP160}$  | P160 Pulse Width                      |                                              | 2 t <sub>c</sub> y | -    | -                  |               |

Note: Flat packages have a merit in assembly space, but they should be installed in better humidity and temperature environment than DIP's.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4620AF

TCP4630AF

### PIN CONNECTIONS (TOP VIEW)



Note) Pins 18 and 39, power supply terminals, are connected in the package.



# INTEGRATEDCIRCUIT

## TECHNICAL DATA

TCP4620AF  
TCP4630AF

### OUTLINE DRAWINGS

Unit in mm



Toshiba

# INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TENTATIVE

"C<sup>2</sup>MOS" DIGITAL INTEGRATED CIRCUIT

TCP4620BP

SILICON MONOLITHIC

CMOS 4-BIT SINGLE CHIP MICROCOMPUTER

### GENERAL DESCRIPTION

This is the specification for TCP4620BP in TLCS-46A family.

TCP4620BP is one version of TLCS-46A developed for the purpose of reducing the power consumption at hold operation so as to correspond to the applications having utilized the features of a CMOS microcomputer. TCP4620BP has realized the following characteristics.

Supply Current in hold operation

$I_{DDHS}$  TYP.=0.1 $\mu$ A ( $V_{DDHS}=2V$ )

Hold voltage in hold operation

$V_{DDHS}$  = 2 V to 6 V

TCP4620BP is a version of TCP4620AP to which the oscillation control (stop/start) function of a clock generator in hold operation has been added. There are some differences in function, pin description, electrical characteristics, and mask option concerning hold operation and oscillation control between TCP4620BP and TCP4620AP; however, other functions, electrical characteristics, instructions, and pin connections are compatible.

When using and examining TCP4620BP, therefore, it is recommended that this specification be used together with the technical data on TCP4620AP.

Main differences with TCP4620AP are as follows:

#### 1. Function

- o In hold operation, the input level of PI60 terminal makes possible the oscillation control (stop/start) of the oscillator, and the oscillation stop enables the power consumption to be reduced.

Supply Current in hold operation (Oscillation stop)

$I_{DDHS}$  TYP.=0.1 $\mu$ A ( $T_a=25^\circ C$ ,  $V_{DDHS}=2V$ )

Hold Voltage in hold operation (Oscillation stop)

$V_{DDHS}$  = 2 V to 6 V

## 2. Pin Description

- o In hold operation, PI60 terminal will function as an oscillation control terminal.

PI60 = "H" ..... Oscillation stop

PI60 = "L" ..... Oscillation start (Continued.)

- o In either case of normal operation/hold operation, PI60 terminal is the reset input terminal of the divider (2).

PI60 = "H" ..... The divider (2) is reset.

PI60 = "L" ..... The divider (2) is not reset. (Reset is released.)

- o No Schmitt circuits are built in the following two terminals:

PI60, INT

## 3. Mask Option

The contents only indicated on the mask option sheet of TCP4620BP can be designated., 400 KHz ceramic oscillator/IFT oscillator can be used.

## PIN NAMES AND PIN DESCRIPTION

| Pin Name                          | Input/Output    | Function                                                                                                                                                                                                                            |
|-----------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P <sub>03</sub> P <sub>00</sub>   | Input/Output    | 4-bit general purpose I/O port (I/O is designated by a program). Can be used as a dedicated output port. (Designated by mask options.)                                                                                              |
| P <sub>13</sub> P <sub>10</sub>   | Output          | 4-bit general purpose output port.                                                                                                                                                                                                  |
| P <sub>23</sub> P <sub>20</sub>   | Input or Output | 4-bit general purpose Input/Output port. Input/Output is designated by mask options.                                                                                                                                                |
| P <sub>43</sub> P <sub>40</sub>   | Input or Output | 4-bit general purpose Input/Output port. by mask options.                                                                                                                                                                           |
| P <sub>54</sub> P <sub>50</sub>   | Output          | 5-digit output port for display.<br>(Can be used as the general purpose output port.)                                                                                                                                               |
| P <sub>67</sub> P <sub>60</sub>   | Output          | 8-segment output port for display.<br>(Can be used as the general purpose 8-bit output port (4-bit x 2))                                                                                                                            |
| P <sub>I53</sub> P <sub>I50</sub> | Input           | 4-bit general purpose input port.                                                                                                                                                                                                   |
| P <sub>I60*</sub>                 | Input           | 1-bit general purpose input port/reset input of divider(2) [Note 1] (without Schmitt circuit). During hold operation this input functions as an input for stopping the oscillation and for controlling restart of the oscillator. * |
| RESET                             | Input           | Reset signal input                                                                                                                                                                                                                  |
| INT                               | Input           | Interrupt request signal input (without Schmitt circuit).                                                                                                                                                                           |
| X <sub>IN</sub>                   | Input           | Oscillator connecting terminal.                                                                                                                                                                                                     |
| X <sub>OUT</sub>                  | Output          | Oscillator connecting terminal.                                                                                                                                                                                                     |
| CK                                | Output          | External timing output.                                                                                                                                                                                                             |
| TEST                              | Input           | LSI test signal input, used by connection to GND.                                                                                                                                                                                   |
| V <sub>DD</sub>                   |                 | Power Supply                                                                                                                                                                                                                        |
| GND                               |                 | GND                                                                                                                                                                                                                                 |

Note 1) In either case of normal operation or hold operation, the divider (2) is reset at "H" level input.

Note 2) \* denotes the differences between TCP4620BP and TCP4620AP/TCP4630AP.

### HOLD OPERATION

The hold operation of TCP4620BP is performed by setting "1" to H flag. In other words, immediately when "1" is set to H flag by execution of SBS, IBS, and LSM instructions, the internal timing signals  $\phi_8$  and  $\phi$  are stopped and TCP4620BP begins hold operation. (Refer to Figs. 1 and 3.)

During hold operation the program counter, instruction register, data memory, and other internal registers hold the contents stored before hold operation. However, the interrupt latch is cleared during hold operation, the waiting interrupt request and a new interrupt request are ignored.

The oscillation of oscillator is suspended by holding PI60 terminal to "H" level during hold operation, so that the power consumption may be saved greatly. That is, while H flag  $\wedge$  PI60 = 1, the oscillation is suspended. (Refer to Fig. 3.)

TCP4620BP is restarted from hold operation due to reset of H flag to "0" by the rising signal of the counter buffer C2 bit.

Since the counter buffer is the output of the divider (2) which is counting the internal basic clock (cp), TCP4620BP is restarted at regular intervals if oscillation is not suspended during hold operation. (Refer to Fig. 2.) This is the same operation as the hold operation of TCP4620AP/TCP4630AP. (However, there is a difference in nothing but restart condition by mask option between them.)

When the oscillation is suspended during hold operations, restart operation begins in the lapse of a certain period of time after a start of oscillation by holding PI60 terminal to "L" level. (Refer to Fig. 4.) Special attention should be paid to the fact that in TCP4620BP the divider (2) is reset to "0" by holding PI60 terminal to "H" level.



Fig. 1 Timing to Hold Operation (Oscillation Continuity)



Fig. 2 Restart Timing from Hold Operation (Oscillation Continuity)



# INTEGRATEDCIRCUIT

## TECHNICAL DATA

TCP4620BP



Fig. 3 Timing to Hold Operation (Oscillation Stop)



Fig. 4 Restart Timing from Hold Operation (Oscillation Stop)



## INTEGRATED CIRCUIT

TCP4620BP

## TECHNICAL DATA

## TCP4620BP MASK OPTION

| Oscillating Frequency                 | O S C       | TYP011<br>050<br>400K<br>Ceramic<br>IFT |
|---------------------------------------|-------------|-----------------------------------------|
| Frequency division for internal clock | CP          | 02                                      |
| Ext. timing output                    | CK          | CP                                      |
| Divider 1 input                       | PD          | CP                                      |
| COUNTER Divider 3 input               | COUNTER PDR | PD2                                     |
| Reset Timing                          | PDR         | N                                       |
| Buffer 0 input                        | CO          | PI60                                    |
| COUNTER Buffer 1 input                | COUNTER C1  | RD7                                     |
| BUFFER Buffer 2 input                 | BUFFER C2   | RDA                                     |
| Buffer 3 input                        | C3          | RDD                                     |
| H Flag                                | HOLD        | H                                       |
| Restart Signal                        | RSTH        | C2 Rise                                 |
| I/O Port                              | Port 0      | STD                                     |
| Input/Output port                     | Port 2      | P2 /F/(OUT)                             |
|                                       | Port 4      | P4 /F/(OUT)                             |
| Input resistance (Input port 5)       |             | PI5 0 (UP)                              |
| DECODE                                | Line 0      | DEC0 / /                                |
|                                       | Line 1      | DEC1 / /                                |
| MATRIX                                | Line 2      | DECODER DEC2 / /                        |
|                                       | Line 3      | DEC3 / /                                |
|                                       | Line 4      | DEC4 / /                                |
| Output Port                           | 6/7         | PO6 1(P6/P7) 0 (P6)                     |
| PLA                                   | Line 0      | PLA0 / 0 0 / / /                        |
|                                       | Line 1      | PLA1 / 1 1 / / /                        |
|                                       | Line 2      | PLA2 / 2 2 / / /                        |
|                                       | Line 3      | PLA3 / 3 3 / / /                        |
|                                       | Line 4      | PLA4 / 4 4 / / /                        |
|                                       | Line 5      | PLA5 / 5 5 / / /                        |
|                                       | Line 6      | PLA6 / 6 6 / / /                        |
|                                       | Line 7      | PLA7 / 7 7 / / /                        |
|                                       | Line 8      | PLA8 / 8 8 / / /                        |
|                                       | Line 9      | PLA9 / 9 9 / / /                        |
|                                       | Line A      | PLAA / A A / / /                        |
|                                       | Line B      | PLAB / B B / / /                        |
|                                       | Line C      | PLAC / C C / / /                        |
|                                       | Line D      | PLAD / D D / / /                        |
|                                       | Line E      | PLAE / E E / / /                        |
|                                       | Line F      | PLAF / F F / / /                        |

- INT and PI60 are normal input terminal containing no Schmitt circuit.
- In Hold operation, oscillation is stopped at PI60="H" and started at PI60="L".
- Divider (2) is reset at PI60="H".



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4620BP

## ELECTRICAL CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL           | ITEM                  | RATING                         |
|------------------|-----------------------|--------------------------------|
| V <sub>DD</sub>  | Supply Voltage        | -0.3V to +7.0V                 |
| V <sub>IN</sub>  | Input Voltage         | -0.3V to V <sub>DD</sub> +0.3V |
| V <sub>OUT</sub> | Output Volatge        | -0.3V to V <sub>DD</sub> +0.3V |
| P <sub>D</sub>   | Power Dissipation     | 600 mW                         |
| T <sub>sol</sub> | Soldering Temperature | 260°C(10 SEC)                  |
| T <sub>stg</sub> | Storage Temperature   | -55°C to +125°C                |
| T <sub>opr</sub> | Operating Temperature | -30°C to + 85°C                |

## ALLOWABLE OPERATING CONDITIONS

| SYMBOL             | ITEM                                                 | CONDITION                                |
|--------------------|------------------------------------------------------|------------------------------------------|
| V <sub>DD</sub>    | Supply Voltage                                       | 4V to 6V                                 |
| T <sub>a</sub>     | Ambient Temperature                                  | -30°C to +85°C                           |
| V <sub>OH</sub>    | Output High Voltage                                  | Min. V <sub>DD</sub> -3.5V( $\geq$ 1.5V) |
| V <sub>OL</sub>    | Output Low Voltage                                   | Max. 3V                                  |
| f <sub>X</sub>     | Xtal Operating Frequency                             | 40KHz to 400KHz                          |
| t <sub>cycl</sub>  | Cycle Time                                           | 10μs to 100μs                            |
| V <sub>DDHCS</sub> | Hold Voltage at Hold Operation<br>(Oscillation Stop) | 2V to 6V                                 |

## Normal Operation

DC CHARACTERISTICS ( $T_a = -30^\circ\text{C}$  to  $+85^\circ\text{C}$ ,  $V_{DD} = 4\text{V}$  to  $6\text{V}$ )

| SYMBOL    | PARAMETER                                                        | TEST CONDITION                                                            | MIN.                | TYP.<br>(Note 1) | MAX.                | UNIT             |
|-----------|------------------------------------------------------------------|---------------------------------------------------------------------------|---------------------|------------------|---------------------|------------------|
| $V_{IH}$  | Input High Voltage                                               | $V_{DD}=6\text{V}, V_{IN}=6\text{V}$                                      | $V_{DD}\times 0.7$  | -                | $V_{DD}$            | V                |
| $V_{IHS}$ | Input High Voltage (Schmitt)                                     |                                                                           | $V_{DD}\times 0.85$ | -                | $V_{DD}$            |                  |
| $V_{IHC}$ | Input High Voltage ( $X_{IN}$ )                                  |                                                                           | $V_{DD}\times 0.75$ | -                | $V_{DD}$            |                  |
| $V_{IL}$  | Input Low Voltage                                                |                                                                           | 0                   | -                | $V_{DD}\times 0.3$  |                  |
| $V_{ILS}$ | Input Low Voltage (Schmitt)                                      |                                                                           | 0                   | -                | $V_{DD}\times 0.15$ |                  |
| $V_{ILC}$ | Input Low Voltage ( $X_{IN}$ )                                   |                                                                           | 0                   | -                | $V_{DD}\times 0.25$ |                  |
| $I_{IH}$  | Input High Current                                               | $V_{DD}=6\text{V}, V_{IN}=6\text{V}$                                      | -                   | -                | 20                  | $\mu\text{A}$    |
| $I_{IL}$  | Input Low Current                                                | $V_{DD}=6\text{V}, V_{IN}=0\text{V}$                                      | -                   | -                | -20                 | $\mu\text{A}$    |
| $R_{IN}$  | Input Resistance (PI5)                                           | $V_{DD}=5\text{V}$                                                        | 75                  | 150              | 350                 | $\text{k}\Omega$ |
| $V_{OH}$  | Output High Voltage                                              | $V_{DD}=5\text{V}, \text{Output Open}$                                    | 4.7                 | 4.9              | -                   | V                |
| $V_{OL}$  | Output Low Voltage                                               |                                                                           | -                   | 0.1              | 0.3                 |                  |
| $I_{OH}$  | Output High Current                                              | $V_{DD}=4.5\text{V}, V_{OH}=2.4\text{V}$                                  | -0.7                | -2               | -                   | mA               |
| $I_{OHL}$ | Output High Current<br>(P05, P06)                                |                                                                           | -2.5                | -6               | -                   |                  |
| $I_{OL}$  | Output Low Current                                               |                                                                           | -1.1                | -2.5             | -                   |                  |
| $I_{OLL}$ | Output Low Current (P05, P06)                                    | $V_{DD}=4.5\text{V}, V_{OL}=0.45\text{V}$                                 | 1.6                 | 4                | -                   |                  |
| $I_{DDO}$ | $V_{DD}$ Supply Current in<br>Normal Operation                   | $V_{DD}=6\text{V}, f_x=400\text{kHz}$<br>$V_{IN}=5.9\text{V}/0.1\text{V}$ | -                   | 400              | 1200                | $\mu\text{A}$    |
| $I_{DDH}$ | $V_{DD}$ Supply Current in Hold<br>operation (Oscillation Cont.) | $PI5$ Open,<br>$C_L=50\text{pF}$ (Note 3)                                 | -                   | 150              | 450                 | $\mu\text{A}$    |

Note : Typical values are at  $T_a=25^\circ\text{C}$ Note : Output characteristic excludes  $X_{OUT}$  terminal.Note :  $X_{IN}$  input waveform at the time of measuring  $V_{DD}$  Supply Current



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4620BP

## Normal Operation

AC CHARACTERISTICS (Ta=-30°C to +85°C, V<sub>DD</sub>=4V to 6V)

| SYMBOL              | PARAMETER                 | TEST CONDITION                                                        | MIN.   | TYP. | MAX.   | UNIT |
|---------------------|---------------------------|-----------------------------------------------------------------------|--------|------|--------|------|
| t <sub>WXIN</sub>   | XIN Pulse Width           | External Input<br>V <sub>IN</sub> =V <sub>IHC</sub> /V <sub>ILC</sub> | 0.4/fx | -    | 0.6/fx | SEC  |
| t <sub>WRESET</sub> | RESET Pulse Width         | V <sub>IN</sub> =V <sub>IHS</sub> /V <sub>ILS</sub>                   | 2 tcy  | -    | -      | μs   |
| t <sub>WINT</sub>   | INT Pulse Width           | V <sub>IN</sub> = V <sub>IH</sub> /V <sub>IL</sub>                    | 2 tcy  | -    | -      |      |
| t <sub>WPI60</sub>  | P160 Pulse Width (Note 1) |                                                                       | 2 tcy  | -    | -      |      |

Note 1 : PI<sub>60</sub> terminal used for general purpose input port.



## INTEGRATED CIRCUIT



## TECHNICAL DATA

TCP4620BP

## Hold Operation (Oscillation stop)

DC CHARACTERISTICS (Ta=-30°C to 85°C, V<sub>DD</sub>=2V to 6V)

| SYMBOL             | PARAMETER                                   | TEST CONDITION                                                                                          | MIN. | TYP.<br>(Note1) | MAX.   | UNIT |
|--------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------------|------|-----------------|--------|------|
| V <sub>DD</sub>    | Hold Voltage in Hold operation              |                                                                                                         | 2.0  | -               | 6.0    | V    |
| I <sub>DDHS</sub>  | V <sub>DD</sub> Supply Current in Hold Mode | V <sub>DDHS</sub> =2V, V <sub>IN</sub> =1.9V/<br>0.1V PI5 Open<br>V <sub>RESET</sub> =V <sub>DDHS</sub> | -    | 0.1             | T.B.D. | -    |
|                    |                                             | V <sub>DDHS</sub> =5V, V <sub>IN</sub> =4.9V/<br>0.1V PI5 Open<br>V <sub>RESET</sub> =V <sub>DDHS</sub> | -    | 0.2             | T.B.D. | μA   |
| V <sub>IHHS</sub>  | Input High Voltage (PI60)                   | V <sub>DDHS</sub> =2V                                                                                   | 1.9  | -               | -      | V    |
| R <sub>IN</sub>    | Input Resistance (PI5)                      |                                                                                                         | 75   | 150             | 350    | KΩ   |
| I <sub>OHHS</sub>  | Output High Current                         | V <sub>DDHS</sub> =2V, V <sub>OH</sub> =1V                                                              | -    | -0.4            | -      | mA   |
| I <sub>OHLHS</sub> | Output High Current(PI5,PI6)                | V <sub>DDHS</sub> =2V, V <sub>OH</sub> =1V                                                              | -    | -0.9            | -      | mA   |
| I <sub>OLHS</sub>  | Output High Current                         | V <sub>DDHS</sub> =2V, V <sub>OL</sub> =0.45V                                                           | -    | 2.0             | -      | mA   |
| I <sub>OOLHS</sub> | Output High Current(PO5,PO6)                | V <sub>DDHS</sub> =2V, V <sub>OL</sub> =0.45V                                                           | -    | 3.5             | -      | mA   |

Note 1 : Typical values are at Ta=25°C.

Note 2 : The limits of V<sub>IHHS</sub>, I<sub>OHHS</sub>, I<sub>OLHS</sub> and I<sub>OOLHS</sub> are equal to the limits of V<sub>IH</sub>, I<sub>OH</sub>, I<sub>OHL</sub>, IOC and IOC1 in [Normal Operation] respectively.  
(V<sub>DDHS</sub> 4V)

## AC CHARACTERISTICS (Ta=-30°C to 85°C)

| SYMBOL            | PARAMETER                            | TEST CONDITION                                                                  | MIN. | TYP.    | MAX. | UNIT |
|-------------------|--------------------------------------|---------------------------------------------------------------------------------|------|---------|------|------|
| t <sub>WRST</sub> | Restort Internal from Hold operation | V <sub>IN</sub> =V <sub>IH</sub> /V <sub>IIL</sub><br>V <sub>DD</sub> =4V to 6V | -    | 2050tcy | -    | μS   |



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4620BP

### TIMING WAVEFORMS

(1)  $X_{IN}$  Input Waveform



(2)  $\overline{RESET}$  Input Waveform



(3)  $\overline{INT}$ ,  $PI_{60}$  Input Waveform



(4) Restart timing from Hold Operation after Oscillation Stop.



## APPLICATION EXAMPLES

## [1] Battery Backup

It is thinkable that there is a backup method which utilizes a battery and a capacitor, as application of the system required to uninterruptedly resume the process before cutting-off of the power supply when the power supply has been restored after the power supply was cut off during the operation of the system.

Fig. 1 shows the example of utilizing a battery and Fig. 2 shows the example of utilizing a capacitor. In both the cases, the operations are almost identical. Let us explain the circuit operation of the example (Fig. 1) of utilizing a battery.

Under the condition of "Main Power Voltage > Backup Voltage," the power (VDD) of TCP4620BP is supplied from the main power supply. When Q1 is ON, "L" level is applied to PI60 terminal.

In other words, the oscillator is in oscillation state, and the operation of TCP4620BP depends on a program.

Under the condition of "Main Power Voltage < Backup Voltage," the power (VDD) of TCP4620BP is supplied from the battery, and when Q1 comes into OFF state, "H" level is applied to PI60 terminal.

In other words, the oscillator depends on the operating state of TCP4620BP, and if it is in hold state, oscillation is stopped.

When TCP4620BP is put to hold state immediately after the power supply has been cut off, the oscillation is stopped, permitting a backup for a long period time.



Fig. 1 Example of Backup Circuit by Use of Battery



Fig. 2 Example of Backup Circuit by Use of Capacitor

## [2] Restart by Key Input

The possibility of a remote control system utilizing TCP4620BP can be considered as application of a system which operates only when the key is fed.

Let us explain the example of application in Fig. 3. Usually TCP4620BP is in hold state, and only when the key is fed, the hold state is released to perform the process according to the input data.

In other words, TCP4620BP is put to hold state after data X'F' has been output (putting SW1 to SW16 to selection state) to its output port 1 (P1).

When the keys (SW1 to SW16) are depressed in this state, "L" level is applied to PI60 terminal and the hold state is released after certain period of time.

The keys are scanned after the release of hold state, and the process is performed according to the key input data. After processing, the data output (X'F') to the output port 1 (P1) and a hold state are established.

In such an application, TCP4620BP operates only when a key is depressed, permitting a sharp reduction in power consumption and a better display of the functions of TCP4620BP.



Fig. 3 Example of Restart Circuit by Key Input



Fig. 4 Example of Circuit (Fig. 3) Timing Chart



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4621AP

C<sup>2</sup>-MOS DIGITAL INTEGRATED CIRCUIT

SILICON MONOLITHIC

### GENERAL DESCRIPTION

The TCP4621AP is a CMOS 4-bit single chip microcomputer most suitable for applications of driving fluorescent display tubes and of interfacing with high voltage circuits.

Output high breakdown voltage:

V<sub>DD</sub> - 32V (Absolute max. rating V<sub>DD</sub> - 35V)

Output high breakdown voltage port:

14 ports (P<sub>060</sub> to P<sub>067</sub>, P<sub>050</sub> to P<sub>054</sub>, P<sub>10</sub>)

The TCP4621AP has adopted the P-channel Open Drain structure of some output ports of the TCP4620AP, resulting in high breakdown voltage. There are some difference between the TCP4620AP and the TCP4621AP in electrical characteristics, pin functions, and mask options, but the other functions, electrical characteristics, instructions, and pin connections of the TCP4621AP are compatible with those of the TCP4620AP. For the use and study of this device, use jointly with TCP4620AP Technical Data.

The following items are the points of difference in electrical characteristics.

1. Operating temperature and ambient temperature

T<sub>opr</sub> = -20 to +70°C

T<sub>a</sub> = -20 to +70°C

2. Output high breakdown voltage port and output high level current

I<sub>OH1</sub> (P<sub>060</sub> to P<sub>067</sub>) = -1mA MIN. (V<sub>DD</sub>=4.5V, V<sub>OH</sub>=2.5V)

I<sub>OH1</sub> (P<sub>050</sub> to P<sub>054</sub>, P<sub>10</sub>) = -7mA MIN. (V<sub>DD</sub>=4.5V, V<sub>OH</sub>=2.5V)

3. Mask option

The contents only which are shown on the TCP4621AP mask option sheet can be designated. 400 KHz ceramic/IFT can be used as an oscillator.



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4621AP

## PIN NAMES &amp; PIN DESCRIPTION

| Pin Name                             | Pin No. | Input/Output    | Function                                                                                                                                             |
|--------------------------------------|---------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| P <sub>03</sub> to P <sub>00</sub>   | 4       | Input/Output    | 4-bit general purpose I/O port (I/O is changed over by a program.) This port can be used as a dedicated output. (I/O is designated by mask options.) |
| P <sub>13</sub> to P <sub>10</sub>   | 4       | Output          | 4-bit general purpose output port<br>* P <sub>10</sub> only is a output high breakdown voltage port                                                  |
| P <sub>23</sub> to P <sub>20</sub>   | 4       | Input or Output | 4-bit general purpos Input/Output port                                                                                                               |
| P <sub>43</sub> to P <sub>40</sub>   | 4       | Input or Output | Input/Output is designated by mask options.                                                                                                          |
| P <sub>054</sub> to P <sub>050</sub> | 5       | Output          | * 5-digit Output high breakdown voltage port for display. (Can be used as the general purpose output port.)                                          |
| P <sub>067</sub> to P <sub>060</sub> | 8       | Output          | * 8-segment output high breakdown port for display [Can be used as the general purpose 8-bit output port (4 × 2 bits).]                              |
| P <sub>I53</sub> to P <sub>I50</sub> | 4       | Input           | 4-bit general purpose input port                                                                                                                     |
| P <sub>I60</sub>                     | 1       | Input           | 1-bit general purpose input port (with an internal Schmitt circuit)                                                                                  |
| RESET                                | 1       | Input           | Reset input terminal (with an internal Schmitt circuit)                                                                                              |
| INT                                  | 1       | Input           | Interrupt request input terminal (with an internal Schmitt circuit)                                                                                  |
| X <sub>IN</sub>                      | 1       | Input           | Oscillator connecting terminal                                                                                                                       |
| X <sub>OUT</sub>                     | 1       | Output          | Oscillator connecting terminal                                                                                                                       |
| C K                                  | 1       | Output          | External timing output                                                                                                                               |
| TEST                                 | 1       | Input           | Used by connecting to GND at all times                                                                                                               |
| V <sub>DD</sub>                      | 1       |                 | Power supply                                                                                                                                         |
| GND                                  | 1       |                 | GND                                                                                                                                                  |

Note) The asterisk(\*) indicates the points of difference between the TCP4620AP and this device.

Output high breakdown voltage ports are of P-channel open drain structure.



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4621AP

## TCP4621AP MASK OPTIONS

|                                   |                 | O S C       | TYP021                        | TYP022                        |
|-----------------------------------|-----------------|-------------|-------------------------------|-------------------------------|
| Oscillation frequency             |                 |             | 050<br>400K<br>ceramic<br>IFT | 050<br>400K<br>ceramic<br>IFT |
| Dividing ratio for internal clock |                 | CP          | 02                            | 02                            |
| External timing output            |                 | CK          | CP                            | PD2                           |
| Counter                           | Divider 1 Input | PD          | CP                            | CP                            |
|                                   | Divider 3 Input | COUNTER PDR | PD2                           | PD2                           |
|                                   | Reset timing    | PDR         | N                             | /12500/                       |
| Counter Buffer                    | Buffer 0 Input  | CO          | PI60                          | PI60                          |
|                                   | Buffer 1 Input  | COUNTER C1  | RD7                           | RDB                           |
| Counter Buffer                    | Buffer 2 Input  | BUFFER C2   | RDA                           | RDC                           |
|                                   | Buffer 3 Input  | C3          | RDD                           | RDD                           |
| H flag                            |                 | HOLD        | 0                             | H                             |
| Restart condition                 |                 | RSTH        | 0                             | C3                            |
| Input/Output port                 | Port 0          | STD         | D(PROG)                       | 1 (OUT)                       |
| I/O Port                          | Port 2          | P2          | /F/(OUT)                      | /F/(OUT)                      |
|                                   | Port 4          | P4          | /F/(OUT)                      | /3/(IN/OUT)                   |
| Input resistance (Input port 5)   |                 | P15         | 0 (UP)                        | 1 (DOWN)                      |
| Decode matrix (P05)               | Line 0          | DECODER     | DECO                          | / /                           |
|                                   | Line 1          |             | DEC1                          | / /                           |
|                                   | Line 2          |             | DEC2                          | / /                           |
|                                   | Line 3          |             | DEC3                          | / /                           |
|                                   | Line 4          |             | DEC4                          | / /                           |
| Output port                       | 6/7             | PLA         | PO6                           | 1 (P6/P7) 0 (P6)              |
|                                   | Line 0          |             | PLA0                          | / 00 / / /                    |
|                                   | Line 1          |             | PLA1                          | / 11 / / /                    |
|                                   | Line 2          |             | PLA2                          | / 22 / / /                    |
|                                   | Line 3          |             | PLA3                          | / 33 / / /                    |
|                                   | Line 4          |             | PLA4                          | / 44 / / /                    |
|                                   | Line 5          |             | PLA5                          | / 55 / / /                    |
|                                   | Line 6          |             | PLA6                          | / 66 / / /                    |
|                                   | Line 7          |             | PLA7                          | / 77 / / /                    |
| P L A (P06)                       | Line 8          |             | PLA8                          | / 88 / / /                    |
|                                   | Line 9          |             | PLA9                          | / 99 / / /                    |
|                                   | Line A          |             | PLAA                          | / AA / / /                    |
|                                   | Line B          |             | PLAB                          | / BB / / /                    |
|                                   | Line C          |             | PLAC                          | / CC / / /                    |
|                                   | Line D          |             | PLAD                          | / DD / / /                    |
|                                   | Line E          |             | PLAE                          | / EE / / /                    |
|                                   | Line F          |             | PLAF                          | / FF / / /                    |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4621AP

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL            | ITEM                                   | RATING                                      | UNIT |
|-------------------|----------------------------------------|---------------------------------------------|------|
| V <sub>DD</sub>   | Supply Voltage                         | -0.3 to +7.0                                | V    |
| V <sub>IN</sub>   | Input Voltage                          | -0.3 to V <sub>DD</sub> +0.3                | V    |
| V <sub>OUT1</sub> | Output Voltage<br>(except P05,P06,P10) | -0.3 to V <sub>DD</sub> +0.3                | V    |
| V <sub>OUT2</sub> | Output Voltage<br>(P05,P06,P10)        | V <sub>DD</sub> -35 to V <sub>DD</sub> +0.3 | V    |
| P <sub>D</sub>    | Power Dissipation                      | 600                                         | mW   |
| T <sub>SOL</sub>  | Soldering Temperature·Time             | 260 (10 SEC)                                | °C   |
| T <sub>STG</sub>  | Storage Temperature                    | -55 to +125                                 | °C   |
| T <sub>OPR</sub>  | Operating Temperature                  | -20 to +70                                  | °C   |

## ALLOWABLE OPERATING CONDITIONS

| SYMBOL           | ITEM                              | RATING                    | UNIT |
|------------------|-----------------------------------|---------------------------|------|
|                  |                                   | V <sub>DD</sub> = 4 to 6V |      |
| T <sub>A</sub>   | Ambient Temperature               | -20 to +70                | °C   |
| V <sub>OUT</sub> | Output Voltage<br>(P06, P05, P10) | Max. V <sub>DD</sub> - 32 | V    |
| f <sub>X</sub>   | X'tal Operating Frequency         | 40 to 400                 | KHz  |
| t <sub>CY</sub>  | Cycle Time                        | 10 to 100                 | μs   |

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TCP4621AP

DC CHARACTERISTICS ( $T_a = -20^\circ\text{C}$  to  $+70^\circ\text{C}$ ,  $V_{DD} = 4\text{V}$  to  $6\text{V}$ )

| SYMBOL     | PARAMETER                                                        | TEST CONDITION                                                     | RATING               |                      |                      | UNIT          |
|------------|------------------------------------------------------------------|--------------------------------------------------------------------|----------------------|----------------------|----------------------|---------------|
|            |                                                                  |                                                                    | MIN.                 | TYP.                 | MAX.                 |               |
| $V_{IH}$   | Input High Voltage                                               |                                                                    | $V_{DD} \times 0.7$  | $V_{DD} \times 0.55$ | $V_{DD}$             | V             |
| $V_{IHS}$  | Input High Voltage (Schmitt)                                     |                                                                    | $V_{DD} \times 0.85$ | $V_{DD} \times 0.75$ | $V_{DD}$             |               |
| $V_{IHC}$  | Input High Voltage (XIN input)                                   |                                                                    | $V_{DD} \times 0.75$ | -                    | $V_{DD}$             |               |
| $V_{IL}$   | Input Low Voltage                                                |                                                                    | 0                    | $V_{DD} \times 0.45$ | $V_{DD} \times 0.3$  |               |
| $V_{ILS}$  | Input Low Voltage (Schmitt)                                      |                                                                    | 0                    | $V_{DD} \times 0.35$ | $V_{DD} \times 0.15$ |               |
| $V_{ILC}$  | Input Low Voltage (XIN input)                                    |                                                                    | -                    | -                    | $V_{DD} \times 0.25$ |               |
| $I_{IH}$   | Input High Current                                               | $V_{DD}=6\text{V}$ , $V_{IN}=6\text{V}$                            | -                    | -                    | 20                   | $\mu\text{A}$ |
| $I_{IL}$   | Input Low Current                                                | $V_{DD}=6\text{V}$ , $V_{IN}=0\text{V}$                            | -                    | -                    | -20                  |               |
| $R_{IN}$   | Input Resistance (PI5)                                           | $V_{DD}=5\text{V}$                                                 | 75                   | 150                  | 350                  |               |
| $V_{OH}$   | Output High Voltage                                              |                                                                    | 4.7                  | 4.9                  | -                    | V             |
| $V_{OL}$   | Output Low Voltage                                               | $V_{DD}=5\text{V}$ , Output Open                                   | -                    | 0.1                  | 0.3                  |               |
| $I_{OH}$   | Output High Current                                              | $V_{DD}=4.5\text{V}$ , $V_{OH}=2.4\text{V}$                        | -0.7                 | -                    | -                    |               |
| $I_{OHI}$  | (PO6)                                                            | $V_{DD}=4.5\text{V}$ , $V_{OH}=2.5\text{V}$                        | -1                   | -                    | -                    | $\text{mA}$   |
|            |                                                                  | $V_{DD}=4.5\text{V}$ , $V_{OH}=2.5\text{V}$                        | -7                   | -                    | -                    |               |
| $I_{OL}$   | Output Low Current                                               | $V_{DD}=4.5\text{V}$ , $V_{OL}=0.45\text{V}$                       | 1.6                  | -                    | -                    | $\mu\text{A}$ |
| $I_{LO}$   | Output Leak Current<br>(PO5, PO6, P10)                           | $V_{DD}=6\text{V}$ , $V_{OUT}=-26\text{V}$                         | -                    | -                    | -20                  |               |
| $I_{IDD}$  | VDD Supply Current in Normal Operation ( $f_X = 400\text{kHz}$ ) | $V_{DD}=6\text{V}$ , $V_{IN}=5.9\text{V}/0\text{V}$<br>(all valid) | -                    | 400                  | 1200                 |               |
| $I_{IDDH}$ | VDD Supply Current in Hold Operation ( $f_X = 400\text{kHz}$ )   | PI5 Open $C_L=50\text{pF}$<br>Output Open                          | -                    | 150                  | 450                  | $\mu\text{A}$ |

Note 1: Typical values are at  $T_a=25^\circ\text{C}$  and  $V_{DD}=5\text{V}$ .2: Output characteristic excludes  $X_{OUT}$  terminal.

3: XIN input waveform at the time of measuring VDD supply current.

AC CHARACTERISTICS ( $T_a = -20$  to  $+70^\circ\text{C}$ ,  $V_{DD} = 4$  to  $6\text{V}$ )

| SYMBOL       | PARAMETER         | TEST CONDITION                       | MIN.      | TYP. | MAX.      | UNIT         |
|--------------|-------------------|--------------------------------------|-----------|------|-----------|--------------|
| $t_{WXIN}$   | XIN Pulse Width   | External Input<br>$V_{IN}=VIHC/VILC$ | $0.4/f_X$ | -    | $0.6/f_X$ | $\text{SEC}$ |
| $t_{WRESET}$ | RESET Pulse Width |                                      | 2 tcy     | -    | -         |              |
| $t_{WIN}$    | INT Pulse Width   |                                      | 2 tcy     | -    | -         |              |
| $t_{WP160}$  | PI60 Pulse Width  |                                      | 2 tcy     | -    | -         |              |



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4621AP

### INTERFACE OF FLUORESCENT DISPLAY TUBE



### INTERFACE WITH PMOS





# INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TCP4632BF  
C<sup>2</sup>-MOS DIGITAL INTEGRATED CIRCUIT  
SILICON MONOLITHIC

PRELIMINARY

### GENERAL DESCRIPTION

The TCP4632BF is a C<sup>2</sup>MOS 4-bit single-chip microcomputer capable of directly driving liquid crystal display provided with 1/3 or 1/4 duty, and is most suitable for use in a wide range of application fields, such as a system requiring low power dissipation.

The TCP4632BF contains the controller and driver for driving the liquid crystal display (hereinafter referred to as LCD) to the TCP4630AP. For the use and study of this device, refer to the technical data for the TCP4630AP in addition to this technical data.

### FEATURES

- o C<sup>2</sup>MOS 4-bit single-chip microcomputer of low power dissipation
- o Memory capacity
  - Program region (ROM) 3072 words x 8-bit
  - Data region (RAM) 160 words x 4-bit (including RAM for display)
- o Instruction execution time: 10 µs (400kHz ceramic oscillator/IFT)
- o 52 instructions
- o Built-in LCD controller
  - 1/3 or 1/4 duty (designated by mask options)
- o Built-in LCD direct driver
  - Common output 4 pins
  - Segment output 24 pins
- o Input/Output port
  - I/O port 1 x 4-bit (I/O can be switched by programs.)
  - 1 x 4-bit (I/O can be designated by mask options.)
  - 1 x 4-bit (I/O can be designated by mask options.)



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4632BF

PRELIMINARY

Output port      3 x 4-bit (General purpose output port)

Input port      1 x 4-bit (Pull-up/Pull-down resistor with input  
resistance can be selected.)

1 x 4-bit

- o External power supply is available for LCD ( $V_{LCD}$ )
- o Built-in display decoder (Can be designated by mask options with  
decoder data.)
- o Blanking operation
- o Hold operation (LCD can be displayed during hold operation.)
- o Power-down mode (Display blanking)
- o 67-pin plastic package

## BLOCK DIAGRAM





# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4632BF

PRELIMINARY

### PIN CONNECTIONS (Top View)



### PIN NAMES/PIN DESCRIPTION

| Pin Name | Input/<br>Output | TCP4620AP/30AP |                                        | TCP4632BF     |                                        |
|----------|------------------|----------------|----------------------------------------|---------------|----------------------------------------|
|          |                  | No.of<br>pins  | Function                               | No.of<br>pins | Function                               |
| TEST     | Input            | 1              | LSI test input (always kept set at 0.) | 1             | LSI test input (always kept set at 0.) |
| XIN      | Input            | 1              | Oscillator connecting terminal         | 1             | Oscillator connecting terminal         |
| XOUT     | Output           | 1              | Oscillator connecting terminal         | 1             | Oscillator connecting terminal         |
| PI5      | Input            | 4              | General purpose input port             | 4             | General purpose input port             |
| RESET    | Input            | 1              | Reset input                            | 1             | Reset input                            |
| INT      | Input            | 1              | Interrupt input                        | 1             | Interrupt input                        |
| PI6      | Input            | 1              | General purpose input                  | 1             | General purpose input                  |



| Pin Name         | Input/<br>Output | TCP4620AP/30AP |                                       | TCP4632BF     |                                         |
|------------------|------------------|----------------|---------------------------------------|---------------|-----------------------------------------|
|                  |                  | No.of<br>pins  | Function                              | No.of<br>pins | Function                                |
| P0               | I/O              | 4              | I/O port                              | 4             | I/O port                                |
| P1               | Output           | 4              | General purpose output port           | 4             | General purpose output port             |
| P2               | Input/<br>Output | 4              | General purpose input/<br>output port | 4             | General purpose input/<br>output port   |
| P4               | Input/<br>Output | 4              | General purpose input/<br>output port | 4             | General purpose input/<br>output port   |
| VDD              |                  | 1              | Power supply                          | 2             | Power supply                            |
| SEG0~23          | Output           |                |                                       | 24            | LCD segment driver out-<br>put          |
| P06              | Output           | 4              | PLA output port                       | 4             | General purpose output port             |
| P07              | Output           | 4              | PLA output port                       |               |                                         |
| P05              | Output           | 5              | Decode matrix output port             | 4             | General purpose output port             |
| COM0~3           |                  |                |                                       | 4             | LCD common driver output                |
| V <sub>LCD</sub> |                  |                |                                       | 1             | LCD external power sup-<br>ply terminal |
| GND              |                  | 1              | GND                                   | 1             | GND                                     |
| CK               | Output           | 1              | External timing output                | 1             | External timing output                  |

## CONFIGURATION OF PORT AND REGISTER

|   | Name              | Symbol          | Pin Name                             | Reg. No. | Function          | Remarks                                                                                                                 |
|---|-------------------|-----------------|--------------------------------------|----------|-------------------|-------------------------------------------------------------------------------------------------------------------------|
| * | I/O Port          | P <sub>0</sub>  | P <sub>03</sub> to P <sub>00</sub>   | 0        | I/O Port          | I/O switching is controlled by D flag of ST.<br>This port can be designated as a dedicated output port by mask options. |
| * | Output Port       | P <sub>1</sub>  | P <sub>13</sub> to P <sub>10</sub>   | 1        | Output Port       | General purpose output port.<br>The contents of register can be referred to by a program.                               |
| * | Input/Output Port | P <sub>2</sub>  | P <sub>23</sub> to P <sub>20</sub>   | 2        | Input/Output Port | Input/output can be designated by mask options. The contents of register can be referred to by a program.               |
| * | Command Register  | C/S             | —                                    | 3        | Command Register  | LCD display is controlled by a 2-bit register. The contents of register can be referred to by a program.                |
| * | Input/Output Port | P <sub>4</sub>  | P <sub>43</sub> to P <sub>40</sub>   | 4        | Input/Output Port | Input/output can be designated by mask options. The contents of register can be referred to by a program.               |
| * | Input Port        | P <sub>15</sub> | P <sub>153</sub> to P <sub>150</sub> | 5        | Input Port        | General purpose input port with 150kΩ (TYP.) resistance. Pull-up/Pull-down designation can be made by mask options.     |
|   | Output Port       | P <sub>05</sub> | P <sub>053</sub> to P <sub>050</sub> |          | Output Port       | General purpose output port.<br>The contents of register can not be referred to by a program.                           |
| * | Input Port        | P <sub>16</sub> | P <sub>160</sub>                     | 6        | Input Port        | 1-bit general purpose input port.<br>(Built-in Schmitt circuit).                                                        |
|   | Output Port       | P <sub>06</sub> | P <sub>063</sub> to P <sub>060</sub> |          | Output Port       | General purpose output port.<br>The contents of register can not be referred to by a program.                           |
| * | PLA               | PLA             | —                                    | 7        | PLA               | PLA. PLA can be used as a display data decoder or a data decoder. The contents of decode is designated by mask options. |

Note      The asterisk (\*) indicates the points of difference between TCP4620AP/TCP4630AP and this device.

- (a) Neither command register nor PLA (available for reference by a program) is contained in the TCP4620AP/TCP4630AP.
- (b) Since P<sub>0</sub>s and P<sub>0</sub><sub>6</sub> contain neither decode matrix nor PLA, the number of output pins of each port is 4.
- (c) Care should be taken to the fact that P<sub>0</sub>, P<sub>2</sub>, P<sub>4</sub>, P<sub>0</sub><sub>5</sub> and P<sub>0</sub><sub>6</sub> of this device are different from those of TCP4620AP/TCP4630AP in electrical characteristics.

#### LCD CONTROLLER/DRIVER

The TCP4632BF contains a driver circuit capable of directly, dynamically driving the LCD provided with 1/3 or 1/4 duty by the 1/3 bias method.

LCD connection terminals amount to 29 in total as follows:

|                                             |    |
|---------------------------------------------|----|
| Common driver output (COM0 to COM3)         | 4  |
| Segment driver output (SEG0 to SEG23)       | 24 |
| VLCD terminal as LCD driving power terminal | 1  |

The display ability makes it possible directly to drive the following LCDs according to the number of time divisions:

- (a) 1/4 duty (1/3 bias) LCD  
Max. 96 segments (12 digits x 8 segments)
- (b) 1/3 duty (1/3 bias) LCD  
Max. 72 segments (8 digits x 9 segments)

**BLOCK DIAGRAM OF LCD DRIVE CONTROLLER**

**CONTROL OF DRIVE CIRCUIT**

The operation of LCD drive circuit is controlled by the contents of command register. The command register is a 2-bit register and is accessed as register No. '3'. Both of two bits are reset to "0" by an initialize operation.





## DISPLAY OPERATION

## SETUP OF DISPLAY DATA

The TCP4632BF internal processing data corresponds to LCD drive terminal in such a way as bit 0, bit 1, bit 2 and bit 3 of the processing data correspond to each segment data of COM0, COM1, COM2, and COM3, respectively.



The conversion of LCD display data is arbitrarily set up by a program or by a built-in PLA register (setup of the contents by mask options).

## TRANSFER OF DISPLAY DATA

LCD display data setup by a program or PLA register is displayed by transferring it to the shift register of LCD driver by the program.

The transfer method is divided into two categories: one is that the converted data is transferred as it is, and another is that a displaying data region set up in the data memory (RAM) is transferred after it has been once stored. Even by either method, each bit of LCD segment (dot) and TCP4632BF internal processing data corresponds to each other by one to one.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4632BF

PRELIMINARY

| Address | Bit | MSB | 2 | 1 | LSB | 0                                                                               |
|---------|-----|-----|---|---|-----|---------------------------------------------------------------------------------|
| 0       |     |     |   |   |     | (SEG <sub>0</sub> )                                                             |
| 1       |     |     |   |   |     | (SEG <sub>1</sub> )                                                             |
| 2       |     |     |   |   |     | (SEG <sub>2</sub> )                                                             |
| 3       |     |     |   |   |     | (SEG <sub>3</sub> )                                                             |
|         | ~   | ~   | ~ | ~ | ~   | ~                                                                               |
| 22      |     |     |   |   |     | (SEG <sub>22</sub> )                                                            |
| 23      |     |     |   |   |     | (SEG <sub>23</sub> )                                                            |
|         |     |     |   |   |     | (COM <sub>3</sub> ) (COM <sub>2</sub> ) (COM <sub>1</sub> ) (COM <sub>0</sub> ) |

In case data memory is provided with display region

| Register | Bit | MSB | 2 | 1 | LSB | 0                                                                                             |
|----------|-----|-----|---|---|-----|-----------------------------------------------------------------------------------------------|
|          |     |     |   |   |     | (SEG <sub>i</sub> )                                                                           |
|          |     |     |   |   |     | (COM <sub>3</sub> ) (COM <sub>2</sub> ) (COM <sub>1</sub> ) (COM <sub>0</sub> ) (i = 0 to 23) |

In case processing data intact is transferred

Each bit of display data expresses data of segment (dot) equivalent to (SEG<sub>i</sub> COM<sub>j</sub> :  $0 \leq i \leq 23$ ,  $0 \leq j \leq 3$ ). When the data displays "1", the display lights. In case of the use of LCD with 1/3 duty (COM<sub>0</sub> to COM<sub>2</sub>), the data of bit 3 (MSB) has no meaning as a LCD display data.



Transfer and rewrite of display data is made by a program as follows:

First, clear SCAN bit to '0'. (Immediately after initialization, the bit is at '0'.) Next, transfer 4-bit data equivalent to SEG. 23 to Register No. 6 (SAR 6), and then transfer 4-bit data equivalent to SEG 22. Continuously transfer 4-bit data in sequence by programs until the transfer of data equivalent to SEG. 0 is completed.

This operation allows 4×24-bit data to be written into the shift register within LCD drive circuit. After the data transfer of 24 words has been finished, SCAN bit is set to '1'. When SCAN bit goes to '1', writing into the shift register is inhibited, and LCD begins to be driven by the data newly held. Data switching is made from COMj to come next (data output equivalent to bit j to SEGi) and is automatically scanned to the next COMj+1.

In the case that the period (period of SCAN = 0) of 24-word data transfer by means of a program is within the one COM period (1/4fF), the blank period does not come into the transfer period, and the display contents are switched. However, in the case that the period (period of SCAN = 0) of 24-word data transfer by means of a program crosses switching of COM (this phenomenon presents by timing of data transfer period or it presents when the data transfer period becomes longer than one COM period), no correct display data is secured during the period; thus, a blank is automatically inserted in the period.

When the display data is transferred to a shift register equivalent to Register No.6 during the period of SCAN = 0, all of 24 words must be transferred to the shift register. However, if SEGO to SEG<sub>k-1</sub> outputs only, not all of SEG0 ~ SEG23 outputs, are used, k word only can be transferred.

In case of SCAN = 0, write in Register No. 6 (SAR = 6) means write in the shift register as a display data. In case of SCAN = 1, however, it means write in output port P06.



As the display data transfer period is short, it does not come in the blanking period.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4632BF

PRELIMINARY



As the display data transfer period is long, it comes in the blanking period.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4632BF

PRELIMINARY

### LCD FRAME FREQUENCY

Frame frequency (LCD drive frequency) is given by the built-in devider. The frame frequency  $f_F$  is given from internal clock frequency  $f_{CP}$  by the following formula:

$$f_F = f_{CP} \times \frac{1}{2^m \times n}$$

Where,  $m$  is the number of divider stages. When  $f_X = 400$  kHz and  $f = 200$  kHz,  $m$  is set to 9.  $n$  is the number of time division. Therefore,

$$\text{In case of } 1/3 \text{ duty} \quad f_F \approx 130 \text{ Hz}$$

$$\text{In case of } 1/4 \text{ duty} \quad f_F \approx 98 \text{ Hz}$$

The period equivalent to one COM is

$$\frac{2^m}{f_{CP}} \quad (\div \frac{2^m-1}{f_{CY}})$$

therefore, when  $m = 9$ , the period is equivalent to 256 steps.

### LCD DRIVE WAVEFORM

TCP4632BF is capable of directly, dynamically driving the LCD provided with 1/3 or 1/4 duty by 1/3 bias method.

In case of 1/3 or 1/4 duty, the voltage applied to LCD is  $+ (V_{DD} - V_{LCD})$  to  $- (V_{DD} - V_{LCD})$ .





# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4632BF

PRELIMINARY



1/3 duty (1/3 bias) drive

(Note)  $f_F$  : LCD frame frequency  
 $V_{LCD}$  :  $V_{LCD}$  terminal voltage

Each terminal waveform in case of displaying data "3" at 1/4 duty is as follows:





# INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TCP4632BF

PRELIMINARY

The voltage between each SEG - COM is as follows:



## LCD DRIVE VOLTAGE

$V_{LCD}$  is an input terminal of LCD driving power. LCD drive voltage is required to be supplied between  $V_{DD}$ - $V_{LCD}$ .

If the operation voltage of the TCP4632BF is identical with the LCD drive voltage,  $V_{LCD}$  is connected to GND.

The supply of drive voltage generated by LCD drive circuit is controlled within this device according to the operating status of CPU. In the following cases that there is a possibility of keeping LCD drive circuit stationary for a long period of time, the supply of LCD drive voltage is cut with the built-in switch.

- ① Initialize operation
- ② SCAN = 0 and H = 1



The switch turned off by initialize operation is turned on by setting the SCAN bit of command register to '1', thus resulting in the supply of LCD drive voltage. After that, even if the SCAN bit of command register is reset to '0', LCD drive voltage is kept supplied.

For performing hold operation, H must be set to '1' in a state of SCAN = 1 and at time of normal LCD display because rewrite of display data has been already finished. In this case, LCD drive circuit is still in operation to continue display. However, while display data is being rewritten, if H is set to '1' at time of SCAN = 0, the supply of LCD drive voltage is cut.

When the supply of LCD drive voltage is cut with the built-in switch, all of SEG and COM outputs attain V<sub>DD</sub> level.

#### OUTPUT PORT (P05, P06)

P05 and P06 are 4-bit general purpose output ports. Each port is provided with a latch, and its contents are held until they are rewritten by a program. Each bit is reset to "0" by initialize operation, but the contents being held cannot be referred to by the program.

The authorization/inhibit of content rewrite by the program of P06 is controlled by SCAN bit of command register.

| Command register<br>SCAN | Object of content rewrite by<br>program        |
|--------------------------|------------------------------------------------|
| 0                        | Output to shift register<br>(LCD segment data) |
| 1                        | Output to P06                                  |

Unlike P05 and P06 of TCP4630AP, those of TCP4632BF do not contain decode matrix, and PLA; therefore, there is difference between them in output timing.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4632BF

PRELIMINARY



### PLA

A program can make reference of PLA by use of a decoder for display data or the like. If 4-bit BCD data is written in PLA (Register No.7) by a program, one of sixteen addresses is selected by 4-to-16 decoder within PLA, and the corresponding 8-bit data is written in PLA register.

PLA contents of PLA register can be read out by executing the instruction for making reference of PLA. How to read out 8-bit data of PLA register varies with option designation of 1/3 duty or 1/4 duty. PLA register is not affected by reset operations.

#### (a) Designating 1/4 duty by options

The 8-bit data can be read out by executing the instruction for making reference of PLA register two times. In other words, 4-bit (bit 3 to 0) data on the lower level can be read out by the first execution of the instruction (LAR 7) for making reference of PLA

after BCD data has been written in PLA (SAR 7), and similarly 4-bit (bit 7 to 4) data on the higher level can be read out by the second execution of the same instruction.

When the same data is read out again, and when PLA register is required to be updated, the reabout must be performed after BCD data has been written in the PLA over again.

Internal bus



(b) Designating 1/3 duty by options

The 8-bit data can be read out by executing the instruction for making reference of PLA register three times. In other words, 3-bit (bit 2 to 0) data on the lower level can be read out by the first execution of the instruction (LAR 7) for making reference of PLA after BCD data has been written in PLA (SAR 7), and similarly 3-bit (bit 5 to 3) data on the intermediate level can be read out by the second execution of the same instruction, and also 2-bit (bit 7 to 6) data on the higher level by the third execution of the same instruction, respectively.

While the reference instruction above mentioned is being executed, 1 bit (bit 3) on MSB side of the lower or intermediate level and 2 bits (bit 3 and 2) on MSB side of the higher level are always read out as zero. When the same data is read out again, and when PLA register is required to be updated, the readout is performed after BCD data has been written in the PLA over again.

Internal bus



## LCD DATA TRANSFER PROGRAM - EXAMPLE

| LR | 0 | 1 | 2 | 3 | 4          | 5     | 6  | 7  | 8  | 9  | A  | B  | C | D  | E  | F            |
|----|---|---|---|---|------------|-------|----|----|----|----|----|----|---|----|----|--------------|
| HR |   |   |   |   | 1<br>Digit | 2     | 3  | 4  | 5  | 6  | 7  | 8  | 9 | 10 | 11 | 12-<br>digit |
|    |   |   |   |   |            |       |    |    |    |    |    |    |   |    |    |              |
| 7  |   |   |   |   |            | SEG23 | 21 | 19 | 17 | 15 | 13 | 11 | 9 | 7  | 5  | 3 SEG 1      |
| 8  |   |   |   |   |            | SEG22 | 20 | 18 | 16 | 14 | 12 | 10 | 8 | 6  | 4  | 2 SEG 0      |
| 9  |   |   |   |   |            |       |    |    |    |    |    |    |   |    |    |              |

Example of a program which the data of HR = 7 and LR = 4 to F are displayed on LCD through segment conversion

LCD: 1/4 duty, 12 digits (24 Seg.)





# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4632BF

PRELIMINARY





# INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4632BF

PRELIMINARY

```
10 ; *** TCP4632BF LCD DATA TRANSFER PROGRAM
20 ;
0100 30 ORG 100H
0100 64 40 START: LLI 4
0101 77 50 NEXT: LHI 7
0102 04 60 LAM
0103 2F 70 SAR 7
0104 78 80 LHI 8
0105 17 90 LAR 7
0106 0C 100 SAM
0107 79 110 LHI 9
0108 17 120 LAR 7
0109 0C 130 SAM
010A 02 140 ICL
010B 06 150 LAL
010C 90 160 ADI 0
010D D110 170 BCC NEXT
010F 42 180 TRANS: LAI 2
0110 2B 190 SAR 3 ; DISP=1,SCAN=0 SET
0111 64 200 LLI 4
0112 78 210 TRANSF: LHI 8
0113 04 220 LAM
0114 2E 230 SAR 6
0115 79 240 LHI 9
0116 04 250 LAM
0117 2E 260 SAR 6
0118 02 270 ICL
0119 06 280 LAL
011A 90 290 ADI 0
011B D211 300 BCC TRANSF
011D 43 310 DISP: LAI 3
011E 2B 320 SAR 3 ; DISP=SCAN=1 SET
330 ;
340 ;
```





## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4632BF

PRELIMINARY

TCP4632BF MASK OPTIONS

|                                   |             |                                         |               |            |               |
|-----------------------------------|-------------|-----------------------------------------|---------------|------------|---------------|
| Oscillation frequency             | O S C       | TYP032<br>050<br>400K<br>ceramic<br>IFT |               |            |               |
| Dividing ratio for internal clock | CP          | 02                                      |               |            |               |
| External timing output            | CK          | C1                                      |               |            |               |
| Divider 1 Input                   | PD          | CP                                      |               |            |               |
| Divider 3 Input                   | COUNTER PDR | PD2                                     |               |            |               |
| Counter Reset timing              | PDR         | N                                       |               |            |               |
| Buffer 0 Input                    | CO          | PI60                                    |               |            |               |
| Buffer 1 Input                    | COUNTER C1  | RD7                                     |               |            |               |
| Buffer 2 Input                    | BUFFER C2   | RDA                                     |               |            |               |
| Buffer 3 Input                    | C3          | RDD                                     |               |            |               |
| H flag                            | HOLD        | H                                       |               |            |               |
| Restart condition                 | RSTH        | C3                                      |               |            |               |
| Input/Output port                 | STD         | D (PROG)                                | 1 (OUT)       |            |               |
| Port 0                            |             |                                         |               |            |               |
| Input/Output port                 | P2          | /F / (OUT)                              | /F / (OUT)    | /0 / (IN)  | /0 / (IN)     |
| Port 2                            |             |                                         |               |            |               |
| Input/Output port                 | P4          | /F / (OUT)                              | /3 / (IN/OUT) | /F / (OUT) | /3 / (IN/OUT) |
| Port 4                            |             |                                         |               |            |               |
| Input resistance (Input port 5)   | P15         | 0 (UP)                                  | 1 (DOWN)      |            |               |
| P L A (#7)                        | Line 0      | PLAO                                    | / /           |            |               |
|                                   | Line 1      | PLA1                                    | / /           |            |               |
|                                   | Line 2      | PLA2                                    | / /           |            |               |
|                                   | Line 3      | PLA3                                    | / /           |            |               |
|                                   | Line 4      | PLA4                                    | / /           |            |               |
|                                   | Line 5      | PLA5                                    | / /           |            |               |
|                                   | Line 6      | PLA6                                    | / /           |            |               |
|                                   | Line 7      | PLA7                                    | / /           |            |               |
|                                   | Line 8      | PLA8                                    | / /           |            |               |
|                                   | Line 9      | PLA9                                    | / /           |            |               |
|                                   | Line A      | PLAA                                    | / /           |            |               |
|                                   | Line B      | PLAB                                    | / /           |            |               |
|                                   | Line C      | PLAC                                    | / /           |            |               |
|                                   | Line D      | PLAD                                    | / /           |            |               |
|                                   | Line E      | PLAE                                    | / /           |            |               |
|                                   | Line F      | PLAF                                    | / /           |            |               |
| Oscillation Stop Control          | RSTX        | N                                       |               |            |               |
| PI60                              |             |                                         |               |            |               |
| LCD Duty                          | DUT         | 4                                       | 3             |            |               |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4632BF

PRELIMINARY

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL           | ITEM                       | RATING                        | UNIT |
|------------------|----------------------------|-------------------------------|------|
| V <sub>DD</sub>  | Supply Voltage             | -0.3 to +7.0                  | V    |
| V <sub>IN</sub>  | Input Voltage              | -0.3 to V <sub>DD</sub> + 0.3 | V    |
| V <sub>OUT</sub> | Output Voltage             | -0.3 to V <sub>DD</sub> + 0.3 | V    |
| P <sub>D</sub>   | Power Dissipation          | 400                           | mW   |
| T <sub>sol</sub> | Soldering Temperature·Time | 260 (10 SEC)                  | °C   |
| T <sub>slg</sub> | Storage Temperature        | -55 to +125                   | °C   |
| T <sub>opr</sub> | Operating Temperature      | -20 to +70                    | °C   |

## ALLOWABLE OPERATING CONDITIONS

| SYMBOL           | ITEM                                                                         | RATING                   | UNIT |
|------------------|------------------------------------------------------------------------------|--------------------------|------|
| V <sub>DD</sub>  | Supply Voltage                                                               | 4 to 6                   | V    |
| T <sub>a</sub>   | Ambient Temperature                                                          | -20 to +70               | °C   |
| I <sub>OUT</sub> | Max. Output Current                                                          | ±3                       | mA   |
| f <sub>X</sub>   | X'tal Operating Frequency                                                    | 40 to 400                | kHz  |
| t <sub>CY</sub>  | Cycle Time                                                                   | 10 to 100                | μs   |
| V <sub>LCD</sub> | LCD Supply Voltage<br>(V <sub>LCD</sub> is with respect to V <sub>DD</sub> ) | -V <sub>DD</sub> to -2.7 | V    |

**DC CHARACTERISTICS (Ta = -20 to +70°C, V<sub>DD</sub> = 4 to 6V)**

| SYMBOL                               | PARAMETER                                                                   | TEST CONDITION                                                         | MIN.                  | (Note 1)<br>TYP. | MAX.                  | UNIT |
|--------------------------------------|-----------------------------------------------------------------------------|------------------------------------------------------------------------|-----------------------|------------------|-----------------------|------|
| V <sub>IH</sub>                      | Input High Voltage                                                          |                                                                        | V <sub>DD</sub> ×0.7  | -                | V <sub>DD</sub>       | V    |
| V <sub>IHS</sub>                     | Input High Voltage (Schmitt)                                                |                                                                        | V <sub>DD</sub> ×0.85 | -                | V <sub>DD</sub>       |      |
| V <sub>IHC</sub>                     | Input High Voltage (X <sub>IN</sub> Input)                                  |                                                                        | V <sub>DD</sub> ×0.75 | -                | V <sub>DD</sub>       |      |
| V <sub>IL</sub>                      | Input Low Voltage                                                           |                                                                        | 0                     | -                | V <sub>DD</sub> ×0.3  |      |
| V <sub>ILS</sub>                     | Input Low Voltage (Schmitt)                                                 |                                                                        | 0                     | -                | V <sub>DD</sub> ×0.15 |      |
| V <sub>ILC</sub>                     | Input Low Voltage (X <sub>IN</sub> Input)                                   |                                                                        | 0                     | -                | V <sub>DD</sub> ×0.25 |      |
| I <sub>IH</sub>                      | Input High Current                                                          | V <sub>DD</sub> =6V, V <sub>IN</sub> =6V                               | -                     | -                | 20                    |      |
| I <sub>IL</sub>                      | Input Low Current                                                           | V <sub>DD</sub> =6V, V <sub>IN</sub> =0V                               | -                     | -                | -20                   |      |
| R <sub>IN</sub>                      | Input Resistance (PI <sub>5</sub> )                                         | V <sub>DD</sub> =5V                                                    | 75                    | 150              | 350                   | kΩ   |
| V <sub>OH</sub>                      | Output High Voltage (Port)                                                  | V <sub>DD</sub> =5V, Output open                                       | 4.7                   | 4.9              | -                     | V    |
| V <sub>OL</sub>                      | Output Low Voltage (Port)                                                   | V <sub>DD</sub> =5V, Output open                                       | -                     | 0.1              | 0.3                   |      |
| I <sub>OH</sub>                      | Output High Current (P <sub>1</sub> )                                       | V <sub>DD</sub> =4.5V, V <sub>OH</sub> =2.4V                           | -0.7                  | -                | -                     |      |
| I <sub>OH2</sub>                     | Output High Current (P <sub>o</sub> , P <sub>2</sub> , P <sub>4</sub> , CK) | V <sub>DD</sub> =4.5V, V <sub>OH</sub> =2.4V                           | -0.35                 | -                | -                     |      |
| I <sub>OH3</sub>                     | Output High Current (P <sub>5</sub> , P <sub>6</sub> )                      | V <sub>DD</sub> =4.5V, V <sub>OH</sub> =2.4V                           | -0.15                 | -                | -                     |      |
| I <sub>OL</sub>                      | Output Low Current (P <sub>1</sub> )                                        | V <sub>DD</sub> =4.5V, V <sub>OL</sub> =0.45V                          | 1.6                   | -                | -                     |      |
| I <sub>OL2</sub>                     | Output Low Current (P <sub>o</sub> , P <sub>2</sub> , P <sub>4</sub> , CK)  | V <sub>DD</sub> =4.5V, V <sub>OL</sub> =0.45V                          | 0.8                   | -                | -                     |      |
| I <sub>OL3</sub>                     | Output Low Current (P <sub>5</sub> , P <sub>6</sub> )                       | V <sub>DD</sub> =4.5V, V <sub>OL</sub> =0.45V                          | 0.4                   | -                | -                     |      |
| R <sub>OS3</sub> , R <sub>OS0</sub>  | Output Impedance (SEG)                                                      | V <sub>DD</sub> =5V, V <sub>DD</sub> -V <sub>LCD</sub> =3V<br>(Note 5) | -                     | 2                | T.B.D                 | kΩ   |
| R <sub>OC3</sub> , R <sub>OC0</sub>  | Output Impedance (COM)                                                      | V <sub>OUT</sub> =V <sub>LCD</sub> +0.5V/<br>V <sub>DD</sub> -0.5V     | -                     | 2                | T.B.D                 |      |
| R <sub>OS2</sub> , R <sub>OS1</sub>  | Output Impedance (SEG)                                                      | V <sub>DD</sub> =5V, V <sub>DD</sub> -V <sub>LCD</sub> =3V<br>(Note 5) | -                     | 20               | T.B.D                 |      |
| R <sub>OC2</sub> , R <sub>OC1</sub>  | Output Impedance (COM)                                                      | V <sub>OUT</sub> =3+0.5V/<br>4-0.5V                                    | -                     | 20               | T.B.D                 |      |
| V <sub>OS1</sub><br>V <sub>OS2</sub> | Output Intermediate Voltage (SEG, COM)                                      | V <sub>DD</sub> =5V, V <sub>DD</sub> -V <sub>LCD</sub> =3V             | 3 - 0.2<br>4 - 0.2    | 3<br>4           | 3 + 0.2<br>4 + 0.2    | V    |
| I <sub>DDO</sub>                     | V <sub>DD</sub> Supply Current in Normal Operation                          | (Note 4)<br>f <sub>x</sub> = 400 kHz                                   | -                     | 600              | T.B.D                 |      |
| I <sub>DDH</sub>                     | V <sub>DD</sub> Supply Current in Hold operation                            |                                                                        | -                     | 250              | T.B.D                 |      |

- Note 1) Typical values are at Ta=25°C and V<sub>DD</sub>=5V.  
 2) Output characteristic excludes X<sub>OUT</sub> terminal.  
 3) Output current at the time when other terminals than those to be tested are open.  
 4) Test conditions of current dissipation  
     V<sub>DD</sub> = 6V, V<sub>IN</sub> = V<sub>IH</sub>/V<sub>IL</sub> (all valid), PI<sub>5</sub> Open, CL = 50pF  
     X<sub>IN</sub> Input waveform



- 5) When supplying V<sub>LCD</sub> power, When switching input/output.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

PRELIMINARY

TCP4632BF

### OUTLINE DRAWINGS

Unit mm





INTEGRATEDCIRCUIT

TECHNICAL DATA

"C<sup>2</sup>MOS" DIGITAL INTEGRATED CIRCUIT

TCP4600AC

SILICON MONOLITHIC

CMOS 4-BIT SINGLE CHIP MICROCOMPUTER

#### GENERAL DESCRIPTION

TCP4600AC is a system development evaluator of TLCS-46A family, and makes it possible to configure a system equal to TCP4620AP/TCP4630AP by program memory (ROM) and the external circuits relative to mask options.

Since this technical data mainly makes mention of the function of an evaluator of TCP4600AC, it is recommended that instruction and detail be referred to the technical data of TCP4620AP/TCP4630AP.

#### FEATURES

- o External ROM 4K x 8 Max.
- o Internal RAM 160 x 4
- o Single 5V Supply
  - Wide Operating Range: 4V to 6V
- o Wide Operating Temperature Range: -10°C to 70°C
- o Terminals for System Debugging
  - ° External-Circuit Terminal for Realization of all the Mask Option of TLCS-46A

PIN CONNECTIONS (TOP VIEW)

|                    |    |    |                    |
|--------------------|----|----|--------------------|
| VDD                | 1  | 64 | P <sub>00</sub>    |
| P <sub>13</sub>    | 2  | 63 | P <sub>01</sub>    |
| P <sub>12</sub>    | 3  | 62 | P <sub>02</sub>    |
| P <sub>11</sub>    | 4  | 61 | P <sub>03</sub>    |
| P <sub>10</sub>    | 5  | 60 | RD/DI <sub>0</sub> |
| PC <sub>11</sub>   | 6  | 59 | RD/DI <sub>1</sub> |
| PC <sub>10</sub>   | 7  | 58 | RD/DI <sub>2</sub> |
| PC <sub>9</sub>    | 8  | 57 | RD/DI <sub>3</sub> |
| PC <sub>8</sub>    | 9  | 56 | RD <sub>4</sub>    |
| PC <sub>7</sub>    | 10 | 55 | RD <sub>5</sub>    |
| PC <sub>6</sub>    | 11 | 54 | RD <sub>6</sub>    |
| PC <sub>5</sub>    | 12 | 53 | RD <sub>7</sub>    |
| PC <sub>4</sub>    | 13 | 52 | R/H                |
| PC/DO <sub>3</sub> | 14 | 51 | INTH               |
| PC/DO <sub>2</sub> | 15 | 50 | MH                 |
| PC/DO <sub>1</sub> | 16 | 49 | RS                 |
| PC/DO <sub>0</sub> | 17 | 48 | SEL <sub>2</sub>   |
| PCH                | 18 | 47 | SEL <sub>3</sub>   |
| ST(D)              | 19 | 46 | SEL <sub>4</sub>   |
| WEN                | 20 | 45 | SEL <sub>5</sub>   |
| PO <sub>67</sub>   | 21 | 44 | SEL <sub>6</sub>   |
| PO <sub>66</sub>   | 22 | 43 | SEL <sub>7</sub>   |
| PO <sub>65</sub>   | 23 | 42 | INT                |
| PO <sub>64</sub>   | 24 | 41 | RESET              |
| PO <sub>63</sub>   | 25 | 40 | VS                 |
| PO <sub>62</sub>   | 26 | 39 | φ                  |
| PO <sub>61</sub>   | 27 | 38 | CP                 |
| PO <sub>60</sub>   | 28 | 37 | ST(H)              |
| PO <sub>54</sub>   | 29 | 36 | HOLD               |
| PO <sub>53</sub>   | 30 | 35 | RSTH               |
| PO <sub>52</sub>   | 31 | 34 | PO <sub>50</sub>   |
| PO <sub>51</sub>   | 32 | 33 | GND                |

## PIN NAMES &amp; PIN DESCRIPTION

| Pin Name                                        | Input/Output | Function                                                                                                                 |
|-------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------|
| P <sub>03</sub> - P <sub>00</sub>               | Input/Output | 4-bit general purpose I/O port<br>State of input/output is designated by WEN terminal input. (common to TLCS-46A family) |
| P <sub>13</sub> - P <sub>10</sub>               | Output       | 4-bit general purpose output port (common to TLCS-46A family)                                                            |
| P <sub>054</sub> - P <sub>050</sub>             | Output       | 5-digit output port for display Content of built-in decode matrix is already designated (common to TLCS-46A family)      |
| P <sub>067</sub> - P <sub>060</sub>             | Output       | 8-segment output port for display Built-in PLA is already designated (common to TLCS-46A family)                         |
| <u>RESET</u>                                    | Input        | Initialize Signal Input (without Schmitt circuit) (common to TLCS-46A family)                                            |
| <u>INT</u>                                      | Input        | Interrupt request signal input (without Schmitt circuit) (common to TLCS-46A family)                                     |
| PC <sub>11</sub> - PC <sub>4</sub>              | Output       | The higher order 8-bit address output to external ROM                                                                    |
| PC/DO <sub>3</sub> - PC/DO <sub>0</sub>         | Output       | The lower order 4-bit address output to external ROM/Port data output                                                    |
| RD <sub>7</sub> - RD <sub>4</sub>               | Input        | The higher order 4-bit data input from external ROM                                                                      |
| RD/DI <sub>3</sub> - RD/DL <sub>0</sub>         | Input        | The lower order 4-bit data input from external ROM/Input port                                                            |
| <u>SEL<sub>7</sub></u> - <u>SEL<sub>2</sub></u> | Output       | Selection signal output for external port register and input port                                                        |

Toshiba

東芝

## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4600AC

| Pin Name                      | Input/Output | Function                                                        |
|-------------------------------|--------------|-----------------------------------------------------------------|
| WEN                           | Input        | Designate signal input for Input/Output of port 0               |
| HOLD                          | Input        | Hold operation control signal input                             |
| <u>RSTH</u>                   | Input        | Restart control signal input at time of hold operation          |
| ST(D)                         | Output       | D flag output                                                   |
| ST(H)                         | Output       | H flag output                                                   |
| CP                            | Input        | Internal basic clock input                                      |
| $\bar{\phi}_S$ , $\bar{\phi}$ | Output       | Basic timing output                                             |
| RS                            | Output       | Internal reset signal output                                    |
| MH                            | Input        | Monitor hold control signal input<br>(for system debug)         |
| R/H                           | Output       | Run/Hold status signal output<br>(for system debug)             |
| PCH                           | Input        | Program counter hold control signal input<br>(for system debug) |
| INTH                          | Input        | Interrupt hold control signal input<br>(for system debug)       |
| V <sub>DD</sub>               |              | Power supply                                                    |
| GND                           |              | GND                                                             |

**BLOCK DIAGRAM**


## FUNCTIONAL DESCRIPTION

TCP4600AC is a system development evaluator which is used for developing TLCS-46A application system (program) and for confirming its operation. This makes it possible to form a configuration equal to TCP4620AP/TCP4630AP by program memory (hereinafter called ROM) and the external circuits relative to mask options.

### 1. Connection of Program Memory

Program counter (PC, 12 bits) output is used as address signal of external ROM (maximum capacity is 4096 words x 8 bits). Since the lower order 4 bits of address signal is multiplexed with the output of port data, it is necessary that they are externally separated.

The data (8 bits) read out of ROM is read as instruction code in TCP4600AC. At this time, the data line of the lower order 4 bits is also used as port input data, so that it is necessary that data line is externally multiplexed.



## 2. Schmitt Circuit

Each terminal of RESET, INT, and PI60 of TCP4620AP/TC4630AP are input terminals with Schmitt circuit. However, since no Schmitt circuit is contained in TCP4600AC, the circuit must be externally configured.

It is necessary to add shift register for timing shaping to PI60 terminal.



## 3. Oscillator and Divider

The mask options, which relate to the oscillator and divider of TCP4620AP/TCP4630AP, differ according to an oscillator to be used. For TCP4600AP these mask options are composed of external circuits.

## (1) Oscillator

The basic clock (CP) of TCP4600AC is externally supplied. In this case, the divider forming the basic clock as well as the oscillation circuits of the oscillator to be used are externally composed, and the output of a divider suitable for oscillation frequency is supplied, as a basic clock, to the CP terminal of TCP4600AC.

Since TCP4600AC is not provided with the CK terminal for external timing, a signal equivalent to the CK terminal must be also composed of external circuit.

While the power is being supplied to the evaluator chip, the clock must be being supplied to the CP terminal at all times.



(Note) " " means that either is connected.  
(So with the following figures.)

## (2) Divider

An example of circuit configuration around a divider is shown as follows:



The portion of is required only when 100K Xtal is designated by mask options of mass production chip, and further 14-stage divider (2) is used as a resettable divider of count value "12500".

#### 4. Input Port and Output Port

The input port and output port in TCP4620AP/TCP4630AP have plentiful mask options. In TCP4600AC, such mask options are composed of external circuits.

##### (1) Input port

The data of input port is input from RD/DI terminal.

When the data of input port (port No. i) is input to RD/DI terminal during the period of time when the equation,

$$SEL_i \cdot \phi_s = 1 \quad (i : \text{port No.}),$$

holds, TCP4600AC starts reading it as input port data.

##### (2) Output port

The data of output port is output from PC/DO terminal.

Since TCP4600AC outputs the data of output port (port No. i) from PC/DO terminal during the period of time when the equation,

$$SEL_i \cdot \phi = 1 \quad (i : \text{port No.}),$$

hold, this data is written in the externally installed register.

Further, since at time of system reset an internal initialize signal is output from RS terminal, it is necessary to clear (all "0") the port register by use of this signal and to initialize it.





## (3) Port 0

Port 0 is a port that can make switching of input/output by program (D flag of ST), and can be designated to a port exclusively used for output by mask options.

In TCP4600AC, the mask option of this port can be realized by use of each terminal of WEN and ST(D).

WEN terminal is an input line that defines whether port 0 is placed in an output mode or an input mode. When the terminal is at "1" level, it places port 0 in an output mode and when it is at "0" level, it places port 0 in an input mode.

A state of D flag of status register is output from ST (D) terminal.

- o When input and output are switched by use of program,  
WEN = ST(D)  
WEN terminal is externally connected to ST(D) terminal.
- o When port 0 is used as port exclusively for output,  
WEN = "1"  
WEN terminal is fixed to "1" level.

## (4) Port 2 and Port 4

Port 2 and Port 4 are input/output selectable ports by use of mask options.

When these ports are used as input ports, the external input data is input to RD/DI terminal during the period when each of the following equations holds:  $SEL_2 \cdot \phi_S = 1$  and  $SEL_4 \cdot \phi_S = 1$ .

On the other hand, when these ports are used as output ports, output data are output to PC/DO terminal during the period when each of the following equations holds:

$$\text{SEL}_2 \cdot \phi = 1 \text{ and } \text{SEL}_4 \cdot \phi = 1.$$

Therefore, this data is written in the register externally installed, and is output to the outside through a buffer. And, at the time when the equations, such as  $\text{SEL}_2 \cdot \phi_s = 1$  and  $\text{SEL}_4 \cdot \phi_s = 1$ , hold, the outputs of respective registers are input to RD/DI terminal. The externally installed register must be cleared (all "0") by the internal initialize signal from RS terminal.



## (5) Port 3

Port 3 is I/O port exclusively used for TCP4600AC. The function of port 3 is the same as the function of other ports.

This port is designated as register No. "3" even in case where it is used as either of input port or output port.

## (6) Output port 5 and output port 6 (output port 7)

For TCP4600AC, each output terminal of P05 and P06 is available as output for display. However, when it is used as general output port or when it is used after changing the contents of decode matrix or PLA, it is configured by external circuit.

The contents of decode matrix and PLA built in TCP4600AC are as follows:

Contents of Decode Matrix

| Write Data   |      | F-6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------|------|-----|---|---|---|---|---|---|
| Output State | P054 | 0   | 1 | 0 | 0 | 0 | 0 | 0 |
|              | P053 | 0   | 0 | 1 | 0 | 0 | 0 | 0 |
|              | P052 | 0   | 0 | 0 | 1 | 0 | 0 | 0 |
|              | P051 | 0   | 0 | 0 | 0 | 1 | 0 | 0 |
|              | P050 | 0   | 0 | 0 | 0 | 0 | 1 | 0 |

PLA

PLA can be expressed as memory of 16 words x 8 bits.

The 4-bit write data for port 6 is the address of PLA, and the 8-bit data read out from PLA comes to the output data of the output port.

When the data of 8 bits output at this time is expressed by hexadecimal 2 digits, PLA built-in TCP4600AC is as follows:

| Address | Data | Form of Character |
|---------|------|-------------------|
| 0       | FC   | □                 |
| 1       | 60   | /                 |
| 2       | DA   | 2                 |
| 3       | F2   | 3                 |
| 4       | 66   | 4                 |
| 5       | B6   | 5                 |
| 6       | BE   | 6                 |
| 7       | E4   | 7                 |
| 8       | FE   | 8                 |
| 9       | F6   | 9                 |
| A       | FD   | □.                |
| B       | 00   | (Blank)           |
| C       | 02   | -                 |
| D       | CE   | P                 |
| E       | 9E   | E                 |
| F       | 8E   | F                 |



When the built-in decode matrix and PLA are used changing their contents or are used as general output ports, they are externally configured by use of data output PC/DO, select signals  $\overline{SEL}_5$ ,  $\overline{SEL}_6$  and  $\overline{SEL}_7$  and timing signal  $\overline{\phi}$ .



Output Timing of P05, P06 (P07)



## 5. Hold Operation

TCP4620AP/TCP4630AP is provided with hold function. In TCP4600AC, this function is configured by each terminal of HOLD,  $\overline{\text{RSTH}}$  and ST(H), and the signal of C<sub>3</sub> which is MSB of counter buffer input configured by external circuits. (For C<sub>3</sub>, refer to the figure of divider.)

In case hold operation is performed:

HOLD = ST(H) : Designation of hold operation application

$\overline{\text{RSTH}} = \text{C}_3$  : Designation of hold operation release signal

Each terminal of HOLD and ST(H) is externally connected.

C<sub>3</sub> signal that is MSB of counter buffer is input to  $\overline{\text{RSTH}}$  terminal.

In case hold operation is not performed:

HOLD = "0" : Designation of no use of hold operation

$\overline{\text{RSTH}} = "0"$  : Designation of no use of hold operation

Each terminal of HOLD and  $\overline{\text{RSTH}}$  is fixed to the "0" level.

## CONTROL TERMINALS FOR DEBUG

There are some functions and terminals to make easy the development of TLCS-46A application system (program).

### (1) MH terminal (Monitor hold control input)

Monitor hold function stops the operation of TCP4600AC by unit of execution instruction.



The operation stops after completion of current execution instruction by inputting "1" level into MH terminal. However, during "1" period of Y register flag (EYR = 1), the operation does not stop. When the system enters into the interrupt service routine, if stop request is made, the system stops after having jumped to the interrupt service routine.

In the stop state, program counter output the next address. Restart is made by inputting "0" level into MH terminal, and the first cycle makes instruction fetch and at the same time executes NOP instruction internally.

(2) R/H terminal (Run/Hold status output)

Run/Hold monitor function is the response signal of monitor hold function. During stop of operation by monitor hold function, "0" level is output from R/H terminal (which is reset by the instruction cycle just short of stopping by MH signal), and during normal operation "1" level is output from R/H terminal.

(3) PCH terminal (Program counter hold control input)

Program counter hold function holds the previous state without updating the value of program counter. This function is operated by inputting "1" level into PCH terminal.

(4) INTH terminal (Interrupt hold control input)

Interrupt hold function is a function to make interrupt request waiting. Even if interrupt latch is set by inputting "1" level into INTH terminal, jump to interrupt routine is not performed. In this case, interrupt request is kept waiting until "0" level is input into INTH terminal.

Toshiba

東芝

## INTEGRATED CIRCUIT

## TECHNICAL DATA

TCP4600AC

## ELECTRICAL CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL    | ITEM                         | RATING                 |
|-----------|------------------------------|------------------------|
| $V_{DD}$  | Supply Voltage               | -0.3V to +7.0V         |
| $V_{IN}$  | Input Voltage                | -0.3V to $V_{DD}+0.3V$ |
| $V_{OUT}$ | Output Volatage              | -0.3V to $V_{DD}+0.3V$ |
| $P_D$     | Power Dissipation            | 600 mW                 |
| $T_{sol}$ | Soldering Temperature & Time | 260°C (10 SEC)         |
| $T_{stg}$ | Storage Temperature          | -55°C to +125°C        |
| $T_{opr}$ | Operating Temperature        | -10°C to +70°C         |

## ALLOWABLE OPERATING CONDITIONS

| SYMBOL   | PARAMETER             | RATING                         |
|----------|-----------------------|--------------------------------|
| $T_a$    | Ambient Temperature   | -10°C to +70°C                 |
| $V_{DD}$ | Supply Voltage        | 4V to 6V                       |
| $V_{OH}$ | Output High Voltage   | Min. $V_{DD}-3.5V (\geq 1.5V)$ |
| $V_{OL}$ | Output Low Voltage    | Max. 3V                        |
| fcp      | Basic Clock Frequency | 20KHz to 200KHz                |

DC CHARACTERISTICS ( $T_a=-10^{\circ}\text{C}$  to  $70^{\circ}\text{C}$ ,  $V_{DD}=4\text{V}$  to  $6\text{V}$ )

| SYMBOL    | PARAMETER                             | TEST CONDITIONS                                                   | MIN.                | TYP.<br>(Note 1)     | MAX.                | UNIT          |
|-----------|---------------------------------------|-------------------------------------------------------------------|---------------------|----------------------|---------------------|---------------|
| $V_{IH}$  | Input High Voltage                    |                                                                   | $V_{DD} \times 0.7$ | $V_{DD} \times 0.55$ | $V_{DD}$            | V             |
| $V_{IL}$  | Input Low Voltage                     |                                                                   | 0                   | $V_{DD} \times 0.45$ | $V_{DD} \times 0.3$ |               |
| $I_{IH}$  | Input High Current                    | $V_{DD}=6\text{V}$ , $V_{IN}=6\text{V}$                           | -                   | -                    | 20                  | $\mu\text{A}$ |
| $I_{IL}$  | Input Low Current                     | $V_{DD}=6\text{V}$ , $V_{IN}=0\text{V}$                           | -                   | -                    | -20                 |               |
| $V_{OH}$  | Output High Voltage                   | $V_{DD}=5\text{V}$ , Output Open                                  | 4.7                 | 4.9                  | -                   | V             |
| $V_{OL}$  | Output Low Voltage                    | $V_{DD}=5\text{V}$ , Output Open                                  | -                   | 0.1                  | 0.3                 |               |
| $I_{OH}$  | Output High Current                   | $V_{DD}=4.5\text{V}$ ,                                            | -0.7                | -2                   | -                   |               |
| $I_{OHI}$ | Output High Current<br>(P05, P06)     | $V_{OH}=2.4\text{V}$<br>$V_{DD}=5\text{V}$ , $V_{OH}=4.2\text{V}$ | -2.5                | -6                   | -                   | $\text{mA}$   |
| $I_{OL}$  | Output Low Current                    | $V_{DD}=4.5\text{V}$ ,                                            | 1.6                 | 4                    | -                   |               |
| $I_{OL1}$ | Output Low Current<br>(P05, P06)      | $V_{DD}=4.5\text{V}$ , $V_{OL}=0.45\text{V}$                      | 3.2                 | 8                    | -                   |               |
| $I_{DDO}$ | Supply Current in<br>Normal Operation | $V_{DD}=6\text{V}$ , fcp=100KHz                                   | -                   | 150                  | 450                 | $\mu\text{A}$ |
| $I_{DDH}$ | Supply Current in<br>Hold Operation   | $V_{DD}=5.9\text{V}/Q1V$ (Note 2)                                 | -                   | 40                   | 120                 |               |

Note1: Typical values are at  $T_a=25^{\circ}\text{C}$  and  $V_{DD}=5\text{V}$ .

Note 2: CP input waveform at the time of V<sub>DD</sub> Supply Current



AC CHARACTERISTICS (Ta=-10°C to +70°C, V<sub>DD</sub>=4V to 6V)

| SYMBOL              | PARAMETER                   | TEST CONDITION                                    | MIN.                | TYP.<br>(NOTE 1) | MAX.                | UNIT |
|---------------------|-----------------------------|---------------------------------------------------|---------------------|------------------|---------------------|------|
| t <sub>CI</sub>     | Timing Signal Inhibit Time  | CL = 50 pF<br>( Note 2 )                          | 150                 | -                | 1500                | ns   |
| t <sub>AAD</sub>    | Address Delay Time          |                                                   | -                   | -                | 2000                | ns   |
| t <sub>AH1</sub>    | Address Hold Time           |                                                   | 80                  | -                | -                   | ns   |
| t <sub>AH2</sub>    | " "                         |                                                   | 200                 | -                | -                   | ns   |
| t <sub>RDD</sub>    | Data Delay Time             |                                                   | -                   | -                | 1000                | ns   |
| t <sub>RDH</sub>    | Data Hold Time              |                                                   | 80                  | -                | -                   | ns   |
| t <sub>SELD1</sub>  | SEL Delay Time (for Input)  |                                                   | -                   | -                | 1000                | ns   |
| t <sub>SELD2</sub>  | SEL Delay Time (for Output) |                                                   | 100                 | -                | 500                 | ns   |
| t <sub>SELH</sub>   | SEL Hold Time               |                                                   | 300                 | -                | -                   | ns   |
| t <sub>WDSS</sub>   | Write Data Set Up Time      |                                                   | 500                 | -                | -                   | ns   |
| t <sub>WDH</sub>    | Write Data Hold Time        |                                                   | 300                 | -                | -                   | ns   |
| t <sub>IDSS</sub>   | Read Data Set Up Time       |                                                   | 1000                | -                | -                   | ns   |
| t <sub>IDH</sub>    | Read Data Hold Time         |                                                   | 100                 | -                | -                   | ns   |
| t <sub>MHD</sub>    | MH Input Delay Time         |                                                   | -                   | -                | 500                 | ns   |
| t <sub>MHH</sub>    | MH Input Hold Time          |                                                   | 100                 | -                | -                   | ns   |
| t <sub>PCHD</sub>   | PCH Input Delay Time        |                                                   | -                   | -                | 500                 | ns   |
| t <sub>PCHH</sub>   | PCH Input Hold Time         |                                                   | 100                 | -                | -                   | ns   |
| t <sub>INTHD</sub>  | INTH Input Delay Time       |                                                   | -                   | -                | 500                 | ns   |
| t <sub>INTHH</sub>  | INTH Input Hold Time        |                                                   | 100                 | -                | -                   | ns   |
| t <sub>WCP</sub>    | CP Pulse Width              | V <sub>IN</sub> =V <sub>IH</sub> /V <sub>IL</sub> | 0.4/f <sub>cp</sub> | -                | 0.6/f <sub>cp</sub> | SEC  |
| t <sub>WRESET</sub> | RESET Pulse Width           |                                                   | 2 tcy               | -                | -                   | μs   |
| t <sub>WINT</sub>   | TNT Pulse Width             |                                                   | 2 tcy               | -                | -                   | μs   |

Note 1 : Typical values are at Ta=25°C and V<sub>DD</sub>=5V.

Note 2 : AC test condition



**TIMING WAVEFORMS**


## OUTLINE DRAWINGS

TCP4600AC

Unit in mm



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

Note 2: The lead pitch is 2.54mm, and all the leads are located within ±0.25mm from their theoretical positions with respect to No.1 and No. 64 leads.

Note 3: The metal on the side of the package is GND level.



## PRECAUTIONS FOR USE

## (1) Clock at time of power supplied

When TLCS-46A starts by RESET, clock must be always supplied. There is no problem when clock is obtained by externally mounting the oscillator of crystal, celamic or IFT by use of internal clock generator in TCP4620AP/TCP4630AP, but care should be exercised when clock is externally supplied or when TCP4600AC is used.

## (2) Control of I/O port

In port 0, Input/Output can be switched by program; therefore, care should be taken not to become driver short between the port and external circuit.

## (3) Current capacity of output port

Each of output port 5 and output port 6 has a large current capacity as port for display. However, if the output port is supplied with a large current exceeding its capacity, it may cause destruction or deterioration in character.

## (4) Handling of unused terminal

When an unused input terminal is left open, it may cause malfunction and increase in power dissipation; therefore, insure to connect the terminals to V<sub>DD</sub> or GND level. (It is the safest method to connect terminal via resistance.)

Further, insure to connect TEST terminal to GND because this terminal is installed for LSI testing.



## (5) Electrostatic destruction

In TLCS-46A series, the input circuit is provided with protective resistance and protective diode for preventing electrostatic destruction. However, the surge equivalent weight is small as compared with discrete resistance and diode; therefore, carry TLCS-46A series in a conductive container so as not to add the surge directly into the system, when required.

## (6) Latch-up phenomenon

When the voltage lower than GND or the voltage higher than VDD is applied to input terminal and output terminal, a phenomenon called latch-up characteristic of CMOS presents. This phenomenon may cause destruction and degradation of elements; therefore, care should be taken not to apply the voltage exceeding the maximum rating to the input terminal and output terminal.

# **4BIT SINGLE CHIP MICROCOMPUTER**

## **TLCS-47(NMOS/CMOS)**

### **ADVANCED INFORMATION**





# INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TOSHIBA MOS TYPE DIGITAL INTEGRATED CIRCUIT<sup>TM</sup>

TLCS-47

SILICON MONOLITHIC

PRELIMINARY

### 4-BIT SINGLE CHIP MICROCOMPUTER TLCS-47

#### GENERAL DESCRIPTION

The TLCS-47 is the high speed and high performance, 4-bit single chip microcomputer series designed for general purpose use.

The TLCS-47 has variously powerful functions in order to meet with the advanced and complicated applications, which will be made in near future. In addition, software compatible NMOS family (TLCS-47N) and CMOS family (TLCS-47C) are also provided.

#### FEATURES

- 4-bit, single chip microcomputer with built-in ROM, RAM, input/output port, divider, timer/counter, and serial port.
- Memory capacity
  - ROM : Max  $4,096 \times 8$  bits
  - RAM : Max  $256 \times 4$  bits
- Instruction execution time
  - NMOS family  $2\mu s$ (at 4MHz clock)
  - CMOS family  $4\mu s$ ( " )
- Efficient instruction set
  - 90 instructions
  - Software compatible in the series
- Subroutine nesting: Max. 15 levels
- 6 interrupts (External : 2, Internal : 4)  
Independently latched control and multiple interrupt control
- Input/Output (Standard)
  - Input 1 port 4 pins
  - Output (corresponding to PLA)  
                2 ports 8 pins
  - I/O 4 ports 16 pins
  - I/O (Note) 2 ports 7 pins
- Note : These I/O ports are also used for the interrupt input, timer/counter input, and serial port; therefore, it is programmably selectable for each application.
- PLA data conversion function (instruction) output of data to output port (8-bit)
- Data table look-up and table search function (instruction)  
Table can be set up in the whole ROM area .
- 12-bit timer/counter (2 channels)
- Serial port with 4-bit buffer
- 18-stage divider (with 4-stage prescaler)
- Built-in high output current terminals (NMOS family)  
Typ.  $20mA \times 8$  bits, LED direct drive is available.
- Built-in high breakdown voltage output terminals (CMOS version)  
Max. 42V breakdown voltage  
FL tube direct drive is available.
- Built-in LCD drive circuit (automatic display)(CMOS version)
  - LCD direct drive is available (1/4 duty LCD, Max. 12-digit display)
  - 1/4, 1/3, 1/2 duties or static LCD drive are programmably selectable.
- Stand-by operation (NMOS/CMOS)  
Battery back-up, battery operation and condenser back-up are available.
- On chip oscillator
- TTL/CMOS compatible
- +5V single power supply



## INTEGRATED CIRCUIT

TLCS-47

## TECHNICAL DATA

PRELIMINARY

## Configuration of TLCS-47 Series

| Family                                              |                                  | TLCS-47N                |                   |                                                                |                                                                                           |                     |  |  |
|-----------------------------------------------------|----------------------------------|-------------------------|-------------------|----------------------------------------------------------------|-------------------------------------------------------------------------------------------|---------------------|--|--|
| Item                                                | Unit                             | Name                    | TMP4740P          | TMP4720P                                                       | TMP4700C                                                                                  | TMP4799C            |  |  |
| ROM Capacity                                        | Bytes                            |                         | 4,096             | 2,048                                                          | (External)<br>4,096                                                                       | (External)<br>4,096 |  |  |
| RAM Capacity                                        | Words                            |                         | 256               | 128                                                            | 256                                                                                       | 256                 |  |  |
| Instruction Execution time                          | μs                               |                         |                   | 2                                                              |                                                                                           |                     |  |  |
| No. of instructions                                 |                                  |                         |                   | 90                                                             |                                                                                           |                     |  |  |
| Subroutine nesting                                  | Levels                           |                         | Max.              | 15                                                             |                                                                                           |                     |  |  |
| Interrupts                                          | External                         |                         |                   | 2                                                              |                                                                                           |                     |  |  |
|                                                     | Internal                         |                         |                   | 4 (Serial I/O, timer/counter overflow(2),<br>timer of divider) |                                                                                           |                     |  |  |
| Timer/counter                                       | Channels                         |                         |                   | 2                                                              |                                                                                           |                     |  |  |
|                                                     | Bit length                       | Bits                    |                   | 12                                                             | (Event counter, timer and pulse width<br>measurement mode is programmably<br>selectable.) |                     |  |  |
|                                                     | (Mode)                           |                         |                   |                                                                | (Event counter, timer and pulse width<br>measurement mode is programmably<br>selectable.) |                     |  |  |
| Serial port                                         | Bits                             |                         |                   | 4 (With buffer)                                                | (Receive/transmit mode is programmably<br>selectable.)                                    |                     |  |  |
|                                                     | (Mode)                           |                         |                   |                                                                | (External/internal, and leading/trailing<br>edge mode are programmably selectable.)       |                     |  |  |
|                                                     | (Clock)                          |                         |                   |                                                                | (External/internal, and leading/trailing<br>edge mode are programmably selectable.)       |                     |  |  |
| Divider                                             | Stage                            |                         | 18                | (With 4-stage prescaler)                                       |                                                                                           |                     |  |  |
| Input/Output Ports                                  | Input                            |                         | 4                 |                                                                |                                                                                           |                     |  |  |
|                                                     | Output (corresponding<br>to PLA) |                         | 8                 |                                                                |                                                                                           |                     |  |  |
|                                                     | I/O                              |                         | 16                |                                                                |                                                                                           |                     |  |  |
|                                                     | I/O (Combined use)               |                         | 7                 |                                                                |                                                                                           |                     |  |  |
|                                                     | Total                            |                         | 35                |                                                                |                                                                                           |                     |  |  |
| With built-in high output<br>current terminals      | Bits                             |                         | 8                 |                                                                |                                                                                           |                     |  |  |
| With built-in high break-<br>down voltage terminals |                                  |                         | —                 |                                                                |                                                                                           |                     |  |  |
| With built-in LCD driver                            |                                  |                         | —                 |                                                                |                                                                                           |                     |  |  |
| Memory Standby function                             |                                  |                         | YES               |                                                                |                                                                                           |                     |  |  |
| Hold function                                       |                                  |                         | —                 |                                                                |                                                                                           |                     |  |  |
| Clock oscillator                                    |                                  |                         | With built-in     |                                                                |                                                                                           |                     |  |  |
| Power supply                                        | V                                | + 5.0                   |                   |                                                                |                                                                                           |                     |  |  |
| Process                                             |                                  | Nch Si Gate E/D MOS LSI |                   |                                                                |                                                                                           |                     |  |  |
| Package                                             |                                  | DIP - 42                |                   | QIC-80                                                         | DIC-42                                                                                    |                     |  |  |
| Remark                                              |                                  |                         | Evaluator<br>Chip | Evaluator<br>Chip(Piggy<br>back type)                          |                                                                                           |                     |  |  |



## INTEGRATED CIRCUIT

TLCS-47

東芝

## TECHNICAL DATA

RELIMINARY

## Configuration of Series

| Series                                               |                                       | TLCS - 47                  |               |                                                                                     |           |                   |                            |                     |
|------------------------------------------------------|---------------------------------------|----------------------------|---------------|-------------------------------------------------------------------------------------|-----------|-------------------|----------------------------|---------------------|
| Family                                               |                                       | TLCS-47N                   |               | TLCS-47C                                                                            |           | Evaluator<br>chip |                            |                     |
| Item                                                 | Unit                                  | Name                       | TMP4740P      |                                                                                     | TMP47C40P | TMP47C20P         | TMP47C22F                  | TMP4700C            |
| ROM Capacity                                         | Bytes                                 |                            | 4,096         | 2,048                                                                               | 4,096     | 2,048             | 2,048                      | (External)<br>4,096 |
| RAM Capacity                                         | Words                                 |                            | 256           | 128                                                                                 | 256       | 128               | 192                        | 256                 |
| Instruction<br>Execution time                        | μs                                    |                            | 2             | 4                                                                                   |           |                   |                            | 2                   |
| No. of<br>instructions                               |                                       |                            | 90            |                                                                                     |           |                   |                            |                     |
| Subroutine<br>nesting                                | Levels                                |                            | Max. 15       |                                                                                     |           |                   |                            |                     |
| Inter-<br>rupts                                      | External                              |                            | 2             |                                                                                     |           |                   |                            |                     |
|                                                      | Internal                              |                            | 4             | (Serial I/O, timer/counter overflow(2), timer of divider)                           |           |                   |                            |                     |
| Timer/counter                                        | Channels                              |                            | 2             |                                                                                     |           |                   |                            |                     |
| (Bit length)                                         | Bits                                  |                            | 12            | (Event counter, timer and pulse width measurement mode is programmably selectable.) |           |                   |                            |                     |
| (Mode)                                               |                                       |                            |               |                                                                                     |           |                   |                            |                     |
| Serial port                                          | Bits                                  |                            | 4             | (With buffer)<br>(Receive/transmit mode is programmably selectable.)                |           |                   |                            |                     |
| (Mode)                                               |                                       |                            |               |                                                                                     |           |                   |                            |                     |
| (Clock)                                              |                                       |                            |               | (External/internal, and leading/trailing edge mode are programmably selectable.)    |           |                   |                            |                     |
| Divider                                              | Stage                                 |                            | 18            | (With 4-stage prescaler)                                                            |           |                   |                            |                     |
| Input/<br>Output<br>Ports                            | Input                                 |                            | 4             |                                                                                     |           | 4                 | 4                          |                     |
|                                                      | Output (cor-<br>responding to<br>PLA) |                            | 8             |                                                                                     |           | 0                 | 8                          |                     |
|                                                      | I/O                                   |                            | 16            |                                                                                     |           | 16                | 16                         |                     |
|                                                      | I/O                                   |                            | 7             |                                                                                     |           | 7                 | 7                          |                     |
|                                                      | Total                                 |                            | 35            |                                                                                     |           | 27                | 35                         |                     |
| With built-in<br>high output cur-<br>rent terminals  |                                       |                            | YES           |                                                                                     |           |                   | YES                        |                     |
| With built-in<br>high breakdown<br>voltage terminals |                                       |                            |               | YES                                                                                 |           |                   |                            |                     |
| With built-in<br>LCD driver                          |                                       |                            |               |                                                                                     | YES       |                   |                            |                     |
| Memory Standby<br>function                           |                                       |                            | YES           |                                                                                     |           |                   | YES                        |                     |
| Hold function                                        |                                       |                            |               | YES                                                                                 |           | YES               | (YES)                      |                     |
| Clock oscillator                                     |                                       |                            | With built-in |                                                                                     |           |                   |                            |                     |
| Power supply                                         | V                                     |                            | + 5.0         |                                                                                     |           |                   |                            |                     |
| Process                                              |                                       | Nch Si Gate<br>E/D MOS LSI |               | Si Gate C2MOS LSI                                                                   |           |                   | Nch Si Gate<br>E/D MOS LSI |                     |
| Package                                              |                                       | DIP - 42                   |               |                                                                                     | FP - 67   |                   | QIC - 80                   |                     |



# **TLCS-47(N)**

- **TMP 4740P**
- **TMP 4720P**
- **TMP 4700C**
- **TMP 4799C**





# INTEGRATED CIRCUIT

## TECHNICAL DATA

TOSHIBA MOS TYPE DIGITAL INTEGRATED CIRCUIT

TMP4740P TMP4720P

SILICON MONOLITHIC

N-CHANNEL SILICON GATE DEPRESSION LOAD

PRELIMINARY

NMOS 4-BIT SINGLE CHIP MICROCOMPUTER (TLCS-47N)

TMP4740P, TMP4720P

### GENERAL DESCRIPTION

The TLCS-47 is the high speed and high performance, 4-bit single chip microcomputer series designed for the general purpose use.

The TLCS-47 has variously powerful functions in order to meet with the advanced and complicated applications, which will be made in near future.

In addition, software compatible NMOS family (TLCS-47N) and CMOS family (TLCS-47C) are also provided.

The TMP4740P and TMP4720P are the standard chips for the TLCS-47N. These chips are similar to each other, except memory capacity. The TMP4700C is an evaluator chip used for the system development.

| Part No. | ROM (Bit)                          | RAM (Bit) |
|----------|------------------------------------|-----------|
| TMP4740P | 4,096 × 8                          | 256 × 4   |
| TMP4720P | 2,048 × 8                          | 128 × 4   |
| TMP4700C | Externally provided<br>(4,096 × 8) | 256 × 4   |



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

**PRELIMINARY**

### FEATURES

- 4-bit single chip microcomputer with built-in ROM, RAM, input/output port, divider, timer/counter, and serial port.
- Instruction execution time : 2  $\mu$ s (at 4 MHz clock)
- Effective instruction set  
90 instructions, Software compatible in the series
- Subroutine nesting : Maximum 15 levels
- 6 interrupts (External : 2, Internal : 4)  
Independently latched control and multiple interrupt control
- Input/Output port (35 pins)

|                               |         |         |
|-------------------------------|---------|---------|
| Input                         | 1 port  | 4 pins  |
| Output (corresponding to PLA) | 2 ports | 8 pins  |
| I/O                           | 4 ports | 16 pins |
| I/O (Note)                    | 2 ports | 7 pins  |
- Note : These I/O ports are also used for the interrupt input, timer/counter input, and serial port; therefore, it is programmably selectable for each application.
- PLA data converting function (Instruction)  
Output of data to output port (8-bit)
- Table look-up and table search function (Instruction)  
Table can be set up in the whole ROM area.
- 12-bit timer/counter (2 channels)  
Event counter, timer, and pulse width measurement mode is programmably selectable.
- Serial port with 4-bit buffer  
Receive/Transfer mode is programmably selectable.  
External/Internal clock and Leading/Trailing edge mode are programmably selectable.
- 18-stage divider (with 4-stage prescaler)  
Frequency applied for timer interrupt of divider is programmably selectable.
- High output current (Output ports)  
TYP. 20mA  $\times$  8 bits, LED direct drive is available.
- Memory stand-by function : Battery backup is available.
- On chip oscillator
- TTL/CMOS Compatible
- +5V single power supply
- 42-pin DIL plastic package
- N-channel Si gate E/D MOS LSI



# INTEGRATED CIRCUIT



## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

### PIN CONNECTIONS (TOP VIEW)

|                 |    |    |                                 |
|-----------------|----|----|---------------------------------|
| R <sub>40</sub> | 1  | 42 | V <sub>DD</sub>                 |
| R <sub>41</sub> | 2  | 41 | R <sub>82</sub> ( <u>SCK</u> )  |
| R <sub>43</sub> | 3  | 40 | R <sub>91</sub> ( <u>SO</u> )   |
| R <sub>47</sub> | 4  | 39 | R <sub>90</sub> ( <u>SI</u> )   |
| R <sub>50</sub> | 5  | 38 | R <sub>83</sub> ( <u>T1</u> )   |
| R <sub>51</sub> | 6  | 37 | R <sub>82</sub> ( <u>INT1</u> ) |
| R <sub>52</sub> | 7  | 36 | R <sub>81</sub> ( <u>T2</u> )   |
| R <sub>53</sub> | 8  | 35 | R <sub>91</sub> ( <u>INT2</u> ) |
| R <sub>63</sub> | 9  | 34 | V <sub>HH</sub>                 |
| R <sub>61</sub> | 10 | 33 | RESET                           |
| R <sub>62</sub> | 11 | 32 | X <sub>OUT</sub>                |
| R <sub>63</sub> | 12 | 31 | X <sub>IN</sub>                 |
| R <sub>70</sub> | 13 | 30 | TEST                            |
| R <sub>71</sub> | 14 | 29 | K <sub>23</sub>                 |
| R <sub>72</sub> | 15 | 28 | K <sub>02</sub>                 |
| R <sub>73</sub> | 16 | 27 | K <sub>01</sub>                 |
| P <sub>13</sub> | 17 | 26 | K <sub>02</sub>                 |
| P <sub>14</sub> | 18 | 25 | P <sub>23</sub>                 |
| P <sub>12</sub> | 19 | 24 | P <sub>02</sub>                 |
| P <sub>13</sub> | 20 | 23 | P <sub>01</sub>                 |
| V <sub>SS</sub> | 21 | 22 | P <sub>02</sub>                 |

### PIN NAMES AND PIN DESCRIPTION

| Pin Name                           | No.of pins | Input/Output  | Function                                |
|------------------------------------|------------|---------------|-----------------------------------------|
| K <sub>03</sub> ~ K <sub>00</sub>  | 4          | Input         | Input port                              |
| P <sub>13</sub> ~ P <sub>10</sub>  | 4          | Output        | Output port (Corresponding to PLA)      |
| P <sub>23</sub> ~ P <sub>20</sub>  | 4          | Output        | " ( " " )                               |
| R <sub>43</sub> ~ R <sub>40</sub>  | 4          | I/O           | I/O port                                |
| R <sub>53</sub> ~ R <sub>50</sub>  | 4          | I/O           | "                                       |
| R <sub>63</sub> ~ R <sub>60</sub>  | 4          | I/O           | "                                       |
| R <sub>73</sub> ~ R <sub>70</sub>  | 4          | I/O           | "                                       |
| R <sub>83</sub> (T1)               | 1          | I/O           | I/O port or timer/counter input         |
| R <sub>82</sub> ( <u>INT1</u> )    | 1          | I/O           | I/O port or interrupt input             |
| R <sub>81</sub> (T2)               | 1          | I/O           | I/O port or timer/counter input         |
| R <sub>80</sub> ( <u>INT2</u> )    | 1          | I/O           | I/O port or interrupt input             |
| R <sub>92</sub> ( <u>SCK</u> )     | 1          | I/O           | I/O port or shift clock for serial port |
| R <sub>91</sub> ( <u>SO</u> )      | 1          | I/O           | I/O port or serial output               |
| R <sub>90</sub> ( <u>SI</u> )      | 1          | I/O           | I/O port or serial input                |
| X <sub>IN</sub> , X <sub>OUT</sub> | 2          | Input, Output | Resonator connection terminals          |
| RESET                              | 1          | Input         | Initialize signal input                 |
| TEST                               | 1          | Input         | (Low level is input.)                   |
| V <sub>DD</sub>                    | 1          | Power supply  | +5V                                     |
| V <sub>HH</sub>                    | 1          | Power supply  | +5V (Memory power supply)               |
| V <sub>SS</sub>                    | 1          | Power supply  | 0V                                      |

## TECHNICAL DATA

## BLOCK DIAGRAM



## BLOCK NAMES AND DESCRIPTION

| Block Name                        | Function                                                                                                |
|-----------------------------------|---------------------------------------------------------------------------------------------------------|
| PC                                | Program counter (12 bits)                                                                               |
| ROM                               | Program memory (including fixed data)                                                                   |
| IR, decoder                       | Instruction register, Decoder                                                                           |
| HR, LR                            | H register (page assignment of RAM), L register (address assignment in RAM page), (each 4-bit register) |
| RAA                               | RAM address buffer register (8 bits)                                                                    |
| RAM                               | Data memory                                                                                             |
| STACK                             | Save area of program counter and flags (RAM area)                                                       |
| SPW                               | Stack pointer word (RAM area)                                                                           |
| DC, data table                    | Data counter (12 bits, RAM area), Data table (ROM area).                                                |
| AX, AY                            | Temporary register of ALU input                                                                         |
| ALU                               | Arithmetic and logic unit                                                                               |
| AC                                | Accumulator                                                                                             |
| FLAG (CF, ZF, SF, GF)             | Flags                                                                                                   |
| K, P, R                           | Ports                                                                                                   |
| INTR Control                      | Interrupt control (EIF: Enable interrupt master F/F, EIR: Enable interrupt register)                    |
| FD                                | Frequency divider (4-stage prescaler + 18 stages)                                                       |
| TC <sub>1</sub> , TC <sub>2</sub> | 12-bit timer/counter 2 channels (RAM area)                                                              |
| TC control                        | Timer/counter control                                                                                   |
| SIO control                       | Serial port control                                                                                     |
| SYS control                       | Generation of various internal control signals                                                          |
| CG, TG                            | Clock generator, Timing generator                                                                       |



# INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

### FUNCTIONAL DESCRIPTION

#### 1. System Configuration

1. Program Counter (PC)
2. Program Memory (ROM)
3. H Register (HR), L Register (LR), RAM Address Buffer Register (RAA)
4. Data Memory (RAM)
  - (1) Stack (STACK)
  - (2) Stack Pointer Word (SPW)
  - (3) Data Counter (DC)
5. ALU, Accumulator (AC)
6. Flags (FLAC)
7. Ports (PORT)
8. Interrupt Control Circuit (INTR)
9. Frequency Divider (FD)
10. Timer/Counter (TC<sub>1</sub>, TC<sub>2</sub>)
11. Serial Port (SIO)

Concerning the above component parts, the configuration and functions of hardwares are described :

Hexadecimal notation is used for the description, charts, and tables in order to indicate the address and the like, without assigning identification symbols as far as it does not give rise to confusion.

The following names and symbols are used unconsciously.

- (a) CPU      Control Processing Unit except for the built-in peripheral circuitry, such as interrupt control circuit, timer/counter, and serial port.
- (b) CP      Clock pulse generated in the clock oscillator.  
It is called the "basic clock" or merely "clock".
- (c) fc      Indicates the frequency of the clock oscillator, namely, the frequency of the basic clock.
- (d) MSB/LSB      Indicates Most/Least Significant Bit.
- (e) F/F      Indicates Flip/Flop.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

**PRELIMINARY**

### 1.1 Program Counter (PC)

It is a 12-bit binary counter, and the contents of the program counter indicate the address of program memory in which the next instruction to be executed is stored.

The program counter generally gains increment at every instruction fetch by the number of bytes assigned to the instruction. However, when executing the branch and subroutine instructions or receiving the interrupt, the values specified by these instructions and operation are set.

Value "0" is specified by initializing the program counter.

The page structure of program memory is made with 64 words per page. The TMP4740P has 64 pages and the TMP4720P 32 pages.

At the execution of (BSS a) instruction, the value assigned by the instruction is set in the lower 6 bits of the program counter when the branch condition is met. That is, the (BSS a) instruction is used as a branch or jump instruction within a page. If the (BSS a) instruction is stored in the last address of the page, the value in the higher 6 bits of the program counter indicates that the branch or jump instruction to the next page is executed.

At the execution of (CALL a) instruction, the value specified by the instruction is set in the program counter after the previous contents of the program counter has been saved in the stack. Since 11 bits are of the address bit length which can be assigned by the instruction, the call address of subroutine should be in the range of addresses 000 - 7FF.

| MSB              |                  |                 |                 |                 |                 |                 |                 | LSB             |                 |                 |                 |
|------------------|------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| PC <sub>H</sub>  |                  |                 |                 | PC <sub>M</sub> |                 |                 |                 | PC <sub>L</sub> |                 |                 |                 |
| PC <sub>11</sub> | PC <sub>10</sub> | PC <sub>9</sub> | PC <sub>8</sub> | PC <sub>7</sub> | PC <sub>6</sub> | PC <sub>5</sub> | PC <sub>4</sub> | PC <sub>3</sub> | PC <sub>2</sub> | PC <sub>1</sub> | PC <sub>0</sub> |

Page assignment      Address assignment in page

## (a) Configuration of Program Counter



## (b) Configuration of ROM

(Page) (Address in page)      ROM      (Execution flow)



(c) Special example of branch caused by (BSS a) instruction.

Fig.1.1.1 Program Counter and Program Memory (ROM)



### 1.2 Program Memory (ROM)

Processing programs and fixed data are stored in the program memory. The next instruction to be executed is read out from the address indicated by the contents of the program counter.

The fixed data stored in the program memory can be read by using the ROM data referring instruction or the PLA referring instruction. The ROM data referring instruction reads out the higher or lower 4-bit data of the fixed data stored in the address decided by the data counter [(LDH A, @DC+) and (LDL A, @DC) instruction respectively], and stores the data in the accumulator. The PLA referring instruction (OUTB @HL) reads out the fixed data (8-bit) stored in the address decided by the contents of the data memory indicated by the contents of H and L registers as well as contents of the carry flag, and outputs the data to output ports (P2 · P1).

Addresses are individually assigned to the program memory and data memory, so that the fixed data in the ROM area cannot be directly read out by the address of the data memory.

#### Specific Addresses of Program Memory

The following addresses of the program memory are used for specific purposes. When not used for these purposes, the specific addresses can be used to store the processing programs and fixed data.



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Specific Address                     | Specific Purposes                     |
|--------------------------------------|---------------------------------------|
| 000<br>(001)                         | Start address by initialization       |
| 002<br>(003)                         | INT1 Interrupt vector address         |
| 004<br>(005)                         | ISIO Interrupt vector address         |
| 006<br>(007)                         | IOVF1 Interrupt vector address        |
| 008<br>(009)                         | IOVF2 Interrupt vector address        |
| 00A<br>(00B)                         | ITMR Interrupt vector address         |
| 00C<br>(00D)                         | INT2 Interrupt vector address         |
| 8n + 6<br>(n = 1 ~ 15)<br>086 (Note) | Call address by instruction (CALLS a) |
| FEO<br>~<br>FFF                      | PLA data conversion table             |

Note : 086 (hexadecimal) = 134 (decimal)

Table 1.2.1 Specific Address of Program Memory

**ROM CAPACITY**

The TMP4740P and TMP4720P contain a program memory with 4,096 x 8-bit (addresses 000 - FFF) capacity and 2,048 x 8-bit (addresses 000 - 7FF) capacity, respectively. But the TMP4720P contains a program counter with 12-bit length. Therefore, when one of addresses 800 - FFF is accessed in a program, the ROM data corresponding to addresses 000 - 7FF read out. It is because there is no physical ROM in addresses 800-FFF, but the MSB in the program counter is not decoded. For example, when the data located in address FF3 is output to a port by the PLA referring instruction on a program, the data located in address 7F3 is read out. In the TMP4720P, the PLA data conversion table (addresses FEO - FFF) is, therefore, located in addresses 7EO - 7FF.

"0" [(NOP) instruction] is read out for the ROM data within the range of the built-in ROM capacity, if it is not specified by the user.



Fig. 1.2.1 ROM Capacity and Address



### 1.3 H Register (HR), L Register (LR), and RAM Address Buffer Register (RAA)

The H and L registers are 4-bit registers used as the data memory address pointers or general purpose registers.

The page structure of the data memory is based on 16 words per page. Pages are specified by H register, and addresses in page are done by L register, respectively. TMP4740P has 16 pages and TMP4720P 8 pages.

The L register is also used to specify the bits corresponding to pins R<sub>73</sub>~R<sub>40</sub> of the I/O port when instructions (SET @L), (CLR @L), and (TEST @L), are executed.

The RAM address buffer register is a temporary register used to specify the address in the data memory, and serves as an input of the RAM address decoder. Normally, the data specified by the contents of the H and L registers or immediate data of an instruction is fed into the RAM address buffer register.



Fig. 1.3.1 H Register, L Register and Data Memory (RAM)

#### 1.4 Data Memory (RAM)

The processing data of user are stored in the data memory. The data is read out or written in according to the address indicated by the contents of the RAM address buffer register.

##### Specific addresses of data memory

The data memory is also used for the following specific purposes. When it is not used for the respective purposes, the RAM of the corresponding address can be used to store the user processing data.

- (1) Stack (STACK)
- (2) Stack pointer word (SPW)
- (3) Data counter (DC)
- (4) Timer/Counter (TC1, TC2)

##### (1) Stack (STACK)

The stack, which is contained in the data memory (one level of the stack consists of 4-word RAM), is area to save the contents of the program counter (return address) and flag prior to jumping to the processing program at time of subroutine call or interrupt acceptance. To return from the processing program, (RET) instruction is used to restore the contents saved in the stack to the program counter, and (RETI) instruction is used to restore the contents saved in the stack to the program counter and flags.

The location of the stack to save/restore the contents is determined by the stack pointer word, which is automatically decremented after the saving operation, and incremented prior to the restoring operation.



## (2) Stack Pointer Word (SPW)

The address FF in the data memory is called a stack pointer word and decides the stack pointer. The stack is contained in the RAM, and accessed by the stack pointer.

The stack pointer is decided with the format shown in Fig. 1.4.1, but this address indicates the lower RAM address in each level of the stack.

Values "E" - "0" can be assigned for the stack pointer word, so that the maximum of 15 nesting levels are available for the stack. However, when the timer/counter mentioned following is used, the level containing the RAM address corresponding to the timer/counter cannot be used for the stack (value "F" is not assigned to the stack pointer word, because the stack contains the RAM address corresponding to the stack pointer word). The stack pointer word is automatically updated by the subroutine call or interrupt acceptance; however, it cannot exceed the allowable size of the stack for the system configuration.

Since the stack pointer word is never initialized in terms of hardware, it is necessary to set it to the highest possible level of the stack in the user's initialization program. For instance, it is set to "C" level when the two channels of timer/counter are used.

Note: The "level" indicates the depth of the nesting in the stack as well as the location of the next available stack. That is, it represents the contents of the stack pointer word.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY



\*: Can be used to store the user processing data

(a) Specific purposive map of RAM



(b) Stack pointer and stack pointer word



(c) Structure of stack

Fig. 1.4.1 Specific Address and Stack of Data Memory



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P  
TMP4720P

**PRELIMINARY**

### (3) Data Counter (DC)

Data counter is a 12-bit binary counter used to specify the address when the data table in the ROM area is referred (ROM data referring instruction).

The RAM address with 4-bit unit is allocated to the data counter, so that the initial value setting and the content reading of the data counter can be executed by the RAM manipulative instructions.

|                | MSB | D               | C               | LSB             |
|----------------|-----|-----------------|-----------------|-----------------|
| (Data Counter) |     | DC <sub>H</sub> | DC <sub>M</sub> | DC <sub>L</sub> |
| (RAM Address)  |     | (FE)            | (FD)            | (FC)            |

Fig. 1.4.2 Data Counter and RAM Address

### (4) Timer/Counter (TC1, TC2)

The two channels of 12-bit timer/counter are built-in, and the RAM address with 4-bit unit is allocated to the timer/counter, so that the initial value setting and the content reading of the timer/counter can be executed by the RAM manipulative instructions.

When the timer/counter 1 is not used, the stack lower from level 13 can be used. When both of the timer/counter 1 and 2 are not used, the stack lower from level 14 can be used.

|                   | MSB | TC1              | LSB              |
|-------------------|-----|------------------|------------------|
| (Timer/Counter 1) |     | TC1 <sub>H</sub> | TC1 <sub>M</sub> |
| (RAM Address)     |     | (F6)             | (F5)             |

|                   | MSB | TC2              | LSB              |
|-------------------|-----|------------------|------------------|
| (Timer/Counter 2) |     | TC2 <sub>H</sub> | TC2 <sub>M</sub> |
| (RAM Address)     |     | (FA)             | (F9)             |

Fig. 1.4.3 Timer/Counter and RAM Address

### (5) Page 0 in Data Memory

Page 0 in the data memory (addresses 00 - 0F) is effectively used as a flag or pointer in a user's program.

**RAM Capacity**

Data memory contained in TMP4740P has a 256 x 4-bit (addresses 00 - FF) capacity, and that contained in TMP4720P has a 128 x 4-bit (addresses 00 - 7F) capacity.

Since the TMP4720P also has the RAM address buffer register of 8-bit length, there is no physical RAM in addresses 80 - FF in the TMP4720P. However, the RAM equivalent to addresses 00 - 7F are referred when addresses 80 - FF are accessed in a program, because the MSB of RAM address buffer register is not decoded. That is, the specific RAM address is distributed to CO - FF in a program, but the RAM equivalent to addresses 40 - 7F are assigned in the TMP4720P.



Fig. 1.4.4 RAM Capacity and Address

### 1.5 ALU, Accumulator (AC)

The ALU is a circuit used for various arithmetic and logical operation for 4-bit binary data. It performs the operation designated by the instruction, and outputs the 4-bit result, carry (C), and zero detection signal (Z).

The accumulator is a 4-bit register to use a source operand for the arithmetic operation, and in which the result is stored.



Fig. 1.5.1 ALU, Accumulator

#### Detection of operating condition

Output C from the ALU indicates the carry output from the most significant position in the addition operation.

However, the subtraction is executed with the addition of the 2's complement, so that output C in the subtraction operation indicates the "non-borrow" from the most significant position (i.e., in case of non-borrow, C = "1"). Accordingly, borrow (B) can be represented with " $\bar{C}$ ".

Output Z indicates the zero detection signal to which "1" is applied when all of the 4-bit data transferred to accumulator or output of the ALU are cleared to zero.



Example (4-bit operation)

- |                                |                  |
|--------------------------------|------------------|
| (a) $4 + 5 = 9$                | $(C = 0, Z = 0)$ |
| (b) $7 + 9 = 0$                | $(C = 1, Z = 1)$ |
| (c) $3 - 1 = 2$                | $(B = 0, Z = 0)$ |
| (d) $2 - 2 = 0$                | $(B = 0, Z = 1)$ |
| (e) $6 - 8 = -2 \text{ or } E$ | $(B = 1, Z = 0)$ |

Note :  $B = \bar{C}$  is indicated.

#### 1.6 Flag (FLAG)

Flag is a 4-bit register used to store the condition of arithmetic operation, and of which the set/reset conditions are specified by the instruction. The flag consisting of CF, ZF, SF, and GF is saved in the stack when the interrupt is accepted. By executing the (RETI) instruction, it is restored from the stack to the conditions immediately before the interrupt is accepted.



Fig. 1.6.1 Flag

##### (1) Carry Flag (CF)

This flag is used to hold the carry in the addition operation as an input to the ALU by the (ADDC A, @HL) instruction as well as to hold the non-borrow in the subtraction operation (the carry in the addition of the 2's complement) as an input to the ALU by the (SUBRC A, @HL) instruction. The rotate instruction makes the flag hold the data shifted out of the accumulator.



## (2) Zero Flag (ZF)

This flag is stored the zero detection signal (Z) when the instruction designate to change. "1" is set if all 4 bits are cleared to zero by an arithmetic operation or data processing.

## (3) Status Flag (SF)

This flag is set or reset according to the condition specified by the instruction. With the exception of particular cases, it is usually presented at every execution of an instruction, and holds the contents of the result during execution of the next instruction. It is normally set to "1", but is reset to "0" for a time under the certain condition (it varies according to the instruction, for examples, when the result is zero, when carry occurs in the addition, or when borrow occurs in the subtraction, the flag is reset).

The status flag is referred to as branch condition in a branch instruction. The memory location is branched when this flag is set to "1"; therefore, normally the branch instruction can be required as "unconditional jump instruction". On the contrary, the instruction becomes a "conditional instruction" if it is executed immediately after loading the instruction to set/reset the status flag according to the condition determined by some previous instruction.

The status flag is initialized to "1" at initialization, and is also set to "1" after the contents have been saved in the stack when the interrupt is accepted. The contents saved in the stack is restored by the (RETI) instruction.

## (4) General Flag (GF)

This is a single-bit general purpose flag, being set or reset, and also used in a test by a program. This can be used for any purpose in the user program.



## 1.7 Port (PORT)

Data transfer to/from the external circuitry, and command/status/data transfer between the built-in peripheral circuitry are carried out by the input/output instructions.

- (a) Input/Output port : Data transfer to/from external circuitry.
- (b) Command/data output : Control of circuitry of built-in peripheral circuitry, and output of data.
- (c) Status/data input : Input of status signal (Note) and data from the built-in peripheral circuitry.

Note : Status signal is provided from serial port and is different from the status flag (SF).

To transfer the data or to control the circuitry, each port or register is selected by designating the address (Port address) by input/output operational instructions (13 instructions) in the same way as the memory.

The port address is composed of 5 bits (addresses 0 - 31).

The address to be accessed differs according to a instruction.

By way of caution, the port address space is independent of the program memory address space and the data memory address space.

Every output port contains a latch in order to hold the output data. Since every input port is operated without latching, it is desired to externally hold the data to be input from the external devices till the data is completely read out, or to read the data several times to confirm the contents.

The details to specify the input/output circuit format of ports and initialization of the output latch are 2.6 (2) Input/Output Circuit Format.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P  
TMP4720P

PRELIMINARY

| Port address | Symbol (Input/Output) | Port, Register (Input/Output)                                 | Input/Output Instructions |           |          |          |         |           |          |
|--------------|-----------------------|---------------------------------------------------------------|---------------------------|-----------|----------|----------|---------|-----------|----------|
|              |                       |                                                               | IN %P, A                  | OUT A ,%P | OUT#K,%P | OUTB @HL | SET%P,b | TEST %P,b | TEST%P,b |
| 00           | IPO0/IPO0             | K <sub>0</sub> Input port / P <sub>1</sub> Output             | 0                         |           |          |          |         | 0         |          |
| 01           | IPO1/IPO1             | P <sub>1</sub> Output latch / Port                            | 0                         | 0         | 0        |          | 0       | 0         |          |
| 02           | IPO2/IPO2             | " / P <sub>2</sub> "                                          | 0                         | 0         | 0        |          | 0       | 0         |          |
| 03           | IPO3/IPO3             | —                                                             |                           |           |          |          |         |           |          |
| 04           | IPO4/IPO4             | R <sub>4</sub> I/O port                                       | 0                         | 0         | 0        |          | 0       | 0         | 0        |
| 05           | IPO5/IPO5             | R <sub>5</sub> "                                              | 0                         | 0         | 0        |          | 0       | 0         | 0        |
| 06           | IPO6/IPO6             | R <sub>6</sub> "                                              | 0                         | 0         | 0        |          | 0       | 0         | 0        |
| 07           | IPO7/IPO7             | R <sub>7</sub> "                                              | 0                         | 0         | 0        |          | 0       | 0         | 0        |
| 08           | IPO8/IPO8             | R <sub>8</sub> "                                              | 0                         | 0         | 0        |          | 0       | 0         |          |
| 09           | IPO9/IPO9             | R <sub>9</sub> "                                              | 0                         | 0         | 0        |          | 0       | 0         |          |
| 0A           | IPOA/IPOA             | —                                                             |                           |           |          |          |         |           |          |
| 0B           | IPOB/IPOB             | —                                                             |                           |           |          |          |         |           |          |
| 0C           | IPOC/IPOC             | —                                                             |                           |           |          |          |         |           |          |
| 0D           | IPOD/IPOD             | —                                                             |                           |           |          |          |         |           |          |
| OE           | IPOE/IPOE             | Status input /                                                | 0                         |           |          |          |         |           | 0        |
| OF           | IPOF/IPOF             | (*) / (***)                                                   | 0                         | 0         | 0        |          |         |           |          |
| 10           | /OP10                 | / —                                                           |                           |           |          |          |         |           |          |
| 11           | /OP11                 | /P <sub>2</sub> •P <sub>1</sub> output port<br>(8-bit output) |                           |           |          |          | 0       |           |          |
| 12           | /OP12                 | / —                                                           |                           |           |          |          |         |           |          |
| 13           | /OP13                 | / —                                                           |                           |           |          |          |         |           |          |
| 14           | /OP14                 | / —                                                           |                           |           |          |          |         |           |          |
| 15           | /OP15                 | / —                                                           |                           |           |          |          |         |           |          |
| 16           | /OP16                 | / —                                                           |                           |           |          |          |         |           |          |
| 17           | /OP17                 | / —                                                           |                           |           |          |          |         |           |          |
| 18           | /OP18                 | / —                                                           |                           |           |          |          |         |           |          |
| 19           | /OP19                 | / (a)                                                         |                           |           |          |          | 0       |           |          |
| 1A           | /OP1A                 | / —                                                           |                           |           |          |          |         |           |          |
| 1B           | /OP1B                 | / —                                                           |                           |           |          |          |         |           |          |
| 1C           | /OP1C                 | / (b)                                                         |                           |           |          |          | 0       |           |          |
| 1D           | /OP1D                 | / (c)                                                         |                           |           |          |          | 0       |           |          |
| 1E           | /OP1E                 | / —                                                           |                           |           |          |          |         |           |          |
| 1F           | /OP1F                 | / (d)                                                         |                           |           |          |          | 0       |           |          |

Note 1: Inputs (IP10 - IP1F) of port addresses 10 - 1F remain undefined.

Note 2: Port addresses with "—" mark are reserved addresses and cannot be used at user's program.

Note 3: OP11 is automatically accessed by (OUTB @HL) instruction, but cannot be done by the instructions other than this one.

Table 1.7.1 Port Address Allocation and Input/Output Instructions

(1) K<sub>0</sub> (K<sub>03</sub> ~ K<sub>00</sub>) Port

This is a 4-bit port used for input.



Fig. 1.7.1 K<sub>0</sub> Port

(2) P<sub>1</sub> (P<sub>13</sub> ~ P<sub>10</sub>), P<sub>2</sub> (P<sub>23</sub> ~ P<sub>20</sub>) Port

These ports are 4-bit ports with a latch used for output. The latch data can be read by the instruction.

These two ports can independently access by specifying port addresses IPO1/OP01, and IPO2/OP02. In addition, they can output 8-bit data by the (OUTB @HL) instruction.

## PLA data conversion

A hardware PLA is not contained in the system; however, the function equivalent to it can be performed by access to the PLA data conversion table provided in the RCM by use of the (CUTB @HL) instruction.

The PLA referring instruction (OUTB @HL) : This instruction reads out the 8-bit data stored in the program memory, whose address is determined by the contents of the data memory indicated by the contents of the H and L registers as well as the contents of the carry flag, and outputs the data to 8-bit ports P2 and P1. At this time OPLL is automatically selected as the port address.

Ports P<sub>1</sub> and P<sub>2</sub> are capable of reading the latch data by the instruction, so that the data output by the PLA referring instruction can be qualified or modified; that is, the convert pattern can be changed or the numbers of pattern will be increased.



Fig. 1.7.2 P<sub>1</sub> and P<sub>2</sub> Ports

### (3) R<sub>4</sub>(R<sub>43</sub> ~ R<sub>40</sub>), R<sub>5</sub>(R<sub>53</sub> ~ R<sub>50</sub>), R<sub>6</sub>(R<sub>63</sub> ~ R<sub>60</sub>), R<sub>7</sub>(R<sub>73</sub> ~ R<sub>70</sub>) Port

Each of these ports is a 4-bit I/O port with a latch. The latch should be set to "1" when the port is used as an input port.

Pins R<sub>73</sub> - R<sub>40</sub> can be used for bit scanning for set/reset and test according to the contents of the L register by executing the (SET @L), (CLR @L) and (TEST @L) instructions. Table 1.7.2 shows the pins corresponding to the contents of the L register.

| L register<br>3 2 1 0 | Corresponding Pin | L register<br>3 2 1 0 | Corresponding Pin |
|-----------------------|-------------------|-----------------------|-------------------|
| 0 0 0 0               | R <sub>40</sub>   | 1 0 0 0               | R <sub>60</sub>   |
| 0 0 0 1               | R <sub>41</sub>   | 1 0 0 1               | R <sub>61</sub>   |
| 0 0 1 0               | R <sub>42</sub>   | 1 0 1 0               | R <sub>62</sub>   |
| 0 0 1 1               | R <sub>43</sub>   | 1 0 1 1               | R <sub>63</sub>   |
| 0 1 0 0               | R <sub>50</sub>   | 1 1 0 0               | R <sub>70</sub>   |
| 0 1 0 1               | R <sub>51</sub>   | 1 1 0 1               | R <sub>71</sub>   |
| 0 1 1 0               | R <sub>52</sub>   | 1 1 1 0               | R <sub>72</sub>   |
| 0 1 1 1               | R <sub>53</sub>   | 1 1 1 1               | R <sub>73</sub>   |

Table 1.7.2 Correspondence of Individual Bits of L Register and I/O Port



Note : For bit set/reset of port,  
latch output serves as input data.

Fig. 1.7.3 R<sub>4</sub> ~ R<sub>7</sub> Ports

#### (4) R<sub>8</sub> (R<sub>83</sub> ~ R<sub>80</sub>) Port

This is a 4-bit I/O port with a latch. The latch should be set to "1" when the port is used as an input port.

It is a port common to external interrupt input or external timer/counter input. When it is driven by the external circuitry, such as external interrupt input or external timer/counter input, the latch must be set to "1". When it is used as normal I/O port, some measures, such as inhibition of the external interrupt input acceptance or disable of the mode depending on the external input of the timer/counter should be taken in a program.

(Note) When pin R<sub>82</sub> ( $\overline{\text{INT1}}$ ) is used as a port, INT1 interrupt request takes place because the falling edge of the pin input/output is detected (interrupt enabling master F/F is normally set to "1"). This causes the CPU to process a dummy interrupt acceptance [e.g. the (RETI) instruction only is executed]. When pin R<sub>80</sub> ( $\overline{\text{INT2}}$ ) is used, INT2 interrupt request also takes place in the same manner as the case of pin R<sub>82</sub>, but the interrupt request is not accepted by merely resetting the LSB (EIR<sub>0</sub>) of the enable interrupt register to "0" in advance. Therefore, the above processing is not required.



Note: For bit set/reset of port, latch output serves as input data.

Fig. 1.7.4 R<sub>8</sub> Port

#### (5) R<sub>9</sub>(R<sub>92</sub> ~ R<sub>90</sub>) Port

This is a 3-bit I/O port with a latch, and the latch must be set to "1" when it is used as input port.

The R<sub>9</sub> port is also used as serial port. The latch must be set to "1" when R<sub>9</sub> port is used as serial port. The port used as normal I/O port is not entirely influenced by disabling the serial port. Pin R<sub>93</sub> is not mounted in the port, but "1" is read by accessing to pin R<sub>93</sub> in a program.



Note: For bit set/reset of port, latch output serves as input data.

Fig. 1.7.5 R<sub>9</sub> Port



## 1.8 Interrupt control circuit (INTR)

Interrupt factors are composed of two from the external circuitry, and four from the internal circuitry. By setting the interrupt latch provided for each factor, an interrupt request is generated to the CPU. The interrupt latch is set when the edge of the input signal is detected.

The interrupt request is not always accepted by the CPU if generated. It is not accepted till the priority in the six factors determined according to the hardware and the enabling/disabling control by the program become all affirmative.

In order to control enabling/disabling of interrupt by the program, an F/F (EIF) and a 4-bit register (EIR) are provided. By using these means, preferential acceptance of the interrupt factors by the program, and multiple interrupt control can be realized.



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Factor                      | Priority according to hardware             | Interrupt Latch | Enable condition according to program | Vector Address           |
|-----------------------------|--------------------------------------------|-----------------|---------------------------------------|--------------------------|
| External interrupt 1 (INT1) | (Higher)<br>1                              | INTL5           | (Note 1)<br>EIF = 1                   | 002                      |
| Internal interrupt          | Serial Input/Output (ISI0) interrupt       | 2               | INTL4                                 | EIF·EIR3 = 1             |
|                             | Timer counter 1 Overflow (IOVF1) interrupt | 3               | INTL3                                 | EIF·EIR2 = 1             |
|                             | Timer counter 2 Overflow (IOVF2) interrupt | 4               | INTL2                                 | (Note 2)<br>EIF·EIR1 = 1 |
|                             | Timer interrupt of divider (ITMR)          | 5               | INTL1                                 | (Note 2)<br>EIF·EIR1 = 1 |
| External interrupt 2 (INT2) | 6<br>(Lower)                               | INTL0           | EIF·EIR0 = 1                          | 00C                      |

Interrupt enabling master F/F

Interrupt enabling register (EIR)



(Note 1) Since EIR register cannot make disabling of the INT1 interrupt, this interrupt is always accepted under the interrupt enabled condition (EIF = 1). Therefore, this should be used for the interrupt requiring the first priority such as emergency interrupt.

(Note 2) The given acceptance condition by the program is the same in IOVF2 and ITMR; accordingly, the action of these interrupts to the acceptance/inhibition control is the same.

Table 1.8.1 Interrupt Factors



Fig. 1.8.1 Interrupt Control Circuit



Note: On the assumption that  $EIR_1 = 1$ , without other interrupt requests

Fig. 1.8.2 Interrupt Acceptance Timing Chart (Example)



## (1) Interrupt processing

The interrupt request signal to be sent to the CPU is held by the interrupt latch till the request is accepted or the latch is reset by the initialization operation or instruction.

The processing for the interrupt acceptance is performed within two instruction cycle time after the completion of the execution of instruction (after the completion of the timer/counter processing if it is required).

The following operations are performed by the interrupt service program.

- ① The contents of the program counter and flag are saved in the stack.
- ② The vector address is set to the program counter according to the interrupt factor.  
(A jump instruction to each interrupt service program is usually stored in the program memory corresponding to the vector address.)
- ③ The status flag is set to "1".
- ④ The interrupt enabling master F/F is reset to "0" to inhibit the subsequent interrupt acceptance for a time.
- ⑤ The interrupt latch of the accepted interrupt factor is reset to "0".
- ⑥ The instruction stored in the vector address is executed.

The interrupt service program terminates after the execution of the (RETI) instruction.

The following operations are performed by the (RETI) instruction.



- ① The contents of the program counter and flag are restored out of the stack.
- ② The interrupt enabling master F/F is set to "1".

When the multiple interrupt is accepted, the interrupt enabling master F/F should be set by the instruction. At this time, the enabling/disabling for each interrupt factor can be changed by updating the interrupt enabling register by the (XCH A, EIR) instruction.

The program counter and flag are automatically saved/restored in the interrupt processing. However, if saving/restoring of the accumulator and other registers is necessary, it should be designated by a program.

#### (2) Interrupt control by program

##### EIF

This is an enabling interrupt master F/F. Interrupt is put in the interrupt acceptance enabling state by setting the EIF to "1". It is reset to "0" immediately after having accepted an interrupt to inhibit the subsequent interrupt acceptance for a time, but is set to "1" again by the (RETI) instruction after the completion of the interrupt service program to return the enable state again. And then the other interrupt can be received.

The EIF can be set/reset in a program by using the (EICLR IL,r) and (DICLR IL, r) instructions. It is reset to "0" at initialization operation.

##### EIR register

This is a 4-bit register used for selection/control of enabling/disabling of the interrupt acceptance in a program.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

**PRELIMINARY**

Read/write operation is performed by use of the (XCH A, EIR) instruction. It is set to "0" at the initialization operation.

### Interrupt latch

The interrupt latches (INTL<sub>5</sub> - INTL<sub>0</sub>) provided for each interrupt factor are set by the rising edge of the input signal if the interrupt is caused by the internal factors, and are set by the falling edge of the input pin if it is caused by the external factors. Then, interrupt request signal is sent to the CPU. The interrupt latch holds the signal till the interrupt request is accepted, and is reset to "0" immediately after the interrupt has been accepted.

Since the interrupt latch can be reset to "0" by the (EICLR IL, r), (DICLR IL, r) and (CLR IL, r) instructions, the interrupt request signal can be initialized by a program. The latch is reset to "0" at the initialization operation.

### 1.9 Frequency divider (FD)

The divider (FD<sub>1</sub> - FD<sub>18</sub>) is made up 18-stage binary counter, and its output is used to generate various internal timing.

The basic clock (fc Hz) is divided into sixteen by the timing generator and input to the divider; therefore, the output frequency at the last stage is  $fc/2^{22}$  Hz.

It is reset to "0" at the initialization operation.

#### Timer Interrupt of divider (ITMR)

The divider is capable of sending the interrupt request for a certain frequency. Four different frequencies can be selected for timer interrupt by instructions.

The command register is accessed as port address OP19, and is reset to "0" at time of the initialization.

The timer interrupt of divider is caused from the rising edge of the first output of the divider after the data has been written in the command register.



(a) Structure of frequency divider

| (Port address)<br>OP19 | MSB                    LSB |   |   |   | (*: don't care)                                      |
|------------------------|----------------------------|---|---|---|------------------------------------------------------|
|                        | 3                          | 2 | 1 | 0 |                                                      |
| *                      | 0                          | * | * | : | Disable                                              |
| *                      | 1                          | 0 | 0 | : | Interrupt frequency      fc/2 <sup>10</sup> Hz       |
| *                      | 1                          | 0 | 1 | : | "                              fc/2 <sup>11</sup> Hz |
| *                      | 1                          | 1 | 0 | : | "                              fc/2 <sup>12</sup> Hz |
| *                      | 1                          | 1 | 1 | : | "                              fc/2 <sup>13</sup> Hz |

| Interrupt frequency (Hz) | For example,<br>fc=4.194304MHz |
|--------------------------|--------------------------------|
| fc/2 <sup>10</sup>       | 4,096 Hz                       |
| fc/2 <sup>11</sup>       | 2,048 Hz                       |
| fc/2 <sup>12</sup>       | 1,024 Hz                       |
| fc/2 <sup>13</sup>       | 512 Hz                         |

(b) Command register

Fig. 1.9.1 Frequency Divider

### 1.10 Timer/Counter (TC<sub>1</sub>, TC<sub>2</sub>)

Two channels of 12-bit binary counter is contained to count time or event.

Since the RAM address with 4-bit unit is allocated to the timer/counter, the initial value setting and the content reading of the timer/counter can be executed by the RAM manipulated instructions.



Fig. 1.10.1 Timer/Counter

#### (1) Timer/Counter Control

The timer/counter is controlled by the command specifying the operation mode. The command register for the timer/counter 1 and timer/counter 2 is accessed as port addresses OP1C and OP1D, respectively. It is reset to "0" at the initialization operation. The count operation is started from the first rising edge of the count pulse applied by setting the value (mode) to the command register.

When the timer/counter is not used, the RAM addresses corresponding to the timer/counter can be used to store the user processing data by selecting the "disable" state. In the timer mode, the external input pins can be used as I/O ports [R<sub>83</sub> (T1), R<sub>81</sub> (T2)].

TCl Command register  
(Port Address OP1C)



TC2 Command register  
(Port Address OP1D)



Selection of Count Mode

- 00 : Disable state
- 01 : Event count mode  
(Counts external input)
- 10 : Timer mode  
(Counts internal pulse.)
- 11 : Pulse width measurement mode  
(Counts the pulse obtained by sampling of external input by use of internal pulse.)

Selection of Internal Pulse  
(Divider Output) Rate

- 00 :  $fc/2^{10}$  Hz is counted.
- 01 :  $fc/2^{14}$  Hz is counted.
- 10 :  $fc/2^{18}$  Hz is counted.
- 11 :  $fc/2^{22}$  Hz is counted.

(fc: Basic clock frequency)

(a) Command register

| Internal Pulse Rate (Hz) | Max. Setting Time (SEC) | For example, fc=4.194304 MHz |                         |
|--------------------------|-------------------------|------------------------------|-------------------------|
|                          |                         | Internal Pulse Rate (Hz)     | Max. Setting Time (SEC) |
| $fc/2^{10}$              | $2^{22}/fc$             | 4,096                        | 1                       |
| $fc/2^{14}$              | $2^{26}/fc$             | 256                          | 16                      |
| $fc/2^{18}$              | $2^{30}/fc$             | 16                           | 256                     |
| $fc/2^{22}$              | $2^{34}/fc$             | 1                            | 4,096                   |

(b) Selection of timer rate

Fig. 1.10.2 Control of Timer/Counter



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

### (2) Count Operation

When the rising edge of the count pulse is detected, the count latch is set to send a count request to the CPU.

The count operation of the timer/counter is performed requiring one instruction cycle time after completion of the instruction execution. The execution of the next instruction and the acceptance of the interrupt request are kept waiting during the operation. When the count request is sent from the timer/counter 1 and 2, at the same time, the count request of the timer/counter 1 is preferentially executed.

The maximum frequency applied to the external input pin under the event counter mode is  $fc/32$  Hz if one channel is used. When two channels are used,  $fc/32$  Hz is applied to the timer/counter 1, and  $fc/40$  Hz to the timer/counter 2.

In the timer mode, the maximum frequency is determined by a command.

The maximum frequency applied to the external input pin in the pulse width measurement mode should be the frequency level available for analyzing the count value in the program. Normally, the frequency sufficiently slower than the designated internal pulse rate is applied to the external input pin.



Fig. 1.10.3 Mode and Count Value of Timer/Counter

Decrease in execution speed of instruction due to count operation

The CPU carries out the count operation requiring one instruction cycle time for the count request. Therefore, this causes the decrease in the apparent speed of instruction execution. Some examples are shown below :

- (a) In the timer mode with count pulse rate of  $f_c/2^{10}$  Hz :

The count operation is inserted once every 128-instruction cycle time, so that the apparent speed is decreased by  $1/127 \approx 0.8\%$  instruction execution speed. For example, the apparent speed is  $2.016\mu s$  to  $2\mu s$  instruction execution speed.

- (b) In the event count mode :

It depends on the count pulse rate applied to the external input pin. In the worst case, when the timer/counter 1 and 2 are operated at the same time with the maximum count pulse rate, the count operation is inserted once every 4-instruction cycle time for the timer/counter 1, and once every 5-instruction cycle time for the timer/counter 2.

The apparent speed of the instruction execution, therefore, decreases by  $9/11 \approx .82\%$ . The apparent speed is 3.64 $\mu$ s to 2 $\mu$ s instruction execution speed.

### (3) Interrupt by overflow (IOVF1, IOVF2)

At the time when the overflow occurs, the timer/counter generates the interrupt request.

That is, the interrupt request is generated when the count value of FFF is changed to 000. The counting is continued after the interrupt request signal is generated. Assuming that the CPU provides the interrupt enabling state, and that the interrupt is accepted as soon as the overflow interrupt has been generated, the interrupt processing can be performed in the sequence illustrated in Fig. 1.10.4.



Fig. 1.10.4 Timing Chart of Timer/Counter in  
Interrupt by Overflow

### 1.11 Serial Port (SIO)

A 4-bit serial port with a buffer is provided to transfer the serial data from/to the external circuitry. It is connected to the external circuitry through three pins [R92 ( $\overline{SCK}$ ), R91 (SO), R90 (SI)]. Since these pins are also used as port R9, the output latch of the R9 port should be set to "1" when the serial port is used. When it is not used, the pins can be used as I/O port R9.

Pin R90 in the transmit mode and pin R91 in the receive mode are also available as I/O port pin.

#### (1) Circuit configuration

The serial port consists of a 4-bit shift register, a 4-bit buffer register, and its control circuit.



SR : 4-bit shift register      SIOC : Serial port control circuit  
 SB : 4-bit buffer register       $\phi_s$  : Internal shift clock  
 ISIO : Interrupt request

Fig. 1.11.1 Circuit Configuration of Serial Port

## (2) Serial port control

The serial port operation is controlled by the command. The command register is accessed with port address OPIF, and reset to "0" at the initialization operation. The operation status can be informed through the status input, which is accessed with port address IPOE.



Fig. 1.11.2 Command Register, Status Input



## (3) Shift clock (SCK)

The following shift clock modes can be selected by the contents of the command register.

- (a) Clock source (External/internal mode)
- (b) Shift edge of clock (Leading edge/trailing edge mode)

Internal clock mode

$f_c/2^7$  Hz is used for the shift clock (when the basic clock frequency  $f_c$  is 4.194304 MHz, the shift clock frequency is 32.768 kHz.). At this time, the clock is supplied to the external devices through the SCK pin. If the data setting (transmit mode) or the data reading (receive mode) rate by the program cannot follow the clock rate, the shift clock is automatically stopped and the next shift operation is suspended until the data processing is completed ("Wait"operation).

External clock mode

The shift operation is performed by the clock provided from the external circuitry since the SCK pin serves as an input.

Leading edge shift mode

Data is transmitted (transmit mode) or received (receive mode) at the leading edge of the SCK pin signal.

Trailing edge shift mode

Data is received (receive mode) at the trailing edge of the SCK pin signal.

The SCK pin must be set to the "high" level when the serial transfer is started. In the internal clock mode, the SCK pin is automatically set to the "high" level because it serves as an output.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINAR

### (4) Operation mode

Selection of the following three transfer modes is available by changing the combination of the RM bit and LM bit of the command register.

| RM<br>(Bit 2) | LM<br>(Bit 1) | ECKM<br>(Bit 0) | Operation Mode                                                 |
|---------------|---------------|-----------------|----------------------------------------------------------------|
| 0             | 0             | 1/0             | Can not be used                                                |
| 0             | 1             | 1/0             | Transmit mode (Note)<br>(External/Internal clock)              |
| 1             | 0             | 1/0             | Receive(Trailing edge shift) mode<br>(External/Internal clock) |
| 1             | 1             | 1/0             | Receive(Leading edge shift) mode<br>(External/Internal clock)  |

(Note) Leading edge shift operation is performed.

Table 1.11.1 Operation Mode of Serial Port

In the transmit mode, the 4-bit data written to the buffer register from the CPU is shifted out by the shift register, and is output in the SO pin from the data of the LSB in sequence. The buffer register is accessed as the port address OPOF.

In the receive mode, the data to be input to the SI pin is shifted toward the LSB by the shift register in sequence, and is set in the buffer register after the 4-bit data has been received.

The CPU reads the contents of the buffer register, which is accessed as the port address IPOF.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

**PRELIMINARY**

### Transmit mode

After this mode is set in the command register, the first transmit data (4-bit) is written in the buffer register (the data cannot be written in the buffer register, if the transmit mode is not set). Then the data can be transmitted by setting the ESIO (MSB of command register) to "1". The content of the buffer register is transferred to the shift register by the first shift clock, and the data in the LSB ( $D_0$ ) is output to the S0 pin. The buffer register then becomes empty, so that the interrupt (ISIO) requesting the next data takes place (buffer empty). After that, the remaining data ( $D_1 - D_3$ ) is automatically shifted out by the shift register by one data at a shift clock. The control by use of a program is not necessary in this operation.

Data is written in the buffer register by outputting the next transmit data (4-bit) to the port address OPOF in the interrupt service program, and at the same time the interrupt request is reset to "0".

### Internal clock operation

In case of  $f_c/2^7$  Hz internal clock operation, if the next data is not set in the buffer register (OPOF has not been accessed by the program) though the 4-bit data has been entirely shifted out, the shift clock automatically stops, and the wait operation is taking place until the data is set.

The maximum transmission rate is 31250 bit/sec. at the 4 MHz basic clock.

External clock operation

Since the shift operation synchronizes entirely with the clock provided from the external circuitry, the data should have been written in the buffer register before the next 4-bit data is shifted out. Therefore, the transfer rate is determined by the maximum time lag from the receipt of interrupt request (ISIO) to the writing of data in the buffer register by the interrupt service program.



(a) Internal clock operation (with wait operation)



(b) External clock operation

Fig. 1.11.3 Transmit Mode

Completion of transmission

When the buffer register becomes empty, the interrupt occurs to request the next data. In case where the transmission is desired to be completed after the data is entirely transferred, the transmit operation can be stopped upon completion of transferring the current data shifted out, by resetting the ESIO to "0" without outputting the data. Whether or not the transfer operation is completed can be sensed in a program by the SIOF (MSB of the status input).

In the external clock operation, the ESIO must be reset to "0" before the next data is shifted out as in the data updating operation (however, the data is not updated when the operation is completed). When the wait operation have been already performed in the internal clock operation, the data transfer is terminated immediately after ESIO = 0.

One word transfer can be terminated by ESIO = 0 in the interrupt service program on receipt of the interrupt caused by the buffer empty.

**TECHNICAL DATA**


(a) Internal clock operation (with wait operation)



(b) External clock operation



(c) Completion at one-word transfer

Fig. 1.11.4 Completion of Transmission



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

**PRELIMINARY**

### Receive (trailing edge shift) mode

Data can be received by setting the receive mode in the command register as well as by setting the ESIO (MSB of command register) to "1".

When the four data are received from the SI pin, the 4-bit data is transferred from the shift register to the buffer register. At the same time, interrupt (ISIO) takes place to request the data reading (buffer full). Since the shift register has been transferring the data to the buffer register, the shift operation is continued without waiting for the data being read.

When the data received from the port address IPOF is read in the interrupt service program, the interrupt request is reset. And then the next 4-bit data is transferred from the shift register to the buffer register if the buffer register has been full.

### Internal clock operation

During the operation of the internal clock of  $f_c/2^7\text{Hz}$ , if the next 4-bit data is not read out of the buffer register (the IPOF has not been accessed) in the program though the 4-bit data has been entirely input, the shift clock automatically stops, and the wait operation is taking place until the data is read out.

The maximum receiving rate is 31250 bit/sec at the 4 MHz basic clock.

### External clock operation

Since the shift operation synchronizes entirely with the clock provided from the external circuitry, the current data should have been read by the instruction before the next 4-bit data is transferred to the buffer register. The transfer rate is, therefore, determined by the maximum time lag from the receipt of interrupt request (ISIO) to the read of the data in the buffer register by the interrupt service program.



(a) Internal clock operation (with wait operation)



(b) External clock operation

Fig. 1.11.5 Receive (trailing edge shift) Mode



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

**PRELIMINARY**

### Completion of receiving

When all of the data are read, the receiving of data can be completed upon termination of the current data transfer, by resetting the ESIO to "0".

Whether or not the data transmission is terminated can be sensed in a program by the S1OF (MSB of status input).

To complete the receive operation when the synchronization is desired between the serial transfer and interrupt service program (indicates data reading or completion of receiving), there are two ways according to the speed of shift clock.

The receive/transmit mode must be maintained without switching the mode until the last data is read out even if the completion of the data transfer is indicated; otherwise the contents of the buffer register will be lost.

#### (a) Sufficiently slow data transfer rate (external clock operation)

If the timing, operated by the external clock, is slow enough to reset the ESIO to "0" prior to the generation of the next shift clock, the ESIO can be reset to "0" in the interrupt service program which is loaded to read out the last data. Thereafter the last data is read.



Fig. 1.11.6 Completion of Receiving (at slow transfer rate)

#### (b) Fast transfer rate

If the shift operation for the next data may start before the current data is read out by receipt of the interrupt request because the transfer rate is too fast, the interrupt service program which is loaded to read out the last data but one should be used to reset the **ESIO** to "0" after confirming that the **SEF** (bit 2 of status input) has been set to "1".

Thereafter, the data should be read. No operation is required to complete the data transfer in the interrupt service program for reading the last data.

The method mentioned above is usually taken for the internal clock operation. In the external clock operation, however, the reset of the ESIO and the read of data must be completed before the last data is transferred to the buffer register.



(a) Program sequence of receive end indication



(b) Timing Chart  
(in case of internal clock operation with wait operation)

Fig. 1.11.7 Completion of Receiving (at fast transfer rate)

## (c) One word transfer

The data receive operation starts after the ESIO is set to "1". Then, the ESIO is reset to "0" after confirming that the SEF status is set to "1". In this sequence, one interrupt caused by the buffer full takes place; therefore, the data should be read out by the service program.



(a) Program sequence of receiving start/end indication



(b) Timing Chart

Fig. 1.11.8 Receiving Start/Completion (at one word transfer)



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P  
TMP4720P

PRELIMINARY

### Receive (leading edge shift) mode

With this mode set in the command register, the data can be received by setting the ESIO (MSB of command register) to "1".

When the four data are received from the SI pin, the 4-bit data is transferred from the shift register to the buffer register. At the same time, the interrupt (ISIO) occurs to request the data reading (buffer full). Since the shift register is transferring the data to the buffer register, the shift operation has been continued without waiting for the data being read.

When the data received from the port address IPOF is read in the interrupt service program, the interrupt request is reset. And then the next 4-bit data is transferred from the shift register to the buffer register if the buffer register has been full.

The basic operation in the receive (leading edge shift) mode is equivalent to that in the receive (trailing edge shift) mode except that the edge for the shift clock is different, and that at time of the transfer start, the first shifted data has been already input from the external circuitry before the first shift clock is applied to the data receipt. Timing charts are shown below.



(a) Internal clock operation (with wait operation)



(b) External clock operation (at slow transfer rate)



(c) External clock operation (at fast transfer rate)



(d) One-word transfer

Fig. 1.11.9 Receive(Leading Edge Shift) Mode

2. Basic operation and pin operation
  1. Instruction cycle
  2. Basic clock (CP) generation
  3. Initialization operation
  4. Memory stand-by function
  5. Interrupt input
  6. Input/output port
  7. Other pins

The timing in each basic operation, and the configuration, function, and timing of the pins are described according to the above items.

The operation and timing with each component of the hardware are covered in detail in the description of each item of the components.

Different input/output port circuit system can be specified according to the port. The details to specify the type of input/output port circuit are given in the description covering the program tape format.

#### 2.1 Instruction cycle

The instruction execution and the internal hardware control are synchronized with the basic clock (CP, fc Hz).

The minimum unit of the instruction execution is called the "instruction cycle", and all instructions are executed by one or two instruction cycles, each of which is called one-cycle instruction or two-cycle instruction.

An instruction cycle consists of four machine cycles ( $M_1 \sim M_4$ ), and each machine cycle requires two basic clock times.



Fig. 2.1.1 Instruction Cycle

## 2.2 Basic clock (CP) generation

An oscillation circuit is contained, and the necessary clock is easily generated by connecting the resonator to external pins ( $X_{IN}$ ,  $X_{OUT}$ ). By the way, the oscillation circuit serves as schmitt circuit.

The clock generated in the oscillation circuit is called the "basic clock" with which the internal control is synchronized. The basic clock is applied to the timing generator and the control circuit of system to provide various control signals.

The following are the examples of the resonator connection.



(a) For X-tal or ceramic resonator



(b) For RC



(c) For external oscillator

Fig. 2.2.1 Resonator Connections

### 2.3 Initialization operation

Initialization operation is performed by keeping the RESET pin to the low level. However, the following conditions are required to put the initialization operation into practice with certainty

- ① The supply voltage is within the operating voltage.
- ② The oscillation circuit operates stably.
- ③ The RESET is held at the low level in at least three instruction cycle time.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P  
TMP4720P

PRELIMINARY

The following processings are performed by the initialization operation.

- ① Reset the program counter to "0".
- ② Set the status flag to "1".
- ③ Reset the interrupt enabling master F/F and the interrupt enabling register to "0", and also reset the interrupt latch to "0".
- ④ Reset the divider to "0".
- ⑤ Initialize the input/output port and command register to the fixed level.

The initialization operation is released due to the rise of the RESET pin to the high level, and the program can be executed from address 0 in sequence.

The RESET pin serves as Schmitt circuit input, and is connected with pull-up resister ( $\approx 200k\Omega$  TYP., MOS-load resister).

### 2.4 Memory Stand-by function

Even during the cut off of the main power supply ( $V_{DD}$ ), the RAM data can be held with low power dissipation by connecting the back-up power supply to the  $V_{HH}$  pin. This memory stand-by operation is performed by the following procedure.

- ① Keep the RESET pin at the low level in at least three instruction cycle time before the  $V_{DD}$  power goes to the minimum operating voltage.
- ② Hold the low level of the RESET pin. At the same time, the level of the  $V_{HH}$  voltage should be kept at that of more than mimimum stand-by voltage.

The operation should be started from initialization operation after the main power supply is resumed.

The power dissipation at the stand-by time can be minimized by this function.

#### 2.5 Interrupt input

Two pins (INT<sub>1</sub>, INT<sub>2</sub>) are provided for the external interrupt input. Since these pins are common pins with R<sub>8</sub> port, they can be used as I/O pins (R<sub>82</sub>, R<sub>80</sub>) respectively, if not used as the interrupt input pins.

The interrupt via INT<sub>2</sub> can be inhibited at any time by the program, but the interrupt via INT<sub>1</sub> is not inhibited by it independently. Therefore, when this pin is used for the R<sub>82</sub> port, the interrupt will always take place due to the detection of the falling edge of the signal. It is necessary to set a dummy interrupt service program including the (RETI) instruction only, even if the INT<sub>1</sub> is not used.

The interrupt latch is set by the falling edge of the external inputs (INT<sub>1</sub>, INT<sub>2</sub>), and an interrupt request is made to the CPU. To assure that the interrupt latch is positively set or reset, and that the next interrupt request is set, both of the high and low levels should be kept for more than two instruction cycle time.

The external interrupt input is the Schmitt circuit input.



Fig. 2.5.1 Interrupt Timing (Dummy process of INT1 interrupt)

## 2.6 Input/output port

### (1) Input/output timing

The timing to read the external data from the input port or I/O port is in M3 machine cycle in the second cycle of the input instruction (two-cycle instruction). Since this timing cannot be externally recognized, the transient input data should be processed by a program.

The timing to output the data to the output port or I/O port is in M4 machine cycle in the second cycle of the output instruction (two-cycle instruction), but this timing cannot be externally recognized.



Fig. 2.6.1 Input/Output Timing

## (2) Input/Output circuit format

The input/output circuit format of the input/output port is shown following.

For the TMP4740P and the TMP4720P, any of the input/output circuit systems shown in the following tables can be selected. You can specify your input/output circuit system when requesting the program tape.

"I<sub>O</sub>CODE AA" is employed if not specified.

| Input/Output Circuit Code (I <sub>O</sub> CODE) AA |                                                                                                                                                                                          |                                                                                                                                                                       |                                                                                                                                                                                          |                                                                                                                                                                                          |                                                                                                                                                                                            |
|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port Circuit                                       | Input (K <sub>0</sub> )                                                                                                                                                                  | Output (P <sub>1</sub> , P <sub>2</sub> )                                                                                                                             | I/O (R <sub>4</sub> , R <sub>5</sub> , R <sub>6</sub> )                                                                                                                                  | I/O (R <sub>7</sub> )                                                                                                                                                                    | I/O (R <sub>8</sub> , R <sub>9</sub> )                                                                                                                                                     |
| I/O equivalent Circuit                             | <br><br>R = 1kΩ (TYP.) |                                                                                      | <br><br>R = 1kΩ (TYP.) | <br><br>R = 1kΩ (TYP.) | <br><br>R = 1kΩ (TYP.) |
| Remark                                             | <ul style="list-style-type: none"> <li>◦ High threshold input.</li> <li>◦ No resistor is contained.</li> </ul>                                                                           | <ul style="list-style-type: none"> <li>◦ Sink open drain output.</li> <li>◦ High output current.</li> <li>◦ Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>◦ Sink open drain output.</li> <li>◦ Output latch is initialized to the high level.</li> </ul>                                                    | <ul style="list-style-type: none"> <li>◦ Sink open drain output.</li> <li>◦ Output latch is initialized to the high level.</li> </ul>                                                    | <ul style="list-style-type: none"> <li>◦ Schmitt circuit input.</li> <li>◦ Sink open drain output.</li> <li>◦ Output latch is initialized to the high level.</li> </ul>                    |

Note : The input/output port of the evaluator chip TMP4700C is made up with the circuit system equivalent to this input/output circuit system; therefore, the system of the TMP4700C can become equivalent to that of the TMP4740P or the TMP4720P by externally installing EPROM (program memory) on the TMP4700C (but TMP4700C is not contained the pull-up resistor with RESET pin and the pull-down resistor with TEST pin.).

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Input/Output Circuit Code (I <sub>O</sub> CODE) |                                                                                                                                                   | AE                                                                                                                                                                   | I/O (R <sub>4</sub> , R <sub>5</sub> , R <sub>6</sub> )                                                                                                                         | I/O (R <sub>7</sub> )                                                                                                                | I/O (R <sub>8</sub> , R <sub>9</sub> )                                                                                                                                 |
|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port Circuit                                    | Input (K <sub>o</sub> )                                                                                                                           | Output (P <sub>1</sub> , P <sub>2</sub> )                                                                                                                            |                                                                                                                                                                                 |                                                                                                                                      |                                                                                                                                                                        |
| I/O equivalent circuit                          | <br>$R_{IN} = 100\text{k}\Omega$ (TYP.)<br>$R = 1\text{k}\Omega$ |                                                                                     | <br>$RL = 5\text{k}\Omega$ (TYP.)<br>$R = 1\text{k}\Omega$ (TYP.)                              | <br>$R = 1\text{k}\Omega$ (TYP.)                    |                                                                                      |
| Remark                                          | <ul style="list-style-type: none"> <li>o High threshold input</li> <li>o Pull-up resistor is contained.</li> </ul>                                | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o High output current.</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o Pull-up resistor is contained.</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Schmitt circuit input.</li> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level</li> </ul> |

| Input/Output Circuit Code (I <sub>O</sub> CODE) |                                                                                                                                                  | AF                                                                                                                                                                   | I/O (R <sub>4</sub> , R <sub>5</sub> , R <sub>6</sub> )                                                                                                                     | I/O (R <sub>7</sub> )                                                                                                                | I/O (R <sub>8</sub> , R <sub>9</sub> )                                                                                                                                 |
|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port Circuit                                    | Input (K <sub>o</sub> )                                                                                                                          | Output (P <sub>1</sub> , P <sub>2</sub> )                                                                                                                            |                                                                                                                                                                             |                                                                                                                                      |                                                                                                                                                                        |
| I/O equivalent circuit                          | <br>$R_{IN} = 100\Omega$ (TYP.)<br>$R = 1\text{k}\Omega$ (TYP.) |                                                                                     | <br>$RL = 5\text{k}\Omega$ (TYP.)<br>$R = 1\text{k}\Omega$ (TYP.)                          | <br>$R = 1\text{k}\Omega$ (TYP.)                    |                                                                                      |
| Remark                                          | <ul style="list-style-type: none"> <li>o High threshold input</li> <li>o Pull-down resistor is contained.</li> </ul>                             | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o High output current.</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o Pull-up resistor contained.</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Schmitt circuit input.</li> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level</li> </ul> |

| Input/Output Circuit Code (I <sub>O</sub> CODE) AH |                                                                                                                    |                                                                                                                                                                      |                                                                                                                       |                                                                                                                                      |                                                                                                                                                                        |
|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port Circuit                                       | Input (K <sub>0</sub> )                                                                                            | Output (P <sub>1</sub> , P <sub>2</sub> )                                                                                                                            | I/O (R <sub>4</sub> , R <sub>5</sub> , R <sub>6</sub> )                                                               | I/O (R <sub>7</sub> )                                                                                                                | I/O (R <sub>8</sub> , R <sub>9</sub> )                                                                                                                                 |
| I/O equivalent circuit                             | <br>$R_{IN} = 100k\Omega$ (TYP.)<br>$R = 1k\Omega$ (TYP.)                                                          |                                                                                                                                                                      | <br>$R_L = 5k\Omega$ (TYP.)<br>$R = 1k\Omega$ (TYP.)                                                                  | <br>$R = 1k\Omega$ (TYP.)                                                                                                            | <br>$R = 1k\Omega$ (TYP.)                                                                                                                                              |
| Remark                                             | <ul style="list-style-type: none"> <li>o High threshold input</li> <li>o Pull-up resistor is contained.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o High output current.</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o Pull-up resistor is contained.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Schmitt circuit input.</li> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level</li> </ul> |

| Input/Output Circuit Code (I <sub>O</sub> CODE) AI |                                                                                                                      |                                                                                                                                                                      |                                                                                                                       |                                                                                                                                      |                                                                                                                                                                        |
|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port Circuit                                       | Input (K <sub>0</sub> )                                                                                              | Output (P <sub>1</sub> , P <sub>2</sub> )                                                                                                                            | I/O (R <sub>4</sub> , R <sub>5</sub> , R <sub>6</sub> )                                                               | I/O (R <sub>7</sub> )                                                                                                                | I/O (R <sub>8</sub> , R <sub>9</sub> )                                                                                                                                 |
| I/O equivalent circuit                             | <br>$R_{IN} = 100k\Omega$ (TYP.)<br>$R = 1k\Omega$ (TYP.)                                                            |                                                                                                                                                                      | <br>$R_L = 5k\Omega$ (TYP.)<br>$R = 1k\Omega$ (TYP.)                                                                  | <br>$R = 1k\Omega$ (TYP.)                                                                                                            | <br>$R = 1k\Omega$ (TYP.)                                                                                                                                              |
| Remark                                             | <ul style="list-style-type: none"> <li>o High threshold input</li> <li>o Pull-down resistor is contained.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o High output current.</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o Pull-up resistor is contained.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Schmitt circuit input.</li> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level</li> </ul> |



## 2.7 Other pins

Timer/Counter input

Two pins ( $T_1$ ,  $T_2$ ) are provided for the external timer/counter inputs. Since these pins are common pins with  $R_8$  port, they can be also used as I/O pins ( $R_{83}$ ,  $R_{81}$ ), respectively, if not used as the timer/counter inputs.

The count latch is set by the rising edge of the external input ( $T_1$ ,  $T_2$ ), and a count request is made to the CPU. To assure that the count latch is positively set or reset, both of the high and low levels should be kept for more than two instruction cycle times.

The external timer/counter input is the Schmitt circuit input.

Serial port

This port is connected to the external circuitry via three pins ( $\overline{SCK}$ ,  $S_0$ ,  $SI$ ), which are also used for the  $R_9$  port. These pins can be used as the pins of the  $R_9$  port ( $R_{92}$ ,  $R_{91}$ ,  $R_{90}$ ), if not used for the serial port.

To assure that the shift operation is positively performed in the external clock mode, both of the high and low levels should be kept for more than two instruction cycle times.

The  $\overline{SCK}$  input in the external clock mode and the  $SI$  input in the receive mode are Schmitt circuit inputs.

TEST pin

This pin is used for the shipment test. To operate the user system with this pin, the input should be surely set to the low level. By the way, TEST pin is connected with pull-down resistor ( $\approx 70\text{k}\Omega$  TYP., MOS-load resistor).



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P  
TMP4720P

**PRELIMINARY**

### 3. Instructions

The TLCS-47 series microcomputer is provided with 90 instructions, which are software compatible within the series. The instructions of the TLCS-47 series consist of 1-byte instructions or 2-byte instructions. To classify them in terms of the execution time, there are 1-cycle instructions and 2-cycle instructions.

1-byte, 1-cycle instructions are mainly used in this series, and are arranged so as to improve the program efficiency.

|        |                     |    |
|--------|---------------------|----|
| 1-byte | 1-cycle instruction | 40 |
| 1-byte | 2-cycle instruction | 11 |
| 2-byte | 2-cycle instruction | 39 |
| Total  |                     | 90 |

#### (a) Classification by byte/cycle

|                                   |    |
|-----------------------------------|----|
| Move instruction (Note 1)         | 22 |
| Compare instruction               | 6  |
| Arithmetic instruction            | 16 |
| Logical instruction               | 9  |
| Bit manipulation instruction      | 24 |
| Input/Output instruction (Note 2) | 6  |
| Branch, subroutine instruction    | 6  |
| Other instruction                 | 1  |
| Total                             | 90 |

(Note 1) : Including ROM data referring instructions

(Note 2) : Including PLA referring instruction.

#### (b) Classification by function

Table 3.0.1 Classification of Instructions.



## 3.1 Description of symbols

The following symbols are used for describing the instructions in the following explanations.

| Symbol                                 | Description                                                             |
|----------------------------------------|-------------------------------------------------------------------------|
| AC                                     | Accumulator                                                             |
| M[x]                                   | Data memory (Address x)                                                 |
| HR                                     | H register                                                              |
| LR                                     | L register                                                              |
| P[p]                                   | Port (Address p)                                                        |
| FLAG                                   | Flag                                                                    |
| CF                                     | Carry flag                                                              |
| ZF                                     | Zero flag                                                               |
| SF                                     | Status flag                                                             |
| GF                                     | General flag                                                            |
| PC                                     | Program counter                                                         |
| STACK[(SPW)]                           | Stack (Stack level is indicated by the contents of stack pointer word.) |
| SPW                                    | Stack pointer word                                                      |
| EIF                                    | Enable interrupt master F/F                                             |
| EIR                                    | Enable interrupt register                                               |
| INTLj                                  | Interrupt latch (j = 5 - 0)                                             |
| DC                                     | Data counter                                                            |
| ROM[x]                                 | Program memory (Address x)                                              |
| (ROM <sub>H</sub> , ROM <sub>L</sub> ) | (High-order 4 bits or low-order 4 bits are expressed by suffix H/L.)    |
| ←                                      | Transfer                                                                |
| ⇄                                      | Exchange                                                                |
| +                                      | Addition                                                                |
| -                                      | Subtraction                                                             |
| Λ                                      | Logical AND of the corresponding bits                                   |
| ∨                                      | Logical OR of the corresponding bits                                    |
| ⊻                                      | Exclusive OR of the corresponding bits                                  |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Symbol     | Description                                                                                                      |
|------------|------------------------------------------------------------------------------------------------------------------|
| (CF)       | Inversion of carry flag contents                                                                                 |
| null       | Processed result is transferred nowhere                                                                          |
| (AC)       | Contents of accumulator                                                                                          |
| (H,L)      | Contents of 8 bits coupling H register with L register                                                           |
| M[(H,L)]   | Contents of data memory for which the contents of 8 bits coupling H register with L register is used as address. |
| (AC)<b>    | Contents of bit assigned by b of accumulator.                                                                    |
| (LR)<3:2>  | Contents of bit 3 to bit 2 of L register                                                                         |
| (PC)<11:6> | Contents of bit 11 to bit 6 of program counter                                                                   |

## 3.2 Description of instructions (\*): Note 1 (\*\*): Exec.cycle (\*\*): Hexadecimal

| Item Class       | Assembler Mnemonic | Object Code                                                                                                                                |                         | Function                                                                                                                                       | Flag(*) |    |     |
|------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|---------|----|-----|
|                  |                    | Binary                                                                                                                                     | (**)                    |                                                                                                                                                | CF      | ZF | SF  |
| Move Instruction | LD A, @HL          | 0 0 0 0 1 1 0 0                                                                                                                            | 0 C                     | (AC) + M[(H·L)]                                                                                                                                | -       | Z  | 1 1 |
|                  |                    |                                                                                                                                            |                         | Loads the contents of the data memory specified by the H and L registers in the accumulator.                                                   |         |    |     |
|                  | LD A, x            | 0 0 1 1 1 1 0 0<br>x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 C<br>x <sub>HXL</sub> | (AC) + M[x]                                                                                                                                    | -       | Z  | 1 2 |
|                  |                    |                                                                                                                                            |                         | Loads the contents of the data memory specified by the x of the instruction field in the accumulator.                                          |         |    |     |
|                  | LD HL, x           | 0 0 1 0 1 0 0 0<br>x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 2 8<br>x <sub>HXL</sub> | (LR) + M[x'], (HR) + M[x'+1]<br>x' = x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> 00              | -       | -  | 1 2 |
|                  |                    |                                                                                                                                            |                         | Loads the consecutive two-word contents of the data memory specified by the x' (modified x) of the instruction field in the H and L registers. |         |    |     |
|                  | LD A, #k           | 0 1 0 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                        | 4 k                     | (AC) * k                                                                                                                                       | -       | Z  | 1 1 |
|                  |                    |                                                                                                                                            |                         | Loads the immediate data k of the instruction field in the accumulator. Serves as the clear instruction when k=0.                              |         |    |     |



## INTEGRATED CIRCUIT



## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Items<br>Class   | Assembler<br>Mnemonic | Object Code                                                                                                                                |                                      | Function                                                                                                                                                                                                     | Flag(*)                |   | (**) |
|------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---|------|
|                  |                       | Binary                                                                                                                                     | (**)                                 |                                                                                                                                                                                                              | Functional Description |   |      |
| Move Instruction | LD H, #k              | 1 1 0 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                        | C k                                  | (HR)←k                                                                                                                                                                                                       | - -                    | 1 | 1    |
|                  |                       |                                                                                                                                            |                                      | Loads the immediate data k of the instruction field in the H register. Serves as the clear instruction when k=0.                                                                                             |                        |   |      |
|                  | LD L, #k              | 1 1 1 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                        | E k                                  | (LR)←k                                                                                                                                                                                                       | - -                    | 1 | 1    |
|                  |                       |                                                                                                                                            |                                      | Loads the immediate data k of the instruction field in the L register. Serves as the clear instruction when k=0.                                                                                             |                        |   |      |
|                  | LDL A, @DC            | 0 0 1 1 0 0 1 1                                                                                                                            | 3 3                                  | (AC)←ROM <sub>L</sub> [(DC)]                                                                                                                                                                                 | -                      | Z | 1    |
|                  |                       |                                                                                                                                            |                                      | Loads the lower-order 4 bits of the data read out of the data table of the program memory specified by the data counter, in the accumulator.                                                                 |                        |   | 2    |
|                  | LDH A,@DC+            | 0 0 1 1 0 0 1 0                                                                                                                            | 3 2                                  | (AC)←ROM <sub>H</sub> [(DC)], (DC)←(DC)+1                                                                                                                                                                    | -                      | Z | 1    |
|                  |                       |                                                                                                                                            |                                      | Loads the higher-order 4 bits of the data read out of the data table of the program memory specified by the data counter, in the accumulator, and then increments the contents of the data counter. [Note 2] |                        |   |      |
|                  | ST A, @HL             | 0 0 0 0 1 1 1 1                                                                                                                            | 0 F                                  | M[(H·L)]←AC                                                                                                                                                                                                  | - -                    | 1 | 1    |
|                  |                       |                                                                                                                                            |                                      | Stores the contents of the accumulator in the data memory specified by the H and L registers.                                                                                                                |                        |   |      |
|                  | ST A,@HL+             | 0 0 0 1 1 0 1 0                                                                                                                            | 1 A                                  | M[(H·L)]←(AC), (LR)←(LR)+1                                                                                                                                                                                   | -                      | Z | Ā    |
|                  |                       |                                                                                                                                            |                                      | Stores the contents of the accumulator in the data memory specified by the H and L registers, and then increments the contents of the L register. [Note 3]                                                   |                        |   | 1    |
|                  | ST A,@HL-             | 0 0 0 1 1 0 1 1                                                                                                                            | 1 B                                  | M[(H·L)]←(AC), (LR)←(LR)-1                                                                                                                                                                                   | -                      | Z | Ā    |
|                  |                       |                                                                                                                                            |                                      | Stores the contents of the accumulator in the data memory specified by the H and L registers, and then decrements the contents of the L register. [Note 3]                                                   |                        |   | 1    |
|                  | ST A, x               | 0 0 1 1 1 1 1 1<br>x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 F<br>x <sub>H</sub> x <sub>L</sub> | M[x]←(AC)                                                                                                                                                                                                    | - -                    | 1 | 2    |
|                  |                       |                                                                                                                                            |                                      | Stores the contents of the accumulator in the data memory specified by the x of the instruction field.                                                                                                       |                        |   |      |
|                  | ST #k,@HL+            | 1 1 1 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                        | F k                                  | M[(H·L)]←k, (LR)←(LR)+1                                                                                                                                                                                      | -                      | Z | Ā    |
|                  |                       |                                                                                                                                            |                                      | Stores the immediate data k of the instruction field in the data memory specified by the H and L registers, and then increments the contents of the L register. [Note 3]                                     |                        |   | 1    |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Items<br>Class   | Assembler<br>Mnemonic | Object Code                                                                                                                                |             | Function                                                                                                                                                               | Flag(*) |     |    |
|------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----|----|
|                  |                       | Binary                                                                                                                                     | (*)         |                                                                                                                                                                        | CF      | ZF  | SF |
| Move Instruction | ST #k, y              | 0 0 1 0 1 1 0 1<br>k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 D<br>k y  | M[y]=k                                                                                                                                                                 | - -     | 1   | 2  |
|                  |                       |                                                                                                                                            |             | Stores the immediate value k of the instruction field in the data memory specified by y (page 0) of the instruction field. Serves as the clear instruction when k = 0. |         |     |    |
|                  | MOV H, A              | 0 0 0 1 0 0 0 0                                                                                                                            | 1 0         | (AC) ← (HR)                                                                                                                                                            | -       | Z 1 | 1  |
|                  |                       |                                                                                                                                            |             | Loads the contents of the H register in the accumulator.                                                                                                               |         |     |    |
|                  | MOV L, A              | 0 0 0 1 0 0 0 1                                                                                                                            | 1 1         | (AC) ← (LR)                                                                                                                                                            | -       | Z 1 | 1  |
|                  |                       |                                                                                                                                            |             | Loads the contents of the L register in the accumulator.                                                                                                               |         |     |    |
|                  | XCH A, H              | 0 0 1 1 0 0 0 0                                                                                                                            | 3 0         | (HR) ← (AC)                                                                                                                                                            | -       | Z 1 | 2  |
|                  |                       |                                                                                                                                            |             | Exchanges the contents of the accumulator for those of the H register.<br>[Note 2]                                                                                     |         |     |    |
|                  | XCH A, L              | 0 0 1 1 0 0 0 1                                                                                                                            | 3 1         | (LR) ← (AC)                                                                                                                                                            | -       | Z 1 | 2  |
|                  |                       |                                                                                                                                            |             | Exchanges the contents of the accumulator for those of the L register.<br>[Note 2]                                                                                     |         |     |    |
|                  | XCH A, EIR            | 0 0 0 1 0 0 1 1                                                                                                                            | 1 3         | (EIR) ← (AC)                                                                                                                                                           | - -     | 1   | 1  |
|                  |                       |                                                                                                                                            |             | Exchanges the contents of the accumulator for those of the interrupt enable register.                                                                                  |         |     |    |
|                  | XCH A, @HL            | 0 0 0 0 1 1 0 1                                                                                                                            | 0 D         | M[(H·L)] ← (AC)                                                                                                                                                        | -       | Z 1 | 1  |
|                  |                       |                                                                                                                                            |             | Exchanges the contents of the accumulator for those of the data memory specified by the H and L registers.<br>[Note 2]                                                 |         |     |    |
|                  | XCH A, x              | 0 0 1 1 1 1 0 1<br>x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 D<br>xHXL | M[x] ← (AC)                                                                                                                                                            | -       | Z 1 | 2  |
|                  |                       |                                                                                                                                            |             | Exchanges the contents of the accumulator for those of the data memory specified by the x of the instruction field.<br>[Note 2]                                        |         |     |    |
|                  | XCH HL, x             | 0 0 1 0 1 0 0 1<br>x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 2 9<br>xHXL | M[x'] ← (LR), M[x'+1] ← (HR)<br>x' = x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> 00                                      | - -     | 1   | 2  |
|                  |                       |                                                                                                                                            |             | Exchanges the contents of the H and L registers for consecutive two-word contents of the data memory specified by the x' (modified x) of the instruction field.        |         |     |    |

| Items<br>Class            | Assembler<br>Mnemonic | Object Code                                                                                                                                |                                      | Function                                                                                                                                                                                                 | Flag(*)   |                       |
|---------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------------------|
|                           |                       | Binary                                                                                                                                     | (*)                                  |                                                                                                                                                                                                          | CF        | ZF                    |
| Compare Instruction       | CMPR A,@HL            | 0 0 0 1 0 1 1 0                                                                                                                            | 1 6                                  | null<-M[(H·L)]-(AC)                                                                                                                                                                                      | $\bar{B}$ | $\bar{Z}$ $\bar{Z}$ 1 |
|                           |                       |                                                                                                                                            |                                      | Compares the contents of the data memory specified by the H and L registers with those of the accumulator.                                                                                               |           |                       |
|                           | CMPR A, x             | 0 0 1 1 1 1 1 0<br>$x_7x_6x_5x_4x_3x_2x_1x_0$                                                                                              | 3 E<br>x <sub>H</sub> x <sub>L</sub> | null<-M[x]-(AC)                                                                                                                                                                                          | $\bar{B}$ | $\bar{Z}$ $\bar{Z}$ 2 |
|                           |                       |                                                                                                                                            |                                      | Compares the contents of the data memory specified by the x of the instruction field with those of the accumulator.                                                                                      |           |                       |
|                           | CMPR A,#k             | 1 1 0 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                        | D k                                  | null<-k-(AC)                                                                                                                                                                                             | $B$       | $Z$ $\bar{Z}$ 1       |
|                           |                       |                                                                                                                                            |                                      | Compares the immediate data k of the instruction field with the contents of the accumulator. Serves as the accumulator test instruction when k = 0.                                                      |           |                       |
| Arithmetic<br>Instruction | CMPR H,#k             | 0 0 1 1 1 0 0 0<br>1 1 0 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                     | 3 8<br>D k                           | null<-k-(HR)                                                                                                                                                                                             | -         | $Z$ $\bar{B}$ 2       |
|                           |                       |                                                                                                                                            |                                      | Compares the immediate data k of the instruction field with the contents of the H register. Serves as the H register test instruction when k = 0.                                                        |           |                       |
|                           | CMPR L,#k             | 0 0 1 1 1 0 0 0<br>1 0 0 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                     | 3 8<br>9 k                           | null<-k-(LR)                                                                                                                                                                                             | -         | $Z$ $\bar{B}$ 2       |
|                           |                       |                                                                                                                                            |                                      | Compares the immediate data k of the instruction field with the contents of the L register. Serves as the L register test instruction when k = 0.                                                        |           |                       |
|                           | CMPR y,#k             | 0 0 1 0 1 1 1 0<br>k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 E<br>k y                           | null<-k-M[y]                                                                                                                                                                                             | $\bar{B}$ | $\bar{Z}$ $\bar{Z}$ 2 |
|                           |                       |                                                                                                                                            |                                      | Compares the immediate data k of the instruction field with the contents of the data memory specified by the y (page 0) of the instruction field. Serves as the data memory test instruction when k = 0. |           |                       |
|                           | INC A                 | 0 0 0 0 1 0 0 0                                                                                                                            | 0 8                                  | (AC)<-(AC)+1<br>Increments the contents of the accumulator.                                                                                                                                              | -         | $Z$ $\bar{C}$ 1       |
|                           | INC L                 | 0 0 0 1 1 0 0 0                                                                                                                            | 1 8                                  | (LR)<-(LR)+1<br>Increments the contents of the L register.                                                                                                                                               | -         | $Z$ $\bar{C}$ 1       |

| Items<br>Class         | Assembler<br>Mnemonic | Object Code                                                                            |            | Function                                                                                                                                                                                                                                | Flag (*) |    | (**) |
|------------------------|-----------------------|----------------------------------------------------------------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----|------|
|                        |                       | Binary                                                                                 | (*)        |                                                                                                                                                                                                                                         | CF       | ZF |      |
| Arithmetic Instruction | INC @HL               | 0 0 0 0 1 0 1 0                                                                        | 0 A        | M[(H·L)]+M[(H·L)]+1                                                                                                                                                                                                                     | -        | Z  | C 1  |
|                        |                       |                                                                                        |            | Increments the contents of the data memory specified by the H and L registers.                                                                                                                                                          |          |    |      |
|                        | DEC A                 | 0 0 0 0 1 0 0 1                                                                        | 0 9        | (AC)-(AC)-1                                                                                                                                                                                                                             | -        | Z  | B 1  |
|                        |                       |                                                                                        |            | Decrements the contents of the accumulator.                                                                                                                                                                                             |          |    |      |
|                        | DEC L                 | 0 0 0 1 1 0 0 1                                                                        | 1 9        | (LR)-(LR)-1                                                                                                                                                                                                                             | -        | Z  | B 1  |
|                        |                       |                                                                                        |            | Decrements the contents of the L register.                                                                                                                                                                                              |          |    |      |
|                        | DEC @HL               | 0 0 0 0 1 0 1 1                                                                        | 0 B        | M[(H·L)]-M[(H·L)]-1                                                                                                                                                                                                                     | -        | Z  | B 1  |
|                        |                       |                                                                                        |            | Decrements the contents of the data memory specified by the H and L registers.                                                                                                                                                          |          |    |      |
|                        | ADDC A,@HL            | 0 0 0 1 0 1 0 1                                                                        | 1 5        | (AC)+(AC)+M[(H·L)]+(CF)                                                                                                                                                                                                                 | C        | Z  | C 1  |
|                        |                       |                                                                                        |            | Adds the contents of the data memory specified by the H and L registers as well as those of the carry flag to those of the accumulator, and places the result in the accumulator.                                                       |          |    |      |
|                        | ADD A,@HL             | 0 0 0 1 0 1 1 1                                                                        | 1 7        | (AC)+(AC)+M[(H·L)]                                                                                                                                                                                                                      | -        | Z  | C 1  |
|                        |                       |                                                                                        |            | Adds the contents of the data memory specified by the H and L registers to those of the accumulator, and places the result in the accumulator.                                                                                          |          |    |      |
|                        | ADD A, #k             | 0 0 1 1 1 0 0 0<br>0 0 0 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>0 k | (AC)+(AC)+k                                                                                                                                                                                                                             | -        | Z  | C 2  |
|                        |                       |                                                                                        |            | Adds the immediate data k of the instruction field to the contents of the accumulator, and places the result in the accumulator. Serves as the correction instruction for decimal addition and subtraction when k=6 or A.               |          |    |      |
|                        | ADD H, #k             | 0 0 1 1 1 0 0 0<br>1 1 0 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>C k | (HR)+(HR)+k                                                                                                                                                                                                                             | -        | Z  | C 2  |
|                        |                       |                                                                                        |            | Adds the immediate data k of the instruction field to the contents of the H register, and places the result in the H register. Serves as the H register increment instruction or the decrement instruction when k=1 or F, respectively. |          |    |      |

| Items<br>Class         | Assembler<br>Mnemonic | Object Code                                                                                                                                |            | Function                                                                                                                                                                                                                                                                                          | Flag(*) |    |    |   |
|------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----|----|---|
|                        |                       | Binary                                                                                                                                     | (**)       |                                                                                                                                                                                                                                                                                                   | CF      | ZF | SF |   |
| Arithmetic Instruction | ADD L,#k              | 0 0 1 1 1 0 0 0<br>1 0 0 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                     | 3 8<br>8 k | (LR) ← (LR) + k<br>Adds the immediate data k of the instruction field to the contents of the L register, and places the result in the L register.                                                                                                                                                 | -       | Z  | C  | 2 |
|                        | ADD @HL,#k            | 0 0 1 1 1 0 0 0<br>0 1 0 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                     | 3 8<br>4 k | M[(H·L)] ← M[(H·L)] + k<br>Adds the immediate data k of the instruction field to the contents of the data memory specified by the H and L register, and places the result in the data memory. Serves as the correction instruction for the decimal addition and subtraction when k = 6 or A.      | -       | Z  | C  | 2 |
|                        | ADD y,#k              | 0 0 1 0 1 1 1 1<br>k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 F<br>k y | M[y] ← M[y] + k<br>Adds the immediate data k of the instruction field to contents of the data memory specified by the y (page 0) of the instruction field, and places the result in the data memory. Serves as the correction instruction for decimal addition and subtraction when k = 6 or A.   | -       | Z  | C  | 2 |
|                        | SUBRCA,@HL            | 0 0 0 1 0 1 0 0                                                                                                                            | 1 4        | (AC) ← M[(H·L)] - (AC) - (CF)                                                                                                                                                                                                                                                                     | B       | Z  | B  | 1 |
|                        |                       |                                                                                                                                            |            | Subtracts the contents of the accumulator and the inverse contents of the carry flag from the contents of the data memory specified by the H and L registers, and places the result in the accumulator.                                                                                           |         |    |    |   |
|                        | SUBR A,#k             | 0 0 1 1 1 0 0 0<br>0 0 0 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                     | 3 8<br>1 k | (AC) ← k - (AC)<br>Subtracts the contents of the accumulator from the immediate data k of the instruction field, and places the result in the accumulator. Serves as the accumulator 2's complement instruction or the data inversion (1's complement) instruction when k = 0 or F, respectively. | -       | Z  | B  | 2 |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Items<br>Class         | Assembler<br>Mnemonic | Object Code                                                                            |            | Function                               | Flag(*) |    |    |
|------------------------|-----------------------|----------------------------------------------------------------------------------------|------------|----------------------------------------|---------|----|----|
|                        |                       | Binary                                                                                 | (**) (*)   |                                        | CF      | ZF | SF |
| Arithmetic Instruction | SUBR @HL, #k          | 0 0 1 1 1 0 0 0<br>0 1 0 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>5 k | M[(H·L)] ← k - M[(H·L)]                | -       | Z  | B  |
| Logical Instruction    | ROLCA                 | 0 0 0 0 0 1 0 1                                                                        | 0 5        | (rotate left)<br>[CF] → [AC] by 1 bit  | C       | Z  | C  |
|                        | RORCA                 | 0 0 0 0 0 1 1 1                                                                        | 0 7        | (rotate right)<br>[CF] → [AC] by 1 bit | C       | Z  | C  |
|                        | AND A, @HL            | 0 0 0 1 1 1 0                                                                          | 1 E        | (AC) ← (AC) ∧ M[(H·L)]                 | -       | Z  | Z  |
|                        | AND A, #k             | 0 0 1 1 1 0 0 0<br>0 0 1 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>3 k | (AC) ← (AC) ∧ k                        | -       | Z  | Z  |
|                        | AND @HL, #k           | 0 0 1 1 1 0 0 0<br>0 1 1 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>7 k | M[(H·L)] ← M[(H·L)] ∧ k                | -       | Z  | Z  |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Items<br>Class                  | Assembler<br>Mnemonic | Object Code                                                                            |            | Function                                                                                                                                                                                                                  | Flag(*) |               |
|---------------------------------|-----------------------|----------------------------------------------------------------------------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------|
|                                 |                       | Binary                                                                                 | (**)       |                                                                                                                                                                                                                           | CF      | ZF            |
| Logical<br>Instruction          | OR A, @HL             | 0 0 0 1 1 1 0 1                                                                        | 1 D        | $(AC) \leftarrow (AC) \vee M[(H \cdot L)]$                                                                                                                                                                                | -       | Z $\bar{Z}$ 1 |
|                                 |                       |                                                                                        |            | Carries out the logical OR of the corresponding bits with the contents of the accumulator and those of the data memory specified by the H and L registers, and places the result in the accumulator.                      |         |               |
|                                 | OR A, #k              | 0 0 1 1 1 0 0 0<br>0 0 1 0 k <sub>5</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>2 k | $(AC) \leftarrow (AC) \vee k$                                                                                                                                                                                             | -       | Z $\bar{Z}$ 2 |
|                                 |                       |                                                                                        |            | Carries out the logical OR of the corresponding bits with the contents of the accumulator and the immediate data k of the instruction field, and places the result in the accumulator.                                    |         |               |
| Bit Manipulation<br>Instruction | OR @HL, #k            | 0 0 1 1 1 0 0 0<br>0 1 1 0 k <sub>5</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>6 k | $M[(H \cdot L)] \leftarrow M[(H \cdot L)] \vee k$                                                                                                                                                                         | -       | Z $\bar{Z}$ 2 |
|                                 |                       |                                                                                        |            | Carries out the logical OR of the corresponding bits with the contents of the data memory specified by the H and L registers and the immediate data k of the instruction field, and places the result in the data memory. |         |               |
|                                 | XOR A, @HL            | 0 0 0 1 1 1 1 1                                                                        | 1 F        | $(AC) \leftarrow (AC) \oplus M[(H \cdot L)]$                                                                                                                                                                              | -       | Z $\bar{Z}$ 1 |
|                                 |                       |                                                                                        |            | Carries out the logical exclusive OR of the corresponding bits with the contents of the accumulator and those of data memory specified by the H and L registers, and places the result in the accumulator.                |         |               |
| TEST CF                         | TEST CF               | 0 0 0 0 0 1 1 0                                                                        | 0 6        | $(SF) \leftarrow (\overline{CF}), (CF) \leftarrow 0$                                                                                                                                                                      | 0       | - * 1         |
|                                 |                       |                                                                                        |            | Places the inverse contents of the carry flag in the status flag, and then resets the carry flag to "0".                                                                                                                  |         |               |
|                                 | TEST A, b             | 0 1 0 1 1 1 b <sub>1</sub> b <sub>0</sub>                                              | 5 C+b      | $(SF) \leftarrow (\overline{AC}) < b >$                                                                                                                                                                                   | - - *   | 1             |
|                                 |                       |                                                                                        |            | Places the inverse contents of the bit, which is specified by the b of the instruction field, of the accumulator, in the status flag.                                                                                     |         |               |
|                                 | TEST @HL, b           | 0 1 0 1 1 0 b <sub>1</sub> b <sub>0</sub>                                              | 5 8+b      | $(SF) \leftarrow M[(H \cdot L)] < b >$                                                                                                                                                                                    | - - *   | 1             |
|                                 |                       |                                                                                        |            | Places the inverse contents of the bit, which is specified by the b of the instruction field, of the data memory specified by the H and L registers, in the status flag.                                                  |         |               |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Items<br>Class               | Assembler<br>Mnemonic | Object Code                                                                                                      |              | Function                         | Flag(*) |    |
|------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------|--------------|----------------------------------|---------|----|
|                              |                       | Binary                                                                                                           | (**) (SF)    |                                  | CF      | ZF |
| Bit Manipulation Instruction | TEST y, b             | 0 0 1 1 1 0 0 1<br>1 0 b <sub>1</sub> b <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 3 9<br>8+b y | (SF) ← M[y]<b>                   | - - *   | 2  |
|                              | TEST %P,b             | 0 0 1 1 1 0 1 1<br>1 0 b <sub>1</sub> b <sub>0</sub> p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub> | 3 B<br>8+b P | (SF) ← P[p]<b>                   | - - *   | 2  |
|                              | TEST @L               | 0 0 1 1 0 1 1 1                                                                                                  | 3 7          | (SF) ← P[(LR)<3:2>+4]<(LR)<1:0>> | - - *   | 2  |
|                              | TESTP CF              | 0 0 0 0 0 1 0 0                                                                                                  | 0 4          | (SF) ← (CF), (CF) ← 1            | 1 -     | *  |
|                              | TESTP ZF              | 0 0 0 0 1 1 1 0                                                                                                  | 0 E          | (SF) ← (ZF)                      | - - *   | 1  |
|                              | TESTP GF              | 0 0 0 0 0 0 0 1                                                                                                  | 0 1          | (SF) ← (GF)                      | - - *   | 1  |
|                              | TESTP y,b             | 0 0 1 1 1 0 0 1<br>1 1 b <sub>1</sub> b <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 3 9<br>C+b y | (SF) ← M[y]<b>                   | - - *   | 2  |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Items<br>Class               | Assembler<br>Mnemonic | Object Code                                                                                                      |              | Function                                                                                                                                                                                                                                                   | Flag(*) |    |    |
|------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----|----|
|                              |                       | Binary                                                                                                           | (*)          |                                                                                                                                                                                                                                                            | CF      | ZF | SF |
| Bit Manipulation Instruction | TESTP %P, b           | 0 0 1 1 1 0 1 1<br>1 1 b <sub>1</sub> b <sub>0</sub> p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub> | 3 B<br>C+b P | (SF)←P[p]<b>                                                                                                                                                                                                                                               | - -     | *  | 2  |
|                              |                       |                                                                                                                  |              | Places the contents of the bit, which is specified by the b of the instruction field, of the port (port register for the output port, and pin input for the input or I/O ports), which is specified by the p of the instruction field, in the status flag. |         |    |    |
|                              | SET GF                | 0 0 0 0 0 0 1 1                                                                                                  | 0 3          | (GF)←1                                                                                                                                                                                                                                                     | - -     | 1  | 1  |
|                              |                       |                                                                                                                  |              | Sets the general flag to "1".                                                                                                                                                                                                                              |         |    |    |
|                              | SET @HL, b            | 0 1 0 1 0 0 b <sub>1</sub> b <sub>0</sub>                                                                        | 5 b          | M[(H·L)]<b>←1                                                                                                                                                                                                                                              | - -     | 1  | 1  |
|                              |                       |                                                                                                                  |              | Sets the bit, which is specified by the b of the instruction field, of the data memory specified by the H and L registers, to "1".                                                                                                                         |         |    |    |
|                              | SET y, b              | 0 0 1 1 1 0 0 1<br>0 0 b <sub>1</sub> b <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 3 9<br>b y   | M[y]<b>←1                                                                                                                                                                                                                                                  | - -     | 1  | 2  |
|                              |                       |                                                                                                                  |              | Sets the bit, which is specified by the b of the instruction field, of the data memory specified by the y (page 0) of the instruction field, to "1".                                                                                                       |         |    |    |
| Bit Manipulation Instruction | SET %p, b             | 0 0 1 1 1 0 1 1<br>0 0 b <sub>1</sub> b <sub>0</sub> p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub> | 3 B<br>b y   | P[p]<b>←1                                                                                                                                                                                                                                                  | - -     | 1  | 2  |
|                              |                       |                                                                                                                  |              | Sets the bit, which is specified by the b of the instruction field, of the port specified by the p of the instruction field, to "1".                                                                                                                       |         |    |    |
|                              | SET @L                | 0 0 1 1 0 1 0 0                                                                                                  | 3 4          | P[(LR)<3:2>+4]<(LR)<1:0>>←1                                                                                                                                                                                                                                | - -     | 1  | 2  |
|                              |                       |                                                                                                                  |              | Sets the bit, which is specified by the lower-order two bits of the L register, of the ports R <sub>4</sub> - R <sub>7</sub> specified by the higher-order two bits of the L register, to "1".                                                             |         |    |    |
| Bit Manipulation Instruction | CLR GF                | 0 0 0 0 0 0 1 0                                                                                                  | 0 2          | (GF)←0                                                                                                                                                                                                                                                     | - -     | 1  | 1  |
|                              |                       |                                                                                                                  |              | Clears the general flag to "0".                                                                                                                                                                                                                            |         |    |    |
| Bit Manipulation Instruction | CLR @HL, b            | 0 1 0 1 0 1 b <sub>1</sub> b <sub>0</sub>                                                                        | 5 4+b        | M[(H·L)]<b>←0                                                                                                                                                                                                                                              | - -     | 1  | 1  |
|                              |                       |                                                                                                                  |              | Clears the bit, which is specified by the b of the instruction field, of the data memory specified by the H and L register, to "0".                                                                                                                        |         |    |    |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Items<br>Class               | Assembler<br>Mnemonic | Object Code                                                                                                      |                                        | Function                                                                                                                                                                                         | Flag(*) |   |   |
|------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---|---|
|                              |                       | Binary                                                                                                           | (**)                                   |                                                                                                                                                                                                  | C       | F | Z |
| Bit Manipulation Instruction | CLR y, b              | 0 0 1 1 1 0 0 1<br>0 1 b <sub>1</sub> b <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 3 9<br>4+b y                           | M[y]<b> ← 0                                                                                                                                                                                      | - -     | 1 | 2 |
|                              | CLR %P, b             | 0 0 1 1 1 0 1 1<br>0 1 b <sub>1</sub> b <sub>0</sub> p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub> | 3 B<br>4+b p                           | P[p]<b> ← 0                                                                                                                                                                                      | - -     | 1 | 2 |
|                              | CLR @L                | 0 0 1 1 0 1 0 1                                                                                                  | 3. 5                                   | P[(LR)<3:2>+4]<(LR)<1:0>>←0                                                                                                                                                                      | - -     | 1 | 2 |
|                              |                       |                                                                                                                  |                                        | Clears the bit, which is specified by the lower-order two bits of the L register, of the ports R <sub>4</sub> - R <sub>7</sub> specified by the higher-order two bits of the L register, to "0". |         |   |   |
|                              | CLR IL, r             | 0 0 1 1 0 1 1 0<br>1 1 r <sub>5</sub> r <sub>4</sub> r <sub>3</sub> r <sub>2</sub> r <sub>1</sub> r <sub>0</sub> | 3 6<br>C+r <sub>H</sub> r <sub>L</sub> | (INTL)<5:0>←(INTL)<5:0>Λr<5:0>                                                                                                                                                                   | - -     | 1 | 2 |
|                              |                       |                                                                                                                  |                                        | Resets the interrupt latch INTL <sub>j</sub> when the r <sub>j</sub> of the instruction field is "0". (j = 5 - 0)                                                                                |         |   |   |
| Input Instruction            | EICLR IL,r            | 0 0 1 1 0 1 1 0<br>0 1 r <sub>5</sub> r <sub>4</sub> r <sub>3</sub> r <sub>2</sub> r <sub>1</sub> r <sub>0</sub> | 3 6<br>4+r <sub>H</sub> r <sub>L</sub> | (EIF)←1,<br>(INTL)<5:0>←(INTL)<5:0>Λr<5:0>                                                                                                                                                       | - -     | 1 | 2 |
|                              | DICLR IL,r            | 0 0 1 1 0 1 1 0<br>1 0 r <sub>5</sub> r <sub>4</sub> r <sub>3</sub> r <sub>2</sub> r <sub>1</sub> r <sub>0</sub> | 3 6<br>8+r <sub>H</sub> r <sub>L</sub> | (EIF)←0,<br>(INTL)<5:0>←(INTL)<5:0>Λr<5:0>                                                                                                                                                       | - -     | 1 | 2 |
|                              |                       |                                                                                                                  |                                        | Resets the interrupt enable master F/F to "0". Interrupt latch INTL <sub>j</sub> is reset when the r <sub>j</sub> of the instruction field is "0". (j = 5 - 0)                                   |         |   |   |
|                              | IN %P, A              | 0 0 1 1 1 0 1 0<br>0 0 1 0 p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub>                           | 3 2<br>P                               | (AC)←P[p]                                                                                                                                                                                        | -       | Z | 2 |
|                              |                       |                                                                                                                  |                                        | Places the input data from the port specified by the p of the instruction field in the accumulator.                                                                                              |         |   |   |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Items<br>Class                       | Assembler<br>Mnemonic | Object Code                                                                                                                                                                                    |               | Function                                                                                                                                                                                                                                                | Flag(*) |           |    |
|--------------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------|----|
|                                      |                       | Binary                                                                                                                                                                                         | (**)          |                                                                                                                                                                                                                                                         | CF      | ZF        | SF |
| Input/Output Instruction             | IN %P, @HL            | 0 0 1 1 1 0 1 0<br>0 1 1 0 p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub>                                                                                                         | 3 A<br>6 P    | M[(H·L)] $\leftarrow$ P[p]<br>Places the input data from the port specified by the p of the instruction field in the data memory specified by the H and L registers.                                                                                    | -       | $\bar{Z}$ | 2  |
|                                      | OUT A, %P             | 0 0 1 1 1 0 1 0<br>1 0 p <sub>4</sub> 0 p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub>                                                                                            | 3 A<br>8+2P4P | P[p] $\leftarrow$ (AC), P=P <sub>4</sub> P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>                                                                                                                                                    | - -     | 1         | 2  |
|                                      | OUT @HL,%P            | 0 0 1 1 1 0 1 0<br>1 1 p <sub>4</sub> 0 p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub>                                                                                            | 3 A<br>C+2P4P | P[p] $\leftarrow$ M[(H·L)], P=P <sub>4</sub> P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>                                                                                                                                                | - -     | 1         | 2  |
|                                      | OUT #k,%P             | 0 0 1 0 1 1 0 0<br>k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub>                                                     | 2 C<br>k P    | P[p] $\leftarrow$ k<br>Outputs the immediate data k of the instruction field to the port specified by the p of the instruction field. Serves as the clear instruction when k = 0.                                                                       | - -     | 1         | 2  |
|                                      | OUTB @HL              | 0 0 0 1 0 0 1 0                                                                                                                                                                                | 1 2           | P[2]·P[1] $\leftarrow$ ROM[F·(E+(CF)) $\cdot$ M[(H·L)]]                                                                                                                                                                                                 | - -     | 1         | 2  |
| Branch.<br>Subroutine<br>Instruction | BS a                  | 0 1 1 0 a <sub>9</sub> a <sub>8</sub> a <sub>9</sub> a <sub>8</sub><br>a <sub>7</sub> 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> | 6 aH<br>aM aL | If SF=1 then (PC) $\leftarrow$ a else null.<br>Places the immediate data a of the instruction field in the program counter if the status flag is at "1". If the status flag is at "0", sets the status flag only to "1", and moves to the next address. | - -     | 1         | 2  |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Items<br>Class                | Assembler<br>Mnemonic | Object Code                                                                                                                                                                        |               | Function                                                                                                                                                                            | Flag(*) |     | (**) |
|-------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----|------|
|                               |                       | Binary                                                                                                                                                                             | (*)           |                                                                                                                                                                                     | CF      | ZF  |      |
| Branch/Subroutine Instruction | BSS a                 | 1 0 d <sub>5</sub> d <sub>4</sub> d <sub>3</sub> d <sub>2</sub> d <sub>1</sub> d <sub>0</sub>                                                                                      | 8+dHdL        | If SF=1 then (PC)←a else null,<br>a=(PC)<11·6>·d                                                                                                                                    | -       | - 1 | 1    |
|                               | CALL a                | 0 0 1 0 0 a <sub>10</sub> a <sub>9</sub> a <sub>8</sub><br>a <sub>7</sub> 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> | 2 AH<br>AM aL | STACK[(SPW)]←(PC), (SPW)←(SPW)-1<br>(PC)←a, 0 ≤ a ≤ 2,047                                                                                                                           | -       | - - | 2    |
|                               | CALLS a               | 0 1 1 1 n <sub>3</sub> n <sub>2</sub> n <sub>1</sub> n <sub>0</sub>                                                                                                                | 7 n           | STACK[(SPW)]←(PC), (SPW)←(SPW)-1<br>(PC)←a, a=8n+6(n=0), 134(n=0)                                                                                                                   | -       | - - | 2    |
|                               | RET                   | 0 0 1 0 1 0 1 1                                                                                                                                                                    | 2 A           | (SPW)←(SPW)+1, (PC)←STACK[(SPW)]                                                                                                                                                    | -       | - - | 2    |
|                               |                       |                                                                                                                                                                                    |               | Returns from the subroutine to the previous<br>program; increments the stack pointer word,<br>and restores the data of the return address<br>from the stack to the program counter. |         |     |      |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

| Item<br>Class                    | Assembler<br>Mnemonic | Object Code     |      | Function                                                                                                                                                                                                                                                                                                | Flag(*)                |     | (**) |
|----------------------------------|-----------------------|-----------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----|------|
|                                  |                       | Binary          | (**) |                                                                                                                                                                                                                                                                                                         | Functional Description |     |      |
| Branch-Subroutine<br>Instruction | RETI                  | 0 0 1 0 1 0 1 1 | 2 B  | $(SPW) + (SPW) + 1$ ,<br>$(FLAG \cdot PC) \leftarrow STACK[(SPW)]$ , $(EIF) \leftarrow 1$                                                                                                                                                                                                               | * * *                  |     | 2    |
|                                  |                       |                 |      | Returns from the interrupt processing routine;<br>increments the stack pointer word, and re-<br>stores the data of the return address from<br>the stack and the data of the flag, to the<br>program counter and the flag, respectively.<br>And then, it sets the interrupt enable master<br>F/P to "1". |                        |     |      |
| Other<br>Instruc-<br>tion        | NOP                   | 0 0 0 0 0 0 0 0 | 0 0  | no operation                                                                                                                                                                                                                                                                                            |                        | --- | 1    |
|                                  |                       |                 |      | Moves to the next instruction without performing any operation.                                                                                                                                                                                                                                         |                        |     |      |

## Note 1. Setting Condition of Flag.

"C" indicates the carry output from the most significant position in the addition operation, and "B" indicates the borrow output from the most significant position in the subtraction operation.

"Z" indicates the zero detection signal to which "1" is applied only when either the ALU output of the processing result or all four bits of the data transferred to the accumulator are zero.

The flag is set to "C", " $\bar{C}$ ", " $\bar{B}$ ", "z", " $\bar{z}$ ", "1", or "0" according to the data processing result. The value specified by the function is set to the flag with the mark "\*", and the mark "-" denotes no change in the state of the flag.

- Note 2. The zero flag is set according to the data set in the accumulator.
- Note 3. The flags (ZF, SF) are set according to the result of increment or decrement of the L register.
- Note 4. The carry is the data shifted out from the accumulator.
- Note 5. The contents of the program counter indicate the next address of the instruction to be executed.



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P  
TMP4720P

PRELIMINARY

## ELECTRICAL CHARACTERISTICS

ABSOLUTE MAXIMUM RATINGS ( $V_{SS}=0V$ )

| SYMBOL     | ITEM                                       | RATING       | UNITS      |
|------------|--------------------------------------------|--------------|------------|
| $V_{DD}$   | Supply Voltage                             | -0.5 ~ 7     | V          |
| $V_{HH}$   |                                            |              |            |
| $V_{IN}$   | Input Voltage                              | -0.5 ~ 7     | V          |
| $V_{OUT1}$ | Output Voltage (Except Open Drain Port)    | -0.5 ~ 7     | V          |
| $V_{OUT2}$ | Output Voltage (Open Drain Port)           | -0.5 ~ 10    |            |
| $I_{OUT}$  | Output Current ( $P_1, P_2$ )              | 30           | mA         |
| $P_D$      | Power Dissipation ( $T_{opr}=70^\circ C$ ) | 850          | mW         |
| $T_{sol}$  | Soldering Temperature · Time               | 260 (10 sec) |            |
| $T_{stg}$  | Storage Temperature                        | -55 ~ 125    | $^\circ C$ |
| $T_{opr}$  | Operating Temperature                      | -30 ~ 70     |            |

RECOMMENDED OPERATING CONDITIONS ( $V_{SS}=0V$ )

| SYMBOL    | ITEM                                              | CONDITION       | MIN. | MAX.     | UNITS      |
|-----------|---------------------------------------------------|-----------------|------|----------|------------|
| $T_{opr}$ | Operating Temperature                             |                 | -30  | 70       | $^\circ C$ |
| $V_{DD}$  |                                                   |                 |      |          |            |
| $V_{HH}$  | Supply Voltage                                    |                 | 4.5  | 5.5      | V          |
| $V_{HH1}$ | Supply Voltage (Memory Stand-by)                  |                 | 3.5  | 5.5      |            |
| $V_{IH1}$ | High Level Input Voltage ( $R_4 \sim R_7$ )       |                 | 2.2  | $V_{DD}$ |            |
| $V_{IH2}$ | High Level Input Voltage (Except $R_4 \sim R_7$ ) |                 | 3    | $V_{DD}$ | V          |
| $V_{IL1}$ | Low Level Input Voltage (Except $K_0$ )           |                 | 0    | 0.8      |            |
| $V_{IL2}$ | Low Level Input Voltage ( $K_0$ )                 |                 | 0    | 1.2      |            |
| $f_C$     | Clock Frequency                                   |                 | 0.4  | 4.2      | MHz        |
| $t_{WCH}$ | High Level Clock Pulse Width (Note 1)             | $V_{IN}=V_{IH}$ | 80   | -        |            |
| $t_{WCL}$ | Low Level Clock Pulse Width (Note 1)              | $V_{IN}=V_{IL}$ | 80   | -        | nS         |

(Note 1) For external clock operation.

DC CHARACTERISTICS ( $V_{SS}=0V$ ,  $V_{DD}=V_{HH}=5V \pm 10\%$ ,  $T_{opr}=-30 \sim 70^\circ C$ )

| SYMBOL          | PARAMETER                                                   | CONDITION                            | MIN. | (Note 1)<br>TYP. | MAX. | UNITS   |
|-----------------|-------------------------------------------------------------|--------------------------------------|------|------------------|------|---------|
| $V_{HS}$        | Hysteresis Voltage<br>(Schmitt Circuit Input)               |                                      | -    | 0.5              | -    | V       |
| $I_{IN1}$       | Input Current (Note 2)<br>( $K_0$ , RESET, TEST)            | $V_{DD}=V_{HH}=5.5V$ , $V_{IN}=5.5V$ | -    | -                | 20   | $\mu A$ |
| $I_{IN2}$       | Input Current<br>(Open Drain R Port)                        | $V_{DD}=5.5V$ , $V_{IN}=5.5V$        | -    | -                | 20   | $\mu A$ |
| $I_{IL}$        | Low Level Input Current<br>(R Port with Pull-up Resistor)   | $V_{DD}=5.5V$ , $V_{IN}=0.4V$        | -    | -                | -2   | mA      |
| $I_{LO}$        | Output Leak Current<br>(Open Drain P, R Port)               | $V_{DD}=5.5V$ , $V_{OUT}=5.5V$       | -    | -                | 20   | $\mu A$ |
| $V_{OH}$        | High Level Output Voltage<br>(R Port with Full-up Resistor) | $V_{DD}=4.5V$ , $I_{OH}=-200\mu A$   | 2.4  | -                | -    | V       |
| $V_{OL}$        | Low Level Output Voltage<br>(Except XOUT)                   | $V_{DD}=4.5V$ , $I_{OL}=1.6mA$       | -    | -                | 0.4  | V       |
| $I_{OL}$        | Low Level Output Current<br>( $P_1$ , $P_2$ )               | $V_{DD}=5V$ , $V_{OL}=1V$            | -    | 20               | -    | mA      |
| $I_{DD+I_{HH}}$ | Supply Current                                              | $V_{DD}=V_{HH}=5.5V$                 | -    | 50               | 100  | mA      |
| $I_{HH1}$       | Supply Current(Memory Stand-by)                             | $V_{DD}=V_{SS}$ , $V_{HH}=3.5V$      | -    | 5                | 10   | mA      |

(Note 1) Typical values are at  $T_{opr}=25^\circ C$ ,  $V_{DD}=V_{HH}=5V$ .

(Note 2) When an input resistor is built in the device, the input current through the resistor is eliminated.

AC CHARACTERISTICS ( $V_{SS}=0V$ ,  $V_{DD}=V_{HH}=5V \pm 10\%$ ,  $T_{opr}=-30 \sim 70^\circ C$ )

| SYMBOL    | PARAMETER              | CONDITION | MIN.               | TYP. | MAX. | UNITS   |
|-----------|------------------------|-----------|--------------------|------|------|---------|
| $t_{cy}$  | Instruction Cycle Time |           | 1.9                | -    | 20   | $\mu s$ |
| $t_{SDH}$ | Shift data hold time   | (Note 1)  | 0.5 $t_{cy}$ - 300 | -    | -    | ns      |

## AC TIMING CHART

- Serial Port (Completion of transmission)



(Note 1) External circuit for serial ports SCK and SO

## EXTERNAL DIMENSION VIEW

Unit in mm



Weight 5.7g (TYP.)

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.42 leads.



## Specification of program tape and input/output circuit format

Engineering Samples(ES) of the TMP4740P and TMP4720P will be made if you specify the program data and input/output circuit format by use of a paper tape.

The paper tape format is equivalent to the Hex. format of Intel Co. (Format I).

The program data should be specified within the address space corresponding to the built-in ROM capacity; the addresses 000 - 7FF denote the address range in the TMP4720P. Accordingly, if the PLA data conversion table (addresses FEO - FFF) is used, the table data must be assigned as the data located in addresses 7E0 - 7FF.

## 1. Specification of input/output circuit format

The paper tape of Format I starts recording the program data after record mark ":"; but the input/output circuit code should be specified just before the first record mark.

The "IÖCODE XX" format is used to define the input/output circuit code. XX denotes the proper input/output circuit code (two alphabets).

(Note) If the input/output circuit code is not specified, "IÖCODE AA" is employed. It should be noted that if the specified format is different from the standard one, and if the specified input/output circuit code is illegal, such specifications may be considered to have not been made.

(Example of tape list)

```
TOSHIBA MICROCOMPUTER TLCS-47
IÖCODE AA
:100000000665C7D79CF50F3F951FED55A8FF16E570
:1000100088884DDE67E31F5D8ABA6DF292F113F5C1
:100020004FF1F
:
:
:
:1007E000B53D42E0EC32546025B7308CDD52063D1D
:1007F000B4BE9E9E345B6138060B20BC372BF60BD6
:00000001FF
```

## 2. Program tape format (Format I)





## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4740P

TMP4720P

PRELIMINARY

## LIST OF INSTRUCTIONS

| Item<br>Classification | Assembler<br>Mnemonic | Object Code       |                                                                                                                         |                                           |                                                                                                                                      | Function | #1<br>Plazs | Execution cycle |  |  |  |
|------------------------|-----------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------|-------------|-----------------|--|--|--|
|                        |                       | Binary            |                                                                                                                         | Hexadecimal                               |                                                                                                                                      |          |             |                 |  |  |  |
|                        |                       | 1st Byte          | 2nd Byte                                                                                                                | 1st Byte                                  | 2nd Byte                                                                                                                             |          |             |                 |  |  |  |
|                        | LD A ,@HL             | 00 00 11 00       | 0 C                                                                                                                     | (AC)←M[(H+L)]                             | - Z 1 1                                                                                                                              |          |             |                 |  |  |  |
|                        | LD A , X              | 00 11 10 00       | x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 C x <sub>H</sub> x <sub>L</sub>         | (AC)←M[x]                                                                                                                            | - Z 1 2  |             |                 |  |  |  |
|                        | LD HL , X             | 00 10 10 00       | x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 2 8 x <sub>H</sub> x <sub>L</sub>         | (LR)←M[x], (HR)←M[x+1], x=x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>0</sub>   | - - 1 2  |             |                 |  |  |  |
|                        | LD A ,#K              | 01 00             | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 4 k                                       | (AC)←k                                                                                                                               | - Z 1 1  |             |                 |  |  |  |
|                        | LD H ,#K              | 11 00             | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | C k                                       | (HR)←k                                                                                                                               | - - 1 1  |             |                 |  |  |  |
|                        | LD L ,#K              | 11 10             | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | B k                                       | (LH)←k                                                                                                                               | - - 1 1  |             |                 |  |  |  |
|                        | LDL A ,@DC            | 00 11 00 11       | 3 3                                                                                                                     | (AC)←HOM <sub>L</sub> [(DC)]              | - Z 1 2                                                                                                                              |          |             |                 |  |  |  |
|                        | LDH A ,@DC+           | 00 11 00 10       | 3 2                                                                                                                     | (AC)←HOM <sub>H</sub> [(DC)], (DC)←(DC)+1 | - Z 1 2                                                                                                                              | *2       |             |                 |  |  |  |
| Move                   | ST A ,@HL             | 00 00 11 11       | 0 F                                                                                                                     | M[(H+L)]←(AC)                             | - - 1 1                                                                                                                              |          |             |                 |  |  |  |
|                        | ST A ,@HL+            | 00 01 10 10       | 1 A                                                                                                                     | M[(H+L)]←(AC), (LR)←(LR)+1                | - Z C 1                                                                                                                              | *3       |             |                 |  |  |  |
|                        | ST A ,@HL-            | 00 01 10 11       | 1 B                                                                                                                     | M[(H+L)]←(AC), (LR)←(LR)-1                | - Z E 1                                                                                                                              | *3       |             |                 |  |  |  |
|                        | ST A , X              | 00 11 11 11       | x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 F x <sub>H</sub> x <sub>L</sub>         | M[x]←(AC)                                                                                                                            | - - 1 2  |             |                 |  |  |  |
|                        | ST #K ,@HL+           | 11 11             | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | F k                                       | M[(H+L)]←k, (LR)←(LR)+1                                                                                                              | - Z C 1  | *3          |                 |  |  |  |
|                        | ST #K , y             | 00 11 10 01       | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 D k y                                   | M[y]←k                                                                                                                               | - - 1 2  |             |                 |  |  |  |
|                        | MOV H , A             | 00 01 00 00       | 1 0                                                                                                                     | (HR)←(AC)                                 | - Z 1 1                                                                                                                              |          |             |                 |  |  |  |
|                        | MOV L , A             | 00 01 00 01       | 1 1                                                                                                                     | (AC)←(LR)                                 | - Z 1 1                                                                                                                              |          |             |                 |  |  |  |
|                        | XCH A , H             | 00 11 00 00       | 3 0                                                                                                                     | (HR)←(AC)                                 | - Z 1 2                                                                                                                              | *2       |             |                 |  |  |  |
|                        | XCH A , L             | 00 11 00 01       | 3 1                                                                                                                     | (LR)←(AC)                                 | - Z 1 2                                                                                                                              | *2       |             |                 |  |  |  |
|                        | XCH A , EIR           | 00 01 00 11       | 1 3                                                                                                                     | (EIR)←(AC)                                | - - 1 1                                                                                                                              |          |             |                 |  |  |  |
|                        | XCH A ,@HL            | 00 11 11 01       | 0 D                                                                                                                     | M[(H+L)]←(AC)                             | - Z 1 1                                                                                                                              | *2       |             |                 |  |  |  |
|                        | XCH A , X             | 00 11 11 01       | x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 D x <sub>H</sub> x <sub>L</sub>         | M[x]←(AC)                                                                                                                            | - Z 1 2  | *2          |                 |  |  |  |
|                        | XCH HL , X            | 00 10 10 01       | x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 2 9 x <sub>H</sub> x <sub>L</sub>         | M[x']←(LR), M[x'+1]←(HR), x=x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>0</sub> | - - 1 2  |             |                 |  |  |  |
| Compare                | CMPL A ,@HL           | 00 01 01 10       | 1 6                                                                                                                     | null←M[(H+L)]-(AC)                        | B Z C 1                                                                                                                              |          |             |                 |  |  |  |
|                        | CMPL A , X            | 00 11 10 10       | x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 B x <sub>H</sub> x <sub>L</sub>         | null←M[x]-(AC)                                                                                                                       | B Z C 2  |             |                 |  |  |  |
|                        | CMPL A ,#K            | 11 01             | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | D k                                       | null←k-(AC)                                                                                                                          | B Z C 1  |             |                 |  |  |  |
|                        | CMPL H ,#K            | 00 11 10 00 11 01 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 8 D k                                   | null←k-(HR)                                                                                                                          | B E 2    |             |                 |  |  |  |
|                        | CMPL L ,#K            | 00 11 10 00 10 01 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 8 9 k                                   | null←k-(LR)                                                                                                                          | B E 2    |             |                 |  |  |  |
|                        | CMPL y ,#K            | 00 11 10 11 10    | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 E k y                                   | null←k-M[y]                                                                                                                          | B Z C 2  |             |                 |  |  |  |
| Arithmetic             | INC A                 | 00 00 10 00       | 0 8                                                                                                                     | (AC)←(AC)+1                               | - Z C 1                                                                                                                              |          |             |                 |  |  |  |
|                        | INC L                 | 00 01 10 00       | 1 8                                                                                                                     | (LR)←(LR)+1                               | - Z C 1                                                                                                                              |          |             |                 |  |  |  |
|                        | INC @HL               | 00 00 10 10       | 0 A                                                                                                                     | M[(H+L)]←M[(H+1)]+1                       | - Z C 1                                                                                                                              |          |             |                 |  |  |  |
|                        | DEC A                 | 00 00 10 01       | 0 9                                                                                                                     | (AC)←(AC)-1                               | - Z B 1                                                                                                                              |          |             |                 |  |  |  |
|                        | DRC L                 | 00 01 10 01       | 1 9                                                                                                                     | (LR)←(LR)-1                               | - Z B 1                                                                                                                              |          |             |                 |  |  |  |
|                        | DEC @HL               | 00 00 10 11       | 0 B                                                                                                                     | M[(H+L)]←M[(H+1)]-1                       | - Z B 1                                                                                                                              |          |             |                 |  |  |  |
|                        | ADDC A ,@HL           | 00 01 01 01       | 1 5                                                                                                                     | (AC)←(AC)+M[(H+L)]+(CP)                   | C Z C 1                                                                                                                              |          |             |                 |  |  |  |
|                        | ADD A ,@HL            | 00 01 01 11       | 1 7                                                                                                                     | (AC)←(AC)+M[(H+L)]                        | C Z C 1                                                                                                                              |          |             |                 |  |  |  |
|                        | ADD A ,#K             | 00 11 10 00 00 00 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 8 0 k                                   | (AC)←(AC)+k                                                                                                                          | - Z C 2  |             |                 |  |  |  |
|                        | ADD H ,#K             | 00 11 10 00 11 00 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 8 C k                                   | (HR)←(HR)+k                                                                                                                          | - Z C 2  |             |                 |  |  |  |
|                        | ADD L ,#K             | 00 11 10 00 10 01 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 8 B k                                   | (LR)←(LR)+k                                                                                                                          | - Z C 2  |             |                 |  |  |  |
|                        | ADQ @HL,#K            | 00 11 10 00 01 00 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 8 4 k                                   | M[(H+L)]←M[(H+L)]+k                                                                                                                  | - Z C 2  |             |                 |  |  |  |
|                        | ADD y ,#K             | 00 11 10 01 11    | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 F k y                                   | M[y]←M[y]+k                                                                                                                          | - Z C 2  |             |                 |  |  |  |
| Logical                | SUBR A ,@HL           | 00 01 01 00       | 1 4                                                                                                                     | (AC)←M[(H+L)]-(AC)-(CP)                   | B Z B 1                                                                                                                              |          |             |                 |  |  |  |
|                        | SUBR A ,#K            | 00 11 10 00 00 01 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 8 1 k                                   | (AC)←k-(AC)                                                                                                                          | - Z B 2  |             |                 |  |  |  |
|                        | SUBR @HL,#K           | 00 11 10 00 01 01 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 8 5 k                                   | M[(H+L)]←k-M[(H+L)]                                                                                                                  | - Z B 2  |             |                 |  |  |  |
|                        | ROLC A                | 00 00 01 01       | 0 5                                                                                                                     | <u>CP ← AC</u> (rotate left by 1 bit)     | C Z C 1                                                                                                                              | *4       |             |                 |  |  |  |
|                        | RORC A                | 00 00 01 11       | 0 7                                                                                                                     | <u>AC ← CP</u> (rotate right by 1 bit)    | C Z C 1                                                                                                                              | *4       |             |                 |  |  |  |
|                        | AND A ,@HL            | 00 01 11 10       | 1 E                                                                                                                     | (AC)←(AC) M[(H+L)]                        | - Z B 1                                                                                                                              |          |             |                 |  |  |  |
|                        | AND A ,#K             | 00 11 10 00 00 11 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 8 3 k                                   | (AC)←(AC) k                                                                                                                          | - Z C 2  |             |                 |  |  |  |
|                        | AND @HL,#K            | 00 11 10 00 01 11 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 9 7 k                                   | M[(H+L)]←M[(H+L)] k                                                                                                                  | - Z C 2  |             |                 |  |  |  |
|                        | OR A ,@HL             | 00 01 11 01       | 1 D                                                                                                                     | (AC)←(AC) V M[(H+L)]                      | - Z Z 1                                                                                                                              |          |             |                 |  |  |  |
|                        | OR A ,#K              | 00 11 10 00 00 11 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 8 2 k                                   | (AC)←(AC) V k                                                                                                                        | - Z Z 2  |             |                 |  |  |  |
|                        | OR @HL,#K             | 00 11 10 00 01 10 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 8 6 k                                   | M[(H+L)]←M[(H+L)] V k                                                                                                                | - Z Z 2  |             |                 |  |  |  |
|                        | XOR A ,@HL            | 00 01 11 11       | 1 F                                                                                                                     | (AC)←(AC) W M[(H+L)]                      | - Z Z 1                                                                                                                              |          |             |                 |  |  |  |



# INTEGRATED CIRCUIT

## TECHNICAL DATA

PRELIMINARY

(continued)

| Item<br>Classification | Assembler<br>Mnemonic | Object Code                                                                                                                            |          |                                                |             | Function                                                                         | Flags       |             |             | Execution<br>Cycle |  |  |
|------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------|----------|------------------------------------------------|-------------|----------------------------------------------------------------------------------|-------------|-------------|-------------|--------------------|--|--|
|                        |                       | Binary                                                                                                                                 |          | Hexadecimal                                    |             |                                                                                  | 1st<br>Byte | 2nd<br>Byte | 1st<br>Byte | 2nd<br>Byte        |  |  |
|                        |                       | 1st Byte                                                                                                                               | 2nd Byte | 1st<br>Byte                                    | 2nd<br>Byte |                                                                                  |             |             |             |                    |  |  |
| Bit Manipulation       | TEST CF               | 00 00 01 10                                                                                                                            |          | 0 6                                            |             | (SF) ← (CF), (CF) ← 0                                                            |             |             | 0 - * 1     |                    |  |  |
|                        | TEST A , b            | 01 01 11 b <sub>b</sub> b <sub>0</sub>                                                                                                 |          | 5 C+b                                          |             | (SF) ← (AC)<>                                                                    |             |             | - - * 1     |                    |  |  |
|                        | TEST @HL, b           | 01 01 10 b <sub>1</sub> b <sub>0</sub>                                                                                                 |          | 5 8+b                                          |             | (SF) ← M[(H+L)]<b>                                                               |             |             | - - * 1     |                    |  |  |
|                        | TEST y , b            | 00 11 10 01 10 b <sub>1</sub> b <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub>                               |          | 3 9 8+b y                                      |             | (SF) ← M[y]<b>                                                                   |             |             | - - * 2     |                    |  |  |
|                        | TEST %p , b           | 00 11 10 11 10 b <sub>1</sub> b <sub>0</sub> P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>                               |          | 3 B 8+b p                                      |             | (SF) ← P[p]<b>                                                                   |             |             | - - * 2     |                    |  |  |
|                        | TEST @L               | 00 11 01 11                                                                                                                            |          | 3 7                                            |             | (SF) ← P[(LR)<3:2>+4]<(LR)<1:0>>                                                 |             |             | - - * 2     |                    |  |  |
|                        | TESTP CF              | 00 00 01 00                                                                                                                            |          | 0 4                                            |             | (SF) ← (CF), (CF) ← 1                                                            |             |             | 1 - * 1     |                    |  |  |
|                        | TESTP ZF              | 00 00 11 10                                                                                                                            |          | 0 E                                            |             | (SF) ← (ZF)                                                                      |             |             | - - * 1     |                    |  |  |
|                        | TESTP OF              | 00 00 00 01                                                                                                                            |          | 0 1                                            |             | (SF) ← (OF)                                                                      |             |             | - - * 1     |                    |  |  |
|                        | TESTP y , b           | 00 11 10 01 11 b <sub>1</sub> b <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub>                               |          | 3 9 C+b y                                      |             | (SF) ← M[y]<b>                                                                   |             |             | - - * 2     |                    |  |  |
|                        | TESTP %p , b          | 00 11 10 11 11 b <sub>1</sub> b <sub>0</sub> P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>                               |          | 3 B C+b p                                      |             | (SF) ← P[p]<b>                                                                   |             |             | - - * 2     |                    |  |  |
|                        | SET GF                | 00 00 00 11                                                                                                                            |          | 0 3                                            |             | (GR) ← 1                                                                         |             |             | - - 1 1     |                    |  |  |
|                        | SET @HL, b            | 01 01 00 b <sub>b</sub> b <sub>0</sub>                                                                                                 |          | 5 b                                            |             | M[(H+L)]<b>-1                                                                    |             |             | - - 1 1     |                    |  |  |
|                        | SET y , b             | 00 11 10 01 00 b <sub>1</sub> b <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub>                               |          | 3 9 b y                                        |             | M[y]<b>-1                                                                        |             |             | - - 1 2     |                    |  |  |
|                        | SET %p , b            | 00 11 10 11 00 b <sub>1</sub> b <sub>0</sub> P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>                               |          | 3 B b p                                        |             | P[p]<b>-1                                                                        |             |             | - - 1 2     |                    |  |  |
|                        | SET @L                | 00 11 01 00                                                                                                                            |          | 3 4                                            |             | P[(LR)<3:2>+4]<(LR)<1:0>>-1                                                      |             |             | - - 1 2     |                    |  |  |
| Input/Output           | CLR GF                | 00 00 00 10                                                                                                                            |          | 0 2                                            |             | (GR) ← 0                                                                         |             |             | - - 1 1     |                    |  |  |
|                        | CLR @HL, b            | 01 01 01 b <sub>b</sub> b <sub>0</sub>                                                                                                 |          | 5 4+b                                          |             | M[(H+L)]<b>-0                                                                    |             |             | - - 1 1     |                    |  |  |
|                        | CLR y , b             | 00 11 10 01 01 b <sub>1</sub> b <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub>                               |          | 3 9 4+b y                                      |             | M[y]<b>-0                                                                        |             |             | - - 1 2     |                    |  |  |
|                        | CLR %p , b            | 00 11 10 11 01 b <sub>1</sub> b <sub>0</sub> P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>                               |          | 3 B 4+b p                                      |             | P[p]<b>-0                                                                        |             |             | - - 1 2     |                    |  |  |
|                        | CLR @L                | 00 11 01 01                                                                                                                            |          | 3 5                                            |             | P[(LR)<3:2>+4]<(LR)<1:0>>-0                                                      |             |             | - - 1 2     |                    |  |  |
|                        | CLR IL , r            | 00 11 01 10 11 I <sub>5</sub> I <sub>4</sub> I <sub>3</sub> I <sub>2</sub> I <sub>1</sub> I <sub>0</sub>                               |          | 3 6 C+r <sub>HL</sub>                          |             | (INTL)<5:0><- (INTL)<6:0>&r<5:0>                                                 |             |             | - - 1 2     |                    |  |  |
|                        | EICLR IL , r          | 00 11 01 10 01 I <sub>5</sub> I <sub>4</sub> I <sub>3</sub> I <sub>2</sub> I <sub>1</sub> I <sub>0</sub>                               |          | 3 6 4+r <sub>HL</sub>                          |             | (EIF)<1,(INTL)<5:0><- (INTL)<3:0>&r<5:0>                                         |             |             | - - 1 2     |                    |  |  |
|                        | DICLR IL , r          | 00 11 01 10 10 I <sub>5</sub> I <sub>4</sub> I <sub>3</sub> I <sub>2</sub> I <sub>1</sub> I <sub>0</sub>                               |          | 3 6 8+r <sub>HL</sub>                          |             | (ERD)<0,(INTL)<5:0><- (INTL)<5:0>&r<5:0>                                         |             |             | - - 1 2     |                    |  |  |
|                        | IN %p , A             | 00 11 10 10 00 P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>                                                             |          | 3 A z p                                        |             | (AC) ← P[p]                                                                      |             |             | - z Z 2     |                    |  |  |
|                        | IN %p , @HL           | 00 11 10 11 01 P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>                                                             |          | 3 A 6 p                                        |             | M[(H+L)] ← P[p]                                                                  |             |             | - z Z 2     |                    |  |  |
| Branch Subroutine      | OUT A ,%p             | 00 11 00 10 10 I <sub>5</sub> I <sub>4</sub> I <sub>3</sub> I <sub>2</sub> I <sub>1</sub> I <sub>0</sub>                               |          | 3 A 6+p                                        |             | p[P] ← (AC) , p = P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>    |             |             | - - 1 2     |                    |  |  |
|                        | OUT @HL,%p            | 00 11 10 11 I <sub>5</sub> I <sub>4</sub> I <sub>3</sub> I <sub>2</sub> I <sub>1</sub> I <sub>0</sub>                                  |          | 3 A C+2F <sub>4</sub> p                        |             | p[P] ← M[(H+L)], p = P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub> |             |             | - - 1 2     |                    |  |  |
|                        | OUT #k ,%p            | 00 11 10 11 00 K <sub>3</sub> K <sub>2</sub> K <sub>1</sub> K <sub>0</sub> P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub> |          | 2 K C p                                        |             | p[P] ←                                                                           |             |             | - - 1 2     |                    |  |  |
|                        | OUTB @HL              | 00 01 00 10                                                                                                                            |          | 1 Z                                            |             | P[2],P[1] ← ROM[F*(E+(CF))*M[(H+L)]]                                             |             |             | - - 1 2     |                    |  |  |
|                        | BSS a                 | 01 10 a <sub>H</sub> a <sub>M</sub> a <sub>L</sub>                                                                                     |          | 6 a <sub>H</sub> a <sub>M</sub> a <sub>L</sub> |             | If SF=1 then (PC) ← a else null.                                                 |             |             | - - 1 2     |                    |  |  |
| Other                  | BSS a                 | 10 d <sub>5</sub> d <sub>4</sub> d <sub>3</sub> d <sub>2</sub> d <sub>1</sub> d <sub>0</sub>                                           |          | 8+d <sub>1</sub> d <sub>0</sub>                |             | If SF=0 then (PC) ← a else null,a=(PC)&1:&d->d                                   |             |             | - - 1 1 *5  |                    |  |  |
|                        | CALL a                | 00 10 a <sub>H</sub> a <sub>M</sub> a <sub>L</sub>                                                                                     |          | 2 a <sub>H</sub> a <sub>M</sub> a <sub>L</sub> |             | STACK[(SPW)] ← (PC),(SPW) ← (SPW)-1,                                             |             |             | - - - 2 *5  |                    |  |  |
|                        | CALLS a               | 01 11 a <sub>H</sub> a <sub>M</sub> a <sub>L</sub>                                                                                     |          | 7 a                                            |             | (PC) ← a,&a≤2,047                                                                |             |             | - - - 2 *5  |                    |  |  |
|                        | RET                   | 00 10 10 10                                                                                                                            |          | 2 A                                            |             | STACK[(SPW)] ← (PC),(SPW) ← (SPW)-1,                                             |             |             | - - - 2     |                    |  |  |
|                        | RETI                  | 00 10 10 11                                                                                                                            |          | 2 B                                            |             | (PC) ← a,&a=2,047-&n,134(n=..)                                                   |             |             | * * * 2     |                    |  |  |
|                        | NOP                   | 00 00 00 00                                                                                                                            |          | 0 0                                            |             | no operation                                                                     |             |             | - - - 1     |                    |  |  |

Note 1 Setting Condition of Flag.

"C" indicates the carry output from the most significant position in the addition operation, and "B" indicates the borrow output from the most significant position in the subtraction operation.

"Z" indicates the zero detection signal to which "1" is applied only when either the ALU output or the processing result of all four bits of the data transferred to the accumulator are zero.

The flag is set to "C", "C", "B", "Z", "Z", "1", or "0" according to the same processing result. The value specified by the function is set to the flag with the mark "\*", and the mark "-" denotes no change in the state of the flag.

Note 2 The zero flag is set according to the data set in the accumulator.

Note 3 The flags(ZF, SF) are set according to the result of increment or decrement of the L register.

Note 4 The carry is the data shifted out from the accumulator.

Note 5 The contents of the program counter indicate the next address of the instruction to be executed.

Operation Code Map

| Lower<br>higher | 0   | 1     | 2     | 3     | 4     | 5     | 6      | 7      | 8     | 9      | A      | B      | C     | D     | E     | F     |
|-----------------|-----|-------|-------|-------|-------|-------|--------|--------|-------|--------|--------|--------|-------|-------|-------|-------|
| 0               | NOP | TESTP | CLR   | SET   | TESTP | ROL   | TEST   | RORC   | INC   | DEC    | INC    | DEC    | LD    | XCH   | TESTP | ST    |
|                 | OF  | OF    | OF    | OF    | GP    | GP    | CF     | A      | A     | A      | @HL    | @HL    | A,@HL | A,@HL | ZP    | A,@HL |
| 1               | MOV | MOV   | CMPB  | XCH   | SUBR  | CADD  | CMPR   | ADD    | INC   | DEC    | ST     | ST     | OR    | AND   | XOR   |       |
|                 | H,A | L,A   | @HL   | @HL   | A,@HL | A,@HL | A,@HL  | A,@HL  | L     | L      | A,@HL  | A,@HL  | A,@HL | A,@HL | A,@HL |       |
| 2               |     | CALL  | a     |       |       |       | LD     | XCH    | RET   | RET    | OUT    | ST     | CMPR  | ADD   |       |       |
|                 |     |       |       |       |       |       | HL,x   | HL,x   |       |        | #k     | #k,y   | #k,y  | #k,y  |       |       |
| 3               | XCH | XCH   | LDH   | LX    | SET   | CLR   | (OP36) | (OP36) | TEST  | (OP36) | (OP36) | (OP36) | LD    | XCH   | CMPR  | ST    |
|                 | A,H | A,L   | A,@DC | A,@DC | @L    | @L    |        |        |       |        | A,x    | A,x    | A,x   | A,x   | A,x   |       |
| 4               |     |       |       |       | LD    | A,#k  |        |        |       |        |        |        |       |       |       |       |
| 5               |     | SET   | @HL,b |       | CLR   | @HL,b |        | TEST   | @HL,b |        | TEST   | A,b    |       |       |       |       |
| 6               |     |       |       |       | BS    | a     |        |        |       |        |        |        |       |       |       |       |
| 7               |     |       |       |       | CALLS | a     |        |        |       |        |        |        |       |       |       |       |
| 8               |     |       |       |       |       |       |        |        |       |        |        |        |       |       |       |       |
| 9               |     |       |       |       |       |       | BSS    | a      |       |        |        |        |       |       |       |       |
| A               |     |       |       |       |       |       |        |        |       |        |        |        |       |       |       |       |
| B               |     |       |       |       |       |       |        |        |       |        |        |        |       |       |       |       |
| C               |     |       |       |       |       |       | LD     | H,     | #k    |        |        |        |       |       |       |       |
| D               |     |       |       |       |       |       |        | CMPR   | A,    | #k     |        |        |       |       |       |       |
| E               |     |       |       |       |       |       |        | LD     | L,    | #k     |        |        |       |       |       |       |
| F               |     |       |       |       |       |       |        | ST     | #k,   | @HL+   |        |        |       |       |       |       |

## (caution)

1. Blank codes are reserved.
2.  is indicated 2-byte instruction.

(continued)

| 1st byte code            | OP36  | OP38             | OP39          | OP3A | OP3B           |
|--------------------------|-------|------------------|---------------|------|----------------|
| 2nd byte<br>code(higher) | 36    | 38               | 39            | 3A   | 3B             |
| 0                        |       |                  |               |      |                |
| 1                        |       |                  |               |      |                |
| 2                        |       |                  | SET •<br>y, b |      | SET<br>%p, b   |
| 3                        |       |                  |               |      |                |
| 4                        |       |                  |               |      |                |
| 5                        | BICIR |                  |               |      |                |
| 6                        | IL,r  |                  | CLR<br>y, b   |      | CLR<br>%p, b   |
| 7                        |       |                  |               |      |                |
| 8                        |       |                  |               |      |                |
| 9                        | DICIR |                  | TEST<br>y, b  |      | TEST<br>%p, b  |
| A                        | IL,r  |                  |               |      |                |
| B                        |       |                  |               |      |                |
| C                        |       | ADD<br>H,<br>#k  |               |      | OUT<br>@HL,%p  |
| D                        | CLR   | CMPR<br>H,<br>#k | TESTP<br>y, b |      | TESTP<br>%p, b |
| E                        | IL,r  |                  |               |      | OUT<br>@HL,%p  |
| F                        |       |                  |               |      |                |



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TOSHIBA MOS TYPE DIGITAL INTEGRATED CIRCUIT

**TMP4700C**

SILICON MONOLITHIC

N-CHANNEL SILICON GATE DEPRESSION LOAD

**PROVISIONAL**

NMOS 4-BIT SINGLE CHIP MICROCOMPUTER (TLCS-47!) TMP4700C

### GENERAL DESCRIPTION

The TLCS-47 is the high speed and high performance, 4-bit single chip microcomputer series designed for general purpose use.

The TLCS-47 has variously powerful functions in order to meet with the advanced and complicated applications, which will be made in near future. In addition, software compatible NMOS family (TLCS-47N) and CMOS family (TLCS-47C) are also provided.

The TMP4700C is the system development evaluator chip used for developmental and operational check of the TLCS-47 application systems (programs).

Although the TLCS-47N and the TLCS-47C have different electric characteristics and some functions, the individual configuration of a functionally equivalent system is possible by using the TMP4700C.

Further, when the TMP4700C is used, the evaluation boards equivalent to respective versions of the TLCS-47 should be used.

### PIN CONNECTIONS (Top View)





## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4700C

PRELIMINARY

## PIN NAMES AND PIN DESCRIPTIONS

| Pin Names                                                                                                                                                                         | No.of Pins                           | I/O                                                                       | Functions                                                                                                                                                                                                      |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| K <sub>03</sub> ~ K <sub>06</sub>                                                                                                                                                 | 4                                    | Input                                                                     | Input port                                                                                                                                                                                                     |
| P <sub>13</sub> ~ P <sub>16</sub><br>P <sub>23</sub> ~ P <sub>26</sub>                                                                                                            | 4<br>4                               | Output<br>Output                                                          | Output port (corresponding to PLA)<br>" (" ")")                                                                                                                                                                |
| R <sub>43</sub> ~ R <sub>46</sub><br>R <sub>53</sub> ~ R <sub>56</sub><br>R <sub>63</sub> ~ R <sub>66</sub><br>R <sub>73</sub> ~ R <sub>76</sub>                                  | 4<br>4<br>4<br>4                     | I/O<br>I/O<br>I/O<br>I/O                                                  | I/O port<br>"<br>"<br>"<br>"                                                                                                                                                                                   |
| R <sub>83</sub> (T <sub>1</sub> )<br>R <sub>82</sub> (INT <sub>1</sub> )<br>R <sub>81</sub> (T <sub>2</sub> )<br>R <sub>80</sub> (INT <sub>2</sub> )                              | 1<br>1<br>1<br>1                     | I/O<br>I/O<br>I/O<br>I/O                                                  | I/O port or timer/counter input<br>" or interrupt input<br>" or timer/counter input<br>" or interrupt input                                                                                                    |
| R <sub>92</sub> (SCK)<br>R <sub>91</sub> (SO)<br>R <sub>90</sub> (SI)                                                                                                             | 1<br>1<br>1                          | I/O<br>I/O<br>I/O                                                         | I/O port or shift clock for serial port<br>" or serial output<br>" or serial input                                                                                                                             |
| A <sub>11</sub> ~ A <sub>0</sub><br>I <sub>7</sub> (HLT)<br>I <sub>6</sub> (INH)<br>I <sub>5</sub> (SPT)<br>I <sub>4</sub> (DI <sub>4</sub> ) ~ I <sub>0</sub> (DI <sub>0</sub> ) | 12<br>1<br>1<br>1<br>5               | Output<br>Input<br>Input<br>Input<br>Input                                | Program memory address<br>Program data input (Hold request signal input)<br>" (Inhibit control signal input)<br>" (Port control signal input)<br>" (Data input)                                                |
| DO <sub>3</sub> (CF)<br>DO <sub>2</sub> (LR <sub>0</sub> )<br>DO <sub>1</sub> (DEP)<br>DO <sub>0</sub> (DP)                                                                       | 1<br>1<br>1<br>1                     | Output<br>Output<br>Output<br>Output                                      | Data Output (Carry flag monitor)<br>" (L register monitor)<br>" (Port control signal output)<br>" ("")")                                                                                                       |
| PNR <sub>3</sub> ~ PNR <sub>0</sub><br>CLK<br>ST <sub>0</sub> , ST <sub>1</sub><br>SA, SB<br>MR<br>HFR<br>CALD<br>SEL <sub>C</sub><br>HOLD                                        | 4<br>1<br>2<br>2<br>1<br>1<br>1<br>1 | Output<br>Output<br>Output<br>Output<br>Output<br>Input<br>Input<br>Input | Port address output<br>Strobe signal<br>State signal<br>Status signal<br>Master reset signal output<br>Hold monitor output<br>Data fetch cycle request signal input<br>Clock select input<br>Hold signal input |
| XIN, XOUT<br>RESET<br>TEST                                                                                                                                                        | 2<br>1<br>1                          | Input,<br>Output<br>Input<br>Input                                        | Resonator connection terminal<br>Initialize signal input<br>(Low level is input.)                                                                                                                              |
| V <sub>DD</sub><br>V <sub>HH</sub><br>V <sub>SS</sub>                                                                                                                             | 1<br>1<br>1                          | Power supply<br>Power supply<br>Power supply                              | +5V<br>+5V (Memory power supply)<br>0V                                                                                                                                                                         |

**BLOCK DIAGRAM**

**BLOCK NAMES AND DESCRIPTIONS**

| Block Names                       | Functions                                                                                               |
|-----------------------------------|---------------------------------------------------------------------------------------------------------|
| PC                                | Program counter (12 bits)                                                                               |
| IR, decoder                       | Instruction register, Decoder                                                                           |
| HR, LR                            | H register (page assignment of RAM), L register (address assignment in RAM page), (each 4-bit register) |
| RAA                               | RAM address buffer register (8 bits)                                                                    |
| RAM                               | Data memory                                                                                             |
| STACK                             | Save area of program counter and flags. (RAM area)                                                      |
| SPW                               | Stack pointer word (RAM area)                                                                           |
| DC                                | Data counter (12 bits, RAM area)                                                                        |
| AX, AY                            | Temporary register of ALU input                                                                         |
| ALU                               | Arithmetic and logic unit                                                                               |
| AC                                | Accumulator                                                                                             |
| FLAG(CF,ZF,SF,GF)                 | Flags                                                                                                   |
| K, P, R                           | Ports                                                                                                   |
| INTR control                      | Interrupt control<br>(EIF: Enable interrupt master F/F, EIR: Enable interrupt register)                 |
| FD                                | Frequency divider (4-stage prescaler + 18 stages)                                                       |
| TC <sub>1</sub> , TC <sub>2</sub> | 12-bit timer/counter 2-channels (RAM area)                                                              |
| TC control                        | Timer/counter control                                                                                   |
| SIO control                       | Serial port control.                                                                                    |
| HOLD control.                     | Control of hold function                                                                                |
| SYS control                       | Generation of various internal control signals                                                          |
| CG, TG,                           | Clock generator, timing generator                                                                       |



## FUNCTIONAL DESCRIPTION

The TMP4700C is the system development evaluator chip for the TLCS-47. When a program memory (equivalent to TMM2732D, TMM323D-1) is externally mounted, it is possible to configurate a system equivalent to the TMP4740P or the TMP4720P (the input/output circuit format, however, must be equivalent to ( $\overline{I}_{OCODE}$  AA) and in the case of ( $\overline{I}_{OCODE}$  AE) and ( $\overline{I}_{OCODE}$  AF), externally mounted resistors are required).

In the case of other input/output circuit formats of the TMP4740P and TMP4720P, or in the case of other NMOS family or CMOS family, it is also possible to configurate an equivalent system by adding an external circuit using an evaluator chip dedicated terminal. Therefore, in application systems of these models, the evaluation boards equivalent to respective versions shall be used.

Further, when the TMP4700C is used, the technical descriptions for respective versions and the instruction manuals for equivalent evaluation boards, debugging tools and the like shall also be read.

The operation of the TMP4700C is described in the following on the basis of the terminal functions.

#### 1. TLCS-47N standard chip equivalent terminals

The terminals shown in Fig. 1.1 have the functions and characteristics equivalent to the input/output circuit format ( $\overline{I}_{OCODE}$  AA) of the standard chips (TMP4740P, TMP4720P) of the TLCS-47N. Therefore, in this case it is possible to configurate an equivalent system by externally mounting a program memory.



Fig.1.1 TLCS-47N Standard Chip (IOCODEAA) Equivalent Terminals

## 2. Connection of Program Memory

As an externally mounted program memory, a programmable ROM equivalent to the TMM2732D (4K x 8 bits) or TMM323D-1 (2K x 8 bits) is used.

The connecting method of a program memory and the timing chart are shown in Fig. 2.1.

Further, A<sub>11</sub> and I<sub>7</sub> (HLT) terminals in the diagram are MSB, respectively.



Note 1. When the TMM2732D is used, the TMP4700C output terminal A<sub>11</sub> should be opened.

Note 2. The instruction/ROM data input terminal has a built-in pull-up resistors.

(a) Connection of Program Memory



(b) Program Memory Access Timing Chart

Fig. 2.1 Connection of Program Memory



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4700C

PRELIMINARY

### 3. Control Terminals for External Circuits

#### (1) Timing signals (CLK, ST<sub>0</sub>, ST<sub>1</sub>, SELC)

In order for the timing control of the external circuits, 3 types of signals are transmitted from the timing generator of the TMP4700C.

The TMP4700C is capable of supporting either system of the TLCS-47N and the TLCS-47C. For selecting these systems, the SELC signal input is used.

The timing chart of these signals is shown in Fig. 3.1. Further, the SELC terminal has a built-in pull-up resistor.



Note: These are somewhat different from the operating timings of CMOS family.

(b) TLCS-47C Support (SELC = 0)

Fig. 3.1 Clock Timing Chart

## (2) System control signal inputs

 $I_7$  ( $\overline{HLT}$ )

$\overline{HLT}$  signal is the halt request signal input to the TMP4700C at time of the system debugging.  $\overline{HLT}$  signal input is multiplexed with data input from the external ROM and a signal is input when  $ST_1$  signal is at high level.

When a low level signal is input into  $\overline{HLT}$  signal input and accepted, the TMP4700C starts the halt operation. At this time, CPU executes no operation cycle, but as long as  $HLT$  request is being accepted, it stops the divider to operate (therefore, the counting for the timer interruption of divider, the internal clock to the timer/counter and the internal shift clock for serial transfer are also stopped, accordingly), and furthermore, it inhibits the timer/counter operation and acceptance of interrupt requests.

However, a request for LCD data fetch cycle, which is used on LCD driver built-in version is accepted (one instruction cycle). Further, the interrupt latch and the count latch for the timer/counter are set/reset independently of  $HLT$  operation and subsequent  $INH$  operations.

Further,  $I_7$  ( $\overline{HLT}$ ) terminal has a built-in pull-up resistor.

 $I_6$  ( $\overline{INH}$ )

$\overline{INH}$  signal is the control signal input for temporarily inhibiting the divider operation, timer/counter operation and interrupt request acceptance at time of the system debugging.  $\overline{INH}$  signal input is multiplexed with data input from the external ROM and a signal is input when  $ST_1$  is at high level.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4700C

**PRELIMINARY**

As long as a low level signal is input into INH input and is being accepted, the TMP4700C stops the divider to operate and inhibits the timer/counter operation and acceptance of interrupt requests. However, a request for LCD data fetch cycle, which is used on LCD driver built-in version is accepted (one instruction cycle).

Since this INH operation can be controlled independently of HLT operation, it can be used in normal system program operation. Furthermore, it also can be used for controlling the internal monitor at time of the system debugging.

Further, I<sub>6</sub> (INH) terminal has a built-in pull-up resistor.

### HOLD

This input is equivalent to the HOLD terminal provided in the TLCS-47C.

As the system operation for the hold function, operation of this input is similar to that of each version of the TLCS-47C for HOLD terminal input except the followings:

- (a) The oscillator is not stopped (normal oscillation is continued).
- (b) Supply current don't decrease from the value of the TMP4700C operating current.

Further, this HOLD terminal has a built-in pull-up resistor.

### CALD

This is a request signal input for the data fetch cycle, which is used on LCD driver built-in version.

When a low level signal is input into the CALD input and accepted, the TMP4700C executes the LCD data fetch cycle (one instruction cycle).

Further, this CALD terminal has a built-in pull-up resistor.



## (3) System control signal outputs

SA, SB

SA and SB signal outputs are signals for monitoring the internal operation of the TMP4700C (See Table 3.1). These signals are switched for every instruction cycle.

| SA | SB |                                                     |
|----|----|-----------------------------------------------------|
| 0  | 0  | Executes the first cycle of an instruction          |
| 0  | 1  | Executes the LCD data fetch cycle by a CALD request |
| 1  | 0  | Executes the halt operation by a HLT request        |
| 1  | 1  | Executes other operations                           |

Table 3.1 SA, SB Signal Outputs

MR

This is a response signal to RESET signal input, and is the system reset signal.

HFR

This signal is a monitor signal relative to the hold operation and is also used for an external circuit control.

## (4) Port control

In order to support the versions of TLCS-47 series commonly, the TMP4700C is able to input data from an external circuit or to output data to a register created in an external circuit.

## (a) Control signals

 $\text{PNR}_3 \sim \text{PNR}_0$ 

4 bit outputs indicating port addresses.

DO<sub>0</sub> (DP), DO<sub>1</sub> (DEP)

These signals (DP, DEP) control the port write/read by the external circuits. They are multiplexed with data output (DO) and are transmitted when ST<sub>1</sub> signal is at high level.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4700C

PRELIMINARY

### I<sub>5</sub> ( $\overline{\text{SPI}}$ )

$\overline{\text{SPI}}$  signal controls the port read by the external circuits. This signal is multiplexed with data input from an external ROM and is input when ST<sub>1</sub> signal is at high level.

#### (b) Data inputs

$$I_4 (\text{DI}_4) \sim I_0 (\text{DI}_0)$$

These ( $\text{DI}_4 \sim \text{DI}_0$ ) are the data input terminals at time of the read operation from the external circuits. They are multiplexed with data inputs from the external ROM and are input when ST<sub>1</sub> signal is at high level.

#### (c) Data outputs

$$D_0_3 (\text{CF}), D_0_2 (\text{LR}_0), D_0_1 (\text{DEP}), D_0_0 (\text{DP})$$

These ( $D_0_3 \sim D_0_0$ ) are the data output terminals at time of the write operation to the external circuits. These outputs are multiplexed with other outputs and are transmitted out when ST<sub>1</sub> signal is at low level.

Note: The port output timing on each versions of the TLCS-47 series and that on the TMP4700C external circuit somewhat differ each other.

#### D<sub>0</sub><sub>3</sub> (CF)

Contents of the carry flag are transmitted. This CF output is multiplexed with the data output (D0) and is sent out when ST<sub>1</sub> signal is at high level.

#### D<sub>0</sub><sub>2</sub> (LR<sub>0</sub>)

Contents of LSB of L register is transmitted. This LR<sub>0</sub> output is multiplexed with the data output (D0) and is sent out when ST<sub>1</sub> signal is at high level.



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4700C

PRELIMINARY

## ELECTRICAL CHARACTERISTICS

## ABSOLUTE MAXIMUM RATING (VSS = 0V)

| SYMBOL            | ITEM                                              | RATING      | UNIT |
|-------------------|---------------------------------------------------|-------------|------|
| V <sub>DD</sub>   | Supply Voltage                                    | -0.5 ~ 7    | V    |
| V <sub>HH</sub>   |                                                   |             |      |
| V <sub>IN</sub>   | Input Voltage                                     | -0.5 ~ 7    | V    |
| V <sub>OUT1</sub> | Output Voltage (Except Open Drain Port)           | -0.5 ~ 7    | V    |
| V <sub>OUT2</sub> | Output Voltage (Open Drain Port)                  | -0.5 ~ 10   |      |
| I <sub>OUT</sub>  | Output Current (P <sub>1</sub> , P <sub>2</sub> ) | 30          | mA   |
| P <sub>D</sub>    | Power Dissipation (Topr = 70°C)                   | 1           | W    |
| T <sub>SOL</sub>  | Soldering Temperature • Time                      | 260(10sec.) |      |
| T <sub>STG</sub>  | Storage Temperature                               | -55 ~ 125   | °C   |
| Topr              | Operating Temperature                             | -30 ~ 70    |      |

## RECOMMENDED OPERATING CONDITIONS (VSS = 0V)

| SYMBOL           | ITEM                                                | CONDITION                         | MIN. | MAX.            | UNIT |
|------------------|-----------------------------------------------------|-----------------------------------|------|-----------------|------|
| Topr             | Operating Temperature                               |                                   | -30  | 70              | °C   |
| V <sub>DD</sub>  | Supply Voltage                                      |                                   | 4.5  | 5.5             | V    |
| V <sub>HH</sub>  |                                                     |                                   |      |                 |      |
| V <sub>HH1</sub> | Supply Voltage (Memory Stand-by)                    |                                   | 3.5  | 5.5             |      |
| V <sub>IH1</sub> | High Level Input Voltage<br>(Note 1)                |                                   | 2.2  | V <sub>DD</sub> |      |
| V <sub>IH2</sub> | High Level Input Voltage<br>(Note 2)                |                                   | 3    | V <sub>DD</sub> |      |
| V <sub>IL1</sub> | Low Level Input Voltage<br>(Except K <sub>0</sub> ) |                                   | 0    | 0.8             | V    |
| V <sub>IL2</sub> | Low Level Input Voltage<br>(K <sub>0</sub> )        |                                   | 0    | 1.2             |      |
| f <sub>C</sub>   | Clock Frequency                                     |                                   | 0.4  | 4.2             | MHz  |
| t <sub>WCH</sub> | High Level Clock Pulse Width<br>(Note 3)            | V <sub>IN</sub> = V <sub>IH</sub> | 80   | -               | nS   |
| t <sub>WCL</sub> | Low Level Clock Pulse Width<br>(Note 3)             | V <sub>IN</sub> = V <sub>IL</sub> | 80   | -               |      |

(Note 1) Application terminals: R<sub>4</sub> ~ R<sub>7</sub>, I<sub>7</sub>(HLT) ~ IO(DIO)

(Note 2) Application terminals: Inputs other than application terminal (Note 1)

(Note 3) For external clock operation

**D.C. CHARACTERISTICS** (V<sub>SS</sub> = 0V, V<sub>DD</sub> = V<sub>HH</sub> = 5V±10%, Topr = -30 ~ 70°C)

| SYMBOL                         | PARAMETER                                                      | CONDITION                                                     | MIN. | TYP.<br>(*) | MAX. | UNIT |
|--------------------------------|----------------------------------------------------------------|---------------------------------------------------------------|------|-------------|------|------|
| V <sub>HS</sub>                | Hysteresis Voltage<br>(Schmitt Circuit Input)                  |                                                               | -    | 0.5         | -    | V    |
| I <sub>IN1</sub>               | Input Current (K <sub>O</sub> , RESET, TEST)                   | V <sub>DD</sub> =V <sub>HH</sub> =5.5V, V <sub>IN</sub> =5.5V | -    | -           | 20   | μA   |
| I <sub>IN2</sub>               | Input Current (R Port)                                         | V <sub>DD</sub> =5.5V, V <sub>IN</sub> =5.5V                  | -    | -           | 20   |      |
| I <sub>IL</sub>                | Current (**)                                                   | V <sub>DD</sub> =5.5V, V <sub>IN</sub> =0.4V                  | -    | -           | -2   | mA   |
| I <sub>LO</sub>                | Output Leakage Current<br>(P, R Port)                          | V <sub>DD</sub> =5.5V, V <sub>OUT</sub> =5.5V                 | -    | -           | 20   | μA   |
| V <sub>OH</sub>                | High Level Output Voltage<br>(***)                             | V <sub>DD</sub> =4.5V, I <sub>OH</sub> =-400μA                | 2.4  | -           | -    |      |
| V <sub>OL</sub>                | Low Level Output Voltage<br>(Except X <sub>OUT</sub> )         | V <sub>DD</sub> =4.5V, I <sub>OL</sub> =1.6mA                 | -    | -           | 0.4  | V    |
| I <sub>OL</sub>                | Low Level Output Current<br>(P <sub>1</sub> , P <sub>2</sub> ) | V <sub>DD</sub> =5V, V <sub>OL</sub> =1V                      | -    | 20          | -    | mA   |
| I <sub>DD+I<sub>HH</sub></sub> | Supply Current                                                 | V <sub>DD</sub> =V <sub>HH</sub> =5.5V                        | -    | 70          | 150  | mA   |
| I <sub>HH1</sub>               | Supply Current<br>(Memory stand-by)                            | V <sub>DD</sub> =V <sub>SS</sub> , V <sub>HH</sub> =3.5V      | -    | 5           | 10   |      |

(\*) TYP. values are at Topr=25°C, V<sub>DD</sub>=V<sub>HH</sub>=5V.

(\*\*) Application terminals: HOLD, CALD, SELC, I<sub>1</sub>(HLT) ~ I<sub>9</sub>(DI<sub>9</sub>).

(\*\*\*) Application terminals: Control output terminal specific to evaluation.

**A.C. CHARACTERISTICS** (V<sub>SS</sub> = 0V, V<sub>DD</sub> = V<sub>HH</sub> = 5V±10%, Topr = -30 ~ 70°C)

(1)

| SYMBOL           | PARAMETER               | CONDITION | MIN.                     | TYP. | MAX. | Unit |
|------------------|-------------------------|-----------|--------------------------|------|------|------|
| t <sub>cy</sub>  | Instruction Cycle Time  |           | 1.9                      | -    | 40   | μS   |
| t <sub>SDH</sub> | Shift Data Holding Time | (Note 1)  | 0.5t <sub>cy</sub> - 300 | -    | -    | nS   |

(Note 1) SCK, SO Terminal External Circuit



(2)

| SYMBOL                     | PARAMETER          | CONDITION              | MIN. | TYP. | MAX. | UNIT |
|----------------------------|--------------------|------------------------|------|------|------|------|
| t <sub>AD</sub>            | Address Delay Time | C <sub>L</sub> = 100pF | -    | -    | 270  | nS   |
| t <sub>IS</sub>            | Data Set-up Time   | "                      | 150  | -    | -    |      |
| t <subih< sub=""></subih<> | Data Hold Time     | "                      | 50   | -    | -    |      |



## A.C. Timing Chart

## (1) Serial Port (Completion of transmission)



## (2)





# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP4700C

PRELIMINARY

### EXTERNAL DIMENSIONS

Unit : mm





# INTEGRATED CIRCUIT

## TECHNICAL DATA

TOSHIBA MOS TYPE DIGITAL INTEGRATED CIRCUIT

T M P 4 7 9 9 C

SILICON MONOLITHIC

N-CHANNEL SILICON GATE DEPRESSION LOAD

PREF-MINARY

NMOS 4-BIT SINGLE CHIP MICROCOMPUTER (TLCS-47N) TMP4799C

### GENERAL DESCRIPTION

The TLCS-47 is the high speed and high performance, 4-bit single chip microcomputer series designed for the general purpose use.

The TLCS-47 has variously powerful functions in order to meet with the advanced and complicated applications, which will be made in near future. In addition, software compatible NMOS family (TLCS-47N) and CMOS family (TLCS-47C) are also provided.

TMP4799C is the system development evaluator chip, which is equipped with a 24-pin socket which may directly mount the general purpose 32K EPROM (TMM2732D) on the top of the package. Therefore, when the program written in the 32K EPROM is mounted on the package, TMP4799C becomes pin compatible with TMP4740P, TMP4720P and can be used for developmental and operational check of the TLCS-47N application systems and programs.

The former operates the same as the latter.

TMP4799C can be used within the range of a microcomputer for the TLCS-47N system as well as for mounting an equipment made on an experimental basis.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

T M P 4 7 9 9 C

PRELIMINARY

### FEATURES

- General purpose 32K EPROM TMM2732D (equivalent to INTEL 2732) can be used.
- Compatible with TLCS-47N single chip microcomputer family TMP4740P/TMP4720P in pin.
- Compatible with TLCS-47 series in software.
- ROM 4,096 × 8 BIT (external), RAM 256 × 4 BIT (internal)

### PIN CONNECTIONS (Top View)



(NOTE) Mark : Socket for TMM2732D



## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP4799C

PRELIMINARY

## PIN NAMES AND PIN DESCRIPTIONS

| Pin Names                                                                                                                                                            | No. of pins | Input/Output             | Functions                                                                                                   |                        |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------------|-------------------------------------------------------------------------------------------------------------|------------------------|
| K <sub>03</sub> ~ K <sub>00</sub>                                                                                                                                    | 4           | Input                    | Input port                                                                                                  |                        |
| P <sub>13</sub> ~ P <sub>10</sub><br>P <sub>23</sub> ~ P <sub>20</sub>                                                                                               | 4           | Output<br>Output         | Output port (corresponding to PLA)<br>" ( " )                                                               |                        |
| R <sub>43</sub> ~ R <sub>40</sub><br>R <sub>53</sub> ~ R <sub>50</sub><br>R <sub>63</sub> ~ R <sub>60</sub><br>R <sub>73</sub> ~ R <sub>70</sub>                     | 4           | I/O<br>I/O<br>I/O<br>I/O | I/O port<br>"<br>"<br>"                                                                                     |                        |
| R <sub>83</sub> (T <sub>1</sub> )<br>R <sub>82</sub> ( <u>INT</u> <sub>1</sub> )<br>R <sub>81</sub> (T <sub>2</sub> )<br>R <sub>80</sub> ( <u>INT</u> <sub>2</sub> ) | 1           | I/O<br>I/O<br>I/O<br>I/O | I/O port or timer/counter input<br>" or interrupt input<br>" or timer/counter input<br>" or interrupt input |                        |
| R <sub>92</sub> (SCK)<br>R <sub>91</sub> (SO)<br>R <sub>90</sub> (SI)                                                                                                | 1           | I/O<br>I/O<br>I/O        | I/O port or shift clock for serial port<br>" or serial output<br>" or serial input                          |                        |
| X <sub>IN</sub> , X <sub>OUT</sub>                                                                                                                                   | 2           | Input, Output            | Resonator connection terminals                                                                              |                        |
| RESET                                                                                                                                                                | 1           | Input                    | Initialize signal input                                                                                     |                        |
| TEST                                                                                                                                                                 | 1           | Input                    | (Low level is input.)                                                                                       |                        |
| V <sub>DD</sub>                                                                                                                                                      | 1           | Power supply             | +5V                                                                                                         |                        |
| V <sub>HH</sub>                                                                                                                                                      | 1           | Power supply             | +5V (Memory power supply)                                                                                   |                        |
| V <sub>SS</sub>                                                                                                                                                      | 1           | Power supply             | 0V                                                                                                          |                        |
| A <sub>11</sub> ~ A <sub>0</sub><br>O <sub>7</sub> ~ O <sub>0</sub>                                                                                                  | 12<br>8     | Output<br>Input          | Program memory address<br>Program data input                                                                | Socket for<br>TMM2732D |
| <u>OE</u> /V <sub>PP</sub>                                                                                                                                           | 1           | Output                   | Output buffer control                                                                                       |                        |
| <u>CE</u>                                                                                                                                                            | 1           | Output                   | Chip Enable (connected with V <sub>SS</sub> )                                                               |                        |
| V <sub>CC</sub>                                                                                                                                                      | 1           | Power supply             | +5V (connected with V <sub>DD</sub> )                                                                       |                        |
| GND                                                                                                                                                                  | 1           | Power supply             | 0V (connected with V <sub>SS</sub> )                                                                        |                        |

Note : RESET terminal has no built-in pull-up resistor as well as

TEST terminal has no built-in pull-down resistor.

## BLOCK DIAGRAM



## BLOCK NAMES AND DESCRIPTIONS

| Block Names                       | Functions                                                                                               |
|-----------------------------------|---------------------------------------------------------------------------------------------------------|
| PC                                | Program counter (12 bits)                                                                               |
| IR, decoder                       | Instruction register, Decoder                                                                           |
| HR, LR                            | H register (page assignment of RAM), L register (address assignment in RAM page), (each 4-bit register) |
| RAA                               | RAM address buffer register (8 bits)                                                                    |
| RAM                               | Data memory                                                                                             |
| STACK                             | Save area of program counter and flags (RAM area)                                                       |
| SPW                               | Stack pointer word (RAM area)                                                                           |
| DC                                | Data counter (12 bits, RAM area)                                                                        |
| AX, AY                            | Temporary register of ALU input                                                                         |
| ALU                               | Arithmetic and logic unit                                                                               |
| AC                                | Accumulator                                                                                             |
| FLAG(CF,ZF,SF,GF)                 | Flags                                                                                                   |
| K, P, R                           | Ports                                                                                                   |
| INTR control                      | Interrupt control (EIF: Enable interrupt master F/F, EIR: Enable interrupt register)                    |
| FD                                | Frequency divider (4-stage prescaler + 18 stages)                                                       |
| TC <sub>1</sub> , TC <sub>2</sub> | 12-bit timer/counter 2-channels (RAM area)                                                              |
| TC control                        | Timer/counter control                                                                                   |
| SIO control                       | Serial port control                                                                                     |
| SYS control                       | Generation of various internal control signals                                                          |
| CG, TG                            | Clock generator, timing generator                                                                       |

## FUNCTIONAL DESCRIPTION

TMP4799C is the system development evaluator chip for the TLCS-47N. When the 32K EPROM (TMM2732D) in which the program is written is mounted on the package, it is possible to configurate a system equivalent to TMP4740P or TMP4720P.

The precautions for using TMP4799C are described.

#### 1. Program Memory (ROM) and ROM address

The precautions for using TMP4799C as an evaluator chip for TMP4720P are described.

TMP4720P contains a program memory with  $2,048 \times 8$ -bit (addresses 000 - 7FF) capacity. In case of TMP4720P, the PLA data conversion table must be located in addresses 7E0 - 7FF, because the MSB in the program counter is not decoded and there is no physical ROM in addresses 800 - FFF.

When TMP4799C is used with 32K EPROM, the program counter with 12-bit length is decoded and there is a program memory with  $4,096 \times 8$ -bit (addresses 000 - FFF) capacity. In case of TMP4799C, the PLA data conversion table is, therefore, located in addresses FEO - FFF.

No precaution is required, when TMP4799C is used as an evaluator chip for TMP4740P. It is because the former has the same address space as the latter.

Fig. 1.1 shows the ROM address space of TMP4740P, TMP4720P and TMP4799C.



Fig. 1.1 ROM Capacity and Address



# INTEGRATED CIRCUIT

## TECHNICAL DATA

T M P 4 7 9 9 C

PRELIMINARY

### 2. Data Memory (RAM) and RAM address

The precautions for using TMP4799C as an evaluator chip for TMP4720P are described.

Data memory contained in TMP4720P has a  $128 \times 4$ -bit (addresses 00 - 7F) capacity, and the specific RAM address, which is used for the stack area, the data counter, etc., is located in addresses 40 - 7F. It is because the MSB of RAM address buffer register is not decoded and there is no physical RAM in addresses 80 - FF in TMP4720P.

In case of TMP4799C, the RAM address buffer register with 8-bit length is decoded and there is data memory with  $256 \times 4$ -bit (addresses 00 - FF) capacity. Then the specific RAM address area is located in addresses CO - FF in TMP4799C, while it located in addresses 40 - 7F in TMP4720P. Further, it is necessary to pay attention to the addresses of the data memory in case of accessing the data in the specific RAM address area.

Fig. 2.1 shows the RAM address space of TMP4740P, TMP4720P and TMP4799C.



Fig. 2.1 RAM Capacity and Address

## 3. Input/Output circuit format

Fig. 3.1 shows the input/output circuit format of TMP4799C which is equivalent to "IOCODE AA" of TMP4740P and TMP4720P.

| port<br>Cir-<br>cuit              | Input<br>(K <sub>0</sub> )                                                                                     | Output<br>(P <sub>1</sub> , P <sub>2</sub> )                                                                                                                          | I/O<br>(R <sub>4</sub> , R <sub>5</sub> , R <sub>6</sub> )                                                                            | I/O<br>(R <sub>7</sub> )                                                                                                              | I/O<br>(R <sub>8</sub> , R <sub>9</sub> )                                                                                                                               |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I/O<br>equiv-<br>alent<br>Circuit | <br>R=1kΩ (TYP.)              |                                                                                      | <br>R=1kΩ (TYP.)                                     | <br>R=1kΩ (TYP.)                                     | <br>R=1kΩ (TYP.)                                                                       |
| Remark                            | <ul style="list-style-type: none"> <li>• High threshold input.</li> <li>• No resistor is contained.</li> </ul> | <ul style="list-style-type: none"> <li>• Sink open-drain output.</li> <li>• High output current.</li> <li>• Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>• Sink open-drain output.</li> <li>• Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>• Sink open-drain output.</li> <li>• Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>• Schmitt circuit input.</li> <li>• Sink open-drain output.</li> <li>• Output latch is initialized to the high level.</li> </ul> |

Note : TMP4799C does not contain the pull-up resister with RESET pin and does not contain the pull-down resister with TEST pin. It is necessary to provide RESET pin with the pull-up resister ( $\approx 200\text{k}\Omega$  TYP.) and to provide TEST pin with the pull-down resister ( $\approx 70\text{k}\Omega$  TYP.), respectively.

Fig. 3.1 Input/Output circuit format of TMP4799C

TMP4799C cannot be used as an evaluator chip for TMP4740P or TMP4720P which employs "IOCODE AH" or "IOCODE AI", because the output latches of R<sub>4</sub>, R<sub>5</sub>, R<sub>6</sub> are initialized to the high level in the former and to the low level in the latter.

It is necessary to provide the pull-up or pull-down resistors with K0 port and to provide the pull-up resistors with R4, R5, R6 ports when TMP4799C is used as an evaluator chip for TMP4740P or TMP4720P which employs "IOCODE AE" or "IOCODE AF", respectively. Fig. 3.2 shows the examples of the external circuitries.



(1) The external circuitry for TMP4799C  
(equivalent to "IOCODE AE")



(2) The external circuitry for TMP4799C  
(equivalent to "IOCODE AF")

Fig. 3.2 Example of external circuitry for TMP4799C

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP4799C

PRELIMINARY

## ELECTRICAL CHARACTERISTICS

ABSOLUTE MAXIMUM RATINGS ( $V_{SS}=0V$ )

| SYMBOL     | ITEM                                             | RATING       | UNITS            |
|------------|--------------------------------------------------|--------------|------------------|
| $V_{DD}$   | Supply Voltage                                   | -0.5 ~ 7     | V                |
| $V_{HH}$   |                                                  |              |                  |
| $V_{IN}$   | Input Voltage                                    | -0.5 ~ 7     | V                |
| $V_{OUT1}$ | Output Voltage(Except Open Drain Port)           | -0.5 ~ 7     | V                |
| $V_{OUT2}$ | Output Voltage (Open Drain Port)                 | -0.5 ~ 10    |                  |
| $I_{OUT}$  | Output Current ( $P_1, P_2$ )                    | 30           | mA               |
| $P_D$      | Power Dissipation ( $T_{opr}=70^\circ\text{C}$ ) | 1            | W                |
| $T_{sol}$  | Soldering Temperature • Time                     | 260 (10 sec) |                  |
| $T_{stg}$  | Storage Temperature                              | -55 ~ 125    |                  |
| $T_{opr}$  | Operating Temperature                            | -30 ~ 70     | $^\circ\text{C}$ |

RECOMMENDED OPERATING CONDITIONS ( $V_{SS}=0V$ )

| SYMBOL    | ITEM                                              | CONDITION       | MIN. | MAX.     | UNITS            |
|-----------|---------------------------------------------------|-----------------|------|----------|------------------|
| $T_{opr}$ | Operating Temperature                             |                 | -30  | 70       | $^\circ\text{C}$ |
| $V_{DD}$  |                                                   |                 |      |          |                  |
| $V_{HH}$  | Supply Voltage                                    |                 | 4.5  | 5.5      | V                |
| $V_{HBI}$ | Supply Voltage (Memory Stand-by)                  |                 | 3.5  | 5.5      |                  |
| $V_{IH1}$ | High Level Input Voltage ( $R_4 \sim R_7$ )       |                 | 2.2  | $V_{DD}$ |                  |
| $V_{IH2}$ | High Level Input Voltage (Except $R_4 \sim R_7$ ) |                 | 3    | $V_{DD}$ |                  |
| $V_{IL1}$ | Low Level Input Voltage (Except $K_0$ )           |                 | 0    | 0.8      |                  |
| $V_{IL2}$ | Low Level Input Voltage ( $K_0$ )                 |                 | 0    | 1.2      |                  |
| $f_C$     | Clock Frequency                                   |                 | 0.4  | 4.2      | MHz              |
| $t_{WCH}$ | High Level Clock Pulse Width (Note 1)             | $V_{IN}=V_{IH}$ | 80   | -        |                  |
| $t_{WCL}$ | Low Level Clock Pulse Width (Note 1)              | $V_{IN}=V_{IL}$ | 80   | -        | nS               |

(Note 1) For external clock operation.

**D.C. CHARACTERISTICS (V<sub>SS</sub>=0V, V<sub>DD</sub>=V<sub>HH</sub>=5V±10%, T<sub>opr</sub>=-30 ~ 70°C)**

| SYMBOL                         | PARAMETER                                                      | CONDITION                                                     | MIN. | TYP.<br>(*) | MAX. | UNIT |
|--------------------------------|----------------------------------------------------------------|---------------------------------------------------------------|------|-------------|------|------|
| V <sub>HS</sub>                | Hysteresis Voltage<br>(schmitt Circuit Input)                  |                                                               | -    | 0.5         | -    | V    |
| I <sub>IN1</sub>               | Input Current (K <sub>0</sub> , RESET, TEST)                   | V <sub>DD</sub> =V <sub>HH</sub> =5.5V, V <sub>IN</sub> =5.5V | -    | -           | 20   | μA   |
| I <sub>IN2</sub>               | Input Current (R Port)                                         | V <sub>DD</sub> =5.5V, V <sub>IN</sub> =5.5V                  | -    | -           | 20   |      |
| I <sub>IL</sub>                | Current (**)                                                   | V <sub>DD</sub> =5.5V, V <sub>IN</sub> =0.4V                  | -    | -           | -2   | mA   |
| I <sub>LO</sub>                | Output Leakage Current<br>(P, R Port)                          | V <sub>DD</sub> =5.5V, V <sub>OUT</sub> =5.5V                 | -    | -           | 20   | μA   |
| V <sub>OH</sub>                | High Level Output Voltage<br>(***)                             | V <sub>DD</sub> =4.5V, I <sub>OH</sub> =-400μA                | 2.4  | -           | -    | V    |
| V <sub>OL</sub>                | Low Level Output Voltage<br>(Except X <sub>OUT</sub> )         | V <sub>DD</sub> =4.5V, I <sub>OL</sub> =1.6mA                 | -    | -           | 0.4  |      |
| I <sub>OL</sub>                | Low Level Output Current<br>(P <sub>1</sub> , P <sub>2</sub> ) | V <sub>DD</sub> =5V, V <sub>OL</sub> =1V                      | -    | 20          | -    | mA   |
| I <sub>DD+I<sub>HH</sub></sub> | Supply Current                                                 | V <sub>DD</sub> =V <sub>HH</sub> =5.5V                        | -    | 70          | 150  | mA   |
| I <sub>HH1</sub>               | Supply Current<br>(Memory stand-by)                            | V <sub>DD</sub> =V <sub>SS</sub> , V <sub>HH</sub> =3.5V      | -    | 5           | 10   |      |

(\*) TYP. values are at T<sub>opr</sub>=25°C, V<sub>DD</sub>=V<sub>HH</sub>=5V.

(\*\*) Application terminals : O<sub>7</sub> ~ O<sub>0</sub>

(\*\*\*) Application terminals : A<sub>11</sub> ~ A<sub>0</sub>, OE/VPP

**A.C. CHARACTERISTICS (V<sub>SS</sub>=0V, V<sub>DD</sub>=V<sub>HH</sub>=5V±10%, T<sub>opr</sub>=-30 ~ 70°C)**

(1)

| SYMBOL           | PARAMETER               | CONDITION | MIN.                     | TYP. | MAX. | UNIT |
|------------------|-------------------------|-----------|--------------------------|------|------|------|
| t <sub>cyc</sub> | Instruction Cycle Time  |           | 1.9                      | -    | 20   | μS   |
| t <sub>SDH</sub> | Shift Data Holding Time | (Note 1)  | 0.5t <sub>cyc</sub> -300 | -    | -    | nS   |

(Note 1) SCK, SO Terminal External Circuit



(2)

| SYMBOL          | PARAMETER          | CONDITION             | MIN. | TYP. | MAX. | UNIT |
|-----------------|--------------------|-----------------------|------|------|------|------|
| t <sub>AD</sub> | Address Delay Time | C <sub>L</sub> =100pF | -    | -    | 270  | nS   |
| t <sub>IS</sub> | Data Set-up Time   | "                     | 150  | -    | -    |      |
| t <sub>IH</sub> | Data Hold Time     | "                     | 50   | -    | -    |      |



## A.C. Timing Chart

## (1) Serial Port (Completion of transmission)



## (2)





# INTEGRATED CIRCUIT

## TECHNICAL DATA

T M P 4 7 9 9 C

PRELIMINARY

### EXTERNAL DIMENSION VIEW

Unit in mm



Weight 13g (TYP.)

## CONNECTION OF PROGRAM MEMORY

When TMP4799C operates as the evaluator chip for TMP4720P, TMM323D-1 (2,048 × 8 bit) can be used as the program memory. The connecting method of a program memory is shown below.



| Pin Names of<br>TMM323D-1 | Pin Names of<br>TMM2732D | Connection                               |
|---------------------------|--------------------------|------------------------------------------|
| PD/PGM                    | CE                       | No change                                |
| CS                        | OE/VPP                   | No change                                |
| VPP                       | A11                      | A11 is open.<br>Vpp is connected to VDD. |

TMP4799C used with TMM2732D, in which the program is written in the range of addresses 000 - 7FF, operates the same as TMP4720P when the connecting method shown below is adopted.



A<sub>11</sub> of TMP4799C is open.

A<sub>11</sub> of TMM2732D is connected to V<sub>SS</sub>.

# **TLCS-47(C)**

- **TMP47C40P**
- **TMP47C20P**
- **TMP47C41P**
- **TMP47C21P**
- **TMP47C22F**





# INTEGRATED CIRCUIT

## TECHNICAL DATA

TOSHIBA MOS TYPE DIGITAL INTEGRATED CIRCUIT

TMP47C40P, TMP47C41P

TMP47C20P, TMP47C21P

SILICON MONOLITHIC SILICON GATE CMOS

PRELIMINARY

CMOS 4-BIT SINGLE CHIP MICROCOMPUTER (TLCS-47C)

TMP47C40P, TMP47C20P, TMP47C41P, TMP47C21P

### GENERAL DESCRIPTION

The TLCS-47 is the high speed and high performance, 4-bit single chip microcomputer series designed for the general purpose use.

The TLCS-47 has variously powerful functions in order to meet with advanced and complicated applications, which will be made in near future. In addition, software compatible NMOS family (TLCS-47N) and CMOS family (TLCS-47C) are also provided.

The TMP47C40P and TMP47C20P are the standard chips for the TLCS-47C. These chips are similar to each other, except memory capacity. And in the case of high breakdown voltage output type, production part's number is TMP47C41P or TMP47C21P. The TMP4700C (NMOS) is an evaluator chip used for the system development.

| Part No.     | ROM (Bit)                          | RAM (Bit) |
|--------------|------------------------------------|-----------|
| TMP47C40/41P | 4,096 × 8                          | 256 × 4   |
| TMP47C20/21P | 2,048 × 8                          | 128 × 4   |
| TMP4700C     | Externally provided<br>(4,096 × 8) | 256 × 4   |



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P, TMP47C41P

TMP47C20P, TMP47C21P

PRELIMINARY

### FEATURES

- 4-bit single chip microcomputer with built-in ROM, RAM, input/output port, divider, timer/counter, and serial port.
- Instruction execution time:  $4\mu s$  (at 4 MHz clock)
- Effective instruction set 90 instructions, software compatible in the series
- Subroutine nesting: Maximum 15 levels
- 6 interrupts (External: 2, Internal: 4)  
Independently latched control and multiple interrupt control
- Input/output port (35 pins)

|                               |         |         |
|-------------------------------|---------|---------|
| Input                         | 1 port  | 4 pins  |
| Output (corresponding to PLA) | 2 ports | 8 pins  |
| I/O                           | 4 ports | 16 pins |
| I/O (Note)                    | 2 ports | 7 pins  |
- Note: These I/O ports are also used for the interrupt input, timer/counter input, and serial port; therefore, it is programmably selectable for each application.
- PLA data converting function (Instruction)  
Output of data to output port (8-bit)
- Table look-up and table search function (Instruction)  
Table can be set up in the whole ROM area.
- 12-bit timer/counter (2 channels)  
Event counter, timer, and pulse width measurement mode is programmably selectable.
- Serial port with 4-bit buffer  
Receive/transfer mode is programmably selectable.  
External/internal clock and leading/trailing edge mode are programmably selectable.
- 18-stage divider (with 4-stage prescaler)  
Frequency applied for timer interrupt of divider is programmably selectable.
- High breakdown voltage output (20 pins)  
Maximum rating 42V, FL tube direct drive is available.
- Hold function  
Battery operation/condenser backup is available.
- On chip oscillator
- TTL/CMOS compatible
- +5V single power supply
- 42-pin DIL plastic package
- Si-gate CMOS LSI

## PIN CONNECTIONS (Top View)



## PIN NAMES AND PIN DESCRIPTION

| Pin Name                           | No. of pins | Input/Output  | Function                                |
|------------------------------------|-------------|---------------|-----------------------------------------|
| K <sub>03</sub> ~ K <sub>06</sub>  | 4           | Input         | Input port                              |
| P <sub>13</sub> ~ P <sub>16</sub>  | 4           | Output        | Output port (Corresponding to PLA)      |
| P <sub>23</sub> ~ P <sub>26</sub>  | 4           | Output        | " ( " )                                 |
| R <sub>43</sub> ~ R <sub>46</sub>  | 4           | I/O           | I/O port                                |
| R <sub>53</sub> ~ R <sub>56</sub>  | 4           | I/O           | "                                       |
| R <sub>63</sub> ~ R <sub>66</sub>  | 4           | I/O           | "                                       |
| R <sub>73</sub> ~ R <sub>76</sub>  | 4           | I/O           | "                                       |
| R <sub>83</sub> (T1)               | 1           | I/O           | I/O port or timer/counter input         |
| R <sub>82</sub> (INT1)             | 1           | I/O           | I/O port or interrupt input             |
| R <sub>81</sub> (T2)               | 1           | I/O           | I/O port or timer/counter input         |
| R <sub>80</sub> (INT2)             | 1           | I/O           | I/O port or interrupt input             |
| R <sub>92</sub> (SCK)              | 1           | I/O           | I/O port or shift clock for serial port |
| R <sub>91</sub> (SO)               | 1           | I/O           | I/O port or serial output               |
| R <sub>90</sub> (SI)               | 1           | I/O           | I/O port or serial input                |
| X <sub>IN</sub> , X <sub>OUT</sub> | 2           | Input, Output | Resonator connection terminals          |
| RESET                              | 1           | Input         | Initialize signal input                 |
| HOLD                               | 1           | Input         | Hold signal input                       |
| TEST                               | 1           | Input         | (Low level is input.)                   |
| V <sub>DD</sub>                    | 1           | Power Supply  | +5V                                     |
| V <sub>SS</sub>                    | 1           | Power Supply  | 0V                                      |

**BLOCK DIAGRAM**

**BLOCK NAMES AND DESCRIPTION**

| Block Name                        | Function                                                                                                |
|-----------------------------------|---------------------------------------------------------------------------------------------------------|
| PC                                | Program counter (12 bits)                                                                               |
| ROM                               | Program memory (including fixed data)                                                                   |
| IR, decoder                       | Instruction register, Decoder                                                                           |
| HR, LR                            | H register (page assignment of RAM), L register (address assignment in RAM page), (each 4-bit register) |
| RAA                               | RAM address buffer register (8 bits)                                                                    |
| RAM                               | Data memory                                                                                             |
| STACK                             | Save area of program counter and flags (RAM area)                                                       |
| SPW                               | Stack pointer word (RAM area)                                                                           |
| DC, data table                    | Data counter (12 bits, RAM area), Data table (ROM area).                                                |
| AX, AY                            | Temporary register of ALU input                                                                         |
| ALU                               | Arithmetic and logic unit                                                                               |
| AC                                | Accumulator                                                                                             |
| FLAG (CF, ZF, SF, GF)             | Flags                                                                                                   |
| K, P, R                           | Ports                                                                                                   |
| INTR control                      | Interrupt control (EIF: Enable interrupt master F/F, EIR: Enable interrupt register)                    |
| FD                                | Frequency divider (4-stage prescaler + 18 stages)                                                       |
| TC <sub>1</sub> , TC <sub>2</sub> | 12-bit timer/counter 2 channels (RAM area)                                                              |
| TC control                        | Timer/counter control                                                                                   |
| SIO control                       | Serial port control                                                                                     |
| HOLD control                      | Control for hold function                                                                               |
| SYS control                       | Generation of various internal control signals                                                          |
| CG, TG                            | Clock generator, Timing generator                                                                       |



## FUNCTIONAL DESCRIPTION

## 1. System Configuration

1. Program Counter (PC)
2. Program Memory (ROM)
3. H Register (HR), L Register (LR), RAM Address Buffer Register (RAA)
4. Data Memory (RAM)
  - (1) Stack (STACK)
  - (2) Stack Pointer Word (SPW)
  - (3) Data Counter (DC)
5. ALU, Accumulator (AC)
6. Flags (FLAG)
7. Ports (PORT)
8. Interrupt Control Circuit (INTR)
9. Frequency Divider (FD)
10. Timer/Counter (TC<sub>1</sub>, TC<sub>2</sub>)
11. Serial Port (SIO)
12. Hold Control Circuit (HOLDC)

Concerning the above component parts, the configuration and functions of hardwares are described :

Hexadecimal notation is used for the description, charts, and tables in order to indicate the address and the like, without assigning identification symbols as far as it does not give rise to confusion.

The following names and symbols are used unconsciously.

- (a) CPU      Control Processing Unit except for the built-in peripheral circuitry, such as interrupt control circuit, timer/counter, and serial port.
- (b) CP      Clock pulse generated in the clock oscillator.  
It is called the "basic clock" or merely "clock".
- (c) fc      Indicates the frequency of the clock oscillator, namely, the frequency of the basic clock.
- (d) MSB/LSB      Indicates Most/Least Significant Bit.
- (e) F/F      Indicates Flip/Flop.



### 1.1 Program Counter (PC)

It is a 12-bit binary counter, and the contents of the program counter indicate the address of program memory in which the next instruction to be executed is stored.

The program counter generally gains increment at every instruction fetch by the number of bytes assigned to the instruction. However, when executing the branch and subroutine instructions or receiving the interrupt, the values specified by these instructions and operation are set.

Value "0" is specified by initializing the program counter.

The page structure of program memory is made with 64 words per page. The TMP47C40P has 64 pages and the TMP47C20P 32 pages.

At the execution of (BSS a) instruction, the value assigned by the instruction is set in the lower 6 bits of the program counter when the branch condition is met. That is, the (BSS a) instruction is used as a branch or jump instruction within a page. If the (BSS a) instruction is stored in the last address of the page, the value in the higher 6 bits of the program counter indicates that the branch or jump instruction to the next page is executed.

At the execution of (CALL a) instruction, the value specified by the instruction is set in the program counter after the previous contents of the program counter has been saved in the stack. Since 11 bits are of the address bit length which can be assigned by the instruction, the call address of subroutine should be in the range of addresses 000 - 7FF.

| MSB              |                  |                 |                 | PC <sub>M</sub> |                 |                 |                 | LSB             |                 |                 |                 |
|------------------|------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| PC <sub>11</sub> | PC <sub>10</sub> | PC <sub>9</sub> | PC <sub>8</sub> | PC <sub>7</sub> | PC <sub>6</sub> | PC <sub>5</sub> | PC <sub>4</sub> | PC <sub>3</sub> | PC <sub>2</sub> | PC <sub>1</sub> | PC <sub>0</sub> |

## Page assignment

## Address assignment in page

## (a) Configuration of Program Counter

(page) (Address)  
in page



(Address)

## (b) Configuration of ROM

(Page) (Address)  
in page



(Execution flow)

 Only when branch con-  
dition is met

 Note: "a" shall be  
indicated by  
hexadecimal.

## (c) Special example of branch caused by (BSS a) instruction.

Fig.1.1.1 Program Counter and Program Memory (ROM)



## 1.2 Program Memory (ROM)

Processing programs and fixed data are stored in the program memory. The next instruction to be executed is read out from the address indicated by the contents of the program counter.

The fixed data stored in the program memory can be read by using the ROM data referring instruction or the PLA referring instruction. The ROM data referring instruction reads out the higher or lower 4-bit data of the fixed data stored in the address decided by the data counter [(LDH A, @DC+) and (LDL A, @DC) instruction respectively], and stores the data in the accumulator. The PLA referring instruction (OUTB @HL) reads out the fixed data (8-bit) stored in the address decided by the contents of the data memory indicated by the contents of H and L registers as well as contents of the carry flag, and outputs the data to output ports (P2 · P1).

Addresses are individually assigned to the program memory and data memory, so that the fixed data in the ROM area cannot be directly read out by the address of the data memory.

|                                      |
|--------------------------------------|
| Specific Addresses of Program Memory |
|--------------------------------------|

The following addresses of the program memory are used for specific purposes. When not used for these purposes, the specific addresses can be used to store the processing programs and fixed data.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

RELIMINARY

| Specific Address       | Specific Purposes                     |
|------------------------|---------------------------------------|
| 000<br>(001)           | Start address by initialization       |
| 002<br>(003)           | INT1 Interrupt vector address         |
| 004<br>(005)           | ISIO Interrupt vector address         |
| 006<br>(007)           | IOVF1 Interrupt vector address        |
| 008<br>(009)           | IOVF2 Interrupt vector address        |
| 00A<br>(00B)           | ITMR Interrupt vector address         |
| 00C<br>(00D)           | INT2 Interrupt vector address         |
| 8n + 6<br>(n = 1 ~ 15) | Call address by instruction (CALLS a) |
| 086 (Note)             |                                       |
| FEO<br>e<br>FFF        | PLA data conversion table             |

Note : 086 (hexadecimal) = 134 (decimal)

Table 1.2.1 Specific Address of Program Memory

## ROM CAPACITY

The TMP47C40P and TMP47C20P contain a program memory with  $4,096 \times 8 (addresses 000 - FFF) capacity and  $2,048 \times 8 (addresses 000 - 7FF) capacity, respectively. But the TMP47C20P contains a program counter with 12-bit length. Therefore, when one of addresses 800 - FFF is accessed in a program, the ROM data corresponding to addresses 000 - 7FF is read out. It is because there is no physical ROM in addresses 800-FFF, but the MSB in the program counter is not decoded. For example, when the data located in address FF3 is output to a port by the PLA referring instruction on a program, the data located in address 7F3 is read out. In the TMP47C20P, the PLA data conversion table (addresses FEO - FFF) is, therefore, located in addresses 7E0 - 7FF.$$

"0" [(NOP) instruction] is read out for the ROM data within the range of the built-in ROM capacity, if it is not specified by the user.



Fig. 1.2.1 ROM Capacity and Address



PRELIMINARY

### 1.3 H Register (HR), L Register (LR), and RAM Address Buffer Register (RAA)

The H and L registers are 4-bit registers used as the data memory address pointers or general purpose registers.

The page structure of the data memory is based on 16 words per page. Pages are specified by H register, and addresses in page are done by L register, respectively. TMP47C40P has 16 pages and TMP47C20P 8 pages.

The L register is also used to specify the bits corresponding to pins R<sub>73</sub>~R<sub>40</sub> of the I/O port when instructions (SET @L), (CLR @L), and (TEST @L), are executed.

The RAM address buffer register is a temporary register used to specify the address in the data memory, and serves as an input of the RAM address decoder. Normally, the data specified by the contents of the H and L registers or immediate data of an instruction is fed into the RAM address buffer register.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY



Fig. 1.3.1 H Register, L Register and Data Memory (RAM)

#### 1.4 Data Memory (RAM)

The processing data of user are stored in the data memory. The data is read out or written in according to the address indicated by the contents of the RAM address buffer register.

##### Specific addresses of data memory

The data memory is also used for the following specific purposes. When it is not used for the respective purposes, the RAM of the corresponding address can be used to store the user processing data.

- (1) Stack (STACK)
- (2) Stack pointer word (SPW)
- (3) Data counter (DC)
- (4) Timer/Counter (TC1, TC2)

##### (1) Stack (STACK)

The stack, which is contained in the data memory (one level of the stack consists of 4-word RAM), is area to save the contents of the program counter (return address) and flag prior to jumping to the processing program at time of subroutine call or interrupt acceptance. To return from the processing program, (RET) instruction is used to restore the contents saved in the stack to the program counter, and (RETI) instruction is used to restore the contents saved in the stack to the program counter and flags.

The location of the stack to save/restore the contents is determined by the stack pointer word, which is automatically decremented after the saving operation, and incremented prior to the restoring operation.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

### (2) Stack Pointer Word (SPW)

The address FF in the data memory is called a stack pointer word and decides the stack pointer. The stack is contained in the RAM, and accessed by the stack pointer.

The stack pointer is decided with the format shown in Fig. 1.4.1, but this address indicates the lower RAM address in each level of the stack.

Values "E" - "0" can be assigned for the stack pointer word, so that the maximum of 15 nesting levels are available for the stack. However, when the timer/counter mentioned following is used, the level containing the RAM address corresponding to the timer/counter cannot be used for the stack (value "F" is not assigned to the stack pointer word, because the stack contains the RAM address corresponding to the stack pointer word). The stack pointer word is automatically updated by the subroutine call or interrupt acceptance; however, it cannot exceed the allowable size of the stack for the system configuration.

Since the stack pointer word is never initialized in terms of hardware, it is necessary to set it to the highest possible level of the stack in the user's initialization program. For instance, it is set to "C" level when the two channels of timer/counter are used.

Note: The "level" indicates the depth of the nesting in the stack as well as the location of the next available stack. That is, it represents the contents of the stack pointer word.



# INTEGRATED CIRCUIT

東芝  
TO SHIBA

## TECHNICAL DATA

TMP47C40P

TMP47C20P

**PRELIMINARY**



(a) Specific purposive map of RAM



(b) Stack pointer and stack pointer word



(c) Structure of stack

Fig. 1.4.1 Specific Address and Stack of Data Memory

## (3) Data Counter (DC)

Data counter is a 12-bit binary counter used to specify the address when the data table in the ROM area is referred (ROM data referring instruction).

The RAM address with 4-bit unit is allocated to the data counter, so that the initial value setting and the content reading of the data counter can be executed by the RAM manipulative instructions.



Fig. 1.4.2 Data Counter and RAM Address

## (4) Timer/Counter (TC1, TC2)

The two channels of 12-bit timer/counter are built-in, and the RAM address with 4-bit unit is allocated to the timer/counter, so that the initial value setting and the content reading of the timer/counter can be executed by the RAM manipulative instructions.

When the timer/counter 1 is not used, the stack lower from level 13 can be used. When both of the timer/counter 1 and 2 are not used, the stack lower from level 14 can be used.



Fig. 1.4.3 Timer/Counter and RAM Address

## (5) Page 0 in Data Memory

Page 0 in the data memory (addresses 00 - 0F) is effectively used as a flag or pointer in a user's program.

## RAM Capacity

Data memory contained in TMP47C40P has a  $256 \times 4$ -bit (addresses 00 - FF) capacity, and that contained in TMP47C20P has a  $128 \times 4$ -bit (addresses 00 - 7F) capacity.

Since the TMP47C20P also has the RAM address buffer register of 8-bit length, there is no physical RAM in addresses 80 - FF in the TMP47C20P. However, the RAM equivalent to addresses 00 - 7F are referred when addresses 80 - FF are accessed in a program, because the MSB of RAM address buffer register is not decoded. That is, the specific RAM address is distributed to 00 - FF in a program, but the RAM equivalent to addresses 40 - 7F are assigned in the TMP47C20P.



Fig. 1.4.4 RAM Capacity and Address

### 1.5 ALU, Accumulator (AC)

The ALU is a circuit used for various arithmetic and logical operation for 4-bit binary data. It performs the operation designated by the instruction, and outputs the 4-bit result, carry (C), and zero detection signal (Z).

The accumulator is a 4-bit register to use a source operand for the arithmetic operation, and in which the result is stored.



Fig. 1.5.1 ALU, Accumulator

#### Detection of operating condition

Output C from the ALU indicates the carry output from the most significant position in the addition operation.

However, the subtraction is executed with the addition of the 2's complement, so that output C in the subtraction operation indicates the "non-borrow" from the most significant position (i.e., in case of non-borrow, C = "1"). Accordingly, borrow (B) can be represented with " $\bar{C}$ ".

Output Z indicates the zero detection signal to which "1" is applied when all of the 4-bit data transferred to accumulator or output of the ALU are cleared to zero.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

### Example (4-bit operation)

- |                     |                |
|---------------------|----------------|
| (a) 4 + 5 = 9       | (C = 0, Z = 0) |
| (b) 7 + 9 = 0       | (C = 1, Z = 1) |
| (c) 3 - 1 = 2       | (B = 0, Z = 0) |
| (d) 2 - 2 = 0       | (B = 0, Z = 1) |
| (e) 6 - 8 = -2 or E | (B = 1, Z = 0) |

Note : B =  $\overline{C}$  is indicated.

### 1.6 Flag (FLAG)

Flag is a 4-bit register used to store the condition of arithmetic operation, and of which the set/reset conditions are specified by the instruction. The flag consisting of CF, ZF, SF, and GF is saved in the stack when the interrupt is accepted. By executing the (RETI) instruction, it is restored from the stack to the conditions immediately before the interrupt is accepted.



Fig. 1.6.1 Flag

#### (1) Carry Flag (CF)

This flag is used to hold the carry in the addition operation as an input to the ALU by the (ADDC A, @HL) instruction as well as to hold the non-borrow in the subtraction operation (the carry in the addition of the 2's complement) as an input to the ALU by the (SUBRC A, @HL) instruction. The rotate instruction makes the flag hold the data shifted out of the accumulator.



## (2) Zero Flag (ZF)

This flag is stored the zero detection signal (Z) when the instruction designate to change. "1" is set if all 4 bits are cleared to zero by an arithmetic operation or data processing.

## (3) Status Flag (SF)

This flag is set or reset according to the condition specified by the instruction. With the exception of particular cases, it is usually presented at every execution of an instruction, and holds the contents of the result during execution of the next instruction. It is normally set to "1", but is reset to "0" for a time under the certain condition (it varies according to the instruction, for examples, when the result is zero, when carry occurs in the addition, or when borrow occurs in the subtraction, the flag is reset).

The status flag is referred to as branch condition in a branch instruction. The memory location is branched when this flag is set to "1"; therefore, normally the branch instruction can be required as "unconditional jump instruction". On the contrary, the instruction becomes a "conditional instruction" if it is executed immediately after loading the instruction to set/reset the status flag according to the condition determined by some previous instruction.

The status flag is initialized to "1" at initialization, and is also set to "1" after the contents have been saved in the stack when the interrupt is accepted. The contents saved in the stack is restored by the (RETI) instruction.

## (4) General Flag (GF)

This is a single-bit general purpose flag, being set or reset, and also used in a test by a program. This can be used for any purpose in the user program.



## 1.7 Port (PORT)

Data transfer to/from the external circuitry, and command/status/data transfer between the built-in peripheral circuitry are carried out by the input/output instructions.

- (a) Input/Output port : Data transfer to/from external circuitry.
- (b) Command/data output : Control of circuitry of built-in peripheral circuitry, and output of data.
- (c) Status/data input : Input of status signal (Note) and data from the built-in peripheral circuitry.

Note : Status signal is provided from serial port and hold control circuit, and is different from the status flag (SF).

To transfer the data or to control the circuitry, each port or register is selected by designating the address (Port address) by input/output operational instructions (13 instructions) in the same way as the memory.

The port address is composed of 5 bits (addresses 0 - 31).

The address to be accessed differs according to a instruction.

By way of caution, the port address space is independent of the program memory address space and the data memory address space.

Every output port contains a latch in order to hold the output data. Since every input port is operated without latching, it is desired to externally hold the data to be input from the external devices till the data is completely read out, or to read the data several times to confirm the contents.

The details to specify the input/output circuit format of ports and initialization of the output latch are 2.6 (2) Input/Output Circuit Format.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P  
TMP47C20P

| Port address | Symbol (Input/Output) | Port, Register (Input/Output)                              | Input/Output Instructions |           |          |          |         |           |            |
|--------------|-----------------------|------------------------------------------------------------|---------------------------|-----------|----------|----------|---------|-----------|------------|
|              |                       |                                                            | IN %P, A                  | OUT A ,%P | OUT#K,%P | OUTB @HL | SET%P,b | TEST %P,b | SET CLR @L |
| 00           | IP00/OP00             | K <sub>0</sub> Input port / P <sub>1</sub> Output          | 0                         |           |          |          |         | 0         |            |
| 01           | IP01/OP01             | P <sub>1</sub> Output latch / P <sub>2</sub> port          | 0                         | 0         | 0        |          | 0       | 0         |            |
| 02           | IP02/OP02             | P <sub>2</sub> " / P <sub>2</sub> "                        | 0                         | 0         | 0        |          | 0       | 0         |            |
| 03           | IP03/OP03             | —                                                          |                           |           |          |          |         |           |            |
| 04           | IP04/OP04             | R <sub>4</sub> I/O port                                    | 0                         | 0         | 0        |          | 0       | 0         | 0          |
| 05           | IP05/OP05             | R <sub>5</sub> "                                           | 0                         | 0         | 0        |          | 0       | 0         | 0          |
| 06           | IP06/OP06             | R <sub>6</sub> "                                           | 0                         | 0         | 0        |          | 0       | 0         | 0          |
| 07           | IP07/OP07             | R <sub>7</sub> "                                           | 0                         | 0         | 0        |          | 0       | 0         | 0          |
| 08           | IP08/OP08             | R <sub>8</sub> "                                           | 0                         | 0         | 0        |          | 0       | 0         | 0          |
| 09           | IP09/OP09             | R <sub>9</sub> "                                           | 0                         | 0         | 0        |          | 0       | 0         | 0          |
| 0A           | IPOA/OPOA             | —                                                          |                           |           |          |          |         |           |            |
| 0B           | IPOB/OPOB             | —                                                          |                           |           |          |          |         |           |            |
| 0C           | IPOC/OPOC             | —                                                          |                           |           |          |          |         |           |            |
| 0D           | IPOD/OPOD             | —                                                          |                           |           |          |          |         |           |            |
| OE           | IPOE/OPOE             | Status input / —                                           | 0                         |           |          |          |         |           |            |
| OF           | IPOF/OPOF             | (*) / (**)                                                 | 0                         | 0         | 0        |          |         | 0         |            |
| 10           | /OP10                 | / (a)                                                      |                           |           |          |          |         |           |            |
| 11           | /OP11                 | /P <sub>2</sub> ·P <sub>1</sub> output port (8-bit output) |                           |           |          | 0        |         |           |            |
| 12           | /OP12                 | / —                                                        |                           |           |          |          |         |           |            |
| 13           | /OP13                 | / —                                                        |                           |           |          |          |         |           |            |
| 14           | /OP14                 | / —                                                        |                           |           |          |          |         |           |            |
| 15           | /OP15                 | / —                                                        |                           |           |          |          |         |           |            |
| 16           | /OP16                 | / —                                                        |                           |           |          |          |         |           |            |
| 17           | /OP17                 | / —                                                        |                           |           |          |          |         |           |            |
| 18           | /OP18                 | / —                                                        |                           |           |          |          |         |           |            |
| 19           | /OP19                 | / (b)                                                      |                           |           |          |          |         |           |            |
| 1A           | /OP1A                 | / —                                                        |                           |           |          |          |         |           |            |
| 1B           | /OP1B                 | / —                                                        |                           |           |          |          |         |           |            |
| 1C           | /OP1C                 | / (c)                                                      |                           |           |          |          |         |           |            |
| 1D           | /OP1D                 | / (d)                                                      |                           |           |          |          |         |           |            |
| 1E           | /OP1E                 | / (e)                                                      |                           |           |          |          |         |           |            |
| 1F           | /OP1F                 | / (e)                                                      |                           |           |          |          |         |           |            |

Note 1: Inputs (IP10 - IP1F) of port addresses 10 - 1F remain undefined.

Note 2: Port addresses with "—" mark are reserved addresses and cannot be used at user's program.

Note 3: OP11 is automatically accessed by (OUTB @HL) instruction, but cannot be done by the instructions other than this one.

Table 1.7.1 Port Address Allocation and Input/Output Instructions

PRELIMINARY

(1) K<sub>0</sub> (K<sub>03</sub> ~ K<sub>00</sub>) Port

This is a 4-bit port used for input.



Fig. 1.7.1 K<sub>0</sub> Port

(2) P<sub>1</sub> (P<sub>13</sub> ~ P<sub>10</sub>), P<sub>2</sub> (P<sub>23</sub> ~ P<sub>20</sub>) Port

These ports are 4-bit ports with a latch used for output. The latch data can be read by the instruction.

These two ports can independently access by specifying port addresses IP01/OP01, and IP02/OP02. In addition, they can output 8-bit data by the (OUTB @HL) instruction.

#### PLA data conversion

A hardware PLA is not contained in the system; however, the function equivalent to it can be performed by access to the PLA data conversion table provided in the RCM by use of the (OUTB @HL) instruction.

The PLA referring instruction (OUTB @HL) : This instruction reads out the 8-bit data stored in the program memory, whose address is determined by the contents of the data memory indicated by the contents of the H and L registers as well as the contents of the carry flag, and outputs the data to 8-bit ports P<sub>2</sub> and P<sub>1</sub>. At this time OP11 is automatically selected as the port address.

Ports P<sub>1</sub> and P<sub>2</sub> are capable of reading the latch data by the instruction, so that the data output by the PLA referring instruction can be qualified or modified; that is, the convert pattern can be changed or the numbers of pattern will be increased.



Fig. 1.7.2 P<sub>1</sub> and P<sub>2</sub> Ports

### (3) R<sub>4</sub>(R<sub>43</sub> ~ R<sub>40</sub>), R<sub>5</sub>(R<sub>53</sub> ~ R<sub>50</sub>), R<sub>6</sub>(R<sub>63</sub> ~ R<sub>60</sub>), R<sub>7</sub>(R<sub>73</sub> ~ R<sub>70</sub>) Port

Each of these ports is a 4-bit I/O port with a latch. The latch should be set to "1" when the port is used as an input port. (But, these ports are only used to output ports with some input/output circuits.)

Pins R<sub>73</sub> - R<sub>40</sub> can be used for bit scanning for set/reset and test according to the contents of the L register by executing the (SET @L), (CLR @L) and (TEST @L) instructions. Table 1.7.2 shows the pins corresponding to the contents of the L register.

| L register    | Corresponding Pin | L register    | Corresponding Pin |
|---------------|-------------------|---------------|-------------------|
| 3   2   1   0 |                   | 3   2   1   0 |                   |
| 0 0 0 0       | R <sub>40</sub>   | 1 0 0 0       | R <sub>60</sub>   |
| 0 0 0 1       | R <sub>41</sub>   | 1 0 0 1       | R <sub>61</sub>   |
| 0 0 1 0       | R <sub>42</sub>   | 1 0 1 0       | R <sub>62</sub>   |
| 0 0 1 1       | R <sub>43</sub>   | 1 0 1 1       | R <sub>63</sub>   |
| 0 1 0 0       | R <sub>50</sub>   | 1 1 0 0       | R <sub>70</sub>   |
| 0 1 0 1       | R <sub>51</sub>   | 1 1 0 1       | R <sub>71</sub>   |
| 0 1 1 0       | R <sub>52</sub>   | 1 1 1 0       | R <sub>72</sub>   |
| 0 1 1 1       | R <sub>53</sub>   | 1 1 1 1       | R <sub>73</sub>   |

Table 1.7.2 Correspondence of Individual Bits of L Register and I/O Port



Note : For bit set/reset of port,  
latch output serves as input data.

Fig. 1.7.3 R<sub>4</sub> ~ R<sub>7</sub> Ports

#### (4) R<sub>8</sub> (R<sub>83</sub> ~ R<sub>80</sub>) Port

This is a 4-bit I/O port with a latch. The latch should be set to "1" when the port is used as an input port.

It is a port common to external interrupt input or external timer/counter input. When it is driven by the external circuitry, such as external interrupt input or external timer/counter input, the latch must be set to "1". When it is used as normal I/O port, some measures, such as inhibition of the external interrupt input acceptance or disable of the mode depending on the external input of the timer/counter should be taken in a program.

(Note) When pin R<sub>82</sub> (INT1) is used as a port, INT1 interrupt request takes place because the falling edge of the pin input/output is detected (interrupt enabling master F/F is normally set to "1"). This causes the CPU to process a dummy interrupt acceptance [e.g. the (RETI) instruction only is executed]. When pin R<sub>80</sub> (INT2) is used, INT2 interrupt request also takes place in the same manner as the case of pin R<sub>82</sub>, but the interrupt request is not accepted by merely resetting the LSB (EIR<sub>0</sub>) of the enable interrupt register to "0" in advance. Therefore, the above processing is not required.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY



Note: For bit set/reset of port, latch output serves as input data.

Fig. 1.7.4 R<sub>8</sub> Port

### (5) R<sub>9</sub>(R<sub>92</sub> ~ R<sub>90</sub>) Port

This is a 3-bit I/O port with a latch, and the latch must be set to "1" when it is used as input port.

The R<sub>9</sub> port is also used as serial port. The latch must be set to "1" when R<sub>9</sub> port is used as serial port. The port used as normal I/O port is not entirely influenced by disabling the serial port.

Pin R<sub>93</sub> is not mounted in the port, but "1" is read by accessing to pin R<sub>93</sub> in a program.



Note: For bit set/reset of port, latch output serves as input data.

Fig. 1.7.5 R<sub>9</sub> Port



東芝

# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

**PRELIMINARY**

### 1.8 Interrupt control circuit (INTR)

Interrupt factors are composed of two from the external circuitry, and four from the internal circuitry. By setting the interrupt latch provided for each factor, an interrupt request is generated to the CPU. The interrupt latch is set when the edge of the input signal is detected.

The interrupt request is not always accepted by the CPU if generated. It is not accepted till the priority in the six factors determined according to the hardware and the enabling/disabling control by the program become all affirmative.

In order to control enabling/disabling of interrupt by the program, an F/F (EIF) and a 4-bit register (EIR) are provided. By using these means, preferential acceptance of the interrupt factors by the program, and multiple interrupt control can be realized.

| Factor                      | Priority according to hardware             | Interrupt Latch   | Enable condition according to program | Vector Address                       |
|-----------------------------|--------------------------------------------|-------------------|---------------------------------------|--------------------------------------|
| External interrupt 1 (INT1) | (Higher)<br>1                              | INTL <sub>5</sub> | (Note 1)<br>EIF = 1                   | 002                                  |
| Internal interrupt          | Serial Input/Output (ISIO) interrupt       | 2                 | INTL <sub>4</sub>                     | EIF·EIR <sub>3</sub> = 1             |
|                             | Timer counter 1 Overflow (IOVF1) interrupt | 3                 | INTL <sub>3</sub>                     | EIF·EIR <sub>2</sub> = 1             |
|                             | Timer counter 2 Overflow (IOVF2) interrupt | 4                 | INTL <sub>2</sub>                     | (Note 2)<br>EIF·EIR <sub>1</sub> = 1 |
|                             | Timer interrupt of divider (ITMR)          | 5                 | INTL <sub>1</sub>                     | (Note 2)<br>EIF·EIR <sub>1</sub> = 1 |
| External interrupt 2 (INT2) | (Lower)                                    | INTL <sub>0</sub> | EIF·EIR <sub>0</sub> = 1              | 00C                                  |

Interrupt enabling master F/F

Interrupt enabling register (EIR)



(Note 1) Since EIR register cannot make disabling of the INT1 interrupt, this interrupt is always accepted under the interrupt enabled condition (EIF = 1). Therefore, this should be used for the interrupt requiring the first priority such as emergency interrupt.

(Note 2) The given acceptance condition by the program is the same in IOVF2 and ITMR; accordingly, the action of these interrupts to the acceptance/inhibition control is the same.

Table 1.8.1 Interrupt Factors



Fig. 1.8.1 Interrupt Control Circuit



Note: On the assumption that  $EIR_1 = 1$ , without other interrupt requests

Fig. 1.8.2 Interrupt Acceptance Timing Chart (Example)



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

**PRELIMINARY**

### (1) Interrupt processing

The interrupt request signal to be sent to the CPU is held by the interrupt latch till the request is accepted or the latch is reset by the initialization operation or instruction.

The processing for the interrupt acceptance is performed within two instruction cycle time after the completion of the execution of instruction (after the completion of the timer/counter processing if it is required).

The following operations are performed by the interrupt service program.

- ① The contents of the program counter and flag are saved in the stack.
- ② The vector address is set to the program counter according to the interrupt factor.  
(A jump instruction to each interrupt service program is usually stored in the program memory corresponding to the vector address.)
- ③ The status flag is set to "1".
- ④ The interrupt enabling master F/F is reset to "0" to inhibit the subsequent interrupt acceptance for a time.
- ⑤ The interrupt latch of the accepted interrupt factor is reset to "0".
- ⑥ The instruction stored in the vector address is executed.

The interrupt service program terminates after the execution of the (RETI) instruction.

The following operations are performed by the (RETI) instruction.



- ① The contents of the program counter and flag are restored out of the stack.
- ② The interrupt enabling master F/F is set to "1".

When the multiple interrupt is accepted, the interrupt enabling master F/F should be set by the instruction. At this time, the enabling/disabling for each interrupt factor can be changed by updating the interrupt enabling register by the (XCH A, EIR) instruction.

The program counter and flag are automatically saved/restored in the interrupt processing. However, if saving/restoring of the accumulator and other registers is necessary, it should be designated by a program.

#### (2) Interrupt control by program

##### EIF

This is an enabling interrupt master F/F. Interrupt is put in the interrupt acceptance enabling state by setting the EIF to "1". It is reset to "0" immediately after having accepted an interrupt to inhibit the subsequent interrupt acceptance for a time, but is set to "1" again by the (RETI) instruction after the completion of the interrupt service program to return the enable state again. And then the other interrupt can be received.

The EIF can be set/reset in a program by using the (EICLR IL,r) and (DICLR IL, r) instructions. It is reset to "0" at initialization operation.

##### EIR register

This is a 4-bit register used for selection/control of enabling/disabling of the interrupt acceptance in a program.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

**PRELIMINARY**

Read/write operation is performed by use of the (XCH A, EIR) instruction. It is set to "0" at the initialization operation.

### Interrupt latch

The interrupt latches (INTL<sub>5</sub> - INTL<sub>0</sub>) provided for each interrupt factor are set by the rising edge of the input signal if the interrupt is caused by the internal factors, and are set by the falling edge of the input pin if it is caused by the external factors. Then, interrupt request signal is sent to the CPU. The interrupt latch holds the signal till the interrupt request is accepted, and is reset to "0" immediately after the interrupt has been accepted.

Since the interrupt latch can be reset to "0" by the (EICLR IL, r), (DICLR IL, r) and (CLR IL, r) instructions, the interrupt request signal can be initialized by a program. The latch is reset to "0" at the initialization operation.

### 1.9 Frequency divider (FD)

The divider (FD<sub>1</sub> - FD<sub>18</sub>) is made up 18-stage binary counter, and its output is used to generate various internal timing.

The basic clock (f<sub>c</sub> Hz) is divided into sixteen by the timing generator and input to the divider; therefore, the output frequency at the last stage is f<sub>c</sub>/2<sup>22</sup> Hz.

It is reset to "0" at the initialization operation.

### Timer Interrupt of divider (ITMR)

The divider is capable of sending the interrupt request for a certain frequency. Four different frequencies can be selected for timer interrupt by instructions.

The command register is accessed as port address OP19, and is reset to "0" at time of the initialization.

The timer interrupt of divider is caused from the rising edge of the first output of the divider after the data has been written in the command register.



#### (a) Structure of frequency divider

| (Port address)<br>OP19 | MSB                    LSB |   |   |   | (*: don't care)                    |
|------------------------|----------------------------|---|---|---|------------------------------------|
|                        | 3                          | 2 | 1 | 0 |                                    |
| *                      | 0                          | * | * | : | Disable                            |
| *                      | 1                          | 0 | 0 | : | Interrupt frequency $fc/2^{10} Hz$ |
| *                      | 1                          | 0 | 1 | : | " $fc/2^{11} Hz$                   |
| *                      | 1                          | 1 | 0 | : | " $fc/2^{12} Hz$                   |
| *                      | 1                          | 1 | 1 | : | " $fc/2^{13} Hz$                   |

| Interrupt frequency (Hz) | For example,<br>$fc=4.194304 MHz$ |
|--------------------------|-----------------------------------|
| $fc/2^{10}$              | 4,096 Hz                          |
| $fc/2^{11}$              | 2,048 Hz                          |
| $fc/2^{12}$              | 1,024 Hz                          |
| $fc/2^{13}$              | 512 Hz                            |

#### (b) Command register

Fig. 1.9.1 Frequency Divider

1.10 Timer/Counter (TC<sub>1</sub>, TC<sub>2</sub>)

Two channels of 12-bit binary counter is contained to count time or event.

Since the RAM address with 4-bit unit is allocated to the timer/counter, the initial value setting and the content reading of the timer/counter can be executed by the RAM manipulated instructions.



Fig. 1.10.1 Timer/Counter

#### (1) Timer/Counter Control

The timer/counter is controlled by the command specifying the operation mode. The command register for the timer/counter 1 and timer/counter 2 is accessed as port addresses OP1C and OP1D, respectively. It is reset to "0" at the initialization operation. The count operation is started from the first rising edge of the count pulse applied by setting the value (mode) to the command register.

When the timer/counter is not used, the RAM addresses corresponding to the timer/counter can be used to store the user processing data by selecting the "disable" state. In the timer mode, the external input pins can be used as I/O ports [R<sub>83</sub> (T1), R<sub>81</sub> (T2)].

TC1 Command register  
 (Port Address OPI1C)

 TC2 Command register  
 (Port Address OPI1D)


Selection of Count Mode

- 00 : Disable state
- 01 : Event count mode  
(Counts external input)
- 10 : Timer mode  
(Counts internal pulse.)
- 11 : Pulse width measurement mode  
(Counts the pulse obtained by sampling of external input by use of internal pulse.)

 Selection of Internal Pulse  
 (Divider Output) Rate

- 00 :  $fc/2^{10}$  Hz is counted.
- 01 :  $fc/2^{14}$  Hz is counted.
- 10 :  $fc/2^{18}$  Hz is counted.
- 11 :  $fc/2^{22}$  Hz is counted.

(fc: Basic clock frequency)

(a) Command register

| Internal Pulse Rate (Hz) | Max. Setting Time (SEC) | For example, fc=4.194304 MHz |                         |
|--------------------------|-------------------------|------------------------------|-------------------------|
|                          |                         | Internal Pulse Rate (Hz)     | Max. Setting Time (SEC) |
| $fc/2^{10}$              | $2^{22}/fc$             | 4,096                        | 1                       |
| $fc/2^{14}$              | $2^{26}/fc$             | 256                          | 16                      |
| $fc/2^{18}$              | $2^{30}/fc$             | 16                           | 256                     |
| $fc/2^{22}$              | $2^{34}/fc$             | 1                            | 4,096                   |

(b) Selection of timer rate

Fig. 1.10.2 Control of Timer/Counter

## (2) Count Operation

When the rising edge of the count pulse is detected, the count latch is set to send a count request to the CPU.

The count operation of the timer/counter is performed requiring one instruction cycle time after completion of the instruction execution. The execution of the next instruction and the acceptance of the interrupt request are kept waiting during the operation. When the count request is sent from the timer/counter 1 and 2, at the same time, the count request of the timer/counter 1 is preferentially executed.

The maximum frequency applied to the external input pin under the event counter mode is  $fc/64$  Hz if one channel is used. When two channels are used,  $fc/64$  Hz is applied to the timer/counter 1, and  $fc/80$  Hz to the timer/counter 2.

In the timer mode, the maximum frequency is determined by a command.

The maximum frequency applied to the external input pin in the pulse width measurement mode should be the frequency level available for analyzing the count value in the program. Normally, the frequency sufficiently slower than the designated internal pulse rate is applied to the external input pin.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY



(a) Event counter/timer mode



(b) Pulse width measurement mode

Fig. 1.10.3 Mode and Count Value of Timer/Counter

### Decrease in execution speed of instruction due to count operation

The CPU carries out the count operation requiring one instruction cycle time for the count request. Therefore, this causes the decrease in the apparent speed of instruction execution. Some examples are shown below :

(a) In the timer mode with count pulse rate of  $f_c/2^{10}$  Hz :

The count operation is inserted once every 64-instruction cycle time, so that the apparent speed is decreased by  $1/64 = 1.6\%$  instruction execution speed. For example, the apparent speed is 4.063 $\mu$ s to 4 $\mu$ s instruction execution speed.

(b) In the event count mode :

It depends on the count pulse rate applied to the external input pin. In the worst case, when the timer/counter 1 and 2 are operated at the same time with the maximum count pulse rate, the count operation is inserted once every 4-instruction cycle time for the timer/counter 1, and once every 5-instruction cycle time for the timer/counter 2.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

The apparent speed of the instruction execution, therefore, decreases by  $9/11 \approx .82\%$ . The apparent speed is  $7.28\mu s$  to  $4\mu s$  instruction execution speed.

### (3) Interrupt by overflow (IOVF1, IOVF2)

At the time when the overflow occurs, the timer/counter generates the interrupt request.

That is, the interrupt request is generated when the count value of FFF is changed to 000. The counting is continued after the interrupt request signal is generated. Assuming that the CPU provides the interrupt enabling state, and that the interrupt is accepted as soon as the overflow interrupt has been generated, the interrupt processing can be performed in the sequence illustrated in Fig. 1.10.4.



Fig. 1.10.4 Timing Chart of Timer/Counter in  
Interrupt by Overflow

### 1.11 Serial Port (SIO)

A 4-bit serial port with a buffer is provided to transfer the serial data from/to the external circuitry. It is connected to the external circuitry through three pins [R92 ( $\overline{SCK}$ ), R91 (SO), R90 (SI)]. Since these pins are also used as port R9, the output latch of the R9 port should be set to "1" when the serial port is used. When it is not used, the pins can be used as I/O port R9.

Pin R90 in the transmit mode and pin R91 in the receive mode are also available as I/O port pin.

#### (1) Circuit configuration

The serial port consists of a 4-bit shift register, a 4-bit buffer register, and its control circuit.



SR : 4-bit shift register      SIOC : Serial port control circuit  
 SB : 4-bit buffer register       $\phi s$  : Internal shift clock  
 ISIO : Interrupt request

Fig. 1.11.1 Circuit Configuration of Serial Port

## (2) Serial port control

The serial port operation is controlled by the command. The command register is accessed with port address OP1F, and reset to "0" at the initialization operation. The operation status can be informed through the status input, which is accessed with port address IPOE.



Fig. 1.11.2 Command Register, Status Input



## (3) Shift clock (SCK)

The following shift clock modes can be selected by the contents of the command register.

- (a) Clock source (External/internal mode)
- (b) Shift edge of clock (Leading edge/trailing edge mode)

Internal clock mode

$fc/2^7$  Hz is used for the shift clock (when the basic clock frequency  $fc$  is 4.194304 MHz, the shift clock frequency is 32.768 kHz.). At this time, the clock is supplied to the external devices through the SCK pin. If the data setting (transmit mode) or the data reading (receive mode) rate by the program cannot follow the clock rate, the shift clock is automatically stopped and the next shift operation is suspended until the data processing is completed ("Wait" operation).

External clock mode

The shift operation is performed by the clock provided from the external circuitry since the SCK pin serves as an input.

Leading edge shift mode

Data is transmitted (transmit mode) or received (receive mode) at the leading edge of the SCK pin signal.

Trailing edge shift mode

Data is received (receive mode) at the trailing edge of the SCK pin signal.

The SCK pin must be set to the "high" level when the serial transfer is started. In the internal clock mode, the SCK pin is automatically set to the "high" level because it serves as an output.



## (4) Operation mode

Selection of the following three transfer modes is available by changing the combination of the RM bit and LM bit of the command register.

| RM<br>(Bit 2) | LM<br>(Bit 1) | ECKM<br>(Bit 0) | Operation Mode                                                 |
|---------------|---------------|-----------------|----------------------------------------------------------------|
| 0             | 0             | 1/0             | Can not be used                                                |
| 0             | 1             | 1/0             | Transmit mode (Note)<br>(External/Internal clock)              |
| 1             | 0             | 1/0             | Receive(Trailing edge shift) mode<br>(External/Internal clock) |
| 1             | 1             | 1/0             | Receive(Leading edge shift) mode<br>(External/Internal clock)  |

(Note) Leading edge shift operation is performed.

Table 1.11.1 Operation Mode of Serial Port

In the transmit mode, the 4-bit data written to the buffer register from the CPU is shifted out by the shift register, and is output in the SO pin from the data of the LSB in sequence. The buffer register is accessed as the port address OPOF.

In the receive mode, the data to be input to the SI pin is shifted toward the LSB by the shift register in sequence, and is set in the buffer register after the 4-bit data has been received.

The CPU reads the contents of the buffer register, which is accessed as the port address IPOF.

**Transmit mode**

After this mode is set in the command register, the first transmit data (4-bit) is written in the buffer register (the data cannot be written in the buffer register, if the transmit mode is not set). Then the data can be transmitted by setting the ESIO (MSB of command register) to "1". The content of the buffer register is transferred to the shift register by the first shift clock, and the data in the LSB ( $D_0$ ) is output to the S0 pin. The buffer register then becomes empty, so that the interrupt (ISIO) requesting the next data takes place (buffer empty). After that, the remaining data ( $D_1 - D_3$ ) is automatically shifted out by the shift register by one data at a shift clock. The control by use of a program is not necessary in this operation.

Data is written in the buffer register by outputting the next transmit data (4-bit) to the port address OPOF in the interrupt service program, and at the same time the interrupt request is reset to "0".

Internal clock operation

In case of  $f_C/2^7$  Hz internal clock operation, if the next data is not set in the buffer register (OPOF has not been accessed by the program) though the 4-bit data has been entirely shifted out, the shift clock automatically stops, and the wait operation is taking place until the data is set.

The maximum transmission rate is 31250 bit/sec. at the 4 MHz basic clock.

External clock operation

Since the shift operation synchronizes entirely with the clock provided from the external circuitry, the data should have been written in the buffer register before the next 4-bit data is shifted out. Therefore, the transfer rate is determined by the maximum time lag from the receipt of interrupt request (ISIO) to the writing of data in the buffer register by the interrupt service program.



(a) Internal clock operation (with wait operation)



(b) External clock operation

Fig. 1.11.3 Transmit Mode

~~PRELIMINARY~~Completion of transmission

When the buffer register becomes empty, the interrupt occurs to request the next data. In case where the transmission is desired to be completed after the data is entirely transferred, the transmit operation can be stopped upon completion of transferring the current data shifted out, by resetting the ESIO to "0" without outputting the data. Whether or not the transfer operation is completed can be sensed in a program by the SIOF (MSB of the status input).

In the external clock operation, the ESIO must be reset to "0" before the next data is shifted out as in the data updating operation (however, the data is not updated when the operation is completed). When the wait operation have been already performed in the internal clock operation, the data transfer is terminated immediately after  $\text{ESIO} = 0$ .

One word transfer can be terminated by  $\text{ESIO} = 0$  in the interrupt service program on receipt of the interrupt caused by the buffer empty.



(a) Internal clock operation (with wait operation)



(b) External clock operation



(c) Completion at one-word transfer

Fig. 1.11.4 Completion of Transmission

**Receive (trailing edge shift) mode**

Data can be received by setting the receive mode in the command register as well as by setting the ESIO (MSB of command register) to "1".

When the four data are received from the SI pin, the 4-bit data is transferred from the shift register to the buffer register. At the same time, interrupt (ISIO) takes place to request the data reading (buffer full).

Since the shift register has been transferring the data to the buffer register, the shift operation is continued without waiting for the data being read.

When the data received from the port address IPOF is read in the interrupt service program, the interrupt request is reset. And then the next 4-bit data is transferred from the shift register to the buffer register if the buffer register has been full.

**Internal clock operation**

During the operation of the internal clock of  $f_c/2^7\text{Hz}$ , if the next 4-bit data is not read out of the buffer register (the IPOF has not been accessed) in the program though the 4-bit data has been entirely input, the shift clock automatically stops, and the wait operation is taking place until the data is read out.

The maximum receiving rate is 31250 bit/sec at the 4 MHz basic clock.

**External clock operation**

Since the shift operation synchronizes entirely with the clock provided from the external circuitry, the current data should have been read by the instruction before the next 4-bit data is transferred to the buffer register. The transfer rate is, therefore, determined by the maximum time lag from the receipt of interrupt request (ISIO) to the read of the data in the buffer register by the interrupt service program.



Fig. 1.11.5 Receive (trailing edge shift) Mode

Completion of receiving

When all of the data are read, the receiving of data can be completed upon termination of the current data transfer, by resetting the ESIO to "0".

Whether or not the data transmission is terminated can be sensed in a program by the SIOF (MSB of status input).

To complete the receive operation when the synchronization is desired between the serial transfer and interrupt service program (indicates data reading or completion of receiving), there are two ways according to the speed of shift clock.

The receive/transmit mode must be maintained without switching the mode until the last data is read out even if the completion of the data transfer is indicated; otherwise the contents of the buffer register will be lost.

## (a) Sufficiently slow data transfer rate (external clock operation)

If the timing, operated by the external clock, is slow enough to reset the ESIO to "0" prior to the generation of the next shift clock, the ESIO can be reset to "0" in the interrupt service program which is loaded to read out the last data. Thereafter the last data is read.



Fig. 1.11.6 Completion of Receiving (at slow transfer rate)

(b) Fast transfer rate

If the shift operation for the next data may start before the current data is read out by receipt of the interrupt request because the transfer rate is too fast, the interrupt service program which is loaded to read out the last data but one should be used to reset the ESIO to "0" after confirming that the SEF (bit 2 of status input) has been set to "1".

Thereafter, the data should be read. No operation is required to complete the data transfer in the interrupt service program for reading the last data.

The method mentioned above is usually taken for the internal clock operation. In the external clock operation, however, the reset of the ESIO and the read of data must be completed before the last data is transferred to the buffer register.



(a) Program sequence of receive end indication



(b) Timing Chart  
(in case of internal clock operation with wait operation)

Fig. 1.11.7 Completion of Receiving (at fast transfer rate)

(c) One word transfer

The data receive operation starts after the ESIO is set to "1". Then, the ESIO is reset to "0" after confirming that the SEF status is set to "1". In this sequence, one interrupt caused by the buffer full takes place; therefore, the data should be read out by the service program.



(a) Program sequence of receiving start/end indication



(b) Timing Chart

Fig. 1.11.8 Receiving Start/Completion (at one word transfer)



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

### Receive (leading edge shift) mode

With this mode set in the command register, the data can be received by setting the ESIO (MSB of command register) to "1".

When the four data are received from the SI pin, the 4-bit data is transferred from the shift register to the buffer register. At the same time, the interrupt (ISIO) occurs to request the data reading (buffer full). Since the shift register is transferring the data to the buffer register, the shift operation has been continued without waiting for the data being read.

When the data received from the port address IPOF is read in the interrupt service program, the interrupt request is reset. And then the next 4-bit data is transferred from the shift register to the buffer register if the buffer register has been full.

The basic operation in the receive (leading edge shift) mode is equivalent to that in the receive (trailing edge shift) mode except that the edge for the shift clock is different, and that at time of the transfer start, the first shifted data has been already input from the external circuitry before the first shift clock is applied to the data receipt. Timing charts are shown below.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY



(a) Internal clock operation (with wait operation)



(b) External clock operation (at slow transfer rate)



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

RELIMINARY



(d) One-word transfer

Fig. 1.11.9 Receive(Leading Edge Shift) Mode



## 1.12 Hold control circuit (HOLDC)

The hold function is the function that holds the status (contents of the data memory, program counter and other registers) immediately before the system operation is stopped at lower power consumption making the most of the features of CMOS. The hold function is controlled by the HOLD terminal and the command register.

There are two operation modes for the hold operation as shown below. The designation for the hold operation start is made by the command in either mode.

## (a) Backup mode

The HOLD terminal input controls the request/release of the hold operation. Namely, it is the state of the hold that the HOLD input is at the low level, and it is the state of the normal operations that the HOLD input is at the high level.

This mode is used for backup of the capacitor when the main power supply is cut off, backup of the battery for a long time, etc.

## (b) Clock mode

When the hold operation is started by the command even when the HOLD terminal input is at the either levels, the hold operation is continued till the leading edge of the HOLD terminal input is detected. This mode is used when signals in constant cycle are applied to the HOLD terminal input in applications, for example, the clock or timer applications, where relatively short period program processings are repeatedly executed in constant cycle. For instance, the signal is applied to the HOLD input from a source of oscillation at low power consumption.



Fig. 1.12.1 Hold Modes

## (1) Control of hold function

The hold operation is started by a command. The command register is accessed as the port address OP10, and operation mode selection, start control and set-up of warming-up time at time of restart are designated. Furthermore, it is possible to read the status of the HOLD terminal input from the status input. The status input is accessed as the port address IPOE.



Fig. 1.12.2 Hold Function Control



PRELIMINARY

## (2) Hold operation

The hold operation holds the following state:

- ① The oscillation is stopped, and all internal operation are stopped.
- ② The frequency divider is reset to "0".
- ③ The data memory, registers and port latches are held at the state immediately before the hold operation is started. It is therefore necessary to program in advance for the processing of uninterruptable program or status of the output terminal.
- ④ The program counter holds address of the instruction following the instruction directing start of the hold operation.

The hold operation is started under either mode when data is set in a command register. In the case of the backup mode, it is therefore necessary to recognize the status of the HOLD input (the hold operation request) on the program. To do this, the following two methods are considered available:

- (a) Test HLDF of the status input
- (b) Apply the HOLD input to the INT<sub>1</sub> input as an interrupt request.

The hold operation is released when the HOLD terminal input becomes the high level. That is, under the backup mode, the hold status is kept held as long as the HOLD input is at the low level. However, if the HOLD input is already at the high level when a command directing start of the hold operation is executed, the hold operation is not started but the restarting sequence is started. Under the clock mode, the hold operation is continued till the leading edge of the HOLD input is detected.



Further, in the hold operation, current consumption based on the oscillator and internal hardware is reduced, but current consumption based on the terminal interface (depending upon the external circuit and program) is not directly concerned with the hardware operation of the hold function, and it is therefore necessary to pay attention in designing system as well as interface circuits. When the input level is stable at the V<sub>DD</sub>/V<sub>SS</sub> level, current flows scarcely through the CMOS circuit. On the other hand, when the input level is floating from the V<sub>DD</sub>/V<sub>SS</sub> level (by about 0.3 ~ 0.5V), current will flow through the CMOS circuit. Therefore, in a case where the signal level at the I/O port (the open drain output with an input port circuit connected) becomes the 3-state status when the output transistor is cut off, current flows through the input port resistor and it is therefore necessary to fix the signal level by pulling up, etc.

#### Restart from Hold

The restart from hold is performed in the following sequence.

- ① Oscillation is started.
- ② The internal operation is kept stopped for a period of warming-up time assigned by the hold setting command to prevent the malfunction due to unstable oscillation.
- ③ After the warming-up time has passed <sup>(Note)</sup>, the normal operation is restarted by the instruction following the instruction directing the hold setting. Further, the divider starts to operate from the state where it has been reset to "0".

Note : Since the warming-up time is obtained from the value counted the basic clock by the divider, if oscillation frequency fluctuates at time of the restarting from the hold operation, the warming-up time shown in Fig. 1.12.2 may include errors. It is therefore necessary to regard the warming-up time as an approximate value.

The hold operation is released when the RESET terminal is set at the low level and the normal operation (the initialization operation) is immediately executed.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

### 2. Basic operation and pin operation

1. Instruction cycle
2. Basic clock (CP) generation
3. Initialization operation
4. Hold Input
5. Interrupt input
6. Input/output port
7. Other pins

The timing in each basic operation, and the configuration, function, and timing of the pins are described according to the above items.

The operation and timing with each component of the hardware are covered in detail in the description of each item of the components.

Different input/output port circuit system can be specified according to the port. The details to specify the type of input/output port circuit are given in the description covering the program tape format.

#### 2.1 Instruction cycle

The instruction execution and the internal hardware control are synchronized with the basic clock (CP, fc Hz).

The minimum unit of the instruction execution is called the "instruction cycle", and all instructions are executed by one or two instruction cycles, each of which is called one-cycle instruction or two-cycle instruction.

An instruction cycle consists of four machine cycles ( $M_1 \sim M_4$ ). and each machine cycle requires four basic clock times.



Fig. 2.1.1 Instruction Cycle

## 2.2 Basic clock (CP) generation

An oscillation circuit is contained, and the necessary clock is easily generated by connecting the resonator to external pins ( $X_{IN}$ ,  $X_{OUT}$ ). By the way, the oscillation circuit serves as Schmitt circuit.

The clock generated in the oscillation circuit is called the "basic clock" with which the internal control is synchronized. The basic clock is applied to the timing generator and the control circuit of system to provide various control signals.

The following are the examples of the resonator connection.



(a) For X-tal or ceramic resonator



(b) For RC



(c) For external oscillator

Fig. 2.2.1 Resonator Connections

### 2.3 Initialization operation

Initialization operation is performed by keeping the RESET pin to the low level. However, the following conditions are required to put the initialization operation into practice with certainty

- ① The supply voltage is within the operating voltage.
- ② The oscillation circuit operates stably.
- ③ The RESET is held at the low level in at least three instruction cycle time.



The following processing are performed by the initialization operation.

- ① Reset the program counter to "0"
- ② Set the status flag to "1".
- ③ Reset the interrupt enabling master F/F and the interrupt enabling register to "0", and also reset the interrupt latch to "0".
- ④ Reset the divider to "0".
- ⑤ Initialize the input/output port and command register to the fixed level.

The initialization operation is released due to the rise of the RESET pin to the high level, and the program can be executed from address 0 in sequence.

The RESET pin serves as Schmitt circuit input, and is connected with pull-up resistor ( $\approx 200\text{k}\Omega$  TYP., MOS-load resistor).

#### 2.4 Hold input

The hold function is the function that holds the status immediately before the system operation is stopped at low power consumption. The HOLD terminal serves as Schmitt circuit input and is used to the signal input requesting or releasing of the hold operation. Further, for details of the hold operation, refer to the description of the hold control circuit.

**Caution:** To restart the system operation from the hold operation at low holding voltage, the following precaution is required. When supply voltage rises from holding voltage to operating voltage, the RESET input is also at the high level and rises together with supply voltage.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

If a time constant circuit, etc. are externally added in this case, voltage build-up at the RESET input will be slower than that of supply voltage. Therefore, if voltage level at the RESET input drops below the non-reversible high level (Schmitt circuit) at the RESET terminal input at this time, the initialization operation may possibly be executed.

### 2.5 Interrupt input

Two pins (INT<sub>1</sub>, INT<sub>2</sub>) are provided for the external interrupt input. Since these pins are common pins with R<sub>8</sub> port, they can be used as I/O pins (R<sub>82</sub>, R<sub>80</sub>) respectively, if not used as the interrupt input pins.

The interrupt via INT<sub>2</sub> can be inhibited at any time by the program, but the interrupt via INT<sub>1</sub> is not inhibited by it independently. Therefore, when this pin is used for the R<sub>82</sub> port, the interrupt will always take place due to the detection of the falling edge of the signal. It is necessary to set a dummy interrupt service program including the (RETI) instruction only, even if the INT<sub>1</sub> is not used.

The interrupt latch is set by the falling edge of the external inputs (INT<sub>1</sub>, INT<sub>2</sub>), and an interrupt request is made to the CPU. To assure that the interrupt latch is positively set or reset, and that the next interrupt request is set, both of the high and low levels should be kept for more than two instruction cycle time.

The external interrupt input is the Schmitt circuit input.



Fig. 2.5.1 Interrupt Timing (Dummy process of INT1 interrupt)

## 2.6 Input/output port

### (1) Input/output timing

The timing to read the external data from the input port or I/O port is in M<sub>3</sub> machine cycle in the second cycle of the input instruction (two-cycle instruction). Since this timing cannot be externally recognized, the transient input data should be processed by a program.

The timing to output the data to the output port or I/O port is in M<sub>4</sub> machine cycle in the second cycle of the output instruction (two-cycle instruction), but this timing cannot be externally recognized.



Fig. 2.6.1 Input/Output Timing

## (2) Input/output circuit format

The input output circuit format of the input/output port is shown following. For the TMP47C40P, TMP47C20P, TMP47C41P and TMP47C21P, any of the input/output circuit systems shown in the following tables can be selected. You can specify your input/output circuit system when requesting the program tape. (In the case of high breakdown voltage output type, production part's number is TMP47C41P or TMP47C21P.)

\*: Port \*\*: Circuit

| Input/Output Circuit Code (I <sub>O</sub> CODE) FA |                                                                                                                                                                            |                                                                                                                                       |                                                                                                                                       |                                                                                                                                       |                                                                                                                                                                         |
|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| *                                                  | Input (K <sub>0</sub> )                                                                                                                                                    | Output (P <sub>1</sub> , P <sub>2</sub> )                                                                                             | I/O (R <sub>4</sub> , R <sub>5</sub> , R <sub>6</sub> )                                                                               | I/O (R <sub>7</sub> )                                                                                                                 | I/O (R <sub>8</sub> , R <sub>9</sub> )                                                                                                                                  |
| **                                                 |                                                                                           |                                                      |                                                      |                                                      |                                                                                       |
| Input/Output Circuit Format                        | R = 1kΩ (TYP.)                                                                                                                                                             |                                                                                                                                       | R = 1kΩ (TYP.)                                                                                                                        | R = 1kΩ (TYP.)                                                                                                                        | R = 1kΩ (TYP.)                                                                                                                                                          |
| Remark                                             | <ul style="list-style-type: none"> <li>o No resistor is contained.</li> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Schmitt circuit input.</li> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level.</li> </ul> |

| Input/Output Circuit Code (I <sub>O</sub> CODE) HA |                                                                                                                                                                                                                                                |                                                                                                                                                                                                           |                                                                                                                                      |                                                                                                                                      |                                                                                                                                                                         |
|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| *                                                  | Input (K <sub>0</sub> )                                                                                                                                                                                                                        | Output (P <sub>1</sub> , P <sub>2</sub> )                                                                                                                                                                 | I/O (R <sub>4</sub> , R <sub>5</sub> , R <sub>6</sub> )                                                                              | I/O (R <sub>7</sub> )                                                                                                                | I/O (R <sub>8</sub> , R <sub>9</sub> )                                                                                                                                  |
| **                                                 |                                                                                                                                                               |                                                                                                                          |                                                     |                                                     |                                                                                       |
| Input/Output Circuit Format                        | R = 1kΩ (TYP.)                                                                                                                                                                                                                                 |                                                                                                                                                                                                           | R = 1kΩ (TYP.)                                                                                                                       | R = 1kΩ (TYP.)                                                                                                                       | R = 1kΩ (TYP.)                                                                                                                                                          |
| Remark                                             | <ul style="list-style-type: none"> <li>o No resistor is contained.</li> <li>o Source open drain output.</li> <li>o High breakdown voltage output</li> <li>o Output latch is initialized to the low level</li> <li>o Only for output</li> </ul> | <ul style="list-style-type: none"> <li>o Source open drain output.</li> <li>o High breakdown voltage output</li> <li>o Output latch is initialized to the low level</li> <li>o Only for output</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Schmitt circuit input.</li> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level.</li> </ul> |

(Note: In this case, production part's number is TMP47C41P or TMP47C21P.)

**\*: Port \*\*: Circuit**

| Input/Output Circuit Code ( $\overline{I}\overline{O}$ CODE) FB |                                                                                    |                                                                                                                                      |                                                                                                                                      |                                                                                                                                      |                                                                                                                                                                       |
|-----------------------------------------------------------------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ***                                                             | Input ( $K_0$ )                                                                    | Output ( $P_1, P_2$ )                                                                                                                | I/O ( $R_4, R_5, R_6$ )                                                                                                              | I/O ( $R_7$ )                                                                                                                        | I/O ( $R_8, R_9$ )                                                                                                                                                    |
| Input/Output Circuit Format                                     | <br>$R_{IN} = 70\text{k}\Omega$ (TYP.)<br>$R = 1\text{k}\Omega$ (TYP.)             |                                                                                                                                      | <br>$R = 1\text{k}\Omega$ (TYP.)                                                                                                     | <br>$R = 1\text{k}\Omega$ (TYP.)                                                                                                     | <br>$R = 1\text{k}\Omega$ (TYP.)                                                                                                                                      |
| Remark                                                          | <ul style="list-style-type: none"> <li>o Pull-up resistor is contained.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Schmitt circuit input</li> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level.</li> </ul> |

**\*: Port \*\*: Circuit**

| Input/Output Circuit Code ( $\overline{I}\overline{O}$ CODE) FC |                                                                                      |                                                                                                                                      |                                                                                                                                      |                                                                                                                                      |                                                                                                                                                                       |
|-----------------------------------------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ***                                                             | Input ( $K_0$ )                                                                      | Output ( $P_1, P_2$ )                                                                                                                | I/O ( $R_4, R_5, R_6$ )                                                                                                              | I/O ( $R_7$ )                                                                                                                        | I/O ( $R_8, R_9$ )                                                                                                                                                    |
| Input/Output Circuit Format                                     | <br>$R_{IN} = 70\text{k}\Omega$ (TYP.)<br>$R = 1\text{k}\Omega$ (TYP.)               |                                                                                                                                      | <br>$R = 1\text{k}\Omega$ (TYP.)                                                                                                     | <br>$R = 1\text{k}\Omega$ (TYP.)                                                                                                     | <br>$R = 1\text{k}\Omega$ (TYP.)                                                                                                                                      |
| Remark                                                          | <ul style="list-style-type: none"> <li>o Pull-down resistor is contained.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Schmitt circuit input</li> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level.</li> </ul> |



## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

\*: Port \*\*: Circuit

| Input/Output Circuit Code (IODECODE) HB |   |                                                                                    |                                                                                                                                                                                 |                                                                                                                                                                                                             |                                                                                                                                      |                                                                                                                                                                         |
|-----------------------------------------|---|------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| **                                      | * | Input ( $K_0$ )                                                                    | Output ( $P_1, P_2$ )                                                                                                                                                           | I/O ( $R_4, R_5, R_6$ )                                                                                                                                                                                     | I/O ( $R_7$ )                                                                                                                        | I/O ( $R_8, R_9$ )                                                                                                                                                      |
| Input/Output Circuit Format             |   | <br>$R_{IN}=70k\Omega$ (TYP.)<br>$R = 1k\Omega$ (TYP.)                             |                                                                                                                                                                                 |                                                                                                                                                                                                             | <br>$R = 1k\Omega$ (TYP.)                                                                                                            | <br>$R = 1k\Omega$ (TYP.)                                                                                                                                               |
| Remark                                  |   | <ul style="list-style-type: none"> <li>o Pull-up resistor is contained.</li> </ul> | <ul style="list-style-type: none"> <li>o Source open drain output.</li> <li>o High breakdown voltage output</li> <li>o Output latch is initialized to the low level.</li> </ul> | <ul style="list-style-type: none"> <li>o Source open drain output.</li> <li>o High breakdown voltage output</li> <li>o Output latch is initialized to the low level.</li> <li>o Only for output.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Schmitt circuit input.</li> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level.</li> </ul> |

(Note: In this case, production part's number is TMP47C41P or TMP47C21P.)

\*: Port \*\*: Circuit

| Input/Output Circuit Code (IODECODE) HC |   |                                                                                      |                                                                                                                                                                                 |                                                                                                                                                                                                              |                                                                                                                                       |                                                                                                                                                                         |
|-----------------------------------------|---|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| **                                      | * | Input ( $K_0$ )                                                                      | Output ( $P_1, P_2$ )                                                                                                                                                           | I/O ( $R_4, R_5, R_6$ )                                                                                                                                                                                      | I/O ( $R_7$ )                                                                                                                         | I/O ( $R_8, R_9$ )                                                                                                                                                      |
| Input/Output Circuit Format             |   | <br>$R_{IN}=70k\Omega$ (TYP.)<br>$R = 1k\Omega$ (TYP.)                               |                                                                                                                                                                                 |                                                                                                                                                                                                              | <br>$R = 1k\Omega$ (TYP.)                                                                                                             | <br>$R = 1k\Omega$ (TYP.)                                                                                                                                               |
| Remark                                  |   | <ul style="list-style-type: none"> <li>o Pull-down resistor is contained.</li> </ul> | <ul style="list-style-type: none"> <li>o Source open drain output.</li> <li>o High breakdown voltage output</li> <li>o Output latch is initialized to the low level.</li> </ul> | <ul style="list-style-type: none"> <li>o Source open drain output.</li> <li>o High breakdown voltage output</li> <li>o Output latch is initialized to the high level.</li> <li>o Only for output.</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level.</li> </ul> | <ul style="list-style-type: none"> <li>o Schmitt circuit input.</li> <li>o Sink open drain output.</li> <li>o Output latch is initialized to the high level.</li> </ul> |

(Note: In this case, production part's number is TMP47C41P or TMP47C21P.)



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

**PRELIMINARY**

### 2.7 Other pins

#### Timer/Counter input

Two pins ( $T_1$ ,  $T_2$ ) are provided for the external timer/counter inputs. Since these pins are common pins with  $R_8$  port, they can be also used as I/O pins ( $R_{83}$ ,  $R_{81}$ ), respectively, if not used as the timer/counter inputs.

The count latch is set by the rising edge of the external input ( $T_1$ ,  $T_2$ ), and a count request is made to the CPU. To assure that the count latch is positively set or reset, both of the high and low levels should be kept for more than two instruction cycle times.

The external timer/counter input is the Schmitt circuit input.

#### Serial port

This port is connected to the external circuitry via three pins ( $SCK$ ,  $S_0$ ,  $SI$ ), which are also used for the  $R_9$  port. These pins can be used as the pins of the  $R_9$  port ( $R_{92}$ ,  $R_{91}$ ,  $R_{90}$ ), if not used for the serial port.

To assure that the shift operation is positively performed in the external clock mode, both of the high and low levels should be kept for more than two instruction cycle times.

The  $\overline{SCK}$  input in the external clock mode and the  $SI$  input in the receive mode are Schmitt circuit inputs.

#### TEST pin

This pin is used for the shipment test. To operate the user system with this pin, the input should be surely set to the low level. By the way, TEST pin is connected with pull-down resistor ( $\approx 70k\Omega$  TYP.).



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

### 3. Instructions

The TLCS-47 series microcomputer is provided with 90 instructions, which are software compatible within the series. The instructions of the TLCS-47 series consist of 1-byte instructions or 2-byte instructions. To classify them in terms of the execution time, there are 1-cycle instructions and 2-cycle instructions.

1-byte, 1-cycle instructions are mainly used in this series, and are arranged so as to improve the program efficiency.

|        |                     |    |
|--------|---------------------|----|
| 1-byte | 1-cycle instruction | 40 |
| 1-byte | 2-cycle instruction | 11 |
| 2-byte | 2-cycle instruction | 39 |
|        | Total               | 90 |

#### (a) Classification by byte/cycle

|                                |          |    |
|--------------------------------|----------|----|
| Move instruction               | (Note 1) | 22 |
| Compare instruction            |          | 6  |
| Arithmetic instruction         |          | 16 |
| Logical instruction            |          | 9  |
| Bit manipulation instruction   |          | 24 |
| Input/Output instruction       | (Note 2) | 6  |
| Branch, subroutine instruction |          | 6  |
| Other instruction              |          | 1  |
|                                | Total    | 90 |

(Note 1) : Including ROM data referring instructions

(Note 2) : Including PLA referring instruction.

#### (b) Classification by function

Table 3.0.1 Classification of Instructions.



## 3.1 Description of symbols

The following symbols are used for describing the instructions in the following explanations.

| Symbol                                 | Description                                                             |
|----------------------------------------|-------------------------------------------------------------------------|
| AC                                     | Accumulator                                                             |
| M[x]                                   | Data memory (Address x)                                                 |
| HR                                     | H register                                                              |
| LR                                     | L register                                                              |
| P[p]                                   | Port (Address p)                                                        |
| FLAG                                   | Flag                                                                    |
| CF                                     | Carry flag                                                              |
| ZF                                     | Zero flag                                                               |
| SF                                     | Status flag                                                             |
| GF                                     | General flag                                                            |
| PC                                     | Program counter                                                         |
| STACK[(SPW)]                           | Stack (Stack level is indicated by the contents of stack pointer word.) |
| SPW                                    | Stack pointer word                                                      |
| EIF                                    | Enable interrupt master F/F                                             |
| EIR                                    | Enable interrupt register                                               |
| INTLj                                  | Interrupt latch ( $j = 5 - 0$ )                                         |
| DC                                     | Data counter                                                            |
| ROM[x]                                 | Program memory (Address x)                                              |
| (ROM <sub>H</sub> , ROM <sub>L</sub> ) | (High-order 4 bits or low-order 4 bits are expressed by suffix H/L.)    |
| +                                      | Transfer                                                                |
| ‡                                      | Exchange                                                                |
| +                                      | Addition                                                                |
| -                                      | Subtraction                                                             |
| Λ                                      | Logical AND of the corresponding bits                                   |
| ∨                                      | Logical OR of the corresponding bits                                    |
| ⊻                                      | Exclusive OR of the corresponding bits                                  |

| Symbol     | Description                                                                                                      |
|------------|------------------------------------------------------------------------------------------------------------------|
| (CF)       | Inversion of carry flag contents                                                                                 |
| null       | Processed result is transferred nowhere                                                                          |
| (AC)       | Contents of accumulator                                                                                          |
| (H.L)      | Contents of 8 bits coupling H register with L register                                                           |
| M[(H.L)]   | Contents of data memory for which the contents of 8 bits coupling H register with L register is used as address. |
| (AC)<b>    | Contents of bit assigned by b of accumulator.                                                                    |
| (LR)<3:2>  | Contents of bit 3 to bit 2 of L register                                                                         |
| (PC)<11:6> | Contents of bit 11 to bit 6 of program counter                                                                   |

3.2 Description of instructions (\*): Note 1 (\*\*): Exec.cycle (\*\*): Hexadecimal

| Item Class       | Assembler Mnemonic | Object Code                                                                                                                                |                                      | Function                                                                                                                                       | Flag(*) |    |    |      |
|------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|---------|----|----|------|
|                  |                    | Binary                                                                                                                                     | (**)                                 |                                                                                                                                                | CF      | ZF | SF | (**) |
| Move Instruction | LD A, @HL          | 0 0 0 0 1 1 0 0                                                                                                                            | 0 C                                  | (AC)+M[(H-L)]                                                                                                                                  | -       | Z  | 1  | 1    |
|                  |                    |                                                                                                                                            |                                      | Loads the contents of the data memory specified by the H and L registers in the accumulator.                                                   |         |    |    |      |
|                  | LD A, x            | 0 0 1 1 1 1 0 0<br>x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 C<br>x <sub>H</sub> x <sub>L</sub> | (AC)+M[x]                                                                                                                                      | -       | Z  | 1  | 2    |
|                  |                    |                                                                                                                                            |                                      | Loads the contents of the data memory specified by the x of the instruction field in the accumulator.                                          |         |    |    |      |
| Move             | LD HL, x           | 0 0 1 0 1 0 0 0<br>x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 2 8<br>x <sub>H</sub> x <sub>L</sub> | (LR)+M[x'], (HR)+M[x+1]<br>x' = x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> , x <sub>3</sub> x <sub>2</sub> 00                 | -       | -  | 1  | 2    |
|                  |                    |                                                                                                                                            |                                      | Loads the consecutive two-word contents of the data memory specified by the x' (modified x) of the instruction field in the H and L registers. |         |    |    |      |
|                  | LD A, #k           | 0 1 0 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                        | 4 k                                  | (AC)+k                                                                                                                                         | -       | Z  | 1  | 1    |
|                  |                    |                                                                                                                                            |                                      | Loads the immediate data k of the instruction field in the accumulator. Serves as the clear instruction when k=0.                              |         |    |    |      |



## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

| Items<br>Class   | Assembler<br>Mnemonic | Object Code                                                                                                                                |                                      | Function                                                                                                                                                                                                                                                     | Flag(*) |     |
|------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----|
|                  |                       | Binary                                                                                                                                     | (**)                                 |                                                                                                                                                                                                                                                              | CF      | ZF  |
| Move Instruction | LD H, #k              | 1 1 0 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                        | C k                                  | (HR)←k<br>Loads the immediate data k of the instruction field in the H register. Serves as the clear instruction when k = 0.                                                                                                                                 | - -     | 1 1 |
|                  | LD L, #k              | 1 1 1 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                        | E k                                  | (LR)←k<br>Loads the immediate data k of the instruction field in the L register. Serves as the clear instruction when k = 0.                                                                                                                                 | - -     | 1 1 |
|                  | LDL A, @DC            | 0 0 1 1 0 0 1 1                                                                                                                            | 3 3                                  | (AC)←ROM <sub>H</sub> [(DC)]<br>Loads the lower-order 4 bits of the data read out of the data table of the program memory specified by the data counter, in the accumulator.                                                                                 | - Z     | 1 2 |
|                  | LDH A,@DC+            | 0 0 1 1 0 0 1 0                                                                                                                            | 3 2                                  | (AC)←ROM <sub>H</sub> [(DC)], (DC)←(DC)+1<br>Loads the higher-order 4 bits of the data read out of the data table of the program memory specified by the data counter, in the accumulator, and then increments the contents of the data counter.<br>[Note 2] | - Z     | 1 2 |
|                  | ST A, @HL             | 0 0 0 0 1 1 1 1                                                                                                                            | 0 F                                  | M[(H·L)]←AC<br>Stores the contents of the accumulator in the data memory specified by the H and L registers.                                                                                                                                                 | - -     | 1 1 |
|                  | ST A,@HL+             | 0 0 0 1 1 0 1 0                                                                                                                            | 1 A                                  | M[(H·L)]←(AC), (LR)←(LR)+1<br>Stores the contents of the accumulator in the data memory specified by the H and L registers, and then increments the contents of the L register.<br>[Note 3]                                                                  | - Z     | C 1 |
|                  | ST A,@HL-             | 0 0 0 1 1 0 1 1                                                                                                                            | 1 B                                  | M[(H·L)]←(AC), (LR)←(LR)-1<br>Stores the contents of the accumulator in the data memory specified by the H and L registers, and then decrements the contents of the L register.<br>[Note 3]                                                                  | - Z     | B 1 |
|                  | ST A, x               | 0 0 1 1 1 1 1 1<br>x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 F<br>x <sub>H</sub> x <sub>L</sub> | M[x]←(AC)<br>Stores the contents of the accumulator in the data memory specified by the x of the instruction field.                                                                                                                                          | - -     | 1 2 |
|                  | ST #k,@HL+            | 1 1 1 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                        | F k                                  | M[(H·L)]←k, (LR)←(LR)+1<br>Stores the immediate data k of the instruction field in the data memory specified by the H and L registers, and then increments the contents of the L register.<br>[Note 3]                                                       | - Z     | C 1 |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

~PRELIMINARY

| Items<br>Class   | Assembler<br>Mnemonic | Object Code                                                                                                                                |             | Function                                                                                                                                                               | Flag(*)  |      |
|------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------|
|                  |                       | Binary                                                                                                                                     | (*)         |                                                                                                                                                                        | CF ZF SF | (**) |
| Move Instruction | ST #k, y              | 0 0 1 0 1 1 0 1<br>k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 D<br>k y  | M[y]+k                                                                                                                                                                 | - - 1    | 2    |
|                  |                       |                                                                                                                                            |             | Stores the immediate value k of the instruction field in the data memory specified by y (page 0) of the instruction field. Serves as the clear instruction when k = 0. |          |      |
|                  | MOV H, A              | 0 0 0 1 0 0 0 0                                                                                                                            | 1 0         | (AC)+(HR)                                                                                                                                                              | - Z 1    | 1    |
|                  |                       |                                                                                                                                            |             | Loads the contents of the H register in the accumulator.                                                                                                               |          |      |
|                  | MOV L, A              | 0 0 0 1 0 0 0 1                                                                                                                            | 1 1         | (AC)+(LR)                                                                                                                                                              | - Z 1    | 1    |
|                  |                       |                                                                                                                                            |             | Loads the contents of the L register in the accumulator.                                                                                                               |          |      |
|                  | XCH A, H              | 0 0 1 1 0 0 0 0                                                                                                                            | 3 0         | (HR)‡(AC)                                                                                                                                                              | - Z 1    | 2    |
|                  |                       |                                                                                                                                            |             | Exchanges the contents of the accumulator for those of the H register. [Note 2]                                                                                        |          |      |
|                  | XCH A, L              | 0 0 1 1 0 0 0 1                                                                                                                            | 3 1         | (LR)‡(AC)                                                                                                                                                              | - Z 1    | 2    |
|                  |                       |                                                                                                                                            |             | Exchanges the contents of the accumulator for those of the L register. [Note 2]                                                                                        |          |      |
|                  | XCH A, EIR            | 0 0 0 1 0 0 1 1                                                                                                                            | 1 3         | (EIR)‡(AC)                                                                                                                                                             | - - 1    | 1    |
|                  |                       |                                                                                                                                            |             | Exchanges the contents of the accumulator for those of the interrupt enable register.                                                                                  |          |      |
|                  | XCH A, @HL            | 0 0 0 0 1 1 0 1                                                                                                                            | 0 D         | M[(H-L)]‡(AC)                                                                                                                                                          | - Z 1    | 1    |
|                  |                       |                                                                                                                                            |             | Exchanges the contents of the accumulator for those of the data memory specified by the H and L registers. [Note 2]                                                    |          |      |
|                  | XCH A, x              | 0 0 1 1 1 1 0 1<br>x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 D<br>xHxL | M[x]‡(AC)                                                                                                                                                              | - Z 1    | 2    |
|                  |                       |                                                                                                                                            |             | Exchanges the contents of the accumulator for those of the data memory specified by the x of the instruction field. [Note 2]                                           |          |      |
|                  | XCH HL, x             | 0 0 1 0 1 0 0 1<br>x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 2 9<br>xHxL | M[x]‡(LR), M[x'+1]‡(HR)<br>x' = x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> 00                                           | - - 1    | 2    |
|                  |                       |                                                                                                                                            |             | Exchanges the contents of the H and L registers for consecutive two-word contents of the data memory specified by the x' (modified x) of the instruction field.        |          |      |



## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

| Items<br>Class            | Assembler<br>Mnemonic | Object Code                                                                                                                                               |                 | Function                                                                                                                                                                                                 | Flag(*) |                               | (**) |
|---------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------------------------------|------|
|                           |                       | Binary                                                                                                                                                    | (*)             |                                                                                                                                                                                                          | CF      | ZF                            |      |
| Compare Instruction       | CMPR A,@HL            | 0 0 0 1 0 1 1 0                                                                                                                                           | 1 6             | null<-M[(H·L)]-(AC)                                                                                                                                                                                      |         | $\bar{B}$ $\bar{Z}$ $\bar{Z}$ | 1    |
|                           |                       |                                                                                                                                                           |                 | Compares the contents of the data memory specified by the H and L registers with those of the accumulator.                                                                                               |         |                               |      |
|                           | CMPR A, x             | 0 0 1 1 1 1 1 0<br>$x_7x_6x_5x_4$ $x_3x_2x_1x_0$                                                                                                          | 3 E<br>$x_Hx_L$ | null<-M[x]-(AC)                                                                                                                                                                                          |         | $\bar{B}$ $\bar{Z}$ $\bar{Z}$ | 2    |
|                           |                       |                                                                                                                                                           |                 | Compares the contents of the data memory specified by the x of the instruction field with those of the accumulator.                                                                                      |         |                               |      |
|                           | CMPR A,#k             | 1 1 0 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                                       | D K             | null<-k-(AC)                                                                                                                                                                                             |         | $\bar{B}$ $\bar{Z}$ $\bar{Z}$ | 1    |
|                           |                       |                                                                                                                                                           |                 | Compares the immediate data k of the instruction field with the contents of the accumulator. Serves as the accumulator test instruction when k = 0.                                                      |         |                               |      |
| Arithmetic<br>Instruction | CMPR H,#k             | 0 0 1 1 1 0 0 0<br>1 1 0 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                    | 3 8<br>D K      | null<-k-(HR)                                                                                                                                                                                             |         | - Z $\bar{B}$                 | 2    |
|                           |                       |                                                                                                                                                           |                 | Compares the immediate data k of the instruction field with the contents of the H register. Serves as the H register test instruction when k = 0.                                                        |         |                               |      |
|                           | CMPR L,#k             | 0 0 1 1 1 0 0 0<br>1 0 0 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                    | 3 8<br>9 k      | null<-k-(LR)                                                                                                                                                                                             |         | - Z $\bar{B}$                 | 2    |
|                           |                       |                                                                                                                                                           |                 | Compares the immediate data k of the instruction field with the contents of the L register. Serves as the L register test instruction when k = 0.                                                        |         |                               |      |
|                           | CMPR y,#k             | 0 0 1 0 1 1 1 0<br>k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>9</sub> y <sub>8</sub> y <sub>7</sub> y <sub>6</sub> y <sub>0</sub> | 2 E<br>k y      | null<-k-M[y]                                                                                                                                                                                             |         | $\bar{B}$ $\bar{Z}$ $\bar{Z}$ | 2    |
|                           |                       |                                                                                                                                                           |                 | Compares the immediate data k of the instruction field with the contents of the data memory specified by the y (page 0) of the instruction field. Serves as the data memory test instruction when k = 0. |         |                               |      |
|                           | INC A                 | 0 0 0 0 1 0 0 0                                                                                                                                           | 0 8             | (AC)<-(AC)+1                                                                                                                                                                                             |         | - Z $\bar{C}$                 | 1    |
|                           |                       |                                                                                                                                                           |                 | Increments the contents of the accumulator.                                                                                                                                                              |         |                               |      |
|                           | INC L                 | 0 0 0 1 1 0 0 0                                                                                                                                           | 1 8             | (LR)<-(LR)+1                                                                                                                                                                                             |         | - Z $\bar{C}$                 | 1    |
|                           |                       |                                                                                                                                                           |                 | Increments the contents of the L register.                                                                                                                                                               |         |                               |      |

| Items<br>Class         | Assembler<br>Mnemonic | Object Code                                                                            |            | Function                                                                                                                                                                                                                                                       | Flag (*)               |     | (**) |
|------------------------|-----------------------|----------------------------------------------------------------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----|------|
|                        |                       | Binary                                                                                 | (*)        |                                                                                                                                                                                                                                                                | Functional Description |     |      |
| Arithmetic Instruction | INC @HL               | 0 0 0 0 1 0 1 0                                                                        | 0 A        | $M[(H \cdot L)] + M[(H \cdot L)] + 1$<br>Increments the contents of the data memory specified by the H and L registers.                                                                                                                                        | -                      | Z C | 1    |
|                        | DEC A                 | 0 0 0 0 1 0 0 1                                                                        | 0 9        | $(AC) - (AC) - 1$<br>Decrements the contents of the accumulator.                                                                                                                                                                                               | -                      | Z B | 1    |
|                        | DEC L                 | 0 0 0 1 1 0 0 1                                                                        | 1 9        | $(LR) - (LR) - 1$<br>Decrements the contents of the L register.                                                                                                                                                                                                | -                      | Z B | 1    |
|                        | DEC @HL               | 0 0 0 0 1 0 1 1                                                                        | 0 B        | $M[(H \cdot L)] - M[(H \cdot L)] - 1$<br>Decrements the contents of the data memory specified by the H and L registers.                                                                                                                                        | -                      | Z B | 1    |
|                        | ADDC A,@HL            | 0 0 0 1 0 1 0 1                                                                        | 1 5        | $(AC) + (AC) + M[(H \cdot L)] + (CF)$<br>Adds the contents of the data memory specified by the H and L registers as well as those of the carry flag to those of the accumulator, and places the result in the accumulator.                                     | C                      | Z C | 1    |
|                        | ADD A,@HL             | 0 0 0 1 0 1 1 1                                                                        | 1 7        | $(AC) + (AC) + M[(H \cdot L)]$<br>Adds the contents of the data memory specified by the H and L registers to those of the accumulator, and places the result in the accumulator.                                                                               | -                      | Z C | 1    |
|                        | ADD A, #k             | 0 0 1 1 1 0 0 0<br>0 0 0 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>0 k | $(AC) + (AC) + k$<br>Adds the immediate data k of the instruction field to the contents of the accumulator, and places the result in the accumulator. Serves as the correction instruction for decimal addition and subtraction when k = 6 or A.               | -                      | Z C | 2    |
|                        | ADD H, #k             | 0 0 1 1 1 0 0 0<br>1 1 0 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>C k | $(HR) + (HR) + k$<br>Adds the immediate data k of the instruction field to the contents of the H register, and places the result in the H register. Serves as the H register increment instruction or the decrement instruction when k = 1 or F, respectively. | -                      | Z C | 2    |

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

| Items<br>Class         | Assembler<br>Mnemonic | Object Code                                                                                                                                |            | Function                | Flag(*) |    |    |      |
|------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------------------|---------|----|----|------|
|                        |                       | Binary                                                                                                                                     | (**) (***) |                         | CF      | ZF | SF | (**) |
| Arithmetic Instruction | ADD L, #k             | 0 0 1 1 1 0 0 0<br>1 0 0 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                     | 3 8<br>8 k | (LR)+(LR)+k             | -       | Z  | C  | 2    |
|                        | ADD @HL, #k           | 0 0 1 1 1 0 0 0<br>0 1 0 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                     | 3 8<br>4 k | M[(H·L)]+M[(H·L)]+k     | -       | Z  | C  | 2    |
|                        | ADD y, #k             | 0 0 1 0 1 1 1 1<br>k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 F<br>k y | M[y]+M[y]+k             | -       | Z  | C  | 2    |
|                        | SUBRCA, @HL           | 0 0 0 1 0 1 0 0                                                                                                                            | 1 4        | (AC)-M[(H·L)]-(AC)-(CF) | B       | Z  | B  | 1    |
|                        | SUBR A, #k            | 0 0 1 1 1 0 0 0<br>0 0 0 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                     | 3 8<br>1 k | (AC)-k-(AC)             | -       | Z  | B  | 2    |

| Items<br>Class            | Assembler<br>Mnemonic | Object Code                                                                            |            | Function                                                                                                                                                                                                                                                                                                          | Flag(*)<br>CF ZF SF (**) |   |
|---------------------------|-----------------------|----------------------------------------------------------------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|---|
|                           |                       | Binary                                                                                 | (**)       |                                                                                                                                                                                                                                                                                                                   | Functional Description   |   |
| Arithmetic<br>Instruction | SUBR @HL, #k          | 0 0 1 1 1 0 0 0<br>0 1 0 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>5 k | M[(H·L)]←k-M[(H·L)]                                                                                                                                                                                                                                                                                               | - Z $\bar{B}$            | 2 |
|                           |                       |                                                                                        |            | Subtracts the contents of the data memory specified by the H and L registers from the immediate data k of the instruction field, and places the result in the data memory. Serves as the data memory 2's complement instruction or the data inversion (1's complement) instruction when k = 0 or F, respectively. |                          |   |
| Logical Instruction       | ROLCA                 | 0 0 0 0 0 1 0 1                                                                        | 0 5        |  (rotate left)<br>by 1 bit                                                                                                                                                                                                       | C Z $\bar{C}$            | 1 |
|                           |                       |                                                                                        |            | Rotates the contents of the accumulator and carry flag to the left by one bit. [Note 4]                                                                                                                                                                                                                           |                          |   |
|                           | RORCA                 | 0 0 0 0 0 1 1 1                                                                        | 0 7        |  (rotate right)<br>by 1 bit                                                                                                                                                                                                      | C Z $\bar{C}$            | 1 |
|                           |                       |                                                                                        |            | Rotates the contents of the accumulator and carry flag to the right by one bit. [Note 4]                                                                                                                                                                                                                          |                          |   |
|                           | AND A, @HL            | 0 0 0 1 1 1 1 0                                                                        | F E        | (AC)←(AC)ΛM[(H·L)]                                                                                                                                                                                                                                                                                                | - Z $\bar{Z}$            | 1 |
|                           |                       |                                                                                        |            | Carries out the logical AND of the corresponding bits with the contents of the accumulator and those of the data memory specified by the H and L register, and places the result in the accumulator.                                                                                                              |                          |   |
|                           | AND A, #k             | 0 0 1 1 1 0 0 0<br>0 0 1 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>3 k | (AC)←(AC)Λk                                                                                                                                                                                                                                                                                                       | - Z $\bar{Z}$            | 2 |
|                           |                       |                                                                                        |            | Carries out the logical AND of the corresponding bits with the contents of the accumulator and the immediate data k of the instruction field, and places the result in the accumulator.                                                                                                                           |                          |   |
|                           | AND @HL, #k           | 0 0 1 1 1 0 0 0<br>0 1 1 1 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>7 k | M[(H·L)]←M[(H·L)]Λk                                                                                                                                                                                                                                                                                               | - Z $\bar{Z}$            | 2 |
|                           |                       |                                                                                        |            | Carries out the logical AND of the corresponding bits with the contents of the data memory specified by the H and L registers and the immediate data k of the instruction field, and places the result in the data memory.                                                                                        |                          |   |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

| Items<br>Class                  | Assembler<br>Mnemonic | Object Code                                                                            |            | Function                                                                                                                                                                                                                  | Flag(*) |       |
|---------------------------------|-----------------------|----------------------------------------------------------------------------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|
|                                 |                       | Binary                                                                                 | (**)       |                                                                                                                                                                                                                           | CF      | ZF    |
| Logical<br>Instruction          | OR A, @HL             | 0 0 0 1 1 1 0 1                                                                        | 1 D        | (AC)+(AC)VM[(H·L)]                                                                                                                                                                                                        | -       | Z Z 1 |
|                                 |                       |                                                                                        |            | Carries out the logical OR of the corresponding bits with the contents of the accumulator and those of the data memory specified by the H and L registers, and places the result in the accumulator.                      |         |       |
|                                 | OR A, #k              | 0 0 1 1 1 0 0 0<br>0 0 1 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>2 k | (AC)+(AC)vk                                                                                                                                                                                                               | -       | Z Z 2 |
|                                 |                       |                                                                                        |            | Carries out the logical OR of the corresponding bits with the contents of the accumulator and the immediate data k of the instruction field, and places the result in the accumulator.                                    |         |       |
| Bit Manipulation<br>Instruction | OR @HL, #k            | 0 0 1 1 1 0 0 0<br>0 1 1 0 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8<br>6 k | M[(H·L)]+M[(H·L)]vk                                                                                                                                                                                                       | -       | Z Z 2 |
|                                 |                       |                                                                                        |            | Carries out the logical OR of the corresponding bits with the contents of the data memory specified by the H and L registers and the immediate data k of the instruction field, and places the result in the data memory. |         |       |
|                                 | XOR A, @HL            | 0 0 0 1 1 1 1 1                                                                        | 1 F        | (AC)+(AC)VM[(H·L)]                                                                                                                                                                                                        | -       | Z Z 1 |
|                                 |                       |                                                                                        |            | Carries out the logical exclusive OR of the corresponding bits with the contents of the accumulator and those of data memory specified by the H and L registers, and places the result in the accumulator.                |         |       |
| Bit Manipulation<br>Instruction | TEST CF               | 0 0 0 0 0 1 1 0                                                                        | 0 6        | (SF)+(CF), (CF)+0                                                                                                                                                                                                         | 0       | - * 1 |
|                                 |                       |                                                                                        |            | Places the inverse contents of the carry flag in the status flag, and then resets the carry flag to "0".                                                                                                                  |         |       |
|                                 | TEST A, b             | 0 1 0 1 1 1 b <sub>1</sub> b <sub>0</sub>                                              | 5 C+b      | (SF)+(AC)<b>                                                                                                                                                                                                              | --      | * 1   |
|                                 |                       |                                                                                        |            | Places the inverse contents of the bit, which is specified by the b of the instruction field, of the accumulator, in the status flag.                                                                                     |         |       |
|                                 | TEST @HL, b           | 0 1 0 1 1 0 b <sub>1</sub> b <sub>0</sub>                                              | 5 8+b      | (SF)+M[(H·L)]<b>                                                                                                                                                                                                          | --      | * 1   |
|                                 |                       |                                                                                        |            | Places the inverse contents of the bit, which is specified by the b of the instruction field, of the data memory specified by the H and L registers, in the status flag.                                                  |         |       |

| Items<br>Class               | Assembler<br>Mnemonic | Object Code                                                                                                      |              | Function                                                                                                                                                                                                                                               | Flag(*)                |   | (**) |
|------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---|------|
|                              |                       | Binary                                                                                                           | (**)         |                                                                                                                                                                                                                                                        | Functional Description |   |      |
| Bit Manipulation Instruction | TEST y, b             | 0 0 1 1 1 0 0 1<br>1 0 b <sub>1</sub> b <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 3 9<br>8+b y | (SF) <sup>+</sup> M[y]<b>                                                                                                                                                                                                                              | - - *                  | 2 |      |
|                              |                       |                                                                                                                  |              | Places the inverse contents of the bit, which is specified by the b of the instruction field, of the data memory specified by the y (page 0) of the instruction field, in the status flag.                                                             |                        |   |      |
|                              | TEST %P,b             | 0 0 1 1 1 0 1 1<br>1 0 b <sub>1</sub> b <sub>0</sub> p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub> | 3 B<br>8+b P | (SF) <sup>+</sup> P[p]<b>                                                                                                                                                                                                                              | - - *                  | 2 |      |
|                              |                       |                                                                                                                  |              | Places the inverse contents of the bit, which is specified by the b of the instruction field, of the port (port register in the output port, and pin input in the input and I/O port) specified by the p of the instruction field, in the status flag. |                        |   |      |
|                              | TEST @L               | 0 0 1 1 0 1 1 1                                                                                                  | 3 7          | (SF) <sup>+</sup> P[(LR)<3:2>+4]<(LR)<1:0>>                                                                                                                                                                                                            | - - *                  | 2 |      |
|                              |                       |                                                                                                                  |              | Places the inverse contents of the bit, which is specified by the lower-order two bits of the L register, of the ports R <sub>4</sub> - R <sub>7</sub> (pin input) specified by the higher two bits of the L register, in the status flag.             |                        |   |      |
|                              | TESTP CF              | 0 0 0 0 0 1 0 0                                                                                                  | 0 4          | (SF) <sup>+</sup> (CF), (CF)+1                                                                                                                                                                                                                         | 1 -                    | * | 1    |
|                              |                       |                                                                                                                  |              | Places the contents of the carry flag in the status flag, and then sets the carry flag to "1".                                                                                                                                                         |                        |   |      |
|                              | TESTP ZF              | 0 0 0 0 1 1 1 0                                                                                                  | 0 E          | (SF) <sup>+</sup> (ZF)                                                                                                                                                                                                                                 | - - *                  | 1 |      |
|                              |                       |                                                                                                                  |              | Places the contents of the zero flag in the status flag.                                                                                                                                                                                               |                        |   |      |
|                              | TESTP GF              | 0 0 0 0 0 0 0 1                                                                                                  | 0 1          | (SF) <sup>+</sup> (GF)                                                                                                                                                                                                                                 | - - *                  | 1 |      |
|                              |                       |                                                                                                                  |              | Places the contents of the general flag in the status flag.                                                                                                                                                                                            |                        |   |      |
|                              | TESTPy,b              | 0 0 1 1 1 0 0 1<br>1 1 b <sub>1</sub> b <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 3 9<br>C+b y | (SF) <sup>+</sup> M[y]<b>                                                                                                                                                                                                                              | - - *                  | 2 |      |
|                              |                       |                                                                                                                  |              | Places the contents of the bit, which is specified by the b of the instruction field, of the data memory specified by the y (page 0) of the instruction field, in the status flag.                                                                     |                        |   |      |

| Items<br>Class               | Assembler<br>Mnemonic                     | Object Code                                                                                                      |                                                                                                                                     | Function                                                                                                                                                               | Flag(*) |    |    |
|------------------------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----|----|
|                              |                                           | Binary                                                                                                           | (*)                                                                                                                                 |                                                                                                                                                                        | CF      | ZF | SF |
| Bit Manipulation Instruction | TESTP %P, b                               | 0 0 1 1 1 0 1 1<br>1 1 b <sub>1</sub> b <sub>0</sub> p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub> | 3 B<br>C+b P                                                                                                                        | (SF)←P[p]<b>                                                                                                                                                           | - -     | *  | 2  |
|                              | SET GF                                    | 0 0 0 0 0 0 1 1                                                                                                  | 0 3                                                                                                                                 | (GF)←1                                                                                                                                                                 | - -     | 1  | 1  |
|                              |                                           |                                                                                                                  |                                                                                                                                     | Sets the general flag to "1".                                                                                                                                          |         |    |    |
|                              | SET @HL, b                                | 0 1 0 1 0 0 b <sub>1</sub> b <sub>0</sub>                                                                        | 5 b                                                                                                                                 | M[(H·L)]<b>←1                                                                                                                                                          | - -     | 1  | 1  |
|                              |                                           |                                                                                                                  |                                                                                                                                     | Sets the bit, which is specified by the b of the instruction field, of the data memory specified by the H and L registers, to "1".                                     |         |    |    |
|                              | SET y, b                                  | 0 0 1 1 1 0 0 1<br>0 0 b <sub>1</sub> b <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 3 9<br>b y                                                                                                                          | M[y]<b>←1                                                                                                                                                              | - -     | 1  | 2  |
|                              |                                           |                                                                                                                  |                                                                                                                                     | Sets the bit, which is specified by the b of the instruction field, of the data memory specified by the y (page 0) of the instruction field, to "1".                   |         |    |    |
|                              | SET %p, b                                 | 0 0 1 1 1 0 1 1<br>0 0 b <sub>1</sub> b <sub>0</sub> p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub> | 3 B<br>b y                                                                                                                          | P[p]<b>←1                                                                                                                                                              | - -     | 1  | 2  |
|                              |                                           |                                                                                                                  |                                                                                                                                     | Sets the bit, which is specified by the b of the instruction field, of the port specified by the p of the instruction field, to "1".                                   |         |    |    |
|                              | SET @L                                    | 0 0 1 1 0 1 0 0                                                                                                  | 3 4                                                                                                                                 | P[(LR)<3:2>+4]<(LR)<1:0>>←1                                                                                                                                            | - -     | 1  | 2  |
|                              |                                           |                                                                                                                  |                                                                                                                                     | Sets the bit, which is specified by the lower-order two bits of the L register, of the ports R4 - R7 specified by the higher-order two bits of the L register, to "1". |         |    |    |
| CLR GF                       | 0 0 0 0 0 0 1 0                           | 0 2                                                                                                              | (GF)←0                                                                                                                              | - -                                                                                                                                                                    | 1       | 1  |    |
|                              |                                           |                                                                                                                  | Clears the general flag to "0".                                                                                                     |                                                                                                                                                                        |         |    |    |
| CLR @HL, b                   | 0 1 0 1 0 1 b <sub>1</sub> b <sub>0</sub> | 5 4+b                                                                                                            | M[(H·L)]<b>←0                                                                                                                       | - -                                                                                                                                                                    | 1       | 1  |    |
|                              |                                           |                                                                                                                  | Clears the bit, which is specified by the b of the instruction field, of the data memory specified by the H and L register, to "0". |                                                                                                                                                                        |         |    |    |



# INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP47C40P

TMP47C20P

~~PRELIMINARY~~

| Items<br>Class               | Assembler<br>Mnemonic | Object Code                                                                                                      |                           | Function                                                                                                                                                                                                                        |  | Flag(*)<br>CF | Flag(*)<br>ZF | Flag(*)<br>SF |
|------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|---------------|---------------|---------------|
|                              |                       | Binary                                                                                                           | (*)                       | Functional Description                                                                                                                                                                                                          |  |               |               |               |
| Bit Manipulation Instruction | CLR y, b              | 0 0 1 1 1 0 0 1<br>0 1 b;bo y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub>                          | 3 9<br>4+b y              | M[y]<b> = 0<br>Clears the bit, which is specified by the b of the instruction field, of the data memory specified by the y (page 0) of the instruction field, to "0".                                                           |  | - -           | 1             | 2             |
|                              | CLR %P, b             | 0 0 1 1 1 0 1 1<br>0 1 b;bo p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub>                          | 3 B<br>4+b p              | P[p]<b> = 0<br>Clears the bit, which is specified by the b of the instruction field, of the port specified by the p of the instruction field, to "0".                                                                           |  | - -           | 1             | 2             |
|                              | CLR @L                | 0 0 1 1 0 1 0 1                                                                                                  | 3 5                       | P[(LR)<3:2>+4]<(LR)<1:0>>=0<br>Clears the bit, which is specified by the lower-order two bits of the L register, of the ports R <sub>4</sub> - R <sub>7</sub> specified by the higher-order two bits of the L register, to "0". |  | - -           | 1             | 2             |
|                              | CLR IL, r             | 0 0 1 1 0 1 1 0<br>1 1 r <sub>5</sub> r <sub>4</sub> r <sub>3</sub> r <sub>2</sub> r <sub>1</sub> r <sub>0</sub> | 3 6<br>C+r <sub>H</sub> L | (INTL)<5:0>+(INTL)<5:0>Ar<5:0><br>Resets the interrupt latch INTLj when the rj of the instruction field is "0". (j = 5 - 0)                                                                                                     |  | - -           | 1             | 2             |
|                              | EICLR IL,r            | 0 0 1 1 0 1 1 0<br>0 1 r <sub>5</sub> r <sub>4</sub> r <sub>3</sub> r <sub>2</sub> r <sub>1</sub> r <sub>0</sub> | 3 6<br>4+r <sub>H</sub> L | (EIF)+1,<br>(INTL)<5:0>+(INTL)<5:0>Ar<5:0><br>Sets the interrupt enable master F/F to "1". Interrupt latch INTLj is reset when the rj of the instruction field is "0". (j = 5 - 0)                                              |  | - -           | 1             | 2             |
|                              | DICLR IL,r            | 0 0 1 1 0 1 1 0<br>1 0 r <sub>5</sub> r <sub>4</sub> r <sub>3</sub> r <sub>2</sub> r <sub>1</sub> r <sub>0</sub> | 3 6<br>8+r <sub>H</sub> L | (EIF)=0,<br>(INTL)<5:0>+(INTL)<5:0>Ar<5:0><br>Resets the interrupt enable master F/F to "0". Interrupt latch INTLj is reset when the rj of the instruction field is "0". (j = 5 - 0)                                            |  | - -           | 1             | 2             |
| Input In-<br>struction       | IN %P, A              | 0 0 1 1 1 0 1 0<br>0 0 1 0 p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub>                           | 3 A<br>2 P                | (AC)<p><br>Places the input data from the port specified by the p of the instruction field in the accumulator.                                                                                                                  |  | - Z           | Z             | 2             |

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

| Items<br>Class                       | Assembler<br>Mnemonic | Object Code                                                                                                                                                                      |                             | Function                                                                                                                                                                                                                                                                                                                                        | Flag(*) |     |
|--------------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----|
|                                      |                       | Binary                                                                                                                                                                           | (***)                       |                                                                                                                                                                                                                                                                                                                                                 | CF      | ZF  |
| Input/Output Instruction             | IN %P, @HL            | 0 0 1 1 1 0 1 0<br>0 1 1 0 p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub>                                                                                           | 3 A<br>6 P                  | M[(H·L)]→P[p]<br>Places the input data from the port specified by the p of the instruction field in the data memory specified by the H and L registers.                                                                                                                                                                                         | - -     | Z 2 |
|                                      | OUT A, %P             | 0 0 1 1 1 0 1 0<br>1 0 p̄ <sub>4</sub> 0 p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub>                                                                             | 3 A<br>8+2p̄ <sub>4</sub> P | P[p]←(AC), P=P <sub>4</sub> P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub><br>Outputs the contents of the accumulator to the port specified by the p of the instruction field. (0 ≤ p ≤ 31)                                                                                                                                        | - -     | 1 2 |
|                                      | OUT @HL,%P            | 0 0 1 1 1 0 1 0<br>1 1 p̄ <sub>4</sub> 0 p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub>                                                                             | 3 A<br>C+2p̄ <sub>4</sub> P | P[p]←M[(H·L)], P=P <sub>4</sub> P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub><br>Outputs the contents of the data memory specified by the H and L registers to the port specified by the p of the instruction field. (0 ≤ p ≤ 31)                                                                                                 | - -     | 1 2 |
|                                      | OUT #k,%P             | 0 0 1 0 1 1 0 0<br>k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> p <sub>3</sub> p <sub>2</sub> p <sub>1</sub> p <sub>0</sub>                                       | 2 C<br>k P                  | P[p]←k<br>Outputs the immediate data k of the instruction field to the port specified by the p of the instruction field. Serves as the clear instruction when k = 0.                                                                                                                                                                            | - -     | 1 2 |
|                                      | OUTB @HL              | 0 0 0 1 0 0 1 0                                                                                                                                                                  | 1 2                         | P[2]·P[1]+ROM[F·(E+(CF))·M[(H·L)]]<br>Outputs the data (eight bits) of the program memory located in addresses FEO - FFF, which use a five-bit data connecting the contents of the data memory specified by the H and L registers and those of the carry flag, as lower-order five-bit addresses, to the P <sub>2</sub> - P <sub>1</sub> ports. | - -     | 1 2 |
| Branch-<br>Subroutine<br>Instruction | BS a                  | 0 1 1 0 a <sub>10</sub> a <sub>9</sub> a <sub>8</sub><br>a <sub>7</sub> 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> | 6 ah<br>aM aL               | If SF=1 then (PC)+a else null.<br>Places the immediate data a of the instruction field in the program counter if the status flag is at "1". If the status flag is at "0", sets the status flag only to "1", and moves to the next address.                                                                                                      | - -     | 1 2 |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

| Items<br>Class                | Assembler<br>Mnemonic | Object Code                                                                                                                                                                        |                                 | Function                                                                                                                                                                            | Flag(*) |     |
|-------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----|
|                               |                       | Binary                                                                                                                                                                             | (**)                            |                                                                                                                                                                                     | CF      | ZF  |
| Branch/Subroutine Instruction | BSS a                 | 1 0 d <sub>5</sub> d <sub>4</sub> d <sub>3</sub> d <sub>2</sub> d <sub>1</sub> d <sub>0</sub>                                                                                      | 8+d <sub>H</sub> d <sub>L</sub> | If SF=1 then (PC)←a else null,<br>a=(PC)<11·6>·d                                                                                                                                    | - -     | 1 1 |
|                               | CALL a                | 0 0 1 0 0 a <sub>10</sub> a <sub>9</sub> a <sub>8</sub><br>a <sub>7</sub> 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> | 2 aH<br>aM aL                   | STACK[(SPW)]←(PC), (SPW)←(SPW)-1<br>(PC)←a, 0 ≤ a ≤ 2,047                                                                                                                           | - - -   | 2   |
|                               | CALLS a               | 0 1 1 1 n <sub>3</sub> n <sub>2</sub> n <sub>1</sub> n <sub>0</sub>                                                                                                                | 7 n                             | STACK[(SPW)]←(PC), (SPW)←(SPW)-1<br>(PC)←a, a=8n+6(n≠0), 134(n=0)                                                                                                                   | - - -   | 2   |
|                               | RET                   | 0 0 1 0 1 0 1 1                                                                                                                                                                    | 2 A                             | (SPW)←(SPW)+1, (PC)←STACK[(SPW)]                                                                                                                                                    | - - -   | 2   |
|                               |                       |                                                                                                                                                                                    |                                 | Returns from the subroutine to the previous<br>program; increments the stack pointer word,<br>and restores the data of the return address<br>from the stack to the program counter. |         |     |



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

| Item<br>Class                    | Assembler<br>Mnemonic | Object Code     |     | Function                                                                                                                                                                                                                                                                            | Flag(*) |    |    |
|----------------------------------|-----------------------|-----------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----|----|
|                                  |                       | Binary          | (*) |                                                                                                                                                                                                                                                                                     | CF      | ZF | SF |
| Branch・Subroutine<br>Instruction | RETI                  | 0 0 1 0 1 0 1 1 | 2 B | $(SPW) \leftarrow (SPW) + 1$ ,<br>$(FLAG \cdot PC) \leftarrow \text{STACK}[(SPW)]$ , $(EIF) \leftarrow 1$                                                                                                                                                                           | *       | *  | 2  |
|                                  |                       |                 |     | Returns from the interrupt processing routine; increments the stack pointer word, and restores the data of the return address from the stack and the data of the flag, to the program counter and the flag, respectively. And then, it sets the interrupt enable master F/F to "1". |         |    |    |
| Other<br>Instruc-<br>tion        | NOP                   | 0 0 0 0 0 0 0 0 | 0 0 | no operation                                                                                                                                                                                                                                                                        | - - -   |    | 1  |
|                                  |                       |                 |     | Moves to the next instruction without performing any operation.                                                                                                                                                                                                                     |         |    |    |

Note 1. Setting Condition of Flag.

"C" indicates the carry output from the most significant position in the addition operation, and "B" indicates the borrow output from the most significant position in the subtraction operation.

"Z" indicates the zero detection signal to which "1" is applied only when either the ALU output of the processing result or all four bits of the data transferred to the accumulator are zero.

The flag is set to "C", " $\bar{C}$ ", " $\bar{B}$ ", "Z", " $\bar{Z}$ ", "1", or "0" according to the data processing result. The value specified by the function is set to the flag with the mark "\*", and the mark "-" denotes no change in the state of the flag.

Note 2. The zero flag is set according to the data set in the accumulator.

Note 3. The flags (ZF, SF) are set according to the result of increment or decrement of the L register.

Note 4. The carry is the data shifted out from the accumulator.

Note 5. The contents of the program counter indicate the next address of the instruction to be executed.



## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

## ELECTRICAL CHARACTERISTICS

ABSOLUTE MAXIMUM RATINGS (V<sub>SS</sub> = 0V)

| SYMBOL            | ITEM                                           | RATING                       | UNIT |
|-------------------|------------------------------------------------|------------------------------|------|
| V <sub>DD</sub>   | Supply Voltage                                 | -0.5 ~ 7                     | V    |
| V <sub>IN</sub>   | Input Voltage                                  | -0.5 ~ V <sub>DD</sub> + 0.5 | V    |
| V <sub>OUT1</sub> | Output Voltage<br>(Except open drain terminal) | -0.5 ~ V <sub>DD</sub> + 0.5 |      |
| V <sub>OUT2</sub> | Output Voltage<br>(Sink open drain terminal)   | -0.5 ~ 10                    | V    |
| V <sub>OUT3</sub> | Output Voltage<br>(Source open drain terminal) | -35 ~ V <sub>DD</sub> + 0.5  |      |
| P <sub>D</sub>    | Power Dissipation (T <sub>opr</sub> =70°C)     | 600                          | mW   |
| T <sub>sld</sub>  | Soldering Temperature · Time                   | 260 (10 sec.)                |      |
| T <sub>stg</sub>  | Storage Temperature                            | -55 ~ 125                    | °C   |
| T <sub>opr</sub>  | Operating Temperature                          | -30 ~ 70                     |      |

RECOMMENDED OPERATING CONDITIONS (V<sub>SS</sub> = 0V)

| SYMBOL           | ITEM                                                                                                  | CONDITION                         | MIN.                   | MAX.                   | UNIT |
|------------------|-------------------------------------------------------------------------------------------------------|-----------------------------------|------------------------|------------------------|------|
| T <sub>opr</sub> | Operating Temperature                                                                                 |                                   | -30                    | 70                     | °C   |
| V <sub>DD</sub>  | Supply Voltage                                                                                        |                                   | 4.5                    | 6                      |      |
| V <sub>DDH</sub> | Supply Voltage (Hold)                                                                                 |                                   | 2                      | 6                      | V    |
| V <sub>IH1</sub> | Input High Voltage (Except Schmitt circuit input) [Note 1]                                            | V <sub>DD</sub> ≥ 4.5V            | V <sub>DD</sub> × 0.7  | V <sub>DD</sub>        |      |
| V <sub>IH2</sub> | Input High Voltage (Schmitt circuit input)                                                            |                                   | V <sub>DD</sub> × 0.75 | V <sub>DD</sub>        |      |
| V <sub>IH3</sub> | Input High Voltage                                                                                    | V <sub>DD</sub> < 4.5             | V <sub>DD</sub> × 0.9  | V <sub>DD</sub>        | V    |
| V <sub>IL1</sub> | Input Low Voltage (Except Schmitt circuit input) [Note 1]                                             | V <sub>DD</sub> ≥ 4.5V            | 0                      | V <sub>DD</sub> × 0.3  |      |
| V <sub>IL2</sub> | Input Low Voltage (Schmitt circuit input)                                                             |                                   | 0                      | V <sub>DD</sub> × 0.25 |      |
| V <sub>IL3</sub> | Input Low Voltage                                                                                     | V <sub>DD</sub> < 4.5V            | 0                      | V <sub>DD</sub> × 0.1  |      |
| V <sub>OUT</sub> | Output Voltage (Source open drain P <sub>1</sub> , P <sub>2</sub> , P <sub>4</sub> ~ P <sub>6</sub> ) |                                   | V <sub>DD</sub> -35    | V <sub>DD</sub>        | V    |
| f <sub>C</sub>   | Clock Frequency                                                                                       |                                   | 0.4                    | 4.2                    | MHz  |
| t <sub>WCH</sub> | Clock High Pulse Width [Note 2]                                                                       | V <sub>IN</sub> = V <sub>IH</sub> | 80                     | -                      | ns   |
| t <sub>WCL</sub> | Clock Low Pulse Width [Note 2]                                                                        | V <sub>IN</sub> = V <sub>IL</sub> | 80                     | -                      |      |

(Note 1) R<sub>4</sub> ~ R<sub>6</sub> ports are exclusively used for output except the sink open drain output.

(Note 2) In case of the external clock operation.

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

D.C. CHARACTERISTICS (V<sub>SS</sub> = 0V, V<sub>DD</sub> = 5V±10%, Topr = -30 ~ 70°C)

| SYMBOL           | Parameter                                                                                                     | CONDITION                                                                                     | MIN. | Note 1<br>TYP. | MAX.   | UNIT |
|------------------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|------|----------------|--------|------|
| V <sub>HS</sub>  | Hysteresis Voltage<br>(Schmitt circuit input)                                                                 |                                                                                               | -    | 0.7            | -      | V    |
| I <sub>IN1</sub> | Input Current<br>(K <sub>0</sub> , RESET, HOLD, TEST) [Note 2]                                                | V <sub>DD</sub> =5.5V,<br>V <sub>IN</sub> =5.5/0V                                             | -    | -              | ±20    | μA   |
| I <sub>IN2</sub> | Input Current<br>(Sink open drain R port)                                                                     |                                                                                               | -    | -              | ±20    |      |
| I <sub>IL</sub>  | Input Low Current<br>(Push-pull R <sub>T</sub> ~ R <sub>S</sub> )                                             | V <sub>DD</sub> =5.5V,<br>V <sub>IN</sub> =0.4V                                               | -    | -              | -2     | mA   |
| R <sub>IN</sub>  | Input resistor<br>(K <sub>0</sub> with input resistor)                                                        |                                                                                               | 30   | 70             | 150    | kΩ   |
| I <sub>LO1</sub> | Output Leak Current<br>(Sink open drain P, R port)                                                            | V <sub>DD</sub> =5.5V,<br>V <sub>OUT</sub> =5.5V                                              | -    | -              | 20     | μA   |
| I <sub>LO2</sub> | Output Leak Current (Source<br>open drain P <sub>1</sub> , P <sub>2</sub> , R <sub>4</sub> ~ R <sub>6</sub> ) | V <sub>DD</sub> =5.5V,<br>V <sub>OUT</sub> =-32V                                              | -    | -              | -20    |      |
| V <sub>OH1</sub> | Output High Voltage<br>(Push pull R <sub>T</sub> ~ R <sub>9</sub> )                                           | V <sub>DD</sub> =4.5V,<br>I <sub>OH</sub> =-200μA                                             | 2.4  | -              | -      |      |
| V <sub>OH2</sub> | Output High Voltage (Source<br>open drain P <sub>1</sub> , P <sub>2</sub> )                                   | V <sub>DD</sub> =4.5V,<br>I <sub>OH</sub> =-1.6mA                                             | 2.4  | -              | -      |      |
| V <sub>OH3</sub> | Output High Voltage (Source<br>open drain R <sub>4</sub> ~ R <sub>6</sub> )                                   | V <sub>DD</sub> =4.5V,<br>I <sub>OH</sub> =-10mA                                              | 2.4  | -              | -      | V    |
| V <sub>OL</sub>  | Output Low Voltage (P, R port<br>except source open drain)                                                    | V <sub>DD</sub> =4.5V,<br>I <sub>OL</sub> =1.6mA                                              | -    | -              | 0.4    |      |
| I <sub>DDO</sub> | Operating Supply<br>Current [Note 3]                                                                          | V <sub>DD</sub> (V <sub>DHH</sub> )=5.5V, f <sub>C</sub> =<br>4MHz, V <sub>IN</sub> =5.3/0.2V | -    | 5              | T.B.D. | mA   |
| I <sub>DHH</sub> | Holding Supply<br>Current [Note 3]                                                                            | (all valid) CL=50pF,<br>C <sub>XIN</sub> =C <sub>XOUT</sub> =10pF                             | -    | 0.5            | T.B.D. | μA   |

(Note 1) TYP. values show those when Topr=25°C, V<sub>DD</sub>=5V.(Note 2) When the K<sub>0</sub> port has a built-in input resistor, current by resistor  
is excluded.(Note 3) When K<sub>0</sub> port has a built-in input resistor, current value is that at  
time of open. Further, voltage level at R port is valid.A.C. CHARACTERISTICS (V<sub>SS</sub> = 0V, V<sub>DD</sub> = 5V±10%, Topr = -30 ~ 70°C)

| SYMBOL           | Parameter              | CONDITION | MIN.                    | TYP. | MAX. | UNIT |
|------------------|------------------------|-----------|-------------------------|------|------|------|
| t <sub>cy</sub>  | Instruction Cycle Time |           | 3.8                     | -    | 40   | μs   |
| t <sub>SDH</sub> | Shift Data Hold Time   | (Note 1)  | 0.5t <sub>cy</sub> -300 | -    | -    | ns   |

## A.C. TIMING CHART

- Serial Port (Completion of Transmission)

(Note 1)  $\overline{SCK}$ , SO terminal  
external circuit



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

### EXTERNAL DIMENSION VIEW

Unit in 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.42 leads.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

### Specification of program tape and input/output circuit format

Engineering Samples(ES) of the TMP47C40P, TMP47C20P, TMP47C41P and TMP47C21P will be made if you specify the program data and input/output circuit format by use of a paper tape.

The paper tape format is equivalent to the Hex. format of Intel Co. (Format I).

The program data should be specified within the address space corresponding to the built-in ROM capacity; the addresses 000 - 7FF denote the address range in the TMP47C20P and TMP47C21P. Accordingly, if the PLA data conversion table (addresses FEO - FFF) is used, the table data must be assigned as the data located in addresses 7EO - 7FF.

#### 1. Specification of input/output circuit format

The paper tape of Format I starts recording the program data after record mark ":"; but the input/output circuit code should be specified just before the first record mark.

The "IÖCÖDE XX" format is used to define the input/output circuit code. XX denotes the proper input/output circuit code (two alphabets).

(Note) If the input/output circuit code is not specified, "IÖCÖDE FA" OR "IÖCÖDE HA" are employed. It should be noted that if the specified format is different from the standard one, and if the specified input/output circuit code is illegal, such specifications may be considered to have not been made.

(Example of tape list)

```
TOSHIBA MICROCOMPUTER TLCS-47
IÖCÖDE FA
:10000000665C7D79CF50F3F951FED55A8FF16E570
:1000100088884DDE67E31F5D8ABA6DF292F113F5C1
:100020004FF1F
:
:
:
:1007E000B53D42E0EC32546025B7308CDD52063D1D
:1007F000B4BE9E9E345B6138060B20BC372BF60BD6
:00000001FF
```



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C40P

TMP47C20P

PRELIMINARY

### 2. Program tape format (Format I)





## INTEGRATED CIRCUIT

## TECHNICAL DATA

PRELIMINARY

TMP47C40P

TMP47C20P

## LIST OF INSTRUCTIONS

| Item<br>Classification | Assembler<br>Mnemonic | Object Code    |                                                                                                                         |             |                                                        | Function                                                                                                                       | #1<br>Flags |    |    | Execution<br>Cycle |    |
|------------------------|-----------------------|----------------|-------------------------------------------------------------------------------------------------------------------------|-------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------|----|----|--------------------|----|
|                        |                       | Binary         |                                                                                                                         | Hexadecimal |                                                        |                                                                                                                                | CF          | ZF | SF |                    |    |
|                        |                       | 1st Byte       | 2nd Byte                                                                                                                | 1st Byte    | 2nd Byte                                               |                                                                                                                                |             |    |    |                    |    |
| Move                   | LD A ,@HL             | 00 00 11 00    |                                                                                                                         | 0 C         | (AC) ← M[(H+L)]                                        |                                                                                                                                | -           | Z  | 1  | 1                  |    |
|                        | LD A , X              | 00 11 10 00    | x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 C         | x <sub>H</sub> x <sub>L</sub>                          | (AC) ← M[x]                                                                                                                    | -           | Z  | 1  | 2                  |    |
|                        | LD HL, X              | 00 10 10 00    | x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 2 B         | x <sub>H</sub> x <sub>L</sub>                          | (LR) ← M[y'], (HR) ← M[x+1], y' = x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> 0  | -           | -  | 1  | 2                  |    |
|                        | LD A ,#K              | 01 00          | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 4 k         |                                                        | (AC) ← k                                                                                                                       |             | -  | Z  | 1                  | 1  |
|                        | LD H ,#K              | 11 00          | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | C k         |                                                        | (HR) ← k                                                                                                                       |             | -  | -  | 1                  | 1  |
|                        | LD L ,#K              | 11 10          | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 8 k         |                                                        | (LR) ← k                                                                                                                       |             | -  | -  | 1                  | 1  |
|                        | LDL A ,@DC            | 00 11 00 11    |                                                                                                                         | 3 3         | (AC) ← R0M <sub>1</sub> [(DC)]                         |                                                                                                                                | -           | Z  | 1  | 2                  |    |
|                        | LDH A ,@DC+           | 00 11 00 10    |                                                                                                                         | 3 2         | (AC) ← R0M <sub>1</sub> [(DC)], (DC) ← (DC)+1          |                                                                                                                                | -           | Z  | 1  | 2                  |    |
|                        | ST A ,@HL             | 00 00 11 11    |                                                                                                                         | 0 F         | M[(H+L)] ← (AC)                                        |                                                                                                                                | -           | -  | 1  | 1                  |    |
|                        | ST A ,@HL+            | 00 01 10 10    |                                                                                                                         | 1 A         | M[(H+L)] ← (AC), (LR) ← (LR) + 1                       |                                                                                                                                | -           | Z  | 1  | *3                 |    |
| Compare                | ST A ,@HL-            | 00 01 10 11    |                                                                                                                         | 1 B         | M[(H+L)] ← (AC), (LR) ← (LR) - 1                       |                                                                                                                                | -           | Z  | 1  | *3                 |    |
|                        | ST A , X              | 00 11 11 11    | x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 F         | x <sub>H</sub> x <sub>L</sub>                          | M[y] ← (AC)                                                                                                                    | -           | -  | 1  | 2                  |    |
|                        | ST #K ,@HL+           | 11 11 11       | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | F K         |                                                        | M[(H+L)] ← k, (LR) ← (LR) + 1                                                                                                  |             | -  | Z  | 1                  | *3 |
|                        | ST #K , Y             | 00 10 11 01    | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 D         | k y                                                    | M[y] ← k                                                                                                                       |             | -  | -  | 1                  |    |
|                        | MOV H , A             | 00 01 00 00    |                                                                                                                         | 1 0         | (AC) ← (HR)                                            |                                                                                                                                | -           | Z  | 1  | 1                  |    |
|                        | MOV L , A             | 00 01 00 01    |                                                                                                                         | 1 1         | (AC) ← (LR)                                            |                                                                                                                                | -           | Z  | 1  | 1                  |    |
|                        | XCH A , H             | 00 11 00 00    |                                                                                                                         | 3 0         | (HR) ← (AC)                                            |                                                                                                                                | -           | Z  | 1  | 2                  |    |
|                        | XCH A , L             | 00 11 00 01    |                                                                                                                         | 3 1         | (LR) ← (AC)                                            |                                                                                                                                | -           | Z  | 1  | 2                  |    |
|                        | XCH A , @IR           | 00 01 00 11    |                                                                                                                         | 1 3         | (BIR) ← (AC)                                           |                                                                                                                                | -           | -  | 1  | 1                  |    |
|                        | XCH A , @HL           | 00 00 11 01    |                                                                                                                         | 0 D         | M[(H+L)] ← (AC)                                        |                                                                                                                                | -           | Z  | 1  | *2                 |    |
| Arithmetic             | XCH A , X             | 00 11 11 01    | x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 D         | x <sub>H</sub> x <sub>L</sub>                          | M[x] ← (AC)                                                                                                                    | -           | Z  | 1  | 2                  |    |
|                        | XCH HL , X            | 00 10 10 01    | x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 2 9         | x <sub>H</sub> x <sub>L</sub>                          | M[x'] = (LR) M[x'+1] = (HR), x' = x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> 00 | -           | -  | 1  | 2                  |    |
|                        | CMPR A ,@HL           | 00 01 01 10    |                                                                                                                         | 1 6         | null1 ← M[(H+L)] - (AC)                                |                                                                                                                                | B           | Z  | 2  | 1                  |    |
|                        | CMPR A , X            | 00 11 11 10    | x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> x <sub>0</sub> | 3 E         | x <sub>H</sub> x <sub>L</sub>                          | null1 ← M[x] - (AC)                                                                                                            | B           | Z  | 2  |                    |    |
|                        | CMPR A ,#K            | 11 01          | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | D k         |                                                        | null1 ← k - (AC)                                                                                                               | B           | Z  | 2  |                    |    |
|                        | CMPR H ,#K            | 00 11 10 00 11 | 01 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                          | 3 8         | D k                                                    | null1 ← k - (HR)                                                                                                               | -           | Z  | 2  |                    |    |
|                        | CMPR L ,#K            | 00 11 10 00 10 | 01 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                          | 3 8         | 9 k                                                    | null1 ← k - (LR)                                                                                                               | -           | Z  | 2  |                    |    |
|                        | CMPR Y ,#K            | 00 10 11 10    | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 8         | k y                                                    | null1 ← M[y] - M[y]                                                                                                            | B           | Z  | 2  |                    |    |
|                        | INC A                 | 00 00 10 00    |                                                                                                                         | 0 8         | (AC) ← (AC) + 1                                        |                                                                                                                                | -           | Z  | 1  | 1                  |    |
|                        | INC L                 | 00 01 10 00    |                                                                                                                         | 1 8         | (LR) ← (LR) + 1                                        |                                                                                                                                | -           | Z  | 1  | 1                  |    |
| Logical                | INC @HL               | 00 00 10 10    |                                                                                                                         | 0 A         | M[(H+L)] ← M[(H+L)] + 1                                |                                                                                                                                | -           | Z  | 1  | 1                  |    |
|                        | DEC A                 | 00 00 10 01    |                                                                                                                         | 0 9         | (AC) ← (AC) - 1                                        |                                                                                                                                | -           | Z  | 1  | 1                  |    |
|                        | DEC L                 | 00 01 10 01    |                                                                                                                         | 1 9         | (LR) ← (LR) - 1                                        |                                                                                                                                | -           | Z  | 1  | .1                 |    |
|                        | DEC @HL               | 00 00 10 11    |                                                                                                                         | 0 B         | M[(H+L)] ← M[(H+L)] - 1                                |                                                                                                                                | -           | Z  | 1  | 1                  |    |
|                        | ADD C A ,@HL          | 00 01 01 01    |                                                                                                                         | 1 5         | (AC) ← (AC) + M[(H+L)] + (CP)                          |                                                                                                                                | C           | Z  | 2  | 1                  |    |
|                        | ADD C A , X           | 00 01 01 11    |                                                                                                                         | 1 7         | (AC) ← (AC) + M[(H+L)]                                 |                                                                                                                                | -           | Z  | 1  | 1                  |    |
|                        | ADD C A ,#K           | 00 11 10 00 00 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 8         | 0 k                                                    | (AC) ← (AC) + k                                                                                                                | -           | Z  | 2  |                    |    |
|                        | ADD C H ,#K           | 00 11 10 00 11 | 00 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                          | 3 8         | C k                                                    | (HR) ← (HR) + k                                                                                                                | -           | Z  | 2  |                    |    |
|                        | ADD C L ,#K           | 00 11 10 00 10 | 00 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                          | 3 8         | 8 k                                                    | (LR) ← (LR) + k                                                                                                                | -           | Z  | 2  |                    |    |
|                        | ADD C @HL ,#K         | 00 11 10 00 01 | 00 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                          | 3 8         | 4 k                                                    | M[(H+L)] ← M[(H+L)] + k                                                                                                        | -           | Z  | 2  |                    |    |
|                        | ADD C Y ,#K           | 00 11 10 11    | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 F         | k y                                                    | M[y] ← M[y] + k                                                                                                                | -           | Z  | 2  |                    |    |
|                        | SUBRC A ,@HL          | 00 01 01 00    |                                                                                                                         | 1 4         | (AC) ← M[(H+L)] - (AC) - CF                            |                                                                                                                                | B           | Z  | 2  | 1                  |    |
|                        | SUBRC A ,#K           | 00 11 10 00 01 | k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                             | 3 8         | 1 k                                                    | (AC) ← k - (AC)                                                                                                                | -           | Z  | 2  |                    |    |
|                        | SUBRC @HL ,#K         | 00 11 10 00 01 | 01 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                          | 3 8         | 5 k                                                    | M[(H+L)] ← k - M[(H+L)]                                                                                                        | -           | Z  | 2  |                    |    |
| Logical                | ROLC A                | 00 00 01 01    |                                                                                                                         | 0 5         | <u>CP</u> ← <u>AC</u> <u>P</u> (rotate left by 1 bit)  |                                                                                                                                | c           | Z  | 2  | 1                  |    |
|                        | RORC A                | 00 00 01 11    |                                                                                                                         | 0 7         | <u>AC</u> ← <u>CP</u> <u>P</u> (rotate right by 1 bit) |                                                                                                                                | c           | Z  | 2  | 1                  |    |
|                        | AND A ,@HL            | 00 01 11 10    |                                                                                                                         | 1 E         | (AC) ← (AC) ∧ M[(H+L)]                                 |                                                                                                                                | -           | Z  | 2  | 1                  |    |
|                        | AND A ,#K             | 00 11 10 00 00 | 11 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                          | 3 8         | 3 k                                                    | (AC) ← (AC) ∧ k                                                                                                                | -           | Z  | 2  | 2                  |    |
|                        | AND @HL ,#K           | 00 11 10 00 11 | 11 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                          | 3 8         | 7 k                                                    | M[(H+L)] ← M[(H+L)] ∧ k                                                                                                        | -           | Z  | 2  | 2                  |    |
|                        | OR A ,@HL             | 00 01 11 01    |                                                                                                                         | 1 D         | (AC) ← (AC) ∨ M[(H+L)]                                 |                                                                                                                                | -           | Z  | 2  | 1                  |    |
|                        | OR A ,#K              | 00 11 10 00 00 | 10 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                          | 3 8         | 2 k                                                    | (AC) ← (AC) ∨ k                                                                                                                | -           | Z  | 2  | 2                  |    |
|                        | OR @HL ,#K            | 00 11 10 00 01 | 10 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                          | 3 8         | 6 k                                                    | M[(H+L)] ← M[(H+L)] ∨ k                                                                                                        | -           | Z  | 2  | 2                  |    |
|                        | XOR A ,@HL            | 00 01 11 11    |                                                                                                                         | 1 F         | (AC) ← (AC) △ M[(H+L)]                                 |                                                                                                                                | -           | Z  | 2  | 1                  |    |



## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

PRELIMINARY

TMP47C40P

TMP47C20P

(continued)

| Item<br>Classification | Assembler<br>Mnemonic | Object Code                         |              |             |                                                     | Function | Flags<br>CF ZF SF | x1<br>Execution<br>Cycle |  |  |  |
|------------------------|-----------------------|-------------------------------------|--------------|-------------|-----------------------------------------------------|----------|-------------------|--------------------------|--|--|--|
|                        |                       | Binary                              |              | Hexadecimal |                                                     |          |                   |                          |  |  |  |
|                        |                       | 1st Byte                            | 2nd Byte     | 1st Byte    | 2nd Byte                                            |          |                   |                          |  |  |  |
| Bit Manipulation       | TEST CF               | 00 00 01 10                         |              | 0 6         | (SF) ← (CF), (CF) ← 0                               |          | 0 - * 1           |                          |  |  |  |
|                        | TEST A , b            | 01 01 11 b1b0                       |              | 5 C+b       | (SF) ← (AC)<0>                                      |          | - - * 1           |                          |  |  |  |
|                        | TEST @HL, b           | 01 01 10 b1b0                       |              | 5 B+b       | (SF) ← M[(H+L)]<>                                   |          | - - * 1           |                          |  |  |  |
|                        | TEST y , b            | 00 11 10 01 10                      | b1b0y3y2y1y0 | 3 9 B+b y   | (SF) ← M[y]<>                                       |          | - - * 2           |                          |  |  |  |
|                        | TEST %p , b           | 00 11 10 11 10                      | b1b0P3P2P1P0 | 3 B C+b p   | (SF) ← P[p]<>                                       |          | - - * 2           |                          |  |  |  |
|                        | TEST @L               | 00 11 01 11                         |              | 3 7         | (SF) ← P[(LR)<3:2>+4]<((LR)<1:0>>)                  |          | - - * 2           |                          |  |  |  |
|                        | TESTP CF              | 00 00 01 00                         |              | 0 4         | (SF) ← (CF), (CF) ← 1                               |          | 1 - * 1           |                          |  |  |  |
|                        | TESTP ZF              | 00 00 11 10                         |              | 0 E         | (SF) ← (ZF)                                         |          | - - * 1           |                          |  |  |  |
|                        | TESTP GF              | 00 00 00 01                         |              | 0 1         | (SF) ← (OF)                                         |          | - - * 1           |                          |  |  |  |
|                        | TESTP y , b           | 00 11 10 01 11                      | b1b0y3y2y1y0 | 3 9 C+b y   | (SF) ← M[y]<>                                       |          | - - * 2           |                          |  |  |  |
|                        | TESTP %p , b          | 00 11 10 11 11                      | b1b0P3P2P1P0 | 3 B C+b p   | (SF) ← P[p]<>                                       |          | - - * 2           |                          |  |  |  |
|                        | SET GF                | 00 00 00 11                         |              | 0 3         | (OF) ← 1                                            |          | - - 1 1           |                          |  |  |  |
|                        | SET @HL, b            | 01 01 00 b1b0                       |              | 5 b         | M[(H+L)]<b>← 1                                      |          | - - 1 1           |                          |  |  |  |
|                        | SET y , b             | 00 11 10 01 00                      | b1b0y3y2y1y0 | 3 9 b y     | M[y]<b>← 1                                          |          | - - 1 2           |                          |  |  |  |
|                        | SET %p , b            | 00 11 10 11 00                      | b1b0P3P2P1P0 | 3 B b p     | P[l]<b>← 1                                          |          | - - 1 2           |                          |  |  |  |
|                        | SET @L                | 00 11 01 00                         |              | 3 4         | P[(LR)<3:2>+4]<((LR)<1:0>>)                         |          | - - 1 2           |                          |  |  |  |
| Input/Output           | CLR GF                | 00 00 00 10                         |              | 0 2         | (OF) ← 0                                            |          | - - 1 1           |                          |  |  |  |
|                        | CLR @HL, b            | 01 01 01 b1b0                       |              | 5 4+b       | M[(H+L)]<b>← 0                                      |          | - - 1 1           |                          |  |  |  |
|                        | CLR y , b             | 00 11 10 01 01                      | b1b0y3y2y1y0 | 3 9 4+b y   | M[y]<b>← 0                                          |          | - - 1 2           |                          |  |  |  |
|                        | CLR %p , b            | 00 11 10 11 01                      | b1b0P3P2P1P0 | 3 B 4+b p   | P[l]<b>← 0                                          |          | - - 1 2           |                          |  |  |  |
|                        | CLR @L                | 00 11 01 01                         |              | 3 5         | P[(LR)<3:2>+4]<((LR)<1:0>>)                         |          | - - 1 2           |                          |  |  |  |
|                        | CLR IL , r            | 00 11 01 10 11                      | r5t4f3t1f0   | 3 6 C+IrFL  | (INTL)<5:0>← (INTL)<5:0>&~<5:0>                     |          | - - 1 2           |                          |  |  |  |
|                        | INCIL IL , r          | 00 11 01 10 01                      | r5t4f3t2f1f0 | 3 6 4+IrFL  | (RIP)<-1, (INTL)<5:0>← (INTL)<5:0>&~<5:0>           |          | - - 1 2           |                          |  |  |  |
|                        | DICLRL IL , r         | 00 11 01 10 10                      | r5t4f3t2f1f0 | 3 6 8+IrFL  | (RIP)<0, (INTL)<5:0>← (INTL)<5:0>&~<5:0>            |          | - - 1 2           |                          |  |  |  |
|                        | IN %p , A             | 01 10 11 10 10                      | P3P2P1P0     | 3 A 2 p     | (AC) ← P[p]                                         |          | - z Z 2           |                          |  |  |  |
|                        | IN %p , @HL           | 00 11 10 10 01                      | P3P2P1P0     | 3 A 6 p     | M[(H+L)] ← P[p]                                     |          | - - Z 2           |                          |  |  |  |
| Branch/Subroutine      | OUT A ,%p             | 00 11 10 10 10                      | P0P3P2P1P0   | 3 A 8+2F4p  | p[p] ← (AC), p = P4P3P2P1P0                         |          | - - 1 2           |                          |  |  |  |
|                        | OUT @HL ,%p           | 00 11 10 11 10                      | P0P3P2P1P0   | 3 A C+2F4p  | p[p] ← M[(H+L)], p = P4P3P2P1P0                     |          | - - 1 2           |                          |  |  |  |
|                        | OUT #k ,%p            | 00 11 10 00 k3k2k1k0P3P2P1P0        |              | 2 C k p     | p[p] ← k                                            |          | - - 1 2           |                          |  |  |  |
|                        | OUTUB @HL             | 00 01 00 10                         |              | 1 2         | P[2]*P[1]+ROM[F*(E+(CF))*M[(H+L)]]                  |          | - - 1 2           |                          |  |  |  |
|                        | BS a                  | 01 10 d9d4g3d9d8a7a6a8a4a3a2a1a0    |              | 6 aH aM aL  | IF SF=1 then PC=a else null.                        |          | - - 1 2           |                          |  |  |  |
| Other                  | BSS a                 | 10 d9d4g3d9d8a7a6a8a4a3a2a1a0       |              | 6+d4d4L     | IF SF=1 then PC=a else null.                        |          | - - 1 1           | *5                       |  |  |  |
|                        | CALL a                | 00 10 01 d9d4g3d9d8a7a6a8a4a3a2a1a0 |              | 2 aH aM aL  | STACK[(SPW)] ← (PC), (SPW) ← (SPW)-1,               |          | - - - 2           | *5                       |  |  |  |
|                        | CALLS a               | 01 11 ngn2gn2n0                     |              | 7 n         | (PC) ← a, a=n+6(n&0), 134(n&1)                      |          | - - - 2           | *5                       |  |  |  |
|                        | RET                   | 00 10 10 10                         |              | 2 A         | (SPW) ← -(SPW)+1, (PC) ← STACK[(SPW)]               |          | - - - 2           |                          |  |  |  |
|                        | RETI                  | 00 10 10 11                         |              | 2 B         | (SPW) ← -(SPW)+1, (FLAG+PC)=STACK[(SPW)], (EIF) ← 1 |          | * * * 2           |                          |  |  |  |
|                        | NOP                   | 00 00 00 00                         |              | 0 0         | no operation                                        |          | - - - 1           |                          |  |  |  |

Note 1 Setting Condition of Flag.

"C" indicates the carry output from the most significant position in the addition operation, and "B" indicates the borrow output from the most significant position in the subtraction operation.

"Z" indicates the zero detection signal to which "1" is applied only when either the ALU output of the processing result or all four bits of the data transferred to the accumulator are zero.

The flag is set to "C", "B", "E", "Z", "Z\*", "1", or "0" according to the data processing result. The value specified by the function is set to the flag with the mark "\*", and the mark "-" denotes no change in the state of the flag.

Note 2 The zero flag is set according to the data set in the accumulator.

Note 3 The flags(ZF, SF) are set according to the result of increment or decrement of the L register.

Note 4 The carry is the data shifted out from the accumulator.

Note 5 The contents of the program counter indicate the next address of the instruction to be executed.

## Operation Code Map

|   | lower | 0    | 1           | 2         | 3         | 4           | 5      | 6          | 7         | 8        | 9        | A          | B          | C           | D            | E            | F           |     |
|---|-------|------|-------------|-----------|-----------|-------------|--------|------------|-----------|----------|----------|------------|------------|-------------|--------------|--------------|-------------|-----|
|   |       | NOP  | TESTF<br>OF | CLR<br>OF | SET<br>OF | TESTF<br>OF | ROLC   | TEST<br>CF | RORC<br>A | INC<br>A | DEC<br>A | INC<br>@HL | DEC<br>@HL | LD<br>A,@HL | XCH<br>A,@HL | TESTF<br>ZF  | ST<br>A,@HL |     |
| 0 | H     | MOV  | MOV         | OUTB      | XCH       | SUBR        | CADD   | CMPR       | ADD       | INC      | DEC      | ST<br>L    | ST<br>L    | OR<br>A,@HL | AND<br>A,@HL | XOR<br>A,@HL | ST<br>A,@HL |     |
| 1 | H,A   | L,A  | @HL         | A,EIR     | A,@HL     | @HL         | A,@HL  | A,@HL      | A,@HL     | A,@HL    | A,@HL    | RET        | RET        | OUT         | ST<br>#k     | CMPR         | ADD         |     |
| 2 |       | CALL | a           |           |           | LD          | XCH    | LD         | XCH       | LD       | XCH      | LD         | XCH        | LD          | XCH          | LD           | XCH         |     |
| 3 | A,H   | A,L  | A,@DH       | A,@DC     | @L        | @L          | (OP36) | TEST       | (OP36)    | (OP39)   | (OP3A)   | (OP3B)     | LD         | XCH         | CMPR         | ST           | LD          | XCH |
| 4 |       |      |             |           |           | LD          | A,#k   |            |           |          |          |            |            |             |              |              |             |     |
| 5 |       | SET  | @HL,b       |           |           | CLR         | @HL,b  |            | TEST      | @HL,b    |          | TEST       | A,b        |             |              |              |             |     |
| 6 |       |      |             |           |           | BS          | a      |            |           |          |          |            |            |             |              |              |             |     |
| 7 |       |      |             |           |           | CALLS       | a      |            |           |          |          |            |            |             |              |              |             |     |
| 8 |       |      |             |           |           | BSS         | a      |            |           |          |          |            |            |             |              |              |             |     |
| 9 |       |      |             |           |           |             |        |            |           |          |          |            |            |             |              |              |             |     |
| A |       |      |             |           |           |             |        |            |           |          |          |            |            |             |              |              |             |     |
| B |       |      |             |           |           |             |        |            |           |          |          |            |            |             |              |              |             |     |
| C |       |      |             |           |           | LD          | H,     | #k         |           |          |          |            |            |             |              |              |             |     |
| D |       |      |             |           |           |             | CMPR   | A,         | #k        |          |          |            |            |             |              |              |             |     |
| E |       |      |             |           |           |             | LD     | L,         | #k        |          |          |            |            |             |              |              |             |     |
| F |       |      |             |           |           |             | ST     | #k,        | @HL+      |          |          |            |            |             |              |              |             |     |

(caution)

1. Blank codes are reserved.
2.  is indicated 2-byte instruction.

(continued)

| 1st byte code         | OP36               | OP38          | OP39           | OP3A           | OP3B |
|-----------------------|--------------------|---------------|----------------|----------------|------|
| 2nd byte code(higher) | 36                 | 38            | 39             | 3A             | 3B   |
| 0                     | ADD<br>A,<br>#k    |               |                |                |      |
| 1                     | SUB<br>A,<br>#k    |               |                |                |      |
| 2                     | OR<br>A,<br>#k     | SET<br>y, b   | IN<br>%p, A    | SET<br>%p, b   |      |
| 3                     | AND<br>A,<br>#k    |               |                |                |      |
| 4                     | ADD<br>@HL,<br>#k  |               |                |                |      |
| 5                     | SUBB<br>@HL,<br>#k |               |                |                |      |
| 6                     | RICIR<br>IL,r      | CLR<br>y, b   | IN<br>%p, @HL  | CLR<br>%p, b   |      |
| 7                     | OR<br>@HL,<br>#k   |               |                |                |      |
| 8                     | AND<br>@HL,<br>#k  |               |                |                |      |
| 9                     | DICIR<br>IL,r      | TEST<br>y, b  | OUT<br>A,%p    | TESTP<br>%p, b |      |
| A                     | CMPR<br>L,<br>#k   |               | OUT<br>A,%p    |                |      |
| B                     |                    |               | OUT<br>A,%p    |                |      |
| C                     | ADD<br>H,<br>#k    |               | OUT<br>@HL,%p  |                |      |
| D                     | CLR<br>IL,r        | TRSTP<br>y, b | TESTP<br>%p, b |                |      |
| E                     | CMPR<br>H,<br>#k   |               | OUT<br>@HL,%p  |                |      |
| F                     |                    |               | OUT<br>@HL,%p  |                |      |

TMP47C40P

TMP47C20P

INTEGRATED CIRCUIT  
TECHNICAL DATA

PRELIMINARY



# INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TOSHIBA MOS TYPE DIGITAL INTEGRATED CIRCUIT

**TMP47C22F**

SILICON MONOLITHIC SILICON GATE CMOS

PRELIMINARY

CMOS 4-BIT SINGLE CHIP MICROCOMPUTER (TLCS-47C) TMP47C22F

### GENERAL DESCRIPTION

The TLCS-47 is the high speed and high performance, 4-bit single chip microcomputer series designed for general purpose use.

The TLCS-47 has variously powerful functions in order to meet with the advanced and complicated applications, which will be made in near future. In addition, software compatible NMOS family (TLCS-47N) and CMOS family (TLCS-47C) are also provided.

The TMP47C22F is a chip containing LCD driver for the TLCS-47C. The memory capacity consists of ROM 2,048 x 8 bits and RAM 192 x 4 bits. The TMP4700C (NMOS) is an evaluator chip used for the system development.

### FEATURES

- 4-bit single chip microcomputer with built-in ROM, RAM, input/output port, divider, timer/counter, and serial port.
- Instruction execution time: 4  $\mu$ s (at 4 MHz clock)
- Effective instruction set 90 instructions, software compatible in the series
- Subroutine nesting: Maximum 15 levels
- 6 interrupts (External: 2, Internal: 4)  
Independently latched control and multiple interrupt control
- Input/output port (27 pins)

|            |         |         |
|------------|---------|---------|
| Input      | 1 port  | 4 pins  |
| I/O        | 4 ports | 16 pins |
| I/O (Note) | 2 ports | 7 pins  |

Note: These I/O ports are also used for the interrupt input, timer/counter input, and serial port; therefore, it is programmably selectable for each application.
- Table look-up and table search function (Instruction)  
Table can be set up in the whole ROM area.
- 12-bit timer/counter (2 channels)  
Event counter, timer, and pulse width measurement mode is programmably selectable.
- Serial port with 4-bit buffer  
Receive/Transfer mode is programmably selectable.  
External/internal clock and leading/trailing edge mode are programmably selectable.
- 18-stage divider (with 4-stage prescaler)  
Frequency applied for timer interrupt of divider is programmably selectable.
- LCD drive circuit (automatic display) built-in
  - LCD direct drive is available (Max. 12-digit display at 1/4 duty LCD)
  - 1/4, 1/3, 1/2 duties or static drive are programmably selectable.
- Hold function  
Battery operation/condenser backup is available.
- On Chip oscillator
- TTL/CMOS compatible
- +5V single power supply
- 67-pin flat package
- Si-gate CMOS LSI



# INTEGRATED CIRCUIT

## TECHNICAL DATA

**PRELIMINARY**

### PIN CONNECTIONS (Top View)



Note 1. Pin 27 is connected to pin 61 through external circuit.

2. N.C. No connection

### PIN NAMES AND PIN DESCRIPTIONS

| Pin Names                           | No.of Pins | I/O           | Functions                                  |
|-------------------------------------|------------|---------------|--------------------------------------------|
| K <sub>03</sub> ~ K <sub>00</sub>   | 4          | Input         | Input port                                 |
| R <sub>43</sub> ~ R <sub>40</sub>   | 4          | I/O           | I/O port                                   |
| R <sub>53</sub> ~ R <sub>50</sub>   | 4          | I/O           | "                                          |
| R <sub>63</sub> ~ R <sub>60</sub>   | 4          | I/O           | "                                          |
| R <sub>73</sub> ~ R <sub>70</sub>   | 4          | I/O           | "                                          |
| R <sub>83</sub> (T1)                | 1          | I/O           | I/O port or timer/counter input            |
| R <sub>82</sub> (INT1)              | 1          | I/O           | I/O port or interrupt input                |
| R <sub>81</sub> (T2)                | 1          | I/O           | I/O port or timer/counter input            |
| R <sub>80</sub> (INT2)              | 1          | I/O           | I/O port or interrupt input                |
| R <sub>92</sub> (SCK)               | 1          | I/O           | I/O port or shift clock for serial port    |
| R <sub>91</sub> (SO)                | 1          | I/O           | " or serial output                         |
| R <sub>90</sub> (SI)                | 1          | I/O           | " or serial input                          |
| SEG <sub>23</sub> ~SEG <sub>0</sub> | 24         | Output        | LCD Segment driver output                  |
| COM <sub>4</sub> ~ COM <sub>1</sub> | 4          | Output        | LCD Common driver output                   |
| XIN, XOUT                           | 2          | Input, Output | Resonator connection terminal              |
| RESET                               | 1          | Input         | Initialize signal input                    |
| HOLD                                | 1          | Input         | Hold signal input<br>(Low level is input.) |
| TEST                                | 1          | Input         |                                            |
| VDD                                 | 1          | Power supply  | +5V                                        |
| VSS                                 | 1          | Power supply  | 0V                                         |
| VLC                                 | 1          | Power supply  | LCD drive power supply                     |

## TECHNICAL DATA

## BLOCK DIAGRAM



BLOCK NAME AND DESCRIPTION

| Block Names                       | Functions                                                                                                |
|-----------------------------------|----------------------------------------------------------------------------------------------------------|
| PC                                | Program counter (12 bits)                                                                                |
| ROM                               | Program memory                                                                                           |
| IR, decoder                       | Instruction register, Decoder                                                                            |
| HR, LR                            | H register (Page assignment of RAM), L register (address assignment in RAM page), (each 4-bit register). |
| RAA                               | RAM address buffer register (8 bits)                                                                     |
| RAM                               | Data memory                                                                                              |
| STACK                             | Save area of program counter and flags(RAM area)                                                         |
| SPW                               | Stack pointer word (RAM area)                                                                            |
| DC, data table                    | Data counter (12 bits, RAM area), Data table (ROM area)                                                  |
| AX, AY                            | Temporary register of ALU input                                                                          |
| ALU                               | Arithmetic and logic unit                                                                                |
| AC                                | Accumulator                                                                                              |
| FLAG(CF,ZF,SF,GF)                 | Flags                                                                                                    |
| K, R                              | Ports                                                                                                    |
| INTR control                      | Interrupt control<br>(EIF: Enable interrupt master F/F, EIR: Enable interrupt register)                  |
| FD                                | Frequency divider (4-stage prescaler + 18 stages)                                                        |
| TC <sub>1</sub> , TC <sub>2</sub> | 12-bit timer/counter 2 channels (RAM area)                                                               |
| TC control                        | Timer/counter control                                                                                    |
| SIO control                       | Serial port control                                                                                      |
| LCD drive control (COM,SEG)       | LCD drive control                                                                                        |
| HOLD control                      | Control of hold function                                                                                 |
| SYS CONTROL                       | Generation of various internal control signals                                                           |
| CG, TG                            | Clock generator, timing generator                                                                        |

## FUNCTIONAL DESCRIPTION

Concerning the TMP47C22F, the configuration and functions of hardwares are described.

As the description has been provided with priority on those parts differing from the TMP47C20P (The TLCS-47C standard chip), the technical material for the TMP47C20P shall also be referred to.

### 1. System Configuration

The configuration will be explained with priority given primarily to the LCD drive circuit.

#### 1.1 Program Counter (PC), Program Memory (ROM)

The TMP47C22F is in 32 page configuration in a unit of 64 words per page with the built-in 12 bit program counter and 2,048 x 8 bit (000 ~ 7FF addresses) program memory.

Further, as the TMP47C22F has no built-in output ports P1 and P2, the instruction (OUTB @HL) and PLA data conversion table cannot be used.

The relationship between ROM capacity and addresses is shown in Fig. 1.3.1.

#### 1.2 H Register (HR), L Register (LR)

The H and L registers are 4-bit registers used as the data memory address pointer or general purpose registers, respectively.

### 1.3 RAM Address Buffer Register (RAA), Data Memory (RAM)

The TMP47C22F contains a data memory with  $192 \times 4$ -bit (addresses 00~BF) and is in 12 pages configuration in a unit of 16 words per page.

On the other hand, since RAM address buffer register (RAA) has 8-bit length, addresses C0~FF have no physical RAM, but the higher order 2 bits (RAA<sub>7</sub> and RAA<sub>6</sub>) are decoded to [(00), (01) and (1\*)]. \* denotes "don't care."]; therefore, when addresses C0~FF are accessed on a program, RAM equivalent to addresses 80~BF is accessed. In other words, on a program a specific address of RAM is addressed to addresses C0~FF, while on the TMP47C22F, RAM equivalent to addresses 80~BF is allocated.

The relationship between RAM capacity and addresses is shown in Fig. 1.3.1.



Fig. 1.3.1 ROM/RAM Capacity and Addresses

#### 1.4 ALU, Accumulator (AC), Flag (FLAG)

The ALU is a circuit used for various operation for 4-bit binary data. It performs the operation designated by the instruction, and outputs the 4-bit result, carry (C), and zero detection signal (Z).

The accumulator is a 4-bit register to use a source operand for the arithmetic operation, and in which the result is stored.

Flag is a 4-bit register used to store the conditions of arithmetic operation, and of which the set/reset conditions are specified by the instruction. The flag consisting of CF, ZF, SF, and GF is saved in the stack when the interrupt is accepted. By executing the (RETI) instruction, it is restored from the stack to the condition immediately before the interrupt is accepted.

#### 1.5 Port (PORT)

Data transfer to/from the external circuitry, and command/status/data transfer between of the built-in peripheral circuitry are carried out by the input/output instructions.

Since the TMP47C22F has no built-in outputs ports P<sub>1</sub> and P<sub>2</sub>, (OUTB @HL) instruction cannot be used; therefore 12 kinds of instructions become available as effective input/output instructions.

The details to specify the input/output circuit format of ports and initialization of the output latches are 2.3 Input/Output Port (Input/Output Circuit Format).

| Port<br>ad-<br>dress | Symbol<br>(Input/<br>Output) | Port, Register<br>(Input/Output) | Input/Output Instructions |                        |          |          |                      |                        |                           |   |
|----------------------|------------------------------|----------------------------------|---------------------------|------------------------|----------|----------|----------------------|------------------------|---------------------------|---|
|                      |                              |                                  | IN %P, A<br>IN %P,@HL     | OUT A ,%P<br>OUT@HL,%P | OUT#K,%P | OUTB @HL | SET %P,b<br>CLR %P,b | TEST %P,b<br>TESTP%P,b | SET CLR @L<br>TEST CLR @L |   |
| 00                   | IPO0/OP00                    | K <sub>0</sub> Input port / -    | 0                         |                        |          |          |                      |                        | 0                         |   |
| 01                   | IPO1/OP01                    | -                                |                           |                        |          |          |                      |                        |                           |   |
| 02                   | IPO2/OP02                    | -                                |                           |                        |          |          |                      |                        |                           |   |
| 03                   | IPO3/OP03                    | -                                |                           |                        |          |          |                      |                        |                           |   |
| 04                   | IPO4/OP04                    | R <sub>4</sub> I/O port          | 0                         | 0                      | 0        |          | 0                    | 0                      |                           | 0 |
| 05                   | IPO5/OP05                    | R <sub>5</sub> "                 | 0                         | 0                      | 0        |          | 0                    | 0                      |                           | 0 |
| 06                   | IPO6/OP06                    | R <sub>6</sub> "                 | 0                         | 0                      | 0        |          | 0                    | 0                      |                           | 0 |
| 07                   | IPO7/OP07                    | R <sub>7</sub> "                 | 0                         | 0                      | 0        |          | 0                    | 0                      |                           | 0 |
| 08                   | IPO8/OP08                    | R <sub>8</sub> "                 | 0                         | 0                      | 0        |          | 0                    | 0                      |                           | 0 |
| 09                   | IPO9/OP09                    | R <sub>9</sub> "                 | 0                         | 0                      | 0        |          | 0                    | 0                      |                           | 0 |
| 0A                   | IPOA/OP0A                    | -                                |                           |                        |          |          |                      |                        |                           |   |
| 0B                   | IPOB/OP0B                    | -                                |                           |                        |          |          |                      |                        |                           |   |
| 0C                   | IPOC/OP0C                    | -                                |                           |                        |          |          |                      |                        |                           |   |
| 0D                   | IPOD/OP0D                    | -                                |                           |                        |          |          |                      |                        |                           |   |
| OE                   | IPOE/OP0E                    | Status input / -                 | 0                         |                        |          |          |                      |                        |                           |   |
| OF                   | IPOF/OP0F                    | (*) / (**)                       | 0                         | 0                      | 0        |          |                      |                        | 0                         |   |
| 10                   | /OP10                        | /Hold control                    |                           | 0                      |          |          |                      |                        |                           |   |
| 11                   | /OP11                        | / -                              |                           |                        |          |          |                      |                        |                           |   |
| 12                   | /OP12                        | / -                              |                           |                        |          |          |                      |                        |                           |   |
| 13                   | /OP13                        | / -                              |                           |                        |          |          |                      |                        |                           |   |
| 14                   | /OP14                        | / -                              |                           |                        |          |          |                      |                        |                           |   |
| 15                   | /OP15                        | / -                              |                           |                        |          |          |                      |                        |                           |   |
| 16                   | /OP16                        | / -                              |                           |                        |          |          |                      |                        |                           |   |
| 17                   | /OP17                        | / -                              |                           |                        |          |          |                      |                        |                           |   |
| 18                   | /OP18                        | / -                              |                           |                        |          |          |                      |                        |                           |   |
| 19                   | /OP19                        | / (a)                            |                           | 0                      |          |          |                      |                        |                           |   |
| 1A                   | /OP1A                        | / (b) (1)                        |                           | 0                      |          |          |                      |                        |                           |   |
| 1B                   | /OP1B                        | / " (2)                          |                           | 0                      |          |          |                      |                        |                           |   |
| 1C                   | /OP1C                        | / (c)                            |                           | 0                      |          |          |                      |                        |                           |   |
| 1D                   | /OP1D                        | / (d)                            |                           | 0                      |          |          |                      |                        |                           |   |
| 1E                   | /OP1E                        | / -                              |                           |                        |          |          |                      |                        |                           |   |
| 1F                   | /OP1F                        | / (e)                            |                           | 0                      |          |          |                      |                        |                           |   |

Note 1: Inputs (IP10 ~ IP1F) of port addresses 10 ~ 1F remain undefined.

Note 2: Port addresses with "-" mark are reserved addresses and cannot be used user's program.

Table 1.5.1 Port Address Allocation and Input/Output Instructions

(1) K<sub>0</sub> (K<sub>03</sub> ~ K<sub>00</sub>) Port

This is a 4-bit port used for input.

(2) R<sub>4</sub> (R<sub>43</sub>~R<sub>40</sub>), R<sub>5</sub> (R<sub>53</sub>~R<sub>50</sub>), R<sub>6</sub> (R<sub>63</sub>~R<sub>60</sub>), R<sub>7</sub> (R<sub>73</sub>~R<sub>70</sub>) Port

Each of these ports is a 4-bit I/O port with a latch.

The latch should be set to "1" when the port is used as an input port.

Pins R<sub>73</sub> ~ R<sub>40</sub> can be used for bit scanning for set/reset and test according to the contents of the L register by executing the (SET @L), (CLR @L) and (TEST @L) instructions.

(3) R<sub>8</sub> (R<sub>83</sub>~R<sub>80</sub>) Port

This is a 4-bit I/O port with a latch. The latch should be set to "1" when the port is used as an input port.

It is a port common to external interrupt input or external timer/counter input. When it is used as normal I/O port, some measures, such as inhibition of the external interrupt input acceptance or disable of the mode depending on the external input of the timer/counter should be taken in a program.

(4) R<sub>9</sub> (R<sub>92</sub>~R<sub>90</sub>) Port

This is a 3-bit I/O port with a latch, and the latch must be set to "1" when it is used as input port.

The R<sub>9</sub> port is also used as serial port. The port used as normal I/O port is not entirely influenced by disabling the serial port.

Pin R<sub>93</sub> is not mounted in the port, but "1" is read by accessing to pin R<sub>93</sub> in a program.

#### 1.6 Interrupt Control Circuit (INTR)

Interrupt factors are composed of two from the external circuitry, and four from the internal circuitry. By setting the interrupt latch provided for each factor, an interrupt is generated to the CPU. The interrupt latch is set when the edge of the input signal is detected.

#### 1.7 Frequency Divider (FD)

The divider ( $FD_1 - FD_{18}$ ) is made up 18-stage binary counter, and its output is used to generate various internal timing.

#### 1.8 Timer/counter (TC<sub>1</sub>, TC<sub>2</sub>)

Two channels of 12-bit binary counter is contained to count time or event.

##### Count Operation

When the rising edge of the count pulse is detected, the count latch is set to send a count request to the CPU.

The maximum frequency applied to the timer/counter is as follows. In the timer mode, the maximum frequency is determined by a command.

The maximum frequency applied to the external input pin in the pulse width measurement mode should be the frequency level available for analyzing the count value in the program.

Normally, the frequency sufficiently slower than the designated internal pulse rate is applied to the external input pin.

The maximum frequency applied to the external input pin under the event counter mode is dependent upon the operating state of the LCD drive circuit.



## (a) At time of blanking operation

Frequency applied at time of a single channel operation is  $fc/64$  Hz. When 2 channels are operated simultaneously, timer/counter 1 is  $fc/64$  Hz and timer/counter 2 is  $fc/80$  Hz.

## (b) When LCD display is enabled

Frequency applied at time of a single channel operation is  $fc/128$  Hz. When 2 channels are operated simultaneously, both timer/counter 1 and timer/counter 2 are  $fc/144$  Hz.

## 1.9 Serial Port (SIO)

A 4-bit serial port with a buffer is provided to transfer the serial data from/to the external circuitry. According to the contents of the command register, either one of transmit mode, receive (trailing edge shift) mode or receive (leading edge shift) mode can be selected.

## 1.10 Hold Control Circuit (HOLDC)

The hold function is the function to hold the status immediately before the system operation is stopped at low power consumption making the most of the features of CMOS.

The hold function is controlled by HOLD terminal input and command register.



## 1.11 LCD Drive Circuit (LCDC)

The TMP47C22F has the built-in circuit that directly drives the liquid crystal display (LCD) and its control circuit.

The TMP47C22F has the following connecting terminals with LCD:

- (a) Common output terminals (COM<sub>1</sub> - COM<sub>4</sub>)
- (b) Segment output terminals (SEG<sub>0</sub> - SEG<sub>23</sub>)

In addition, VLC terminal is provided as the drive power terminal.

As display data transfer operations to the drive circuit are entirely executed by the hardware automatically on the TMP47C22F, it is possible to illuminate LCD if only display data is stored in the data memory.

The devices that can be directly driven is selectable from LCD devices of following drive methods:

- (a) 1/4 duty (1/3 bias) LCD  
Max. 96 segments (12 digits x 8 segments) can be driven.
- (b) 1/3 duty (1/3 bias) LCD  
Max. 72 segments (8 digits x 9 segments) can be driven.
- (c) 1/2 duty (1/2 bias) LCD  
Max. 48 segments (6 digits x 8 segments) can be driven.
- (d) Static LCD  
Max. 24 segments (3 digits x 8 segments) can be driven.

## (1) Circuit configuration

The LCD drive circuit consists of the function blocks shown in Fig. 1.11.1.



Fig. 1.11.1 LCD Drive Circuit

### (2) Control of drive circuit

The operation of LCD drive circuit is controlled by the command.

The command registers are accessed as port addresses OPLA and OPLB, and are reset to "8" and "0" at initialization, respectively.



Fig. 1.11.2 Control of Drive Circuit

Drive waveform of LCD

The LCD drive method is selected according to DTY of command register 2. DTY is reset to "0" at initialization.

The drive method is initialized according to a LCD used in the initial program. (In the case of a 1/4 duty LCD, it is set at initialization.) Thereafter, DTY sets disable code only.

Examples of LCDs and their drive waveforms are shown in Fig. 1.11.3.



(a) 1/4 duty (1/3 bias) drive



(b) 1/3 duty (1/3 bias) drive



(c) 1/2 duty (1/2 bias) drive



(d) Static drive

(Note)  $f_F$  : LCD Frame frequency,  $V_{LCD} = V_{DD} - V_{LC}$

Fig. 1.11.3 LCD Drive Waveform (COM-SEG Terminals)



PRELIMINARY

LCD Frame frequency

Frame frequency (LCD drive frequency) is given by the built-in frequency divider. It is possible to select base frequency (either one of 2 kind frequencies obtained from the divider) by SLF of command register 1. SLF is reset to "0" at the initialization.

Frame frequency ( $f_F$ ) is set according to the drive method and base frequency as shown in the following table:

| SLF | Base fre-quency(Hz)  | Frame Frequency (Hz) |                                        |                                        |                      |
|-----|----------------------|----------------------|----------------------------------------|----------------------------------------|----------------------|
|     |                      | 1/4 Duty             | 1/3 Duty                               | 1/2 Duty                               | Static               |
| 0   | $\frac{f_C}{2^{15}}$ | $\frac{f_C}{2^{15}}$ | $\frac{4}{3} \cdot \frac{f_C}{2^{15}}$ | $\frac{4}{2} \cdot \frac{f_C}{2^{15}}$ | $\frac{f_C}{2^{15}}$ |
|     | ( $f_C=4$ MHz)       | $\div 122$           | $\div 163$                             | $\div 244$                             | $\div 122$           |
| 1   | $\frac{f_C}{2^{14}}$ | $\frac{f_C}{2^{15}}$ | $\frac{4}{3} \cdot \frac{f_C}{2^{15}}$ | $\frac{4}{2} \cdot \frac{f_C}{2^{15}}$ | $\frac{f_C}{2^{15}}$ |
|     | ( $f_C=2$ MHz)       | $\div 122$           | $\div 163$                             | $\div 244$                             | $\div 122$           |

( $f_C$ : Basic clock frequency)

Table 1.11.1 LCD Frame Frequency Setting

LCD drive voltage

The VLC terminal is the LCD drive power terminal. LCD drive voltage ( $V_{LCD}$ ) is given by  $V_{DD} - V_{LC}$ . Therefore, if CPU operating voltage and LCD drive voltage are same, connect the VLC terminal to the VSS terminal.

Drive voltage applied to the LCD drive circuit is internally turned ON/OFF according to the operating state of CPU. That is, at the time of initialize operation and hold operation, the built-in power switch is automatically turned off to cut off drive voltage.

The LCD power switch turned off by the initialize operation is automatically turned on when EDSP (MSB of command register 2) is set at "1" and voltage is applied to the drive circuit. Thereafter, as the power switch is not turned off by the blanking control by means of a program, drive voltage is kept applied to the drive circuit.

On the other hand, the power switch is also turned off at the time of the hold operation, LCD display is turned off and the hold operation is executed at low power consumption. After the hold is released, the TMP47C22F is automatically returned to the state immediately before the hold operation was started.

Further, when the built-in power switch is OFF,  $V_{DD}$  level voltage is generally at either COM terminals or SEG terminals.

## TECHNICAL DATA

## (3) Display operation

Display data setting

Display data is stored in the display area (max. 24 words) in the data memory. The conversion process of ordinary data into LCD display data is executed by instructions (ROM data referring instruction is mainly used.).

Display data converted and stored in the display area is automatically transferred to the LCD drive circuit and displayed by the hardware without any participation by a program. Therefore, change of display pattern is possible by changing only data in the display area in the data memory by a program.

The LCD segment (dot) corresponds to each bit in the display area in the data memory on the one-for-one basis. This relation is shown in Fig. 1.11.4.



Fig. 1.11.4 LCD Diaply Data Area (Data Memory)



Where, each bit of the display data memory shows data of segment (dot) equivalent to  $\text{SEG}_i$ ,  $\text{COM}_j$  ( $0 \leq i \leq 23$ ,  $1 \leq j \leq 4$ ), and when data is "1", the LCD illuminates.

Number of segments that can be driven varies depending upon the LCD drive method. This denotes that even in the display area of the data memory, number of bits used for storing display data varies.

- (a) 1/4 duty LCD ( $\text{COM}_3 - \text{COM}_1$  are used)  
All bits in the display area becomes display data.
- (b) 1/3 duty LCD ( $\text{COM}_3 - \text{COM}_1$  are used)  
Bit 2 - Bit 0 only become display data.
- (c) 1/2 duty LCD ( $\text{COM}_2 - \text{COM}_1$  are used)  
Bit 1 and Bit 0 only become display data.
- (d) Static LCD ( $\text{COM}_1$  only is used)  
Bit 0 only becomes display data.

Therefore, the data memory bits that are not used for storing display data or are equivalent to addresses to which no LCD is connected in the display area can be used for storing ordinary user's processing data.

As stated above, the data memory is used for storing display data (max. 24 words), and it is possible to set an address space in the data memory, to which this display area is to be set, by DAB of command register 1 (See Fig. 1.11.2.).

As the command register 1 is reset at "8" at initialization, the display area is initialized to 80 - 97 addresses.

Transfer of display data

Display data that has been set in the display area of the data memory is automatically transferred to the drive circuit. This operation is executed in the following sequence.

A display data transfer request is sent from the LCD drive circuit to CPU. Upon completion of an instruction under execution (if the timer/counter processing and the interrupt acceptance processing exist, after they are executed), CPU sends segment (dot) data in the display data area to the drive circuit in one instruction cycle.

This data sending cycle is taken place when drive voltage is kept applied to the LCD display drive circuit. Therefore, after initialize operation, this cycle is not taken place until EDSP is set to "1".

Frequency of data sending cycle insertion is as follows:

- (a) In case of other than static drive at SLF=0, 24 times in 512 instruction cycles.
- (b) In case of static drive at SLF=0, 24 times in 2,048 instruction cycles.
- (c) In case of other than static drive at SLF=1, 24 times in 256 instruction cycles.
- (d) In case of static drive at SLF=1, 24 times in 1,024 instruction cycles.

Therefore, when LCD display is enable, the apparent speeds in above cases are decreased by 4.9, 1.2, 10.3 and 2.4%, respectively. For instance, in case of other than the static drive at SLF=0. The apparent speed is 4.2  $\mu$ s to 4  $\mu$ s instruction execution speed.

Blanking Operation

When EDSP (MSB of command register 2) is reset to "0", the LCD display becomes blank. EDSP is reset to "0" at initialization.

The blanking operation turns off the LCD by conditioning non-lighting operation level voltage to COM terminals. On the other hand, the SEG terminals are kept continued at normal operating state. (In the case of static drive, no voltage is applied to COM-SEG terminals when the LCD is turned off by data, however, as the blanking operation keeps the COM terminal at constant  $V_{LCD}/2$  level, the LCD is turned off and the state between COM-SEG terminals where the LCD is driven by  $V_{LCD}/2$ . Therefore, note that the display state is somewhat different in these cases.) For drive waveforms, refer to Fig. 1.11.6 - Fig. 1.11.9.

When EDSP is set at "1", the LCD display is enabled and the LCD display is made according to data stored in the display area of the data memory.

Further, when EDSP is initially set at "1" after the initialization, the LCD power switch is also turned ON and drive voltage is applied to the drive circuit.

LCD Display Control by Program

Provided that EDSP has been set at "1", the LCD is automatically turned ON according to data stored in the display area of the data memory. However, prior to actual display operation it is normally necessary to initialize as shown in Fig. 1.11.5.

To drive the 1/4 duty LCD, 80 - 97 addresses in the display area of the data memory are used, and to operate it at  $SLF = 0$  (low speed operation), when EDSP is set to "1" after initialization of data in the display area, the display operation is started.



[Note 1] Classification of commands for port address OP1B.

|                 |                                          |
|-----------------|------------------------------------------|
| "0000" ~ "0011" | : Setting of LCD drive method            |
| "01**"          | : Blanking by program                    |
| "11**"          | : Releasing of blanking (display enable) |
| "10**"          | : Cannot be used                         |

[Note 2] Normally, only one time of setting is required at the time of initialization, but as an exception, commands should be set at port address OP1A under the blanking state whenever the display area are switched.

Fig. 1.11.5 Initialization of LCD Drive by Program

Examples of display data when a numeral display is made by using the 1/4 duty LCD are shown in Table 1.11.2. For the connecting method of COM terminals and SEG terminals, the example shown in Fig. 1.11.6 is used.

| Nu-<br>meral | Display | Display data memory   |                      | Nu-<br>meral | Display | Display data memory   |                      |
|--------------|---------|-----------------------|----------------------|--------------|---------|-----------------------|----------------------|
|              |         | High order<br>address | Low order<br>address |              |         | High order<br>address | Low order<br>address |
| 0            | 0       | 1 1 0 1               | 1 1 1 1              | 5            | 5       | 1 0 1 1               | 0 1 0 1              |
| 1            | 1       | 0 0 0 0               | 0 1 1 0              | 6            | 6       | 1 1 1 1               | 0 1 0 1              |
| 2            | 2       | 1 1 1 0               | 0 0 1 1              | 7            | 7       | 0 0 0 1               | 0 1 1 1              |
| 3            | 3       | 1 0 1 0               | 0 1 1 1              | 8            | 8       | 1 1 1 1               | 0 1 1 1              |
| 4            | 4       | 0 0 1 1               | 0 1 1 0              | 9            | 9       | 1 0 1 1               | 0 1 1 1              |

Table 1.11.2 Examples of Display Data (1/4 Duty LCD)

Further, examples of display data when a numeral display similar to Table 1.11.2 is made by using the 1/3 duty LCD are shown in Table 1.11.3. For the connecting method of COM terminals and SEG terminals, the example shown in Fig. 1.11.7 is used.

| Nu-<br>meral | Display data memory   |                           |                      | Nu-<br>meral | Display data memory   |                           |                      |
|--------------|-----------------------|---------------------------|----------------------|--------------|-----------------------|---------------------------|----------------------|
|              | High order<br>address | Middle or-<br>der address | Low order<br>address |              | High order<br>address | Middle or-<br>der address | Low order<br>address |
| 0            | * * 1 1               | * 1 0 1                   | * 1 1 1              | 5            | * * 0 1               | * 1 1 1                   | * 0 1 0              |
| 1            | * * 0 0               | * 0 0 0                   | * 0 1 1              | 6            | * * 1 1               | * 1 1 1                   | * 0 1 0              |
| 2            | * * 1 0               | * 1 1 1                   | * 0 0 1              | 7            | * * 0 1               | * 0 0 1                   | * 0 1 1              |
| 3            | * * 0 0               | * 1 1 1                   | * 0 1 1              | 8            | * * 1 1               | * 1 1 1                   | * 0 1 1              |
| 4            | * * 0 1               | * 0 1 0                   | * 0 1 1              | 9            | * * 0 1               | * 1 1 1                   | * 0 1 1              |

(\* : don't care)

Table 1.11.3 Examples of Display Data (1/3 Duty LCD)

Display Output

The following are the examples of display output from LCD drive circuit according to each drive method.

1/4 Duty (1/3 Bias) Drive



Fig. 1.11.6 Example of 1/4 Duty LCD Display Output

**1/3 Duty (1/3 Bias) Drive**

**Fig. 1.11.7 Example of 1/3 Duty LCD Display Output**

1/2 Duty (1/2 Bias) Drive



(a) Example of connection and display character

(b) Example of drive output

Fig. 1.11.8 Example of 1/2 Duty LCD Display Output

~~~PRELIMINARY~~



(Display data memory)

| Address | Data    |
|---------|---------|
| 0       | * * * 1 |
| 1       | * * * 0 |
| 2       | * * * 1 |
| 3       | * * * 1 |
| 4       | * * * 0 |
| 5       | * * * 1 |
| 6       | * * * 1 |
| 7       | * * * 0 |

(\* : Don't care)

- (a) Example of connection and display character



(b) Example of drive output

Fig. 1.11.9 Example of Static LCD Display Output



## 2. Basic operation and pin operation

### 2.1 Instruction cycle, basic clock generation

As the oscillation circuit has been built in, when the external ( $X_{IN}$ ,  $X_{OUT}$ ) are connected to the oscillator, required clocks can be easily obtained. Further, this oscillation circuit is the Schmitt circuit. The clocks obtainable from the oscillation circuit are called the basic clock (CP,  $f_C$  Hz). The basic clock is input into the timing generator and system control circuit from where various control signals are generated.

The instruction execution and the internal hardware control are synchronized with the basic clock. An instruction cycle consists of four machine cycles ( $M_1 \sim M_4$ ), and each machine cycle requires four basic clock times.

### 2.2 Initialization operation, Hold function, interrupt input and others

Initialization operation is performed by keeping the RESET pin to the low level. By this initialize operation, the internal registers are initialized and at the same time, the LCD power switch is turned OFF. Further, no pull-up resistor is built in the RESET terminal of the TMP47C22F.

The hold function is the function to hold the status just before the system operation is stopped at low power consumption by making the most of the features of CMOS. The HOLD terminal is the signal input for the hold operation request and hold operation release request.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C22F

PRELIMINARY

Two pins (INT<sub>1</sub>, INT<sub>2</sub>) are provided for the external interrupt input. Since these pins are common pins with R<sub>8</sub> port, they can be used as I/O pins respectively, if not used as the interrupt input pins. The interrupt latch is set by the falling edge of the external interrupt inputs.

The TEST terminal is used at time of the shippint test. When a user's system is to be operated, low level voltage should be positively applied. Further, the TEST terminal of the TMP 47C22F has no built-in pull-down resistor.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C22F

**PRELIMINARY**

### 2.3 Input/Output port

#### Input/output Circuit Format

The input/output circuit format of the input/output port is shown following. For the TMP47C22F, any of the input/output circuit systems shown in the following tables can be selected. You can specify your input/output circuit system when requesting the program tape. "ICODE GD" is employed if not specified.

| Input/Output Circuit Code (ICODE) GA |                                                                                                  |                                                                                                                                                                             |                                                                                                                                                                             |                                                                                                                                                                                                                                  |
|--------------------------------------|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Circuit Port                         | Input (K <sub>0</sub> )                                                                          | I/O (R <sub>4</sub> , R <sub>5</sub> , R <sub>6</sub> )                                                                                                                     | I/O (R <sub>7</sub> )                                                                                                                                                       | I/O (R <sub>8</sub> , R <sub>9</sub> )                                                                                                                                                                                           |
| I/O equivalent circuit               |                 | <br>R = 1kΩ (TYP.)                                                                         | <br>R = 1kΩ (TYP.)                                                                         | <br>R = 1kΩ (TYP.)                                                                                                                             |
| Remark                               | <ul style="list-style-type: none"> <li><input type="radio"/> No resistor is contained</li> </ul> | <ul style="list-style-type: none"> <li><input type="radio"/> Sink open drain output</li> <li><input type="radio"/> Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li><input type="radio"/> Sink open drain output</li> <li><input type="radio"/> Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li><input type="radio"/> Schmitt circuit input</li> <li><input type="radio"/> Sink open drain output</li> <li><input type="radio"/> Output latch is initialized to the high level</li> </ul> |

| Input/Output Circuit Code (ICODE) GD |                                                                                                  |                                                                                                                                                                       |                                                                                                                                                                             |                                                                                                                                                                                                                                  |
|--------------------------------------|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Circuit Port                         | Input (K <sub>0</sub> )                                                                          | I/O (R <sub>4</sub> , R <sub>5</sub> , R <sub>6</sub> )                                                                                                               | I/O (R <sub>7</sub> )                                                                                                                                                       | I/O (R <sub>8</sub> , R <sub>9</sub> )                                                                                                                                                                                           |
| I/O equivalent circuit               |                | <br>R = 1kΩ (TYP.)                                                                   | <br>R = 1kΩ (TYP.)                                                                         | <br>R = 1kΩ (TYP.)                                                                                                                             |
| Remark                               | <ul style="list-style-type: none"> <li><input type="radio"/> No resistor is contained</li> </ul> | <ul style="list-style-type: none"> <li><input type="radio"/> Push-pull output</li> <li><input type="radio"/> Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li><input type="radio"/> Sink open drain output</li> <li><input type="radio"/> Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li><input type="radio"/> Schmitt circuit input</li> <li><input type="radio"/> Sink open drain output</li> <li><input type="radio"/> Output latch is initialized to the high level</li> </ul> |

| Input/Output Circuit Code (I <sub>O</sub> CODE) GB |                                                                                   |                                                                                                                                     |                                                                                                                                     |                                                                                                                                                                      |
|----------------------------------------------------|-----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port Circuit                                       | Input (K <sub>o</sub> )                                                           | I/O (R <sub>4</sub> , R <sub>5</sub> , R <sub>6</sub> )                                                                             | I/O (R <sub>7</sub> )                                                                                                               | I/O (R <sub>8</sub> , R <sub>9</sub> )                                                                                                                               |
| I/O equivalent circuit                             | <br>$R_{IN} = 70\text{k}\Omega$ (TYP.)<br>$R = 1\text{k}\Omega$ (TYP.)            | <br>$R = 1\text{k}\Omega$ (TYP.)                                                                                                    | <br>$R = 1\text{k}\Omega$ (TYP.)                                                                                                    | <br>$R = 1\text{k}\Omega$ (TYP.)                                                                                                                                     |
| Remark                                             | <ul style="list-style-type: none"> <li>○ Pull-up resistor is contained</li> </ul> | <ul style="list-style-type: none"> <li>○ Sink open drain output</li> <li>○ Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>○ Sink open drain output</li> <li>○ Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>○ Schmitt circuit input</li> <li>○ Sink open drain output</li> <li>○ Output latch is initialized to the high level</li> </ul> |

| Input/Output Circuit Code (I <sub>O</sub> CODE) GC |                                                                                     |                                                                                                                                     |                                                                                                                                     |                                                                                                                                                                      |
|----------------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port Circuit                                       | Input (K <sub>o</sub> )                                                             | I/O (R <sub>4</sub> , R <sub>5</sub> , R <sub>6</sub> )                                                                             | I/O (R <sub>7</sub> )                                                                                                               | I/P (R <sub>8</sub> , R <sub>9</sub> )                                                                                                                               |
| I/O equivalent circuit                             | <br>$R_{IN} = 70\text{k}\Omega$ (TYP.)<br>$R = 1\text{k}\Omega$ (TYP.)              | <br>$R = 1\text{k}\Omega$ (TYP.)                                                                                                    | <br>$R = 1\text{k}\Omega$ (TYP.)                                                                                                    | <br>$R = 1\text{k}\Omega$ (TYP.)                                                                                                                                     |
| Remark                                             | <ul style="list-style-type: none"> <li>○ Pull-down resistor is contained</li> </ul> | <ul style="list-style-type: none"> <li>○ Sink open drain output</li> <li>○ Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>○ Sink open drain output</li> <li>○ Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>○ Schmitt circuit input</li> <li>○ Sink open drain output</li> <li>○ Output latch is initialized to the high level</li> </ul> |

| Input/Output Circuit Code ( $\overline{I}\overline{O}\overline{C}\overline{O}\overline{D}\overline{E}$ ) GE |                                                                                                                                                                      |                                                                                                                               |                                                                                                                                     |                                                                                                                                                                      |
|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port Circuit                                                                                                | Input ( $K_0$ )                                                                                                                                                      | I/O ( $R_4, R_5, R_6$ )                                                                                                       | I/O ( $R_7$ )                                                                                                                       | I/O ( $R_8, R_9$ )                                                                                                                                                   |
| I/O equivalent circuit                                                                                      |  <p><math>R_{IN} = 70k\Omega</math> (TYP.)<br/><math>R = 1k\Omega</math> (TYP.)</p> |  <p><math>R = 1k\Omega</math> (TYP.)</p>     |  <p><math>R = 1k\Omega</math> (TYP.)</p>           |  <p><math>R = 1k\Omega</math> (TYP.)</p>                                            |
| Remark                                                                                                      | <ul style="list-style-type: none"> <li>o Pull-up resistor is contained</li> </ul>                                                                                    | <ul style="list-style-type: none"> <li>o Push-pull output</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Schmitt circuit input</li> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level</li> </ul> |

| Input/Output Circuit Code ( $\overline{I}\overline{O}\overline{C}\overline{O}\overline{D}\overline{E}$ ) GF |                                                                                                                                                                    |                                                                                                                               |                                                                                                                                     |                                                                                                                                                                      |
|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port Circuit                                                                                                | Input ( $K_0$ )                                                                                                                                                    | I/O ( $R_4, R_5, R_6$ )                                                                                                       | I/O ( $R_7$ )                                                                                                                       | I/O ( $R_8, R_9$ )                                                                                                                                                   |
| I/O equivalent circuit                                                                                      |  <p><math>R_{IN}=70k\Omega</math> (TYP.)<br/><math>R = 1k\Omega</math> (TYP.)</p> |  <p><math>R = 1k\Omega</math> (TYP.)</p>     |  <p><math>R = 1k\Omega</math> (TYP.)</p>           |  <p><math>R = 1k\Omega</math> (TYP.)</p>                                            |
| Remark                                                                                                      | <ul style="list-style-type: none"> <li>o Pull-down resistor is contained</li> </ul>                                                                                | <ul style="list-style-type: none"> <li>o Push-pull output</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level</li> </ul> | <ul style="list-style-type: none"> <li>o Schmitt circuit input</li> <li>o Sink open drain output</li> <li>o Output latch is initialized to the high level</li> </ul> |



## 3. Instructions

The TLCS-47 series microcomputer is provided with 90 instructions, which are software compatible within the series. The instructions of the TLCS-47 series consist of 1-byte instructions or 2-byte instructions. To classify them in terms of the execution time, there are 1-cycle instructions and 2-cycle instructions.

1-byte, 1-cycle instructions are mainly used in this series, and are arranged so as to improve the program efficiency.

The TMP47C22F is software compatible with other versions of the TLCS-47 series; however, since it has no built-in output ports P<sub>1</sub> and P<sub>2</sub>, (OUTB @HL) instruction cannot be used, so that 89 instructions become available as effective instructions.

|            |                     |        |
|------------|---------------------|--------|
| 1-byte     | 1-cycle instruction | 40     |
| 1-byte     | 2-cycle instruction | 11 - 1 |
| 2-byte     | 2-cycle instruction | 39     |
| Total 90-1 |                     |        |

## (a) Classification by byte/cycle

|                               |       |
|-------------------------------|-------|
| (Note)                        |       |
| Move instruction              | 22    |
| Compare instruction           | 6     |
| Arithmetic instruction        | 16    |
| Logical instruction           | 9     |
| Bit manipulation instruction  | 24    |
| Input/Output instruction      | 6 - 1 |
| Branch subroutine instruction | 6     |
| Other instruction             | 1     |
| Total 90 - 1                  |       |

(Note): Including ROM data referring instructions

## (b) Classification by function

Table 3.0.1 Classification of instructions



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C22F

PRELIMINARY

| Item<br>Classification | Assembler<br>Mnemonic                                                                                                               | Object Code                       |                                                                                                                                |             |          | Function | Flags | Execution Cycle |  |  |  |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------|----------|----------|-------|-----------------|--|--|--|
|                        |                                                                                                                                     | Binary                            |                                                                                                                                | Hexadecimal |          |          |       |                 |  |  |  |
|                        |                                                                                                                                     | 1st Byte                          | 2nd Byte                                                                                                                       | 1st Byte    | 2nd Byte |          |       |                 |  |  |  |
| LD A ,@HL              | 00 00 11 00                                                                                                                         | 0 C                               | (AC) ← M[(H+L)]                                                                                                                | - Z 1 1     |          |          |       |                 |  |  |  |
| LD A , X               | 00 11 10 00 x7x6x5x4x3x2x1x0                                                                                                        | 3 C x <sub>H</sub> x <sub>L</sub> | (AC) ← M[x]                                                                                                                    | - Z 1 2     |          |          |       |                 |  |  |  |
| LD HL, X               | 00 10 10 00 x7x6x5x4x3x2x1x0                                                                                                        | 2 8 x <sub>H</sub> x <sub>L</sub> | (LR) ← M[x'], (HR) ← M[k+1], x = x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> 0   | - - 1 2     |          |          |       |                 |  |  |  |
| LD A ,#K               | 01 00 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                   | 4 k                               | (AC) ← k                                                                                                                       | - Z 1 1     |          |          |       |                 |  |  |  |
| LD H ,#K               | 11 00 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                   | C k                               | (HR) ← k                                                                                                                       | - - 1 1     |          |          |       |                 |  |  |  |
| LD L ,#K               | 11 10 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                   | E k                               | (LR) ← k                                                                                                                       | - - 1 1     |          |          |       |                 |  |  |  |
| LDL A ,@DC             | 00 11 00 11                                                                                                                         | 3 3                               | (AC) ← ROM <sub>1</sub> [(DC)]                                                                                                 | - Z 1 2     |          |          |       |                 |  |  |  |
| LDH A ,@DC+            | 00 11 00 10                                                                                                                         | 3 2                               | (AC) ← ROM <sub>2</sub> [(DC)], (DC) ← (DC)+1                                                                                  | - Z 1 2     |          |          |       | *2              |  |  |  |
| ST A ,@HL              | 00 00 11 11                                                                                                                         | 0 F                               | M[(H+L)] ← (AC)                                                                                                                | - - 1 1     |          |          |       |                 |  |  |  |
| ST A ,@HL-             | 00 01 10 10                                                                                                                         | 1 A                               | M(H+L) ← (AC), (LR) ← (LR)+1                                                                                                   | - Z 2 1     |          |          |       | *3              |  |  |  |
| ST A ,@HL-             | 00 01 10 11                                                                                                                         | 1 B                               | M(H+L) ← (AC), (LR) ← (LR)-1                                                                                                   | - Z 2 E     |          |          |       | *3              |  |  |  |
| ST A , X               | 00 11 11 11 x7x6x5x4x3x2x1x0                                                                                                        | 3 F x <sub>H</sub> x <sub>L</sub> | M[x] ← (AC)                                                                                                                    | - - 1 2     |          |          |       |                 |  |  |  |
| ST #K,@HL+             | 11 11 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                   | F k                               | M(H+L) ← k, (LR) ← -(IR)+1                                                                                                     | - Z 2 C     |          |          |       | *3              |  |  |  |
| ST #K, Y               | 00 10 11 01 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 D k y                           | M[y] ← k                                                                                                                       | - - 1 2     |          |          |       |                 |  |  |  |
| MOV H , A              | 00 01 00 00                                                                                                                         | 1 0                               | (AC) ← (HR)                                                                                                                    | - Z 1 1     |          |          |       |                 |  |  |  |
| MOV L , A              | 00 01 00 01                                                                                                                         | 1 1                               | (AC) ← (LR)                                                                                                                    | - Z 1 1     |          |          |       |                 |  |  |  |
| XCH A , H              | 00 11 00 00                                                                                                                         | 3 0                               | (HR) ← (AC)                                                                                                                    | - Z 2 1     |          |          |       | *2              |  |  |  |
| XCH A , L              | 00 11 00 01                                                                                                                         | 3 1                               | (LR) ← (AC)                                                                                                                    | - Z 2 1     |          |          |       | *2              |  |  |  |
| XCH A , EIR            | 00 01 00 11                                                                                                                         | 1 3                               | (EIR) ← (AC)                                                                                                                   | - - 1 1     |          |          |       |                 |  |  |  |
| XCH A , @HL            | 00 01 01 01                                                                                                                         | 0 D                               | M(H+L) ← (AC)                                                                                                                  | - Z 1 1     |          |          |       | *2              |  |  |  |
| XCH A , X              | 00 11 11 01 x7x6x5x4x3x2x1x0                                                                                                        | 3 D x <sub>H</sub> x <sub>L</sub> | M[x] ← (AC)                                                                                                                    | - Z 2 1     |          |          |       | *2              |  |  |  |
| XCH HL, X              | 00 10 10 01 x7x6x5x4x3x2x1x0                                                                                                        | 2 9 x <sub>H</sub> x <sub>L</sub> | M[x'] ← (AC), M[x+1] ← (HR), x' = x <sub>7</sub> x <sub>6</sub> x <sub>5</sub> x <sub>4</sub> x <sub>3</sub> x <sub>2</sub> 00 | - - 1 2     |          |          |       |                 |  |  |  |
| CMPR A ,@HL            | 00 01 01 10                                                                                                                         | 1 6                               | null ← M[(H+L)] - (AC)                                                                                                         | B Z Z       |          |          |       |                 |  |  |  |
| CMPR A , X             | 00 11 11 10 x7x6x5x4x3x2x1x0                                                                                                        | 3 E x <sub>H</sub> x <sub>L</sub> | null ← M[x] - (AC)                                                                                                             | B Z Z       |          |          |       |                 |  |  |  |
| CMPR A ,#K             | 11 01 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                                   | D k                               | null ← k - (AC)                                                                                                                | B Z Z       |          |          |       |                 |  |  |  |
| CMPR H ,#K             | 00 11 10 00 01 01 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                       | 3 8 D k                           | null ← k - (HR)                                                                                                                | - Z 2 E     |          |          |       |                 |  |  |  |
| CMPR L ,#K             | 00 11 10 00 01 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                          | 3 8 9 k                           | null ← k - (LR)                                                                                                                | - Z 2 B     |          |          |       |                 |  |  |  |
| CMPR y ,#K             | 00 10 11 10 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 E k y                           | null ← k - M[y]                                                                                                                | B Z Z       |          |          |       |                 |  |  |  |
| INC A ,@HL             | 00 00 00 10                                                                                                                         | 0 8                               | (AC) ← (AC) + 1                                                                                                                | - Z C 1     |          |          |       |                 |  |  |  |
| INC L                  | 00 01 10 00                                                                                                                         | 1 8                               | (LR) ← (LR) + 1                                                                                                                | - Z C 1     |          |          |       |                 |  |  |  |
| INC @HL                | 00 00 10 10                                                                                                                         | 0 A                               | M(H+L) ← M(H+L) + 1                                                                                                            | - Z C 1     |          |          |       |                 |  |  |  |
| DEC A                  | 00 00 10 01                                                                                                                         | 0 9                               | (AC) ← (AC) - 1                                                                                                                | - Z B 1     |          |          |       |                 |  |  |  |
| DEC L                  | 00 01 10 01                                                                                                                         | 1 9                               | (LR) ← (LR) - 1                                                                                                                | - Z B 1     |          |          |       |                 |  |  |  |
| DEC @HL                | 00 00 10 11                                                                                                                         | 0 B                               | M(H+L) ← M(H+L) - 1                                                                                                            | - Z B 1     |          |          |       |                 |  |  |  |
| ADD C A ,@HL           | 00 01 01 01                                                                                                                         | 1 5                               | (AC) ← (AC) + M[(H+L)] + (CP)                                                                                                  | C Z C       |          |          |       |                 |  |  |  |
| ADD A ,@HL             | 00 01 01 11                                                                                                                         | 1 7                               | (AC) ← (AC) + M[(H+L)]                                                                                                         | - Z C 1     |          |          |       |                 |  |  |  |
| ADD A ,#K              | 00 11 10 00 00 00 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                       | 3 8 0 k                           | (AC) ← (AC) + k                                                                                                                | - Z C 2     |          |          |       |                 |  |  |  |
| ADD H ,#K              | 00 11 10 00 00 01 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                       | 3 8 C k                           | (HR) ← (HR) + k                                                                                                                | - Z C 2     |          |          |       |                 |  |  |  |
| ADD L ,#K              | 00 11 10 00 00 10 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                       | 3 8 B k                           | (LR) ← (LR) + k                                                                                                                | - Z C 2     |          |          |       |                 |  |  |  |
| ADD @HL,#K             | 00 11 10 00 01 00 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                       | 3 8 4 k                           | M(H+L) ← M(H+L) + k                                                                                                            | - Z C 2     |          |          |       |                 |  |  |  |
| ADD y ,#K              | 00 10 11 11 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> y <sub>3</sub> y <sub>2</sub> y <sub>1</sub> y <sub>0</sub> | 2 F k y                           | M[y] ← M[y] + k                                                                                                                | - Z C 2     |          |          |       |                 |  |  |  |
| SUBRC A ,@HL           | 00 01 01 00                                                                                                                         | 1 4                               | (AC) ← M(H+L) - (AC) - (CF)                                                                                                    | B Z B       |          |          |       |                 |  |  |  |
| SUBR A ,#K             | 00 11 10 00 00 01 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                       | 3 8 1 k                           | (AC) ← k - (AC)                                                                                                                | - Z B 2     |          |          |       |                 |  |  |  |
| SUB @HL,#K             | 00 11 10 00 01 01 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                       | 3 8 5 k                           | M(H+L) ← k - M(H+L)                                                                                                            | - Z B 2     |          |          |       |                 |  |  |  |
| ROLC A ,@HL            | 00 00 01 01                                                                                                                         | 0 5                               | <u>CP ← (AC) ←</u> (rotate left by 1 bit)                                                                                      | C Z C       |          |          |       | *4              |  |  |  |
| RORC A                 | 00 00 01 11                                                                                                                         | 0 7                               | <u>AC ← CP</u> (rotate right by 1 bit)                                                                                         | C Z C       |          |          |       | *4              |  |  |  |
| AND A ,@HL             | 00 01 11 10                                                                                                                         | 1 E                               | (AC) ← (AC) & M(H+L)                                                                                                           | - Z Z       |          |          |       |                 |  |  |  |
| AND A ,#K              | 00 11 10 00 00 11 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                       | 3 8 3 k                           | (AC) ← (AC) & k                                                                                                                | - Z Z       |          |          |       |                 |  |  |  |
| AND @HL,#K             | 00 11 10 00 01 11 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                       | 3 9 7 k                           | M(H+L) ← M(H+L) & k                                                                                                            | - Z Z       |          |          |       |                 |  |  |  |
| OR A ,@HL              | 00 01 11 01                                                                                                                         | 1 D                               | (AC) ← (AC)   M(H+L)                                                                                                           | - Z Z       |          |          |       |                 |  |  |  |
| OR A ,#K               | 00 11 10 00 00 10 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                       | 3 8 2 k                           | (AC) ← (AC)   k                                                                                                                | - Z Z       |          |          |       |                 |  |  |  |
| OR @HL,#K              | 00 11 10 00 01 10 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub>                                                       | 3 8 6 k                           | M(H+L) ← M(H+L)   k                                                                                                            | - Z Z       |          |          |       |                 |  |  |  |
| XOR A ,@HL             | 00 01 11 11                                                                                                                         | 1 F                               | (AC) ← (AC) ^ M(H+L)                                                                                                           | - Z Z       |          |          |       |                 |  |  |  |



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C22F

**PRELIMINARY**

(continued)

| Item<br>Classification | Assembler<br>Mnemonic | Object Code                     |          |             |                                                    | Function | Flags<br>CF ZF SF | x1<br>Execution<br>Cycle |  |  |  |
|------------------------|-----------------------|---------------------------------|----------|-------------|----------------------------------------------------|----------|-------------------|--------------------------|--|--|--|
|                        |                       | Binary                          |          | Hexadecimal |                                                    |          |                   |                          |  |  |  |
|                        |                       | 1st Byte                        | 2nd Byte | 1st Byte    | 2nd Byte                                           |          |                   |                          |  |  |  |
| Bit Manipulation       | TEST CF               | 00 00 01 10                     |          | 0 6         | (SF) ← (CF), (CF) ← 0                              |          | 0 - * 1           |                          |  |  |  |
|                        | TEST A , b            | 01 01 11 b1b0                   |          | 5 C+b       | (SF) ← (AC)<1>                                     |          | - - * 1           |                          |  |  |  |
|                        | TEST @HL, b           | 01 01 10 b1b0                   |          | 5 8+b       | (SF) ← M[(H+L)]<1>                                 |          | - - * 1           |                          |  |  |  |
|                        | TEST y , b            | 00 11 10 01 10 b1b0y3y2y1y0     |          | 3 9 8+b y   | (SF) ← M[y]<1>                                     |          | - - * 2           |                          |  |  |  |
|                        | TEST %p , b           | 00 11 10 11 10 b1b0P3P2P1P0     |          | 3 B 8+b p   | (SF) ← P[P]<1>                                     |          | - - * 2           |                          |  |  |  |
|                        | TEST @L               | 00 11 01 11                     |          | 3 7         | (SF) ← P[(LR)<3:2>+4]<(LR)<1:0>>                   |          | - - * 2           |                          |  |  |  |
|                        | TESTP CF              | 00 00 01 00                     |          | 0 4         | (SF) ← (CF), (CF) ← 1                              |          | 1 - * 1           |                          |  |  |  |
|                        | TESTP ZF              | 00 00 11 10                     |          | 0 E         | (SF) ← (ZF)                                        |          | - - * 1           |                          |  |  |  |
|                        | TESTP OF              | 00 00 00 01                     |          | 0 1         | (SF) ← (OF)                                        |          | - - * 1           |                          |  |  |  |
|                        | TESTP y , b           | 00 11 10 01 11 b1b0y3y2y1y0     |          | 3 9 C+b y   | (SF) ← M[y]<1>                                     |          | - - * 2           |                          |  |  |  |
|                        | TESTP %p , b          | 00 11 10 11 11 b1b0P3P2P1P0     |          | 3 B C+b p   | (SF) ← P[P]<b>                                     |          | - - * 2           |                          |  |  |  |
|                        | SET GF                | 00 00 00 11                     |          | 0 3         | (OF) ← 1                                           |          | - - 1 1           |                          |  |  |  |
|                        | SET @HL, b            | 01 01 00 b1b0                   |          | 5 b         | M[(H+L)]<b>-1                                      |          | - - 1 1           |                          |  |  |  |
|                        | SET y , b             | 00 11 10 01 00 b1b0y3y2y1y0     |          | 3 9 b y     | M[y]<1>-1                                          |          | - - 1 2           |                          |  |  |  |
|                        | SET %p , b            | 00 11 10 11 00 b1b0P3P2P1P0     |          | 3 B b p     | P[P]<b>-1                                          |          | - - 1 2           |                          |  |  |  |
|                        | SET @L                | 00 11 01 00                     |          | 3 4         | P[(LR)<3:2>+4]<(LR)<1:0>>-1                        |          | - - 1 2           |                          |  |  |  |
|                        | CLR GF                | 00 00 00 10                     |          | 0 2         | (OF) ← 0                                           |          | - - 1 1           |                          |  |  |  |
|                        | CLR @HL, b            | 01 01 01 b1b0                   |          | 5 4+b       | M[(H+L)]<b>-0                                      |          | - - 1 1           |                          |  |  |  |
|                        | CLR y , b             | 00 11 10 01 01 b1b0y3y2y1y0     |          | 3 9 4+b y   | M[y]<1>-0                                          |          | - - 1 2           |                          |  |  |  |
|                        | CLR %p , b            | 00 11 10 11 01 b1b0P3P2P1P0     |          | 3 B 4+b p   | P[P]<b>-0                                          |          | - - 1 2           |                          |  |  |  |
|                        | CLR @L                | 00 11 01 01                     |          | 3 5         | P[(LR)<3:2>+4]<(LR)<1:0>>-0                        |          | - - 1 2           |                          |  |  |  |
| Input/Output           | CLR IL , r            | 00 11 01 10 11 r5r4r3r2r1r0     |          | 3 6 C+rHFL  | (INTL)<8:0>-+((INTL)<5:0>&V<5:0>                   |          | - - 1 2           |                          |  |  |  |
|                        | EICLR IL , r          | 00 11 01 10 01 r5r4r3r2r1r0     |          | 3 6 4+rHFL  | (RIF)←1, (INTL)<8:0>-+((INTL)<3:0>&V<3:0>          |          | - - 1 2           |                          |  |  |  |
|                        | DICLR IL , r          | 00 11 01 10 10 r5r4r3r2r1r0     |          | 3 6 8+rHFL  | (RIP)←0, (INTL)<5:0>-+((INTL)<5:0>>V<5:0>          |          | - - 1 2           |                          |  |  |  |
|                        | IN %P , A             | 00 11 10 10 00 10 P3P2P1P0      |          | 3 A 2 p     | (AC) ← P[p]                                        |          | - Z Z 2           |                          |  |  |  |
|                        | IN %P , @HL           | 00 11 10 10 01 10 P3P2P1P0      |          | 3 A 6 p     | M[(H+L)] ← P[p]                                    |          | - - Z 2           |                          |  |  |  |
| Branch/Subroutine      | OUT A , %P            | 00 11 10 00 10 P0               | P3P2P1P0 | 3 A 8T2P4P  | p[p] ← (AC) , p = P*P3P2P1P0                       |          | - - 1 2           |                          |  |  |  |
|                        | OUT @HL,%P            | 00 11 10 10 11 P0               | P3P2P1P0 | 3 A C2P4P   | p[p] ← M[(H+L)] , p = P*P3P2P1P0                   |          | - - 1 2           |                          |  |  |  |
|                        | OUT #k , %P           | 00 10 11 00 k3k2k1k0P3P2P1P0    |          | 2 C k p     | p[p] ← k                                           |          | - - 1 2           |                          |  |  |  |
|                        | OUT@L                 | 00 01 00 10                     |          | 1 2         | P[2]<1>-ROM[P*(B+(CF))]*M[(H+L)]                   |          | - - 1 2           |                          |  |  |  |
| Branch                 | BS a                  | 01 10 aaaaaaaaaaaaaaaaaaaaaaa   |          | 6 aH aM aL  | If SF=1 then(PC) ← else null,                      |          | - - 1 2           |                          |  |  |  |
|                        | BSS a                 | 10 d5d4d3d2d1d0                 |          | 8+dHdL      | If SF=1 then(PC) ← a else null,a=(PC)>1:6>d        |          | - - 1 1 *5        |                          |  |  |  |
|                        | CALL a                | 00 10 0 aaaaaaaaaaaaaaaaaaaaaaa |          | 2 aH aM aL  | STACK[(SPW)] ← (PC), (SPW) ← (SPW)-1 ,             |          | - - - 2 *5        |                          |  |  |  |
|                        | CALLS a               | 01 11 nnnnnnnn                  |          | 7 n         | (PC) ← a, 0 ≤ a ≤ 2,047                            |          | - - - 2 *5        |                          |  |  |  |
|                        | RET RTRI              | 00 10 10 10                     |          | 2 A         | STACK[(SPW)] ← (FC), (SPW) ← (SPW)-1 ,             |          | - - - 2           |                          |  |  |  |
| Other                  |                       | 00 10 10 11                     |          | 2 B         | (PC) ← a, a=nn-6(n≠0),134(n=1)                     |          | * * * 2           |                          |  |  |  |
|                        | NOP                   | 00 00 00 00                     |          | 0 0         | (SPW) ← (SPW)+1, (PC) ← STACK[(SPW)]               |          | - - - 1           |                          |  |  |  |
|                        |                       |                                 |          |             | (SPW) ← (SPW)+1, (FLAG*PC) ← STACK[(SPW)], (EIF)←1 |          |                   |                          |  |  |  |

Note 1 Setting Condition of Flag.

"C" indicates the carry output from the most significant position in the addition operation, and "B" indicates the borrow output from the most significant position in the subtraction operation.

"Z" indicates the zero detection signal to which "1" is applied only when either the ALU output or the processing result or all four bits of the data transferred to the accumulator are zero.

The flag is set to "C", "S", "B", "Z", "1", or "0" according to the data processing result. The value specified by the function is set to the flag with the mark "\*", and the mark "-" denotes no change in the state of the flag.

Note 2 The zero flag is set according to the data set in the accumulator.

Note 3 The flags(ZF, SF) are set according to the result of increment or decrement of the L register.

Note 4 The carry is the data shifted out from the accumulator.

Note 5 The contents of the program counter indicate the next address of the instruction to be executed.



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C22F

PRELIMINARY

## ELECTRICAL CHARACTERISTICS

ABSOLUTE MAXIMUM RATINGS ( $V_{SS} = 0V$ )

| SYMBOL | ITEM                                        | RATING         | UNIT |
|--------|---------------------------------------------|----------------|------|
| VDD    | Supply Voltage                              | -0.5 ~ 7       | V    |
| VLC    | Supply Voltage (LCD Drive)                  | -0.5 ~ VDD+0.5 |      |
| VIN    | Input Voltage                               | -0.5 ~ VDD+0.5 | V    |
| VOUT1  | Output Voltage (Except open drain terminal) | -0.5 ~ VDD+0.5 |      |
| VOUT2  | Output Voltage (Open drain terminal)        | -0.5 ~ 10      |      |
| PD     | Power Dissipation (Topr = 70°C)             | 400            | mW   |
| Tsld   | Soldering Temperature · Time                | 260 (10 sec.)  | °C   |
| Tstg   | Storage Temperature                         | -55 ~ 125      |      |
| Topr   | Operating Temperature                       | -30 ~ 70       |      |

RECOMMENDED OPERATING CONDITIONS ( $V_{SS} = 0V$ )

| SYMBOL           | ITEM                                                       | CONDITION                         | MIN.     | MAX.     | UNIT |
|------------------|------------------------------------------------------------|-----------------------------------|----------|----------|------|
| Topr             | Operating Temperature                                      |                                   | -30      | 70       | °C   |
| VDD              | Supply Voltage                                             |                                   | 4.5      | 6        | V    |
| VDDH             | Supply Voltage (Hold)                                      |                                   | 2        | 6        |      |
| VLC              | Supply Voltage (LCD Drive)                                 |                                   | 0        | VDD-2.7  |      |
| V <sub>IH1</sub> | High Level Input Voltage<br>(Except Schmitt circuit input) | VDD > 4.5V                        | VDDx0.7  | VDD      |      |
| V <sub>IH2</sub> | High Level Input Voltage<br>(Schmitt circuit input)        |                                   | VDDx0.75 | VDD      |      |
| V <sub>IH3</sub> | High Level Input Voltage                                   | VDD < 4.5V                        | VDDx0.9  | VDD      |      |
| V <sub>IL1</sub> | Low Level Input Voltage<br>(Except Schmitt circuit input)  | VDD > 4.5V                        | 0        | VDDx0.3  |      |
| V <sub>IL2</sub> | Low Level Input Voltage<br>(Schmitt circuit input)         |                                   | 0        | VDDx0.25 |      |
| V <sub>IL3</sub> | Low Level Input Voltage                                    | VDD < 4.5V                        | 0        | VDDx0.1  |      |
| f <sub>C</sub>   | Clock Frequency                                            |                                   | 0.4      | 4.2      | MHz  |
| t <sub>WCH</sub> | High Level Clock Pulse Width (Note 1)                      | V <sub>IN</sub> = V <sub>IH</sub> | 80       | -        | nS   |
| t <sub>WCL</sub> | Low Level Clock Pulse Width (Note 1)                       | V <sub>IN</sub> = V <sub>IL</sub> | 80       | -        |      |

(Note 1) For external clock operation

**D.C. CHARACTERISTICS (V<sub>SS</sub>=0V, V<sub>DD</sub>=5V±10%, T<sub>opr</sub>=-30~70°C)**

| SYMBOL                              | PARAMETER                                          | CONDITION                                                                                                            | MIN. | TYP.   | NOTE 1 | MAX.  | UNIT |
|-------------------------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|------|--------|--------|-------|------|
| V <sub>HHS</sub>                    | HYSTERESIS VOLTAGE (SCHMITT CIRCUIT INPUT)         |                                                                                                                      | -    | ~      | -      | -     | V    |
| I <sub>IN1</sub>                    | INPUT CURRENT (KO,RESET, HOLE, TEST) (NOTE 1)      | V <sub>DD</sub> =5V, V <sub>IN</sub> =5.5V                                                                           | -    | -      | -      | ±1    | μA   |
| I <sub>INK</sub>                    | INPUT CURRENT (OPEN DRAIN R PORT)                  | V <sub>DD</sub> =5V, V <sub>IN</sub> =5.5V                                                                           | -    | -      | -      | ±1    | mA   |
| I <sub>IL</sub>                     | LOW LEVEL INPUT CURRENT (PUSH-PULL R PORT)         | V <sub>DD</sub> =5V, V <sub>IN</sub> =5.4V                                                                           | -    | -      | -      | -1    | mA   |
| R <sub>IN</sub>                     | INPUT RESISTANCE (KO WITH INPUT RESISTOR)          |                                                                                                                      | 3    | ~      | 10     | ∞     | kΩ   |
| I <sub>IO</sub>                     | OUTPUT LEAKAGE CURRENT (OPEN DRAIN R PORT)         | V <sub>DD</sub> =5V, V <sub>OUT</sub> =5V                                                                            | -    | -      | -      | 2     | μA   |
| V <sub>OH</sub>                     | OUTPUT VOLTAGE (HIGH LEVEL (PUSH-PULL R PORT))     | V <sub>DD</sub> =4.2V, I <sub>OH</sub> =20μA                                                                         | 3.4  | -      | -      | -     | V    |
| V <sub>OL</sub>                     | OUTPUT VOLTAGE (LOW LEVEL (R PORT))                | V <sub>DD</sub> =4.2V, I <sub>OL</sub> =10mA                                                                         | -    | -      | -      | .4    | V    |
| R <sub>O54</sub> , R <sub>O50</sub> | OFFSET IMPEDANCE (HIGH-LOW LEVEL (SEG) (NOTE 4,5)) | V <sub>DD</sub> =5V, V <sub>LCD</sub> (NOTE 3)=5V                                                                    | -    | -      | -      | T.B.D |      |
| R <sub>O54</sub> , R <sub>O53</sub> | OFFSET IMPEDANCE (HIGH-LAW LEVEL (COM) (NOTE 4,5)) | V <sub>DD</sub> =5V, V <sub>LCD</sub> =5V                                                                            | -    | 1.0    | -      | T.B.D |      |
| R <sub>O54</sub> , R <sub>O51</sub> | 1/3, 1/2 LEVEL (SEG) (NOTE 4)                      | V <sub>DD</sub> =5V, V <sub>LCD</sub> =5V                                                                            | -    | 1.0    | -      | T.B.D |      |
| R <sub>O54</sub> , R <sub>O52</sub> | 1/3, 1/2 LEVEL (COM) (NOTE 4)                      | V <sub>DD</sub> =5V, V <sub>LCD</sub> =5V                                                                            | -    | 1.0    | -      | T.B.D |      |
| R <sub>O54</sub>                    | 1/2 LEVEL (SEG) (NOTE 5)                           | V <sub>DD</sub> =5V, V <sub>LCD</sub> =5V                                                                            | -    | 1.0    | -      | T.B.D |      |
| R <sub>O52</sub>                    | 1/2 LEVEL (COM) (NOTE 5)                           | V <sub>DD</sub> =5V, V <sub>LCD</sub> =5V                                                                            | -    | 1.0    | -      | T.B.D |      |
| V <sub>O3</sub>                     | 1/3 LEVEL (SEG, COM) (NOTE 4)                      | 4~1.4                                                                                                                | 4    | 4±1%   | -      | -     | V    |
| V <sub>O1</sub>                     | 1/2 LEVEL (SEG, COM) (NOTE 5)                      | 3.6~1.2                                                                                                              | 3.6  | 3.6±1% | -      | -     | V    |
| V <sub>O1</sub>                     | 1/2 LEVEL (SEG, COM) (NOTE 4)                      | 3~1.2                                                                                                                | 3    | 3±1%   | -      | -     | V    |
| I <sub>IND</sub>                    | SUPPLY CURRENT (AT OPERATING) (NOTE 3)             | V <sub>DD</sub> =V <sub>DE</sub> =5V, V <sub>LCD</sub> =V <sub>SS</sub> , f <sub>c</sub> =+MHz                       | -    | 2      | -      | T.B.D | mA   |
| I <sub>DDH</sub>                    | SUPPLY CURRENT (AT HOLDING) (NOTE 3)               | V <sub>DD</sub> =5V, V <sub>LCD</sub> =5V (all valid), C <sub>L</sub> =5PF, C <sub>XIN</sub> =C <sub>XOUT</sub> =5PF | -    | 0.5    | -      | T.B.D | μA   |

(NOTE 1) TYP. VALUES SHOW THOSE WHEN T<sub>opr</sub>=25°C, V<sub>DD</sub>=5V.  
 WHEN THE KO PORT HAS A BUILT-IN INPUT RESISTER, CURRENT BY RESISTER IS EXCLUDED.  
 V<sub>LCD</sub>=V<sub>DD</sub>-V<sub>LCD</sub>.  
 SHOWS ON-RESISTANCE AT TIME OF LEVEL SWITCHING WHEN THE 1/4 OR 1/2 DUTY LCD IS USED.  
 SHOWS ON-RESISTANCE AT TIME OF LEVEL SWITCHING WHEN THE 1/3 DUTY OR STATIC LCD IS USED.  
 (NOTE 2) WHEN KO PORT HAS A BUILT-IN INPUT RESISTER, CURRENT VALUE IS THAT AT TIME OF OPEN.  
 FURTHER, VOLTAGE LEVEL AT R PORT IS VALID.

**A.C. CHARACTERISTICS (V<sub>SS</sub>=0V, V<sub>DD</sub>=5V±10%, T<sub>opr</sub>=-30~70°C)**

| SYMBOL           | PARAMETER                     | CONDITION             | MIN. | TYP. | MAX. | UNIT |
|------------------|-------------------------------|-----------------------|------|------|------|------|
| t <sub>cyc</sub> | INSTRUCTION CYCLE TIME        |                       | 3.8  | -    | 4.0  | μs   |
| t <sub>SDH</sub> | SHIFT DATA HOLD TIME (NOTE 1) | t <sub>cyc</sub> -500 | -    | -    | -    | nS   |

**A.C. TIMING CHART**

(NOTE 1) SCK, SO TERMINAL EXTERNAL CIRCUIT





# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP47C22F

PRELIMINARY

### EXTERNAL DIMENSIONS

Unit : mm



Weight 1.3g (TYP.)



## Specification of program tape and input/output circuit format

The TMP47C22F will be able to make engineering samples (ES) if you specify the program data and input/output circuit format by use of a paper tape.

The paper tape format is equivalent to the Hex. format of Intel Co. (Format I).

The program data should be specified within the address space corresponding to the built-in ROM capacity; the addresses 000 - 7FF denote the address range in the TMP47C22F.

#### 1. Specification of input/output circuit format

The paper tape of Format I starts recording the program data after record mark ":", but the input/output circuit code should be specified just before the first record mark.

The "IÖCÖDE XX" format is used to define the input/output circuit code. XX denotes the proper input/output circuit code (two alphabets).

(Note) If the input/output circuit code is not specified, "IÖCÖDE GD" is employed. It should be noted that if the specified format is different from the standard one, and if the specified input/output circuit code is illegal, such specifications may be considered to have not been made.

(Example of tape list)

```
TÖSHIBA MICRÖCÖMPUTER TLCS-47
IÖCÖDE GD
:10000000665C7D79CF50F3F951FED55A8FF16E570
:1000100088884DDE76E31F5D8ABA6DF292F113F5C1
:100020004FF1F
:
:
:
:1007E000B53D42E0EC32546025B7308CDD52063D1D
:1007F000B4BE9E9E345B6138060B20BC372BF60BD6
:00000001FF
```

## 2. Program tape format (Format I)





**8BIT SINGLE CHIP MICROCOMPUTER**

**TLCS-84(NMOS/CMOS)**



**Toshiba****INTEGRATEDCIRCUIT****TECHNICAL DATA****8-BIT SINGLE-CHIP MICROCOMPUTER**

TOSHIBA MOS DIGITAL INTEGRATED CIRCUIT

TMP8048P/8048PI

TMP8035P/8035PI

N-CHANNEL SILICON GATE MOS

**GENERAL DESCRIPTION**

The TMP8048, from here on referred to as the TMP8048, is a single chip microcomputer fabricated in N-channel Silicon Gate MOS technology which provides internal 8-bit parallel architecture.

The following basic architectural functions of a computer have been included in a single chip; an 8-bit CPU,  $64 \times 8$  RAM data memory,  $1K \times 8$  ROM program memory, 27 I/O lines and an 8-bit timer/event counter.

The TMP8048 is particularly efficient as a controller. It has extensive bit handling capability as well as facilities for both binary and BCD arithmetic.

The TMP8035P is the equivalent of a TMP8048 without ROM program memory on chip. By using this device with external EPROM or RAM, software debugging becomes easy.

**FEATURES**

- Compatible with Intel's 8048
- 2.5  $\mu$ S Instruction Cycle
- All instruction 1 or 2 cycles
- Over 90 instructions; 70% single byte
- Easy expandable memory and I/O
- $1K \times 8$  masked ROM
- 64  $\times 8$  RAM
- 27 I/O lines
- Interval Timer/Event Counter
- Single level interrupt
- Single 5V supply
- $-40^{\circ}\text{C}$  to  $+85^{\circ}\text{C}$  Operation (TMP8048PI / TMP8035PI : Industrial Specification)

**PIN CONNECTIONS (Top View)**

## BLOCK DIAGRAM





## PIN NAMES AND PIN DESCRIPTION

V<sub>SS</sub> (Power Supply)

Circuit GND potential

V<sub>DD</sub> (Power Supply)

+5V during operation Low power standby pin for TMP8048 RAM

V<sub>CC</sub> (Main Power Supply)

+5V during operation

PROG (Output)

Output strobe for the TMP8243P I/O expander

P<sub>10</sub>-P<sub>17</sub> (Input/Output) Port 1

8-bit quasi-bidirectional port (Internal Pullup  $\geq$  50K $\Omega$ ).

P<sub>20</sub>-P<sub>27</sub> (Input/Output) Port 2

8-bit quasi-bidirectional port (Internal Pullup  $\geq$  50K $\Omega$ ).

P<sub>20</sub>-P<sub>23</sub> Contain the four high order program counter bits during an external program memory fetch and serve as a 4-bit I/O expander bus for the TMP8243P.

DB<sub>0</sub> -DB<sub>7</sub> (Input/Output, 3 State)

True bidirectional port which can be written or read synchronously using the RD, WR strobes. The port can also be statically latched. Contains the 8 low order program counter bits during an external program memory fetch, and receives the addressed instruction under the control of PSEN. Also contains the address and data during an external RAM data store instruction, under control of ALE, RD, and WR.

T<sub>0</sub> (Input/Output)

Input pin testable using the conditional transfer instructions JTO and JNTO. T<sub>0</sub> can be designated as a clock output using ENTO CLK instruction.

T<sub>1</sub> (Input)

Input pin testable using the JT1 and JNT1 instruction. Can be designated the event counter input using the timer/START CNT instruction.

INT (Input)

External interrupt input. Initiates an interrupt if interrupt is enabled. Interrupt is disabled after a reset. Also testable with conditional jump instruction. (Active Low)

RD (Output)

Output strobe activated during a Bus read. Can be used to enable data onto the Bus from an external device. Used as a Read Strobe to External Data Memory (Active Low).

WR (Output)

Output strobe during a Bus write (Active Low) Used as a Write Strobe to External Data Memory.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8048P/8048PI

TMP8035P/8035PI

### RESET (Input)

Active Low signal which is used to initialize the Processor. Also used during Power down.

### ALE (Output)

Address Latch Enable. This signal occurs once during each cycle and is useful as a clock output. The negative edge of ALE strobes address into external data and program memory.

### PSEN (Output)

Program Store Enable. This output occurs only during a fetch to external program memory (Active Low).

### SS (Input)

Single step input can be used in conjunction with ALE to "single step" processor through each instruction when SS is low the CPU is placed into a wait state after it has completed the instruction being executed.

### EA (Input)

External Access input which forces all program memory fetches to reference external memory. Useful for emulation and debug and essential for testing and program verification. (Active High).

### XTAL 1 (Input)

One side of crystal input for internal oscillator. Also input for external source.

### XTAL 2 (Input)

Other side of crystal input.

## FUNCTIONAL DESCRIPTION

### 1. System Configuration

The following system functions of the TMP8048 are described in detail.

- |                               |                               |
|-------------------------------|-------------------------------|
| (1) Program Memory            | (6) Stack (Stack Pointer)     |
| (2) Data Memory               | (7) Flag 0, Flag 1            |
| (3) I/O Port                  | (8) Program Status Word (PSW) |
| (4) Timer/Counter             | (9) Reset                     |
| (5) Interrupt Control Circuit | (10) Oscillator Circuit       |

#### (1) Program Memory

- The maximum memory that can be directly addressed by the TMP8048 is 4096 bytes. The first 1024 bytes from location 0 through 1023 can be internal resident mask ROM. The rest of the 3072 bytes of addressable memory are external to the chip. The TMP8035 has no internal resident memory; all memory must be external.

- There are three locations in Program Memory of special importance.



Program Memory Area

- Location 0

Activating the Reset line of the processor causes the first instruction to be fetched from Location 0.

- Location 3

Activating the interrupt line of the processor (if interrupt enabled) causes a jump to subroutine defined by address held in Location 3.

- Location 7

A timer/counter interrupt resulting from a timer/counter overflow (if enabled) causes a jump to a subroutine defined by address held in Location 7.

- Program addresses 0-2047 and 2048-4095 are called memory banks 0 and 1 respectively. Switching of memory banks is achieved by changing the most significant bit of the program counter (PC) during execution of an unconditional jump instruction or call instruction executed after using SEL M<sub>B</sub>0 or SEL M<sub>B</sub>1.

Reset operation automatically selects Bank 0.

## (2) Data Memory

- Resident Data Memory (volatile RAM) is organized as 64 words by 8-bits wide.
- The first 8 locations (0 - 7) of the memory array are designated as working registers and are directly addressable by several instructions. By executing a Register Bank switch instruction (SEL R<sub>B</sub>1) locations 24 - 31 are designated as the working registers in place of 0 - 7.



Internal Data Memory Area

- RAM locations 8 - 23 serve a dual role in that they contain the program counter stack which is a stack 2 bytes wide by 8 levels deep. These locations store returning addresses from subroutines. If the level of subroutine nesting is less than the permitted 8, you free up 2 bytes of RAM for general use for every level of nesting not utilized.
- ALL 64 locations are indirectly addressable through either of two RAM Pointer Registers which reside at R0 and R1 of the Register array.
- The TMP8048 architecture allows extension of the Data Memory to 256 words.

### (3) Input/Output Ports

- The TMP8048 has 27 I/O lines which can be used for either input or output. These I/O lines are grouped into 3 ports each having 8 bidirectional lines and 3 "test" inputs which can alter program sequences when tested by conditional jump instructions.
- Ports 1 and 2 are each 8-bits wide and have identical characteristics. Data written to these ports is statically latched and remains unchanged until rewritten. As input ports these lines are non-latching, i.e., inputs must be present until read by an input instruction.
- All lines of Ports 1 and 2 are called quasi-bidirectional because of a special output circuit structure (illustrated in Figure 1). Each line is continuously pulled to a +5V level through a high impedance resistive device ( $50K\Omega$ ) which is sufficient to provide the source current for a TTL high level yet can be pulled low by a standard TTL gate thus allowing the same pin to be used for both input and output. In order to speed up the "0" to "1" transition a low impedance device ( $5K\Omega$ ) is switched in momentarily whenever a "1" is written to line. When a "0" is written to line a low impedance device overcomes the pullup and provides TTL current sinking capability.



Fig.1 Input/Output Circuit of Port 1, Port 2

- Reset initializes all lines to a high impedance "1" state.
- When external data memory area is not addressed during execution of an internal program, Port 0 (DB0 - DB7) becomes a true bidirectional port (bus) with associated input and output strobes. If bidirectional feature not needed Bus can serve as either a statically latched output port or a non-latched input port. However, I/O lines of this port cannot be intermixed.
- As a static port data is written and latched using the OUTL instruction and inputted using the INS instruction these two commands generate pulses on the corresponding  $\overline{RD}$  and  $\overline{WR}$  strobe lines.
- As a bidirectional port the MOVX instructions are used to read and write the port which generate the  $\overline{WR}$   $\overline{RD}$  strobes.
- When not being written or read, the Bus lines are in a high impedance state.

## (4) Timer/Event Counter

- The 8-bit binary up counter can use either of the following frequency inputs

(1) Internal clock (1/480 of OSC frequency)

..... Timer mode

(2) External input clock form T1 terminal

(minimum cycle time  $3 \times$  ALE cycle)

..... Event Counter mode

The counter is presettable and readable with two MOV instructions which transfer the content of the accumulator to the counter and vice versa. The counter content is not affected by a Reset and is initialized solely by the MOVT, A instruction. The counter is stopped by a Reset or STOP TCNT instruction and remains stopped until started by START T instruction or as an event counter by a START CNT. Once started the counter will increment to its maximum count (FF) and overflow to Zero continuing its count until stopped by a STOP TCNT instruction or RESET.

The increment from maximum count to Zero (overflow) results in the setting of an overflow flag and the generation of an interrupt request. When interrupt acknowledged a subroutine call to Location 7 will be initiated. Location 7 should store the starting address of the timer or counter service routine. The state of the overflow flag is testable with the conditional JUMP (JTF). The flag is reset by executing a JTF or by RESET. Figure 2 illustrates the concept of the timer circuit.



Fig.2 Concept of Timer Circuit



Fig.3 Concept of Interrupt Control Circuit

## (5) Interrupt Control Circuit

- . There are two distinct types of Interrupts in the TMP8048.
  - (1) External Interrupt from the INT terminal
  - (2) Timer Interrupt caused by timer overflow



- The interrupt system is single level in that once an interrupt is detected all further interrupt requests are ignored until execution of an RETR (which should occur at the end of an interrupt service routine) reenables the interrupt input logic.
- An interrupt sequence is initiated by applying a low level "0" to the INT pin. INT is level triggered and active low which allows "Wire Oring" of several interrupt sources. The interrupt level is sampled every machine cycle during ALE and when detected causes a "jump to subroutine" at Location 3. As in any call to subroutine, the Program Counter and Program Status Word are saved in the stack.
- When an overflow occurs in the internal timer/event counter an interrupt request is generated which is reservised as outlined in previous paragraph except that a jump to Location 7 is used instead of 3. If INT and times overflow occur simultaneously then external request INT takes precedence.
- If an extra external interrupt is needed in addition to INT this can be achieved by enabling the counter interrupt, loading FFH in the counter (one less than the terminal count), and enabling the event counter mode. A "1" to "0" transition on T1 will cause an interrupt vector to Location 7.
- The interrupt service routine pointed to be addresses in Location 3 or 7 must reside in memory between 0 and 2047, i.e., Bank 0.

Figure 3 illustrates the concept of the interrupt control circuit.

#### (6) Stack (stack Pointer)

- An interrupt or Call to a subroutine causes the contents of the program counter to be stored in one of the 8 register pairs of the Program Counter Stack. The pair to be used is determined by a 3-bit stack pointer which is part of the Program Status Word (PSW explained in section (8)). Data RAM locations, 8 through 23 are available as stack registers and are used to store the program counter and 4-bits of PSW as shown in the figure.
- The stack pointer when initialized points to RAM locations 8 and 9. The first subroutine jump or interrupt results in the program counter contents being transferred to Locations 8 and 9. Then the stack pointer is incremented by one to point to Locations 10 and 11. Eight levels of subroutine are obviously possible.
- At the end of a subroutine signalled by a RET or RETR causes the stack pointer to be decremented by one and the contents of the resulting pair to be transferred to the Program Counter.



(7) Flag 0, Flag 1, (F0, F1)

- The TMP8048 has two flags F0 and F1 which are used for conditional jump. These flags can be set, reset and tested with the conditional jump instruction JFO.
- F0 is a part of the program status word (PSW) and is saved in the stack area when a subroutine is called.

(8) Program Status Word (PSW)

- An 8-bit status word which can be loaded to and from the accumulator exists called the Program Status Word (PSW). The PSW is read by a MOV A, PSW and written to by a MOV PSW, A. The information available in the PSW is shown in the diagram below.



Bits 0 - 2 : Stack Pointer Bits( $S_0$ ,  $S_1$ ,  $S_2$ )

Bit 3 : Not used ("1" level when read.)

Bit 4 : Working Register Bank Switch Bit (BS)
 

- 0 = Bank 0
- 1 = Bank 1

Bit 5 : Flag 0 (FO)

Bit 6 : Auxiliary Carry (AC) carry bit generated by an ADD instruction and used by the decimal adjust instruction DA, A (AC)

Bit 7 : Carry (C) flag which indicates that the previous operation has resulted in the accumulator.  
(C)

(9) Reset

- The reset input provides a means for initialization of the processor. This Schmitt trigger input has an internal pullup resistor which in combination with an external 1 $\mu$ F capacitor provides an internal reset pulse sufficient length to guarantee that all internal logic is initialized.



- If the pulse is generated externally the reset pin must be held at ground ( $\leq 0.5V$ ) for at least 50mS after the power supply is within tolerance.
- Reset performs the following functions within the chip:
  - (i) Sets PC to Zero.
  - (ii) Sets Stack Pointer to Zero.
  - (iii) Selects Register Bank 0.
  - (iv) Selects Memory Bank 0.
  - (v) Sets BUS (DB0 - DB7) to high impedance state. (Except when EA = 5V)
  - (vi) Sets Ports 1 and 2 to input mode.
  - (vii) Disables interrupts (timer and external).
  - (viii) Stops Timer.
  - (ix) Clears Timer Flag.
  - (x) Clears F0 and F1.
  - (xi) Disables clock output from T0.

#### (10) Oscillator Circuit

- TMP8048 can be operated by the external clock input in addition to crystal oscillator as shown below.



#### 2. Basic Operation and Timing

The following basic operations and timing are explained

- (1) Instruction Cycle
- (2) External Memory Access Timing
- (3) Interface with I/O Expander TMP8243P
- (4) Internal Program Verify (Read) Timing
- (5) Single Step Operation Timing
- (6) Low Power Stand-by Mode

### (1) Instruction Cycle

- The instructions of TMP8048 are executed in one or two machine cycles, and one machine cycle consists of five states.
- Fig.4 illustrates its relationship with the clock input to CPU.
- $\phi_2$  clock shown in Fig.4 is derived to outside by ENTO CLK instruction.
- ALE can be also used as the clock to indicate the machine cycle as well as giving the external address latch timing.

### (2) External Memory Access Timing

#### (i) Program Memory Access

- TMP8048 programs are executed in the following three modes.
  - (1) Execution of internal program only.
  - (2) Execution of both external and internal programs.
  - (3) Execution of external program only.The external program memory is accessed (instructions are fetched) automatically when the internal ROM address is exceeded in mode (2) and from initial start address 0 in mode (3).
  - In the external program memory access operation, the following will occur
    - The contents of the 12-bit program counter will be output on BUS(DB0 - DB7) and the lower 4-bits of Port 2.
    - Address Latch Enable (ALE) will indicate the time at which address is valid. The trailing edge of ALE is used to latch the address externally.
    - Program Store Enable (PSEN) indicates that an external instruction fetch is in progress and serves to enable the external memory device.
    - BUS (DB0 - DB7) reverts to Input mode and the processor accepts its 8-bit contents as an Instruction Word.
  - Figure 5 illustrates the timing.

#### (ii) Access of External Data Memory

- In the extended data memory access operation during READ/WRITE cycle the following occurs
  - The contents of R0 R1 is output onto BUS (DB0 - DB7).
  - ALE indicates address is valid. The trailing edge of ALE is used to latch the address externally.
  - A read  $\overline{RD}$  or write  $\overline{WR}$  pulse on the corresponding output pins indicates the type of data memory access in progress. Output data valid at trailing edge of  $\overline{WR}$  and input data must be valid at trailing edge of  $\overline{RD}$ .
  - Data (8-bits) is transferred over BUS.



Fig.4 Instruction Cycle Timing



Fig.5 Timing of External Program Memory Access



Suggest we have two diagrams



Fig.6 Timing of Accessing External Data Memory

- Figure 6 illustrates the timing of accessing the external data memory during execution of external program.

### (3) Interface with I/O Expander (TMP8243P)

- The TMP8048 I/O can be easily expanded using the TMP8243 I/O Expander. This device uses only the lower half 4-bits of Port 2 for communication with the TMP8048. The TMP8243 contains four 4-bit I/O ports which serve as extensions of one chip I/O and are addressed as Ports (4-7). All communication takes place over the lower half of Port 2 (P20 - P23) with timing provided by an output pulse on the PROG pin. Each transfer consists of two 4-bit nibbles the first containing the "OP Code" and port address and the second containing the actual 4-bits of data.



Fig.7 Timing of Rading Internal Program Memory



Fig.8(a) Single Step Circuit

## (4) Reading of Internal Program Memory

- The processor is placed in the READ mode by applying +12V to the EA pin and OV to the RESET pin. The address of the location to be read is then applied to BUS and the low order 2-bits of Port 2. The address is latched by a 0 to 1 transition on RESET and the high level causes the contents of program memory location addressed to appear on the eight lines of BUS.
- Figure 7 illustrates the timing diagram for this operation.

## (5) Single Step Operation.

- A single step feature useful for debug can be implemented by utilizing a circuit shown in Figure 8 (a) combined with the SS pin and ALE pin.
- A D-type flip flop with set and reset is used to generate  $\overline{SS}$ . In the run mode  $\overline{SS}$  is held high by keeping the flip flop set. To enter single step, set is removed allowing ALE to bring  $\overline{SS}$  low via reset input. The next instruction is started by clocking a "1" into the FF which will not appear on  $\overline{SS}$  unless ALE is high removing reset. In response to  $\overline{SS}$  going high the processor begins an instruction fetch which brings ALE low resetting FF and causing the processor to again enter the stopped state.
- The timing diagram in this case is as shown in Figure 8 (b). (EA = 5V).

## (6) Lower Power Stand-by Mode.

- The TMP8048 has been organized to allow power to be removed from all but the volatile,  $64 \times 8$  data RAM array. In power down mode the contents of data RAM can be maintained while drawing typically 10 - 15% of normal operating power requirements.

VCC serves as the 5V supply for the bulk of the TMP8048 while the VDD supplies only the RAM array. In standby mode VCC is reduced to OV but VDD is kept at 5V. Applying a low level to reset inhibits any access to the RAM by the processor and guarantees that RAM cannot be inadvertently altered as power is removed from VCC.



Fig.8(b) Single Step Operation Timing

## INSTRUCTION

## ACCUMULATOR INSTRUCTION

| Mnemonic     | Instruction Code |         |         |         |         |         |         |         | Operation                            | Bytes | Cycles | Flag |    |
|--------------|------------------|---------|---------|---------|---------|---------|---------|---------|--------------------------------------|-------|--------|------|----|
|              | D7               | D6      | D5      | D4      | D3      | D2      | D1      | D0      |                                      |       |        | C    | AC |
| ADD A,Rr     | 0                | 1       | 1       | 0       | 1       | r       | r       | r       | (A) ← (A) + (Rr)<br>r = 0 - 7        | 1     | 1      | ○    | ○  |
| ADD A,@Rr    | 0                | 1       | 1       | 0       | 0       | 0       | 0       | r       | (A) ← (A) + (Rr)<br>r = 0, 1         | 1     | 1      | ○    | ○  |
| ADD A,#Data  | 0<br>d7          | 0<br>d6 | 0<br>d5 | 0<br>d4 | 0<br>d3 | 0<br>d2 | 1<br>d1 | 1<br>d0 | (A) ← (A) + Data                     | 2     | 2      | ○    | ○  |
| ADDC A,Rr    | 0                | 1       | 1       | 1       | 1       | r       | r       | r       | (A) ← (A) + (Rr) + (C)<br>r = 0 - 7  | 1     | 1      | ○    | ○  |
| ADDC A,@Rr   | 0                | 1       | 1       | 1       | 0       | 0       | 0       | r       | (A) ← (A) + ((Rr)) + (C)<br>r = 0, 1 | 1     | 1      | ○    | ○  |
| ADDC A,#Data | 0<br>d7          | 0<br>d6 | 0<br>d5 | 1<br>d4 | 0<br>d3 | 0<br>d2 | 1<br>d1 | 1<br>d0 | (A) ← (A) + Data + (C)               | 2     | 2      | ○    | ○  |
| ANL A,Rr     | 0                | 1       | 0       | 1       | 1       | r       | r       | r       | (A) ← (A) ∧ (Rr)<br>r = 0 - 7        | 1     | 1      | -    | -  |
| ANL A,@Rr    | 0                | 1       | 0       | 1       | 0       | 0       | 0       | r       | (A) ← (A) ∧ ((Rr))<br>r = 0, 1       | 1     | 1      | -    | -  |
| ANL A,#Data  | 0<br>d7          | 1<br>d6 | 0<br>d5 | 1<br>d4 | 0<br>d3 | 0<br>d2 | 1<br>d1 | 1<br>d0 | (A) ← (A) ∧ Data                     | 2     | 2      | -    | -  |
| ORL A,Rr     | 0                | 1       | 0       | 0       | 1       | r       | r       | r       | (A) ← (A) ∨ (Rr)<br>r = 0 - 7        | 1     | 1      | -    | -  |
| ORL A,@Rr    | 0                | 1       | 0       | 0       | 0       | 0       | 0       | r       | (A) ← (A) ∨ ((Rr))<br>r = 0, 1       | 1     | 1      | -    | -  |
| ORL A,#Data  | 0<br>d7          | 1<br>d6 | 0<br>d5 | 0<br>d4 | 0<br>d3 | 0<br>d2 | 1<br>d1 | 1<br>d0 | (A) ← (A) ∨ Data                     | 2     | 2      | -    | -  |
| XRL A,Rr     | 1                | 1       | 0       | 1       | 1       | r       | r       | r       | (A) ← (A) ▷ (Rr)<br>r = 0 - 7        | 1     | 1      | -    | -  |
| XRL A,@Rr    | 1                | 1       | 0       | 1       | 0       | 0       | 0       | r       | (A) ← (A) ▷ ((Rr))<br>r = 0, 1       | 1     | 1      | -    | -  |
| XRL A,#Data  | 1<br>d7          | 1<br>d6 | 0<br>d5 | 1<br>d4 | 0<br>d3 | 0<br>d2 | 1<br>d1 | 1<br>d0 | (A) ← (A) ▷ Data                     | 2     | 2      | -    | -  |
| INC A        | 0                | 0       | 0       | 1       | 0       | 1       | 1       | 1       | (A) ← (A) + 1                        | 1     | 1      | -    | -  |
| DEC A        | 0                | 0       | 0       | 0       | 0       | 1       | 1       | 1       | (A) ← (A) - 1                        | 1     | 1      | -    | -  |
| CLR A        | 0                | 0       | 1       | 0       | 0       | 1       | 1       | 1       | (A) ← 0                              | 1     | 1      | -    | -  |
| CPL A        | 0                | 0       | 1       | 1       | 0       | 1       | 1       | 1       | (A) ← NOT (A)                        | 1     | 1      | -    | -  |
| DA A         | 0                | 1       | 0       | 1       | 0       | 1       | 1       | 1       | Decimal Adjust<br>Accumulator        | 1     | 1      | ○    | -  |
| SWAP A       | 0                | 1       | 0       | 0       | 0       | 1       | 1       | 1       | (A4-7) ↗ (A0-3)                      | 1     | 1      | -    | -  |



## INTEGRATEDCIRCUIT

## TECHNICAL DATA

TMP8048P/8048PI

TMP8035P/8035PI

| Mnemonic | Instruction Code |    |    |    |    |    |    |    | Operation                                        | Bytes | Cycles | Flag  |
|----------|------------------|----|----|----|----|----|----|----|--------------------------------------------------|-------|--------|-------|
|          | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                                                  |       |        |       |
| RL A     | 1                | 1  | 1  | 0  | 0  | 1  | 1  | 1  | (An+1)←(An)<br>n = 0 - 6<br>(A0)←(A7)            | 1     | 1      | - - - |
| RLCA     | 1                | 1  | 1  | 1  | 0  | 1  | 1  | 1  | (An+1)←(An)<br>n = 0 - 6<br>(C)←(A7)<br>(A0)←(C) | 1     | 1      | - - - |
| RR A     | 0                | 1  | 1  | 1  | 0  | 1  | 1  | 1  | (An)←(An+1)<br>n = 0 - 6<br>(A7)←(A0)            | 1     | 1      | - - - |
| RRCA     | 0                | 1  | 1  | 0  | 0  | 1  | 1  | 1  | (An)←(An+1)<br>n = 0 - 6<br>(C)←(AO)<br>(A7)←(C) | 1     | 1      | - - - |

## Input/Output Instruction

| Mnemonic      | Instruction Code |    |    |    |    |    |    |    | Operation                            | Bytes | Cycles | Flag  |
|---------------|------------------|----|----|----|----|----|----|----|--------------------------------------|-------|--------|-------|
|               | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                                      |       |        |       |
| IN A,Pp       | 0                | 0  | 0  | 0  | 1  | 0  | P  | P  | (A)←(Pp)<br>P = 1, 2                 | 1     | 2      | - - - |
| OUTL Pp,A     | 0                | 0  | 1  | 1  | 1  | 0  | P  | P  | (Pp)←(A)<br>P = 1, 2                 | 1     | 2      | - - - |
| ANL Pp,#Data  | 1                | 0  | 0  | 1  | 1  | 0  | P  | P  | (Pp)←(Pp)AND Data<br>P = 1, 2        | 2     | 2      | - - - |
| ORL Pp,#Data  | 1                | 0  | 0  | 0  | 1  | 0  | P  | P  | (Pp)←(Pp)VData<br>P = 1, 2           | 2     | 2      | - - - |
| INS A,BUS     | 0                | 0  | 0  | 0  | 1  | 0  | 0  | 0  | (A)←(BUS)                            | 1     | 2      | - - - |
| OUTL BUS,A    | 0                | 0  | 0  | 0  | 0  | 0  | 1  | 0  | (BUS)←(A)                            | 1     | 2      | - - - |
| ANI BUS,#Data | 1                | 0  | 0  | 1  | 1  | 0  | 0  | 0  | (BUS)←(BUS)AND Data                  | 2     | 2      | - - - |
| ORL BUS,#Data | 1                | 0  | 0  | 0  | 1  | 0  | 0  | 0  | (BUS)←(BUS)VData                     | 2     | 2      | - - - |
| MOVD A,Pp     | 0                | 0  | 0  | 0  | 1  | 1  | P  | P  | (A0-3)←(Pp)<br>(A4-7)←0<br>P = 4 - 7 | 1     | 2      | - - - |
| MOV D Pp,A    | 0                | 0  | 1  | 1  | 1  | 1  | P  | P  | (Pp)←(A0-3)<br>P = 4 - 7             | 1     | 2      | - - - |

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP8048P/8048PI

TMP8035P/8035PI

| Mnemonic  | Instruction Code |    |    |    |    |    |    |    | Operation                     | Bytes | Cycles | Flag |    |
|-----------|------------------|----|----|----|----|----|----|----|-------------------------------|-------|--------|------|----|
|           | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                               |       |        | C    | AC |
| ANLD Pp,A | 1                | 0  | 0  | 1  | 1  | 1  | P  | P  | (Pp)←(Pp)^(A0-3)<br>P = 4 - 7 | 1     | 2      | -    | -  |
| ORLD Pp,A | 1                | 0  | 0  | 0  | 1  | 1  | P  | P  | (Pp)←(Pp)V(A0-3)<br>P = 4 - 7 | 1     | 2      | -    | -  |

## Register Instruction

| Mnemonic | Instruction Code |    |    |    |    |    |    |    | Operation                   | Bytes | Cycles | Flag |    |
|----------|------------------|----|----|----|----|----|----|----|-----------------------------|-------|--------|------|----|
|          | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                             |       |        | C    | AC |
| INC Rr   | 0                | 0  | 0  | 1  | 1  | r  | r  | r  | (Rr)←(Rr)+1<br>r = 0 - 7    | 1     | 1      | -    | -  |
| INC @Rr  | 0                | 0  | 0  | 1  | 0  | 0  | 0  | r  | ((Rr))←((Rr))+1<br>r = 0, 1 | 1     | 1      | -    | -  |
| DEC Rr   | 1                | 1  | 0  | 0  | 1  | r  | r  | r  | (Rr)←(Rr)-1<br>r = 0 - 7    | 1     | 1      | -    | -  |

## Branch Instruction

| Mnemonic            | Instruction Code |          |          |         |         |         |         |         | Operation                                               | Bytes | Cycles | Flag |    |
|---------------------|------------------|----------|----------|---------|---------|---------|---------|---------|---------------------------------------------------------|-------|--------|------|----|
|                     | D7               | D6       | D5       | D4      | D3      | D2      | D1      | D0      |                                                         |       |        | C    | AC |
| JMP Address         | a10<br>a7        | a9<br>a6 | a8<br>a5 | 1<br>a4 | 0<br>a3 | 1<br>a2 | 0<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>(PC8-10)←(a8-10)<br>(PC11)←DBF        | 2     | 2      | -    | -  |
| JMPP @A             | 1                | 0        | 1        | 1       | 0       | 0       | 1       | 1       | (PC0-7)←((A))                                           | 1     | 2      | -    | -  |
| DJNZ Rr,<br>Address | 1<br>a7          | 1<br>a6  | 1<br>a5  | 0<br>a4 | 1<br>a3 | r<br>a2 | r<br>a1 | r<br>a0 | (Rr)←(Rr)-1<br>if Rr not 0<br>(PC0-7)←(a0-7)            | 2     | 2      | -    | -  |
| JC Address          | 1<br>a7          | 1<br>a6  | 1<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if C = 1<br>(PC) = (PC)+2<br>if C = 0 | 2     | 2      | -    | -  |
| JNC Address         | 1<br>a7          | 1<br>a6  | 1<br>a5  | 0<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if C = 0<br>(PC)←(PC)+2<br>if C = 1   | 2     | 2      | -    | -  |

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP8048P/8048PI

TMP8035P/8035PI

| Mnemonic     | Instruction |          |          |         |         |         |         |         |                                                                        | Operation | Bytes | Cycles | Flag |   |
|--------------|-------------|----------|----------|---------|---------|---------|---------|---------|------------------------------------------------------------------------|-----------|-------|--------|------|---|
|              | D7          | D6       | D5       | D4      | D3      | D2      | D1      | D0      | C                                                                      |           |       |        | AC   |   |
| JZ Address   | 1<br>a7     | 1<br>a6  | 0<br>a5  | 0<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if (A) = 0<br>(PC)←(PC)+2<br>if (A) ≠ 0              | 2         | 2     | -      | -    | - |
| JNZ Address  | 1<br>a7     | 0<br>a6  | 0<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if (A) ≠ 0<br>(PC)←(PC)+2<br>if (A) = 0              | 2         | 2     | -      | -    | - |
| JTO Address  | 0<br>a7     | 0<br>a6  | 1<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if TO = 1<br>(PC)←(PC)+2<br>if TO = 0                | 2         | 2     | -      | -    | - |
| JNT0 Address | 0<br>a7     | 0<br>a6  | 1<br>a5  | 0<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if TO = 0<br>(PC)←(PC)+2<br>if TO = 1                | 2         | 2     | -      | -    | - |
| JT1 Address  | 0<br>a7     | 1<br>a6  | 0<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if T1 = 1<br>(PC)←(PC)+2<br>if T1 = 0                | 2         | 2     | -      | -    | - |
| JNT1 Address | 0<br>a7     | 1<br>a6  | 0<br>a5  | 0<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if T1 = 0<br>(PC)←(PC)+2<br>if T1 = 1                | 2         | 2     | -      | -    | - |
| JFO Address  | 1<br>a7     | 0<br>a6  | 1<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if FO = 1<br>(PC)←(PC)+2<br>if FO = 0                | 2         | 2     | -      | -    | - |
| JF1 Address  | 0<br>a7     | 1<br>a6  | 1<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if F1 = 1<br>(PC)←(PC)+2<br>if F1 = 0                | 2         | 2     | -      | -    | - |
| JTF Address  | 0<br>a7     | 0<br>a6  | 0<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if TF = 1<br>(PC)←(PC)+2<br>if TF = 0                | 2         | 2     | -      | -    | - |
| JN1 Address  | 1<br>a7     | 0<br>a6  | 0<br>a5  | 0<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if INT = 0<br>(PC)←(PC)+2<br>if INT = 1              | 2         | 2     | -      | -    | - |
| JBb Address  | b2<br>a7    | b1<br>a6 | b0<br>a5 | 1<br>a4 | 0<br>a3 | 0<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if Bb = 1<br>(PC)←(PC)+2<br>if Bb = 0<br>(b = 0 - 7) | 2         | 2     | -      | -    | - |



## INTEGRATED CIRCUIT



## TECHNICAL DATA

TMP8048P/8048PI

TMP8035P/8035PI

## Subroutine Instruction

| Mnemonics    | Instruction Code |          |          |         |         |         |         |         | Operation                                                                                         | Bytes | Cycles | Flag |    |
|--------------|------------------|----------|----------|---------|---------|---------|---------|---------|---------------------------------------------------------------------------------------------------|-------|--------|------|----|
|              | D7               | D6       | D5       | D4      | D3      | D2      | D1      | D0      |                                                                                                   |       |        | C    | AC |
| CALL Address | a10<br>a7        | a9<br>a6 | a8<br>a5 | 1<br>a4 | 0<br>a3 | 1<br>a2 | 0<br>a1 | 0<br>a0 | ((SP))<-<br>(PC), (PSW4-7)<br>(SP)<-(SP)+1<br>(PC8-10)<-(a8-10)<br>(PC0-7)<-(a0-7)<br>(PC11)<-DBF | 2     | 2      | -    | -  |
| RET          | 1                | 0        | 0        | 0       | 0       | 0       | 1       | 1       | (SP)<-(SP)-1<br>(PC)<-(SP))                                                                       | 1     | 2      | -    | -  |
| RETR         | 1                | 0        | 0        | 1       | 0       | 0       | 1       | 1       | (SP)<-(SP)-1<br>(PC)<-(SP))<br>(PSW4-7)<-(SP))                                                    | 1     | 2      | -    | -  |

## Flag Manipulation Instruction

| Mnemonics | Instruction Code |    |    |    |    |    |    |    | Operation     | Bytes | Cycles | Flag |    |
|-----------|------------------|----|----|----|----|----|----|----|---------------|-------|--------|------|----|
|           | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |               |       |        | C    | AC |
| CLR C     | 1                | 0  | 0  | 1  | 0  | 1  | 1  | 1  | (C)<=0        | 1     | 1      | O    | -  |
| CPL C     | 1                | 0  | 1  | 0  | 0  | 1  | 1  | 1  | (C)<=NOT(C)   | 1     | 1      | O    | -  |
| CLR FO    | 1                | 0  | 0  | 0  | 0  | 1  | 0  | 1  | (FO)<=0       | 1     | 1      | -    | -  |
| CPL FO    | 1                | 0  | 0  | 1  | 0  | 1  | 0  | 1  | (FO)<=NOT(FO) | 1     | 1      | -    | -  |
| CLR F1    | 1                | 0  | 1  | 0  | 0  | 1  | 0  | 1  | (F1)<=0       | 1     | 1      | -    | -  |
| CPL F1    | 1                | 0  | 1  | 1  | 0  | 1  | 0  | 1  | (F1)<=NOT(F1) | 1     | 1      | -    | -  |

## Data Transfer Instruction

| Mnemonics   | Instruction Code |         |         |         |         |         |         |         | Operation              | Bytes | Cycles | Flag |    |
|-------------|------------------|---------|---------|---------|---------|---------|---------|---------|------------------------|-------|--------|------|----|
|             | D7               | D6      | D5      | D4      | D3      | D2      | D1      | D0      |                        |       |        | C    | AC |
| MOV A,Rr    | 1                | 1       | 1       | 1       | 1       | r       | r       | r       | (A)<-(Rr)<br>r = 0 - 7 | 1     | 1      | -    | -  |
| MOV A,@Rr   | 1                | 1       | 1       | 1       | 0       | 0       | 0       | r       | (A)<-(Rr))<br>r = 0, 1 | 1     | 1      | -    | -  |
| MOV A,#Data | 0<br>d7          | 0<br>d6 | 1<br>d5 | 0<br>d4 | 0<br>d3 | 0<br>d2 | 1<br>d1 | 1<br>d0 | (A)<Data               | 2     | 2      | -    | -  |
| MOV Rr,A    | 1                | 0       | 1       | 0       | 1       | r       | r       | r       | (Rr)<-(A)<br>r = 0 - 7 | 1     | 1      | -    | -  |

| Mnemonics     | Instruction Code |    |    |    |    |    |    |    |                                             | Operation | Bytes | Cycles | Flag |    |
|---------------|------------------|----|----|----|----|----|----|----|---------------------------------------------|-----------|-------|--------|------|----|
|               | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 | C                                           |           |       |        | C    | AC |
| MOV @Rr,A     | 1                | 0  | 1  | 0  | 0  | 0  | 0  | r  | ((Rr))<-(A)<br>r = 0, 1                     | 1         | 1     | -      | -    |    |
| MOV Rr,#Data  | 1                | 0  | 1  | 1  | 1  | r  | r  | r  | (Rr)<-Data<br>r = 0-7                       | 2         | 2     | -      | -    |    |
| MOV @Rr,#Data | 1                | 0  | 1  | 1  | 0  | 0  | 0  | r  | ((Rr))<-Data<br>r = 0, 1                    | 2         | 2     | -      | -    |    |
| MOV A,PSW     | 1                | 1  | 0  | 0  | 0  | 1  | 1  | 1  | (A)<-(PSW)                                  | 1         | 1     | -      | -    |    |
| MOV PSW,A     | 1                | 1  | 0  | 1  | 0  | 1  | 1  | 1  | (PSW)<-(A)                                  | 1         | 1     | -      | -    |    |
| XCH A,Rr      | 0                | 0  | 1  | 0  | 1  | r  | r  | r  | (A)≠(Rr)<br>r = 0-7                         | 1         | 1     | -      | -    |    |
| XCH A,@Rr     | 0                | 0  | 1  | 0  | 0  | 0  | 0  | r  | (A)≠((Rr))<br>r = 0, 1                      | 1         | 1     | -      | -    |    |
| XCHD A,@Rr    | 0                | 0  | 1  | 1  | 0  | 0  | 0  | r  | (A0-3)≠((Rr0-3))<br>r = 0, 1                | 1         | 1     | -      | -    |    |
| MOVX A,@Rr    | 1                | 0  | 0  | 0  | 0  | 0  | 0  | r  | (A)<((Rr))<br>r = 0, 1                      | 1         | 2     | -      | -    |    |
| MOVX @Rr,A    | 1                | 0  | 0  | 1  | 0  | 0  | 0  | r  | ((Rr))<-(A)<br>r = 0, 1                     | 1         | 2     | -      | -    |    |
| MOV P A,@A    | 1                | 0  | 1  | 0  | 0  | 0  | 1  | 1  | (PC0-7)<-(A)<br>(A)<-(PC))                  | 1         | 2     | -      | -    |    |
| MOV P3 A,@A   | 1                | 1  | 1  | 0  | 0  | 0  | 1  | 1  | (PC0-7)<-(A)<br>(PC8-11)=0011<br>(A)<-(PC)) | 1         | 2     | -      | -    |    |

## Timer/Counter Instruction

| Mnemonics | Instruction Code |    |    |    |    |    |    |    |                                               | Operation | Bytes | Cycles | Flag |    |
|-----------|------------------|----|----|----|----|----|----|----|-----------------------------------------------|-----------|-------|--------|------|----|
|           | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 | C                                             |           |       |        | C    | AC |
| MOV A,T   | 0                | 1  | 0  | 0  | 0  | 0  | 1  | 0  | (A)<-(T)                                      | 1         | 1     | -      | -    |    |
| MOV T,A   | 0                | 1  | 1  | 0  | 0  | 0  | 1  | 0  | (T)<-(A)                                      | 1         | 1     | -      | -    |    |
| STRT T    | 0                | 1  | 0  | 1  | 0  | 1  | 0  | 1  | Counting is started in the timer mode         | 1         | 1     | -      | -    |    |
| STRT CNT  | 0                | 1  | 0  | 0  | 0  | 1  | 0  | 1  | Counting is started in the event counter mode | 1         | 1     | -      | -    |    |

| Mnemonics | Instruction Code |    |    |    |    |    |    |    | Operation                                      | Bytes | Cycles | Flag |    |
|-----------|------------------|----|----|----|----|----|----|----|------------------------------------------------|-------|--------|------|----|
|           | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                                                |       |        | C    | AC |
| STOP TCNT | 0                | 1  | 1  | 0  | 0  | 1  | 0  | 1  | Stop both time accumulation and event counting | 1     | 1      | -    | -  |
| EN TCNT1  | 0                | 0  | 1  | 0  | 0  | 1  | 0  | 1  | Timer interrupt is enabled                     | 1     | 1      | -    | -  |
| DIS TCNT1 | 0                | 0  | 1  | 1  | 0  | 1  | 0  | 1  | Timer interrupt is disabled                    | 1     | 1      | -    | -  |

## Control Instruction

| Mnemonics | Instruction Code |    |    |    |    |    |    |    | Operation                                            | Bytes | Cycles | Flag |    |
|-----------|------------------|----|----|----|----|----|----|----|------------------------------------------------------|-------|--------|------|----|
|           | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                                                      |       |        | C    | AC |
| EN I      | 0                | 0  | 0  | 0  | 0  | 1  | 0  | 1  | External interrupt is enabled                        | 1     | 1      | -    | -  |
| DIS I     | 0                | 0  | 0  | 1  | 0  | 1  | 0  | 1  | External interrupt is disabled                       | 1     | 1      | -    | -  |
| SEL RBO   | 1                | 1  | 0  | 0  | 0  | 1  | 0  | 1  | (BS)=0                                               | 1     | 1      | -    | -  |
| SEL RB1   | 1                | 1  | 0  | 1  | 0  | 1  | 0  | 1  | (BS)=1                                               | 1     | 1      | -    | -  |
| SEL MBO   | 1                | 1  | 1  | 0  | 0  | 1  | 0  | 1  | (DBF)=0                                              | 1     | 1      | -    | -  |
| SEL MB1   | 1                | 1  | 1  | 1  | 0  | 1  | 0  | 1  | (DBF)=1                                              | 1     | 1      | -    | -  |
| ENTO CLK  | 0                | 1  | 1  | 1  | 0  | 1  | 0  | 1  | T <sub>0</sub> is enabled to act as the clock output | 1     | 1      | -    | -  |
| NOP       | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | No operation                                         | 1     | 1      | -    | -  |



## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP8048P/8048PI

TMP8035P/8035PI

[TMP8048P / 8035P]

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL              | ITEM                                                                    | RATING         |
|---------------------|-------------------------------------------------------------------------|----------------|
| V <sub>DD</sub>     | V <sub>DD</sub> Supply Voltage (with respect to GND (V <sub>SS</sub> )) | -0.5V to +7V   |
| V <sub>CC</sub>     | V <sub>CC</sub> Supply Voltage (with respect to GND (V <sub>SS</sub> )) | -0.5V to +7V   |
| V <sub>INA</sub>    | Input Voltage (Except EA)                                               | -0.5V to +7V   |
| V <sub>INB</sub>    | Input Voltage (Only EA)                                                 | -0.5V to +13V  |
| P <sub>D</sub>      | Power Dissipation (Ta=70°C)                                             | 1.5W           |
| T <sub>SOLDER</sub> | Soldering Temperature (Soldering Time 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    |

DC CHARACTERISTICS      TA=0°C to 70°C, V<sub>CC</sub>=V<sub>DD</sub>=+5V±10%, V<sub>SS</sub>=0V, Unless Otherwise Noted.

| SYMBOL                            | PARAMETER                                                   | TEST CONDITIONS                                        | MIN. | TYP. | MAX.            | UNIT |
|-----------------------------------|-------------------------------------------------------------|--------------------------------------------------------|------|------|-----------------|------|
| V <sub>IL</sub>                   | Input Low Voltage<br>(Except XTAL1, XTAL2, RESET)           |                                                        | -0.5 | -    | 0.8             | V    |
| V <sub>IL1</sub>                  | Input Low Voltage<br>(XTAL1, XTAL2, RESET)                  |                                                        | -0.5 | -    | 0.6             | V    |
| V <sub>IH</sub>                   | Input High Voltage<br>(Except XTAL1, XTAL2, RESET)          |                                                        | 2.0  | -    | V <sub>CC</sub> | V    |
| V <sub>IHL</sub>                  | Input High Voltage<br>(XTAL1, XTAL2, RESET)                 |                                                        | 3.8  | -    | V <sub>CC</sub> | V    |
| V <sub>OL</sub>                   | Output Low Voltage (BUS)                                    | I <sub>OL</sub> =2.0mA                                 | -    | -    | 0.45            | V    |
| V <sub>OL1</sub>                  | Output Low Voltage<br>(RD, WR, PSEN, ALE)                   | I <sub>OL</sub> =1.8mA                                 | -    | -    | 0.45            | V    |
| V <sub>OL2</sub>                  | Output Low Voltage (PROG)                                   | I <sub>OL</sub> =1.0mA                                 | -    | -    | 0.45            | V    |
| V <sub>OL3</sub>                  | Output Low Voltage<br>(For other output pins)               | I <sub>OL</sub> =1.6mA                                 | -    | -    | 0.45            | V    |
| V <sub>OH</sub>                   | Output High Voltage (BUS)                                   | I <sub>OH</sub> =-400μA                                | 2.4  | -    | -               | V    |
| V <sub>OH1</sub>                  | Output High Voltage<br>(RD, WR, PSEN, ALE)                  | I <sub>OH</sub> =-100μA                                | 2.4  | -    | -               | V    |
| V <sub>OH2</sub>                  | Output High Voltage<br>(For other output pins)              | I <sub>OH</sub> =-40μA                                 | 2.4  | -    | -               | V    |
| I <sub>LI</sub>                   | Input Leak Current (T1, INT)                                | V <sub>SS</sub> ≤V <sub>IN</sub> ≤V <sub>CC</sub>      | -    | -    | ±10             | μA   |
| I <sub>LII</sub>                  | Input Leak Current<br>(P10-17, P20-P27, EA, SS)             | V <sub>SS</sub> +0.45≤V <sub>IN</sub> ≤V <sub>CC</sub> | -    | -    | -500            | μA   |
| I <sub>LO</sub>                   | Output Leak Current (BUS, T0)<br>(High impedance condition) | V <sub>SS</sub> +0.45≤V <sub>IN</sub> ≤V <sub>CC</sub> | -    | -    | ±10             | μA   |
| I <sub>DD</sub>                   | V <sub>DD</sub> Supply Current                              |                                                        | -    | -    | 15              | mA   |
| I <sub>DD</sub> +I <sub>ICC</sub> | Total Supply Current                                        |                                                        | -    | -    | 135             | mA   |

Toshiba

## INTEGRATED CIRCUIT



## TECHNICAL DATA

TMP8048P/8048PI

TMP8035P/8035PI

AC CHARACTERISTICS      TA=0°C to 70°C, V<sub>CC</sub>=V<sub>DD</sub>=+5V±10%, V<sub>SS</sub>=0V, Unless otherwise Noted.

| SYMBOL           | PARAMETER                              | TEST CONDITION       | MIN. | TYP. | MAX. | UNIT |
|------------------|----------------------------------------|----------------------|------|------|------|------|
| t <sub>LL</sub>  | ALE Pulse Width                        |                      | 400  | -    | -    | ns   |
| t <sub>AL</sub>  | Address Setup Time (ALE)               |                      | 120  | -    | -    | ns   |
| t <sub>LA</sub>  | Address Hold Time (ALE)                |                      | 80   | -    | -    | ns   |
| t <sub>CC</sub>  | Control Pulse Width (PSEN, RD, WR)     |                      | 700  | -    | -    | ns   |
| t <sub>DW</sub>  | Data Setup Time (WR)                   |                      | 500  | -    | -    | ns   |
| t <sub>WD</sub>  | Data Hold Time (WR)                    |                      | 120  | -    | -    | ns   |
| t <sub>CY</sub>  | Cycle Time                             |                      | 2.5  | -    | 15.0 | μs   |
| t <sub>DR</sub>  | Data Hold Time (PSEN, RD)              | C <sub>L</sub> =20pF | 0    | -    | 200  | ns   |
| t <sub>RD</sub>  | Data Input Read Time (PSEN, RD)        |                      | -    | -    | 500  | ns   |
| t <sub>AW</sub>  | Address Setup Time (WR)                |                      | 230  | -    | -    | ns   |
| t <sub>AD</sub>  | Address Setup Time (Data Input)        |                      | -    | -    | 950  | ns   |
| t <sub>AFC</sub> | Address Float Time (RD, PSEN)          |                      | 0    | -    | -    | ns   |
| t <sub>CA</sub>  | Internal between Control Pulse and ALE |                      | 10   | -    | -    | ns   |
| t <sub>CP</sub>  | Port Control Setup Time (PROG)         |                      | 110  | -    | -    | ns   |
| t <sub>PC</sub>  | Port Control Hold Time (PROG)          |                      | 100  | -    | -    | ns   |
| t <sub>PR</sub>  | Port 2 Input Data Set Time (PROG)      |                      | -    | -    | 810  | ns   |
| t <sub>DP</sub>  | Output Data Setup Time (PROG)          |                      | 250  | -    | -    | ns   |
| t <sub>PD</sub>  | Output Data Hold Time (PROG)           |                      | 65   | -    | -    | ns   |
| t <sub>PF</sub>  | Port 2 Input Data Hold Time (PROG)     |                      | 0    | -    | 150  | ns   |
| t <sub>PP</sub>  | PROG Pulse Width                       |                      | 1200 | -    | -    | ns   |
| t <sub>PL</sub>  | Port 2 I/O Data Setup Time             |                      | 350  | -    | -    | ns   |
| t <sub>LP</sub>  | Port 2 I/O Data Hold Time              |                      | 150  | -    | -    | ns   |

Note : t<sub>CY</sub>=2.5μs, Control Output: C<sub>L</sub>=80 pF, BUS Output: C<sub>L</sub>=150pF, PORT20 - 23: C<sub>L</sub>=80pF.



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8048P/8048PI

TMP8035P/8035PI

TMP8048PI/8035PI : INDUSTRIAL SPECIFICATION

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL       | ITEM                                                       | RATING         |
|--------------|------------------------------------------------------------|----------------|
| $V_{DD}$     | $V_{DD}$ Supply Voltage (with respect to GND ( $V_{SS}$ )) | -0.5V to +7V   |
| $V_{CC}$     | $V_{CC}$ Supply Voltage (with respect to GND ( $V_{SS}$ )) | -0.5V to +7V   |
| $V_{INA}$    | Input Voltage (Except EA)                                  | -0.5V to +7V   |
| $V_{INB}$    | Input Voltage (Only EA)                                    | -0.5V to +13V  |
| $P_D$        | Power Dissipation ( $T_a=70^\circ\text{C}$ )               | 1.5W           |
| $T_{SOLDER}$ | Soldering Temperature (Soldering Time 10 sec.)             | 260°C          |
| $T_{STG}$    | Storage Temperature                                        | -55°C to 150°C |
| $T_{OPR}$    | Operating Temperature                                      | -40°C to 85°C  |

DC CHARACTERISTICS  $[T_a=-40^\circ\text{C} \text{ to } 85^\circ\text{C}, V_{CC}=V_{DD}=+5V \pm 10\%, V_{SS}=0V]$ , Unless otherwise Note

| SYMBOL          | PARAMETER                                                                                                           | TEST CONDITIONS                         | MIN. | TYP. | MAX.     | UNIT          |
|-----------------|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------|------|------|----------|---------------|
| $V_{IL}$        | Input Low Voltage (Except XTALL, XTAL2, $\overline{\text{RESET}}$ )                                                 |                                         | -0.5 | -    | 0.7      | V             |
| $V_{IL1}$       | Input Low Voltage (XTALL, XTAL2, $\overline{\text{RESET}}$ )                                                        |                                         | -0.5 | -    | 0.6      | V             |
| $V_{IH}$        | Input High Voltage (Except XTALL, XTAL2, $\overline{\text{RESET}}$ )                                                |                                         | 2.2  | -    | $V_{CC}$ | V             |
| $V_{IH1}$       | Input High Voltage (XTALL, XTAL2, RESET)                                                                            |                                         | 3.8  | -    | $V_{CC}$ | V             |
| $V_{OL}$        | Output Low Voltage (BUS)                                                                                            | $I_{OL}=1.6\text{mA}$                   | -    | -    | 0.45     | V             |
| $V_{OL1}$       | Output Low Voltage ( $\overline{\text{RD}}, \overline{\text{WR}}, \overline{\text{PSEN}}, \overline{\text{ALE}}$ )  | $I_{OL}=1.6\text{mA}$                   | -    | -    | 0.45     | V             |
| $V_{OL2}$       | Output Low Voltage (PROG)                                                                                           | $I_{OL}=0.8\text{mA}$                   | -    | -    | 0.45     | V             |
| $V_{OL3}$       | Output Low Voltage (For other output pins)                                                                          | $I_{OL}=1.2\text{mA}$                   | -    | -    | 0.45     | V             |
| $V_{OH}$        | Output High Voltage (BUS)                                                                                           | $I_{OH}=-280\mu\text{A}$                | 2.4  | -    | -        | V             |
| $V_{OH1}$       | Output High Voltage ( $\overline{\text{RD}}, \overline{\text{WR}}, \overline{\text{PSEN}}, \overline{\text{ALE}}$ ) | $I_{OH}=-80\mu\text{A}$                 | 2.4  | -    | -        | V             |
| $V_{OH2}$       | Output High Voltage (For other output pins)                                                                         | $I_{OH}=-30\mu\text{A}$                 | 2.4  | -    | -        | V             |
| $I_{LI}$        | Input Leak Current ( $T_1, \overline{\text{INT}}$ )                                                                 | $V_{SS} \leq V_{IN} \leq V_{CC}$        | -    | -    | $\pm 10$ | $\mu\text{A}$ |
| $I_{LI1}$       | Input Leak Current ( $P10-17, P20-27, EA, \overline{\text{SS}}$ )                                                   | $V_{SS} + 0.45 \leq V_{IN} \leq V_{CC}$ | -    | -    | -600     | $\mu\text{A}$ |
| $I_{LO}$        | Output Leak Current (BUS, $T_O$ ) (High impedance condition)                                                        | $V_{SS} + 0.45 \leq V_{IN} \leq V_{CC}$ | -    | -    | $\pm 10$ | $\mu\text{A}$ |
| $I_{DD}$        | $V_{DD}$ Supply Current                                                                                             |                                         | -    | -    | 20       | mA            |
| $I_{DD+I_{CC}}$ | Total Supply Current                                                                                                |                                         | -    | -    | 145      | mA            |

## AC CHARACTERISTICS

$T_A = -40^\circ\text{C}$  to  $85^\circ\text{C}$ ,  $V_{CC} = V_{DD} = +5V \pm 10\%$ ,  $V_{SS} = 0V$ , Unless otherwise Noted.

| SYMBOL    | PARAMETER                                                                                         | TEST CONDITIONS     | MIN. | TYP. | MAX. | UNIT          |
|-----------|---------------------------------------------------------------------------------------------------|---------------------|------|------|------|---------------|
| $t_{LL}$  | ALE Pulse Width                                                                                   |                     | 200  | -    | -    | ns            |
| $t_{AL}$  | Address Setup Time (ALE)                                                                          |                     | 120  | -    | -    | ns            |
| $t_{LA}$  | Address Hold Time (ALE)                                                                           |                     | 80   | -    | -    | ns            |
| $t_{CC}$  | Control Pulse Width( $\overline{\text{PSEN}}$ , $\overline{\text{RD}}$ , $\overline{\text{WR}}$ ) |                     | 400  | -    | -    | ns            |
| $t_{DW}$  | Data Setup Time ( $\overline{\text{WR}}$ )                                                        |                     | 420  | -    | -    | ns            |
| $t_{WD}$  | Data Hold Time ( $\overline{\text{WR}}$ )                                                         | $C_L = 20\text{pF}$ | 80   | -    | -    | ns            |
| $t_{CY}$  | Cycle Time                                                                                        |                     | 2.5  | -    | 15.0 | $\mu\text{s}$ |
| $t_{DR}$  | Data Hold Time ( $\overline{\text{PSEN}}$ , $\overline{\text{RD}}$ )                              |                     | 0    | -    | 200  | ns            |
| $t_{RD}$  | Data Input Read Time ( $\overline{\text{PSEN}}$ , $\overline{\text{RD}}$ )                        |                     | -    | -    | 400  | ns            |
| $t_{AW}$  | Address Setup Time ( $\overline{\text{WR}}$ )                                                     |                     | 230  | -    | -    | ns            |
| $t_{AD}$  | Address Setup Time (Data Input)                                                                   |                     | -    | -    | 600  | ns            |
| $t_{AFC}$ | Address Float Time ( $\overline{\text{RD}}$ , $\overline{\text{PSEN}}$ )                          |                     | -40  | -    | -    | ns            |
| $t_{CA}$  | Internal between Control Pulse and ALE                                                            |                     | 10   | -    | -    | ns            |
| $t_{CP}$  | Port Control Setup Time(PROG)                                                                     |                     | 115  | -    | -    | ns            |
| $t_{PC}$  | Port Control Hold Time (PROG)                                                                     |                     | 65   | -    | -    | ns            |
| $t_{PR}$  | Port 2 Input Data Set Time(PROG)                                                                  |                     | -    | -    | 860  | ns            |
| $t_{DP}$  | Output Data Setup Time(PROG)                                                                      |                     | 230  | -    | -    | ns            |
| $t_{PD}$  | Output Data Hold Time (PROG)                                                                      |                     | 25   | -    | -    | ns            |
| $t_{PF}$  | Port 2 Input Data Hold Time(PROG)                                                                 |                     | 0    | -    | 160  | ns            |
| $t_{PP}$  | PROG Pulse Width                                                                                  |                     | 920  | -    | -    | ns            |
| $t_{PL}$  | Port 2 I/O Data Setup Time                                                                        |                     | 300  | -    | -    | ns            |
| $t_{LP}$  | Port 2 I/O Data Hold Time                                                                         |                     | 120  | -    | -    | ns            |

Note :  $t_{CY} = 2.5\mu\text{s}$ , Control Output:  $C_L = 80\text{pF}$ , BUS Output:  $C_L = 150\text{pF}$ , PORT 20 - 23:  $C_L = 80\text{pF}$ .

## TIMING WAVEFORM

## A. Instruction Fetch from External Program Memory



## B. Read from External Data Memory



## C. Write into External Data Memory



## D. Timing of Port 2 during Expander Instruction Execution



## TYPICAL CHARACTERISTICS

1) BUS:  $I_{OH} - V_{OH}$ 3) BUS, P1, P2:  $I_{OL} - V_{OL}$ 2) P1, P2:  $I_{OH} - V_{OH}$ 

## PROGRAM TAPE FORMAT

TMP8048P/8048PI

TMP8035P/8035PI

TMP8084 programs are delivered in the form of paper tape with the following format and it is required to attach the tape list. The format of paper tape is same as the Intel type object tape (hexadecimal tape output by Intel MDS system, PROMPT 48 Development Tool, etc.)

## (1) Tape Format



## (2) Example of Tape List

```

TOSHIBA MICRO COMPUTER TLCS-84
:100000000665C7D79CF50F3F951FED55A8FF16E570
:1000100088884DDE67D31F5D8ABA6DF292F113F5C1
:100020004FF1FB5DFFDA96A99CF7DF94A346B7C09
:10003000197352F729F12F79AA9C057C5B851EED77

```

.....

```

:1003C0005DFDB5E556A67277F61A51C631CF9FOE80
:1003D000BD2F6F20E8BB1977E3FB5AD1F41FDAA7E2
:1003E000B53D42E0EC32546025B7308CDD52063D1D
:1003F000B4BE9E9E345B6138060B20VC372BF60BD6
:00000001FF

```



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8048P/8048PI

TMP8035P/8035PI

## OUTLINE DRAWING



- Note :
1. This dimension shows the center of curvature of leads.
  2. This dimension shows spread of leads.
  3. The pitch of leads is 2.54 and the tolerance is  $\pm 0.25$  from the theoretical center of each lead obtained having No.1 lead and No. 40 lead as the reference.

Note : Toshiba does not assume any responsibility for use of any circuitry described; no circuit patent licenses are implied, and Toshiba reserves the right, at any time without notice, to change said circuitry.

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

## 8-BIT SINGLE-CHIP MICROCOMPUTER

## GENERAL DESCRIPTION

The TMP8049P, from here on referred to as the TMP8049, is a single chip microcomputer fabricated in N-channel Silicon Gate MOS technology which provides internal 8-bit parallel architecture.

The following basic architectural functions of a computer have been included in a single chip; an 8-bit CPU,  $128 \times 8$  RAM data memory,  $2K \times 8$  ROM program memory, 27 I/O lines and an 8-bit timer/event counter.

The TMP8049 is particularly efficient as a controller. It has extensive bit handling capability as well as facilities for both binary and BCD arithmetic.

The TMP8039P is the equivalent of a TMP8049 without ROM program memory on chip. By using this device with external EPROM or RAM, software debugging becomes easy.

The TMP8049P-6/TMP8039P-6 is a lower speed (6MHz) version of the TMP8049P/TMP8039P.

## FEATURES

- Compatible with Intel's 8049
- 1.36 $\mu$ S Instruction Cycle
- All instruction 1 or 2 cycles
- Over 90 instructions; 70% single byte
- Easy expandable memory and I/O
- 2K  $\times$  8 masked ROM
- 128  $\times$  8 RAM
- 27 I/O lines
- Interval Timer/Event Counter
- Single level interrupt
- Single 5V supply
- -40°C to +85°C Operation (TMP8049PI-6/  
TMP8039PI-6 : Industrial Specification)

## PIN CONNECTIONS (Top View)



## BLOCK DIAGRAM





## PIN NAMES AND PIN DESCRIPTION

V<sub>SS</sub> (Power Supply)

Circuit GND potential

V<sub>DD</sub> (Power Supply)

+5V during operation Low power standby pin for TMP8049 RAM

V<sub>CC</sub> (Main Power Supply)

+5V during operation

PROG (Output)

Output strobe for the TMP8243P I/O expander

P<sub>10</sub>-P<sub>17</sub> (Input/Output) Port 1

8-bit quasi-bidirectional port (Internal Pullup  $\geq 50\text{K}\Omega$  ).

P<sub>20</sub>-P<sub>27</sub> (Input/Output) Port 2

8-bit quasi-bidirectional port (Internal Pullup  $\geq 50\text{K}\Omega$  ).

P<sub>20</sub>-P<sub>23</sub> Contain the four high order program counter bits during an external program memory fetch and serve as a 4-bit I/O expander bus for the TMP8243P.

DB<sub>0</sub>-DB<sub>7</sub> (Input/Output, 3 State)

True bidirectional port which can be written or read synchronously using the RD, WR strobes. The port can also be statically latched. Contains the 8 low order program counter bits during an external program memory fetch, and receives the addressed instruction under the control of PSEN. Also contains the address and data during an external RAM data store instruction, under control of ALE, RD, and WR.

T<sub>0</sub> (Input/Output)

Input pin testable using the conditional transfer instructions JTO and JNT0. T<sub>0</sub> can be designated as a clock output using ENTO CLK instruction.

T<sub>1</sub> (Input)

Input pin testable using the JT1 and JNT1 instruction. Can be designated as the event counter input using the timer/STRT CNT instruction.

INT (Input)

External interrupt input. Initiates an interrupt if interrupt is enabled. Interrupt is disabled after a reset. Also testable with conditional jump instruction. (Active Low)

RD (Output)

Output strobe activated during a Bus read. Can be used to enable data onto the Bus from an external device. Used as a Read Strobe to External Data Memory (Active Low).

WR (Output)

Output strobe during a Bus write (Active Low) Used as a Write Strobe to External Data Memory.

RESET (Input)

Active Low signal which is used to initialize the Processor. Also used during Power down.

ALE (Output)

Address Latch Enable. This signal occurs once during each cycle and is useful as a clock output. The negative edge of ALE strobes address into external data and program memory.

PSEN (Output)

Program Store Enable. This output occurs only during a fetch to external program memory (Active Low).

SS (Input)

Single step input can be used in conjunction with ALE to "single step" processor through each instruction when SS is low the CPU is placed into a wait state after it has completed the instruction being executed.

EA (Input)

External Access input which forces all program memory fetches to reference external memory. Useful for emulation and debug and essential for testing and program verification. (Active High).

XTAL 1 (Input)

One side of crystal input for internal oscillator. Also input for external source.

XTAL 2 (Input)

Other side of crystal input.

## FUNCTIONAL DESCRIPTION

## 1. System Configuration

The following system functions of the TMP8049 are described in detail.

- |                               |                               |
|-------------------------------|-------------------------------|
| (1) Program Memory            | (6) Stack (Stack Pointer)     |
| (2) Data Memory               | (7) Flag 0, Flag 1            |
| (3) I/O Port                  | (8) Program Status Word (PSW) |
| (4) Timer/Counter             | (9) Reset                     |
| (5) Interrupt Control Circuit | (10) Oscillator Circuit       |

## (1) Program Memory

- The maximum memory that can be directly addressed by the TMP8049 is 4096 bytes. The first 2048 bytes from location 0 through 2047 can be internal resident mask ROM. The rest of the 2048 bytes of addressable memory are external to the chip. The TMP8039 has no internal resident memory; all memory must be external.

- There are three locations in Program Memory of special importance.



- Location 0

Activating the Reset line of the processor causes the first instruction to be fetched from Location 0.

- Location 3

Activating the interrupt line of the processor (if interrupt enabled) causes a jump to subroutine defined by address held in Location 3.

- Location 7

A timer/counter interrupt resulting from a timer/counter overflow (if enabled) causes a jump to a subroutine defined by address held in Location 7.

- Program addresses 0-2047 and 2048-4095 are called memory banks 0 and 1 respectively. Switching of memory banks is achieved by changing the most significant bit of the program counter (PC) during execution of an unconditional jump instruction or call instruction executed after using SEL MBO or SEL MB1.

Reset operation automatically selects Bank 0.

## (2) Data Memory

- Resident Data Memory (volatile RAM) is organized as 128 words by 8-bits wide.
- The first 8 locations (0 - 7) of the memory array are designated as working registers and are directly addressable by several instructions. By executing a Register Bank switch instruction (SEL RB1) locations 24 - 31 are designated as the working registers in place of 0 - 7.



Internal Data Memory Area

- RAM locations 8 – 23 serve a dual role in that they contain the program counter stack which is a stack 2 bytes wide by 8 levels deep. These locations store returning addresses from subroutines. If the level of subroutine nesting is less than the permitted 8, you free up 2 bytes of RAM for general use for every level of nesting not utilized.
- ALL 128 locations are indirectly addressable through either of two RAM Pointer Registers which reside at R0 and R1 of the Register array.
- The TMP8049 architecture allows extension of the Data Memory to 256 words.

### (3) Input/Output Ports

- The TMP8049 has 27 I/O lines which can be used for either input or output. These I/O lines are grouped into 3 ports each having 8 bidirectional lines and 3 "test" inputs which can alter program sequences when tested by conditional jump instructions.
- Ports 1 and 2 are each 8-bits wide and have identical characteristics. Data written to these ports is statically latched and remains unchanged until rewritten. As input ports these lines are non-latching, i.e., inputs must be present until read by an input instruction.
- All lines of Ports 1 and 2 are called quasi-bidirectional because of a special output circuit structure (illustrated in Figure 1). Each line is continuously pulled to a +5V level through a high impedance resistive device ( $50K\Omega$ ) which is sufficient to provide the source current for a TTL high level yet can be pulled low by a standard TTL gate thus allowing the same pin to be used for both input and output. In order to speed up the "0" to "1" transition a low impedance device ( $5K\Omega$ ) is switched in momentarily whenever a "1" is written to line. When a "0" is written to line a low impedance device overcomes the pullup and provides TTL current sinking capability.



Fig.1 Input/Output Circuit of Port 1, Port 2

- Reset initializes all lines to a high impedance "1" state.
- When external data memory area is not addressed during execution of an internal program, Port 0 (DB0 - DB7) becomes a true bidirectional port (bus) with associated input and output strobes. If bidirectional feature not needed Bus can serve as either a statically latched output port or a non-latched input port. However, I/O lines of this port cannot be intermixed.
- As a static port data is written and latched using the OUTL instruction and inputted using the INS instruction these two commands generate pulses on the corresponding RD and WR strobe lines.
- As a bidirectional port the MOVX instructions are used to read and write the port which generate the WR RD strobes.
- When not being written or read, the Bus lines are in a high impedance state.

#### (4) Timer/Event Counter

- The 8-bit binary up counter can use either of the following frequency inputs

(1) Internal clock (1/480 of OSC frequency)

..... Timer mode

## (2) External input clock from T1 terminal

 (minimum cycle time  $3 \times \text{ALE cycle}$ )

..... Event Counter mode

The counter is presettable and readable with two MOV instructions which transfer the content of the accumulator to the counter and vice versa. The counter content is not affected by a Reset and is initialized solely by the MOVT, A instruction. The counter is stopped by a Reset or STOP TCNT instruction and remains stopped until started by START T instruction or as an event counter by a START CNT. Once started the counter will increment to its maximum count (FF) and overflow to Zero continuing its count until stopped by a STOP TCNT instruction or RESET.

The increment from maximum count to Zero (overflow) results in the setting of an overflow flag and the generation of an interrupt request. When interrupt acknowledged a subroutine call to Location 7 will be initiated. Location 7 should store the starting address of the timer or counter service routine. The state of the overflow flag is testable with the conditional JUMP (JTF). The flag is reset by executing a JTF or by RESET. Figure 2 illustrates the concept of the timer circuit.



Fig.2 Concept of Timer Circuit



Fig.3 Concept of Interrupt Control Circuit

#### (5) Interrupt Control Circuit

- There are two distinct types of Interrupts in the TMP8049.
  - External Interrupt from the  $\overline{\text{INT}}$  terminal
  - Timer Interrupt caused by timer overflow

- The interrupt system is single level in that once an interrupt is detected all further interrupt requests are ignored until execution of an RETR (which should occur at the end of an interrupt service routine) reenables the interrupt input logic.
- An interrupt sequence is initiated by applying a low level "0" to the INT pin. INT is level triggered and active low which allows "Wire Oring" of several interrupt sources. The interrupt level is sampled every machine cycle during ALE and when detected causes a "jump to subroutine" at Location 3. As in any call to subroutine, the Program Counter and Program Status Word are saved in the stack.
- When an overflow occurs in the internal timer/event counter an interrupt request is generated which is reservised as outlined in previous paragraph except that a jump to Location 7 is used instead of 3. If INT and times overflow occur simultaneously then external request INT takes precedence.
- If an extra external interrupt is needed in addition to INT this can be achieved by enabling the counter interrupt, loading FFH in the counter (one less than the terminal count), and enabling the event counter mode. A "1" to "0" transition on T1 will cause an interrupt vector to Location 7.
- The interrupt service routine pointed to be addresses in Location 3 or 7 must reside in memory between 0 and 2047, i.e., Bank 0.

Figure 3 illustrates the concept of the interrupt control circuit.

#### (6) Stack (stack Pointer)

- An interrupt or Call to a subroutine causes the contents of the program counter to be stored in one of the 8 register pairs of the Program Counter Stack. The pair to be used is determined by a 3-bit stack pointer which is part of the Program Status Word (PSW explained in section (8)). Data RAM locations, 8 through 23 are available as stack registers and are used to store the program counter and 4-bits of PSW as shown in the figure.
- The stack pointer when initialized points to RAM locations 8 and 9. The first subroutine jump or interrupt results in the program counter contents being transferred to Locations 8 and 9. Then the stack pointer is incremented by one to point to Locations 10 and 11. Eight levels of subroutine are obviously possible.
- At the end of a subroutine signalled by a RET or RETR causes the stack pointer to be decremented by one and the contents of the resulting pair to be transferred to the Program Counter.



(7) Flag 0, Flag 1, (F0, F1)

- The TMP8049 has two flags F0 and F1 which are used for conditional jump. These flags can be set, reset and tested with the conditional jump instruction JFO.
- F0 is a part of the program status word (PSW) and is saved in the stack area when a subroutine is called.

(8) Program Status Word (PSW)

- An 8-bit status word which can be loaded to and from the accumulator exists called the Program Status Word (PSW). The PSW is read by a MOV A, PSW and written to by a MOV PSW, A. The information available in the PSW is shown in the diagram below.



- Bits 0 - 2 : Stack Pointer Bits(S<sub>0</sub>, S<sub>1</sub>, S<sub>2</sub>)
- Bit 3 : Not used ("1" level when read.)
- Bit 4 : Working Register Bank Switch Bit (BS)
  - 0 = Bank 0
  - 1 = Bank 1
- Bit 5 : Flag 0 (FO)
- Bit 6 : Auxiliary Carry (AC) carry bit generated by an ADD instruction and used by the decimal adjust instruction DA, A (AC)
- Bit 7 : Carry (C) flag which indicates that the previous operation has resulted in the accumulator. (C)

#### (9) Reset

- The reset input provides a means for initialization of the processor. This Schmitt trigger input has an internal pullup resistor which in combination with an external 1 $\mu$ F capacitor provides an internal reset pulse sufficient length to guarantee that all internal logic is initialized.



- If the pulse is generated externally the reset pin must be held at ground ( $\leq 0.5V$ ) for at least 50mS after the power supply is within tolerance.
- Reset performs the following functions within the chip:
  - (i) Sets PC to Zero.
  - (ii) Sets Stack Pointer to Zero.
  - (iii) Selects Register Bank 0.
  - (iv) Selects Memory Bank 0.
  - (v) Sets BUS (DB0 - DB7) to high impedance state. (Except when EA = 5V)
  - (vi) Sets Ports 1 and 2 to input mode.
  - (vii) Disables interrupts (timer and external).
  - (viii) Stops Timer.
  - (ix) Clears Timer Flag.
  - (x) Clears F0 and Fl.
  - (xi) Disables clock output T0.

#### (10) Oscillator Circuit

- TMP8049 can be operated by the external clock input in addition to crystal oscillator as shown below.



#### 2. Basic Operation and Timing

The following basic operations and timing are explained

- (1) Instruction Cycle
- (2) External Memory Access Timing
- (3) Interface with I/O Expander TMP8243P
- (4) Internal Program Verify (Read) Timing
- (5) Single Step Operation Timing
- (6) Low Power Stand-by Mode

### (1) Instruction Cycle

- The instructions of TMP8049 are executed in one or two machine cycles, and one machine cycle consists of five states.
- Fig.4 illustrates its relationship with the clock input to CPU.
- $\phi_2$  clock shown in Fig.4 is derived to outside by ENTO CLK instruction.
- ALE can be also used as the clock to indicate the machine cycle as well as giving the external address latch timing.

### (2) External Memory Access Timing

#### (i) Program Memory Access

- TMP8049 programs are executed in the following three modes.

- (1) Execution of internal program only.
- (2) Execution of both external and internal programs.
- (3) Execution of external program only.

The external program memory is accessed (instructions are fetched) automatically when the internal ROM address is exceeded in mode (2) and from initial start address 0 in mode (3).

- In the external program memory access operation, the following will occur
  - The contents of the 12-bit program counter will be output on BUS(DB0 - DB7) and the lower 4-bits of Port 2.
  - Address Latch Enable (ALE) will indicate the time at which address is valid. The trailing edge of ALE is used to latch the address externally.
  - Program Store Enable (PSEN) indicates that an external instruction fetch is in progress and serves to enable the external memory device.
  - BUS (DB0 - DB7) reverts to Input mode and the processor accepts its 8-bit contents as an Instruction Word.
- Figure 5 illustrates the timing.

#### (ii) Access of External Data Memory

- In the extended data memory access operation during READ/WRITE cycle the following occurs
  - The contents of R0 R1 is output onto BUS (DB0 - DB7).
  - ALE indicates address is valid. The trailing edge of ALE is used to latch the address externally.
  - A read  $\overline{RD}$  or write  $\overline{WR}$  pulse on the corresponding output pins indicates the type of data memory access in progress. Output data valid at trailing edge of  $\overline{WR}$  and input data must be valid at trailing edge of  $\overline{RD}$ .
  - Data (8-bits) is transferred over BUS.



# INTEGRATEDCIRCUIT

## TECHNICAL DATA

TMP8049P/8049P-6/8049PI-6

TMP8039P/8039P-6/8039PI-6



Fig.4 Instruction Cycle Timing



Fig.5 Timing of External Program Memory Access



Suggest we have two diagrams



Fig.6 Timing of Accessing External Data Memory

- Figure 6 illustrates the timing of accessing the external data memory during execution of external program.

### (3) Interface with I/O Expander (TMP8243P)

- The TMP8049 I/O can be easily expanded using the TMP8243 I/O Expander. This device uses only the lower half 4-bits of Port 2 for communication with the TMP8049. The TMP8243 contains four 4-bit I/O ports which serve as extensions of one chip I/O and are addressed as Ports (4-7). All communication takes place over the lower half of Port 2 (P20 - P23) with timing provided by an output pulse on the PROG pin. Each transfer consists of two 4-bit nibbles the first containing the "OP Code" and port address and the second containing the actual 4-bits of data.



Fig.7 Timing of Rading Internal Program Memory



Fig.8(a) Single Step Circuit

## (4) Reading of Internal Program Memory

- The processor is placed in the READ mode by applying +12V to the EA pin and OV to the RESET pin. The address of the location to be read is then applied to BUS and the low order 2-bits of Port 2. The address is latched by a 0 to 1 transition on RESET and the high level causes the contents of program memory location addressed to appear on the eight lines of BUS.
- Figure 7 illustrates the timing diagram for this operation.

## (5) Single Step Operation.

- A single step feature useful for debug can be implemented by utilizing a circuit shown in Figure 8 (a) combined with the SS pin and ALE pin.
- A D-type flip flop with set and reset is used to generate  $\overline{SS}$ . In the run mode SS is held high by keeping the flip flop set. To enter single step, set is removed allowing ALE to bring  $\overline{SS}$  low via reset input. The next instruction is started by clocking a "1" into the FF which will not appear on SS unless ALE is high removing reset. In response to SS going high the processor begins an instruction fetch which brings ALE low resetting FF and causing the processor to again enter the stopped state.
- The timing diagram in this case is as shown in Figure 8 (b). (EA = 5V).

## (6) Lower Power Stand-by Mode.

- The TMP8049 has been organized to allow power to be removed from all but the volatile,  $128 \times 8$  data RAM array. In power down mode the contents of data RAM can be maintained while drawing typically 10 - 15% of normal operating power requirements.
- VCC serves as the 5V supply for the bulk of the TMP8049 while the VDD supplies only the RAM array. In standby mode VCC is reduced to OV but VDD is kept at 5V. Applying a low level to reset inhibits any access to the RAM by the processor and guarantees that RAM cannot be inadvertently altered as power is removed from VCC.



Fig. 8(b) Single Step Operation Timing



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8049P/8049P-6/8049PI-6

TMP8039P/8039P-6/8039PI-6

## INSTRUCTION

## ACCUMULATOR INSTRUCTION

| Mnemonic     | Instruction Code |         |         |         |         |         |         |         | Operation                            | Bytes | Cycles | Flag |    |
|--------------|------------------|---------|---------|---------|---------|---------|---------|---------|--------------------------------------|-------|--------|------|----|
|              | D7               | D6      | D5      | D4      | D3      | D2      | D1      | D0      |                                      |       |        | C    | AC |
| ADD A,Rr     | 0                | 1       | 1       | 0       | 1       | r       | r       | r       | (A) ← (A) + (Rr)<br>r = 0 - 7        | 1     | 1      | ○    | ○  |
| ADD A,@Rr    | 0                | 1       | 1       | 0       | 0       | 0       | 0       | r       | (A) ← (A) + (Rr)<br>r = 0, 1         | 1     | 1      | ○    | ○  |
| ADD A,#Data  | 0<br>d7          | 0<br>d6 | 0<br>d5 | 0<br>d4 | 0<br>d3 | 0<br>d2 | 1<br>d1 | 1<br>d0 | (A) ← (A) + Data                     | 2     | 2      | ○    | ○  |
| ADDC A,Rr    | 0                | 1       | 1       | 1       | 1       | r       | r       | r       | (A) ← (A) + (Rr) + (C)<br>r = 0 - 7  | 1     | 1      | ○    | ○  |
| ADDC A,@Rr   | 0                | 1       | 1       | 1       | 0       | 0       | 0       | r       | (A) ← (A) + ((Rr)) + (C)<br>r = 0, 1 | 1     | 1      | ○    | ○  |
| ADDC A,#Data | 0<br>d7          | 0<br>d6 | 0<br>d5 | 1<br>d4 | 0<br>d3 | 0<br>d2 | 1<br>d1 | 1<br>d0 | (A) ← (A) + Data + (C)               | 2     | 2      | ○    | ○  |
| ANL A,Rr     | 0                | 1       | 0       | 1       | 1       | r       | r       | r       | (A) ← (A) ∧ (Rr)<br>r = 0 - 7        | 1     | 1      | -    | -  |
| ANL A,@Rr    | 0                | 1       | 0       | 1       | 0       | 0       | 0       | r       | (A) ← (A) ∧ ((Rr))<br>r = 0, 1       | 1     | 1      | -    | -  |
| ANL A,#Data  | 0<br>d7          | 1<br>d6 | 0<br>d5 | 1<br>d4 | 0<br>d3 | 0<br>d2 | 1<br>d1 | 1<br>d0 | (A) ← (A) ∧ Data                     | 2     | 2      | -    | -  |
| ORL A,Rr     | 0                | 1       | 0       | 0       | 1       | r       | r       | r       | (A) ← (A) ∨ (Rr)<br>r = 0 - 7        | 1     | 1      | -    | -  |
| ORL A,@Rr    | 0                | 1       | 0       | 0       | 0       | 0       | 0       | r       | (A) ← (A) ∨ ((Rr))<br>r = 0, 1       | 1     | 1      | -    | -  |
| ORL A,#Data  | 0<br>d7          | 1<br>d6 | 0<br>d5 | 0<br>d4 | 0<br>d3 | 0<br>d2 | 1<br>d1 | 1<br>d0 | (A) ← (A) ∨ Data                     | 2     | 2      | -    | -  |
| XRL A,Rr     | 1                | 1       | 0       | 1       | 1       | r       | r       | r       | (A) ← (A) ≈ (Rr)<br>r = 0 - 7        | 1     | 1      | -    | -  |
| XRL A,@Rr    | 1                | 1       | 0       | 1       | 0       | 0       | 0       | r       | (A) ← (A) ≈ ((Rr))<br>r = 0, 1       | 1     | 1      | -    | -  |
| XRL A,#Data  | 1<br>d7          | 1<br>d6 | 0<br>d5 | 1<br>d4 | 0<br>d3 | 0<br>d2 | 1<br>d1 | 1<br>d0 | (A) ← (A) ≈ Data                     | 2     | 2      | -    | -  |
| INC A        | 0                | 0       | 0       | 1       | 0       | 1       | 1       | 1       | (A) ← (A) + 1                        | 1     | 1      | -    | -  |
| DEC A        | 0                | 0       | 0       | 0       | 0       | 1       | 1       | 1       | (A) ← (A) - 1                        | 1     | 1      | -    | -  |
| CLR A        | 0                | 0       | 1       | 0       | 0       | 1       | 1       | 1       | (A) ← 0                              | 1     | 1      | -    | -  |
| CPL A        | 0                | 0       | 1       | 1       | 0       | 1       | 1       | 1       | (A) ← NOT (A)                        | 1     | 1      | -    | -  |
| DA A         | 0                | 1       | 0       | 1       | 0       | 1       | 1       | 1       | Decimal Adjust<br>Accumulator        | 1     | 1      | ○    | -  |
| SWAP A       | 0                | 1       | 0       | 0       | 0       | 1       | 1       | 1       | (A4-7) ↗ (A0-3)                      | 1     | 1      | -    | -  |

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP8049P/8049P-6/8049PI-6

TMP8039P/8039P-6/8039PI-6

| Mnemonic | Instruction Code |    |    |    |    |    |    |    | Operation                                        | Bytes | Cycles | Flag |    |
|----------|------------------|----|----|----|----|----|----|----|--------------------------------------------------|-------|--------|------|----|
|          | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                                                  |       |        | C    | AC |
| RL A     | 1                | 1  | 1  | 0  | 0  | 1  | 1  | 1  | (An+1)←(An)<br>n = 0 - 6<br>(A0)←(A7)            | 1     | 1      | -    | -  |
| RLCA     | 1                | 1  | 1  | 1  | 0  | 1  | 1  | 1  | (An+1)←(An)<br>n = 0 - 6<br>(C)←(A7)<br>(A0)←(C) | 1     | 1      | -    | -  |
| RR A     | 0                | 1  | 1  | 1  | 0  | 1  | 1  | 1  | (An)←(An+1)<br>n = 0 - 6<br>(A7)←(A0)            | 1     | 1      | -    | -  |
| RRCA     | 0                | 1  | 1  | 0  | 0  | 1  | 1  | 1  | (An)←(An+1)<br>n = 0 - 6<br>(C)←(A0)<br>(A7)←(C) | 1     | 1      | -    | -  |

## Input/Output Instruction

| Mnemonic      | Instruction Code |    |    |    |    |    |    |    | Operation                            | Bytes | Cycles | Flag |    |
|---------------|------------------|----|----|----|----|----|----|----|--------------------------------------|-------|--------|------|----|
|               | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                                      |       |        | A    | AC |
| IN A,Pp       | 0                | 0  | 0  | 0  | 1  | 0  | P  | P  | (A)←(Pp)<br>P = 1, 2                 | 1     | 2      | -    | -  |
| OUTL Pp,A     | 0                | 0  | 1  | 1  | 1  | 0  | P  | P  | (Pp)←(A)<br>P = 1, 2                 | 1     | 2      | -    | -  |
| ANL Pp,#Data  | 1                | 0  | 0  | 1  | 1  | 0  | P  | P  | (Pp)←(Pp)AND Data<br>P = 1, 2        | 2     | 2      | -    | -  |
| ORL Pp,#Data  | 1                | 0  | 0  | 0  | 1  | 0  | P  | P  | (Pp)←(Pp)VData<br>P = 1, 2           | 2     | 2      | -    | -  |
| INS A,BUS     | 0                | 0  | 0  | 0  | 1  | 0  | 0  | 0  | (A)←(BUS)                            | 1     | 2      | -    | -  |
| OUTL BUS,A    | 0                | 0  | 0  | 0  | 0  | 0  | 1  | 0  | (BUS)←(A)                            | 1     | 2      | -    | -  |
| ANL BUS,#Data | 1                | 0  | 0  | 1  | 1  | 0  | 0  | 0  | (BUS)←(BUS)AND Data                  | 2     | 2      | -    | -  |
| ORL BUS,#Data | 1                | 0  | 0  | 0  | 1  | 0  | 0  | 0  | (BUS)←(BUS)VData                     | 2     | 2      | -    | -  |
| MOVD A,Pp     | 0                | 0  | 0  | 0  | 1  | 1  | P  | P  | (A0-3)←(Pp)<br>(A4-7)←0<br>P = 4 - 7 | 1     | 2      | -    | -  |
| MOVD Pp,A     | 0                | 0  | 1  | 1  | 1  | 1  | P  | P  | (Pp)←(A0-3)<br>P = 4 - 7             | 1     | 2      | -    | -  |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8049P/8049P-6/8049PI-6

TMP8039P/8039P-6/8039PI-6

| Mnemonic  | Instruction Code |    |    |    |    |    |    |    | Operation                     | Bytes | Cycles | Flag |    |
|-----------|------------------|----|----|----|----|----|----|----|-------------------------------|-------|--------|------|----|
|           | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                               |       |        | C    | AC |
| ANLD Pp,A | 1                | 0  | 0  | 1  | 1  | 1  | P  | P  | (Pp)←(Pp)Λ(A0-3)<br>P = 4 - 7 | 1     | 2      | -    | -  |
| ORLD Pp,A | 1                | 0  | 0  | 0  | 1  | 1  | P  | P  | (Pp)←(Pp)∨(A0-3)<br>P = 4 - 7 | 1     | 2      | -    | -  |

## Register Instruction

| Mnemonic | Instruction Code |    |    |    |    |    |    |    | Operation                   | Bytes | Cycles | Flag |    |
|----------|------------------|----|----|----|----|----|----|----|-----------------------------|-------|--------|------|----|
|          | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                             |       |        | C    | AC |
| INC Rr   | 0                | 0  | 0  | 1  | 1  | r  | r  | r  | (Rr)←(Rr)+1<br>r = 0 - 7    | 1     | 1      | -    | -  |
| INC @Rr  | 0                | 0  | 0  | 1  | 0  | 0  | 0  | r  | ((Rr))←((Rr))+1<br>r = 0, 1 | 1     | 1      | -    | -  |
| DEC Rr   | 1                | 1  | 0  | 0  | 1  | r  | r  | r  | (Rr)←(Rr)-1<br>r = 0 - 7    | 1     | 1      | -    | -  |

## Branch Instruction

| Mnemonic            | Instruction Code |          |          |         |         |         |         |         | Operation                                               | Bytes | Cycles | Flag |    |
|---------------------|------------------|----------|----------|---------|---------|---------|---------|---------|---------------------------------------------------------|-------|--------|------|----|
|                     | D7               | D6       | D5       | D4      | D3      | D2      | D1      | D0      |                                                         |       |        | C    | AC |
| JMP Address         | a10<br>a7        | a9<br>a6 | a8<br>a5 | 1<br>a4 | 0<br>a3 | 1<br>a2 | 0<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>(PC8-10)←(a8-10)<br>(PC11)←DBF        | 2     | 2      | -    | -  |
| JMPP @A             | 1                | 0        | 1        | 1       | 0       | 0       | 1       | 1       | (PC0-7)←((A))                                           | 1     | 2      | -    | -  |
| DJNZ Rr,<br>Address | 1<br>a7          | 1<br>a6  | 1<br>a5  | 0<br>a4 | 1<br>a3 | r<br>a2 | r<br>a1 | r<br>a0 | (Rr)←(Rr)-1<br>if Rr not 0<br>(PC0-7)←(a0-7)            | 2     | 2      | -    | -  |
| JC Address          | 1<br>a7          | 1<br>a6  | 1<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if C = 1<br>(PC) = (PC)+2<br>if C = 0 | 2     | 2      | -    | -  |
| JNC Address         | 1<br>a7          | 1<br>a6  | 1<br>a5  | 0<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if C = 0<br>(PC)←(PC)+2<br>if C = 1   | 2     | 2      | -    | -  |



## INTEGRATED CIRCUIT



## TECHNICAL DATA

TMP8049P/8049P-6/8049PI-6

TMP8039P/8039P-6/8039PI-6

| Mnemonic     | Instruction |          |          |         |         |         |         |         | Operation                                                              | Bytes | Cycles | Flag |    |
|--------------|-------------|----------|----------|---------|---------|---------|---------|---------|------------------------------------------------------------------------|-------|--------|------|----|
|              | D7          | D6       | D5       | D4      | D3      | D2      | D1      | D0      |                                                                        |       |        | C    | AC |
| JZ Address   | 1<br>a7     | 1<br>a6  | 0<br>a5  | 0<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if (A) = 0<br>(PC)←(PC)+2<br>if (A) ≠ 0              | 2     | 2      | -    | -  |
| JNZ Address  | 1<br>a7     | 0<br>a6  | 0<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if (A) ≠ 0<br>(PC)←(PC)+2<br>if (A) = 0              | 2     | 2      | -    | -  |
| JTO Address  | 0<br>a7     | 0<br>a6  | 1<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if TO = 1<br>(PC)←(PC)+2<br>if TO = 0                | 2     | 2      | -    | -  |
| JNT0 Address | 0<br>a7     | 0<br>a6  | 1<br>a5  | 0<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if TO = 0<br>(PC)←(PC)+2<br>if TO = 1                | 2     | 2      | -    | -  |
| JT1 Address  | 0<br>a7     | 1<br>a6  | 0<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if T1 = 1<br>(PC)←(PC)+2<br>if T1 = 0                | 2     | 2      | -    | -  |
| JNT1 Address | 0<br>a7     | 1<br>a6  | 0<br>a5  | 0<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if T1 = 0<br>(PC)←(PC)+2<br>if T1 = 1                | 2     | 2      | -    | -  |
| JFO Address  | 1<br>a7     | 0<br>a6  | 1<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if FO = 1<br>(PC)←(PC)+2<br>if FO = 0                | 2     | 2      | -    | -  |
| JF1 Address  | 0<br>a7     | 1<br>a6  | 1<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if F1 = 1<br>(PC)←(PC)+2<br>if F1 = 0                | 2     | 2      | -    | -  |
| JTF Address  | 0<br>a7     | 0<br>a6  | 0<br>a5  | 1<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if TF = 1<br>(PC)←(PC)+2<br>if TF = 0                | 2     | 2      | -    | -  |
| JNL Address  | 1<br>a7     | 0<br>a6  | 0<br>a5  | 0<br>a4 | 0<br>a3 | 1<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if INT = 0<br>(PC)←(PC)+2<br>if INT = 1              | 2     | 2      | -    | -  |
| JBb Address  | b2<br>a7    | b1<br>a6 | b0<br>a5 | 1<br>a4 | 0<br>a3 | 0<br>a2 | 1<br>a1 | 0<br>a0 | (PC0-7)←(a0-7)<br>if Bb = 1<br>(PC)←(PC)+2<br>if Bb = 0<br>(b = 0 - 7) | 2     | 2      | -    | -  |



## Subroutine Instruction

| Mnemonics    | Instruction Code |          |          |         |         |         |         |         |                                                                                                   | Operation | Bytes | Cycles | Flag |    |
|--------------|------------------|----------|----------|---------|---------|---------|---------|---------|---------------------------------------------------------------------------------------------------|-----------|-------|--------|------|----|
|              | D7               | D6       | D5       | D4      | D3      | D2      | D1      | D0      | C                                                                                                 |           |       |        | C    | AC |
| CALL Address | a10<br>a7        | a9<br>a6 | a8<br>a5 | 1<br>a4 | 0<br>a3 | 1<br>a2 | 0<br>a1 | 0<br>a0 | ((SP))<-<br>(PC), (PSW4-7)<br>(SP)<=(SP)+1<br>(PC8-10)<=(a8-10)<br>(PC0-7)<=(a0-7)<br>(PC11)<=DBF | 2         | 2     | -      | -    | -  |
| RET          | 1                | 0        | 0        | 0       | 0       | 0       | 1       | 1       | (SP)<=(SP)-1<br>(PC)<=((SP))                                                                      | 1         | 2     | -      | -    | -  |
| RETR         | 1                | 0        | 0        | 1       | 0       | 0       | 1       | 1       | (SP)<=(SP)-1<br>(PC)<=((SP))<br>(PSW4-7)<=((SP))                                                  | 1         | 2     | -      | -    | -  |

## Flag Manipulation Instruction

| Mnemonics | Instruction Code |    |    |    |    |    |    |    |              | Operation | Bytes | Cycles | Flag |    |
|-----------|------------------|----|----|----|----|----|----|----|--------------|-----------|-------|--------|------|----|
|           | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 | C            |           |       |        | C    | AC |
| CLR C     | 1                | 0  | 0  | 1  | 0  | 1  | 1  | 1  | (C)<0        | 1         | 1     | O      | -    | -  |
| CPL C     | 1                | 0  | 1  | 0  | 0  | 1  | 1  | 1  | (C)<NOT(C)   | 1         | 1     | O      | -    | -  |
| CLR FO    | 1                | 0  | 0  | 0  | 0  | 1  | 0  | 1  | (FO)<0       | 1         | 1     | -      | -    | -  |
| CPL FO    | 1                | 0  | 0  | 1  | 0  | 1  | 0  | 1  | (FO)<NOT(FO) | 1         | 1     | -      | -    | -  |
| CLR F1    | 1                | 0  | 1  | 0  | 0  | 1  | 0  | 1  | (F1)<0       | 1         | 1     | -      | -    | -  |
| CPL F1    | 1                | 0  | 1  | 1  | 0  | 1  | 0  | 1  | (F1)<NOT(F1) | 1         | 1     | -      | -    | -  |

## Data Transfer Instruction

| Mnemonics   | Instruction Code |         |         |         |         |         |         |    |                        | Operation | Bytes | Cycles | Flag |    |
|-------------|------------------|---------|---------|---------|---------|---------|---------|----|------------------------|-----------|-------|--------|------|----|
|             | D7               | D6      | D5      | D4      | D3      | D2      | D1      | D0 | C                      |           |       |        | C    | AC |
| MOV A,Rr    | 1                | 1       | 1       | 1       | 1       | r       | r       | r  | (A)<(Rr)<br>r = 0 - 7  | 1         | 1     | -      | -    | -  |
| MOV A,@Rr   | 1                | 1       | 1       | 1       | 0       | 0       | 0       | r  | (A)<((Rr))<br>r = 0, 1 | 1         | 1     | -      | -    | -  |
| MOV A,#Data | 0<br>d7          | 0<br>d6 | 1<br>d5 | 0<br>d4 | 0<br>d3 | 0<br>d2 | 1<br>d1 | d0 | (A)<Data               | 2         | 2     | -      | -    | -  |
| MOV Rr,A    | 1                | 0       | 1       | 0       | 1       | r       | r       | r  | (Rr)<=(A)<br>r = 0 - 7 | 1         | 1     | -      | -    | -  |



## INTEGRATED CIRCUIT

TMP8049P/8049P-6/8049PI-6

TMP8039P/8039P-6/8039PI-6



## TECHNICAL DATA

| Mnemonics     | Instruction Code |    |    |    |    |    |    |    | Operation                                   | Bytes | Cycles | Flag |    |
|---------------|------------------|----|----|----|----|----|----|----|---------------------------------------------|-------|--------|------|----|
|               | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                                             |       |        | C    | AC |
| MOV @Rr,A     | 1                | 0  | 1  | 0  | 0  | 0  | 0  | r  | ((Rr))<-(A)<br>r = 0, 1                     | 1     | 1      | -    | -  |
| MOV Rr,#Data  | 1                | 0  | 1  | 1  | 1  | r  | r  | r  | (Rr)<-Data<br>r = 0-7                       | 2     | 2      | -    | -  |
| MOV @Rr,#Data | 1                | 0  | 1  | 1  | 0  | 0  | 0  | r  | ((Rr))<-Data<br>r = 0, 1                    | 2     | 2      | -    | -  |
| MOV A,PSW     | 1                | 1  | 0  | 0  | 0  | 1  | 1  | 1  | (A)<-(PSW)                                  | 1     | 1      | -    | -  |
| MOV PSW,A     | 1                | 1  | 0  | 1  | 0  | 1  | 1  | 1  | (PSW)<-(A)                                  | 1     | 1      | -    | -  |
| XCH A,Rr      | 0                | 0  | 1  | 0  | 1  | r  | r  | r  | (A)>-(Rr)<br>r = 0-7                        | 1     | 1      | -    | -  |
| XCH A,@Rr     | 0                | 0  | 1  | 0  | 0  | 0  | 0  | r  | (A)>-(Rr)<br>r = 0, 1                       | 1     | 1      | -    | -  |
| XCHD A,@Rr    | 0                | 0  | 1  | 1  | 0  | 0  | 0  | r  | (AO-3)>-(RR0-3)<br>r = 0, 1                 | 1     | 1      | -    | -  |
| MOVX A,@Rr    | 1                | 0  | 0  | 0  | 0  | 0  | 0  | r  | (A)<-(Rr)<br>r = 0, 1                       | 1     | 2      | -    | -  |
| MOVX @Rr,A    | 1                | 0  | 0  | 1  | 0  | 0  | 0  | r  | ((Rr))<-(A)<br>r = 0, 1                     | 1     | 2      | -    | -  |
| MOV P A,@A    | 1                | 0  | 1  | 0  | 0  | 0  | 1  | 1  | (PC0-7)<-(A)<br>(A)<-(PC))                  | 1     | 2      | -    | -  |
| MOV P3 A,@A   | 1                | 1  | 1  | 0  | 0  | 0  | 1  | 1  | (PC0-7)<-(A)<br>(PC8-11)=0011<br>(A)<-(PC)) | 1     | 2      | -    | -  |

## Timer/Counter Instruction

| Mnemonics | Instruction Code |    |    |    |    |    |    |    | Operation                                     | Bytes | Cycles | Flag |    |
|-----------|------------------|----|----|----|----|----|----|----|-----------------------------------------------|-------|--------|------|----|
|           | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                                               |       |        | C    | AC |
| MOV A,T   | 0                | 1  | 0  | 0  | 0  | 0  | 1  | 0  | (A)<-(T)                                      | 1     | 1      | -    | -  |
| MOV T,A   | 0                | 1  | 1  | 0  | 0  | 0  | 1  | 0  | (T)<-(A)                                      | 1     | 1      | -    | -  |
| STRT T    | 0                | 1  | 0  | 1  | 0  | 1  | 0  | 1  | Counting is started in the timer mode         | 1     | 1      | -    | -  |
| STRT CNT  | 0                | 1  | 0  | 0  | 0  | 1  | 0  | 1  | Counting is started in the event counter mode | 1     | 1      | -    | -  |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8049P/8049P-6/8049PI-6

TMP8039P/8039P-6/8039PI-6

| Mnemonics | Instruction Code |    |    |    |    |    |    |    | Operation                                      | Bytes | Cycles | Flag |    |
|-----------|------------------|----|----|----|----|----|----|----|------------------------------------------------|-------|--------|------|----|
|           | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                                                |       |        | C    | AC |
| STOP TCNT | 0                | 1  | 1  | 0  | 0  | 1  | 0  | 1  | Stop both time accumulation and event counting | 1     | 1      | -    | -  |
| EN TCNT1  | 0                | 0  | 1  | 0  | 0  | 1  | 0  | 1  | Timer interrupt is enabled                     | 1     | 1      | -    | -  |
| DIS TCNT1 | 0                | 0  | 1  | 1  | 0  | 1  | 0  | 1  | Timer interrupt is disabled                    | 1     | 1      | -    | -  |

## Control Instruction

| Mnemonics | Instruction Code |     |    |    |    |    |    |    | Operation                                            | Bytes | Cycles | Flag |    |
|-----------|------------------|-----|----|----|----|----|----|----|------------------------------------------------------|-------|--------|------|----|
|           | D7               | 'D6 | D5 | D4 | D3 | D2 | D1 | D0 |                                                      |       |        | C    | AC |
| EN I      | 0                | 0   | 0  | 0  | 0  | 1  | 0  | 1  | External interrupt is enabled                        | 1     | 1      | -    | -  |
| DIS I     | 0                | 0   | 0  | 1  | 0  | 1  | 0  | 1  | External interrupt is disabled                       | 1     | 1      | -    | -  |
| SEL RBO   | 1                | 1   | 0  | 0  | 0  | 1  | 0  | 1  | (BS)=0                                               | 1     | 1      | -    | -  |
| SEL RB1   | 1                | 1   | 0  | 1  | 0  | 1  | 0  | 1  | (BS)=1                                               | 1     | 1      | -    | -  |
| SEL MBO   | 1                | 1   | 1  | 0  | 0  | 1  | 0  | 1  | (DBF)=0                                              | 1     | 1      | -    | -  |
| SEL MB1   | 1                | 1   | 1  | 1  | 0  | 1  | 0  | 1  | (DBF)=1                                              | 1     | 1      | -    | -  |
| ENTO CLK  | 0                | 1   | 1  | 1  | 0  | 1  | 0  | 1  | T <sub>0</sub> is enabled to act as the clock output | 1     | 1      | -    | -  |
| NOP       | 0                | 0   | 0  | 0  | 0  | 0  | 0  | 0  | No operation                                         | 1     | 1      | -    | -  |

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP8049P/8049P-6/8049PI-6

TMP8039P/8039P-6/8039PI-6

TMP8049P/8039P/8049P-6/8039P-6

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL              | ITEM                                                                    | RATING         |
|---------------------|-------------------------------------------------------------------------|----------------|
| V <sub>DD</sub>     | V <sub>DD</sub> Supply Voltage (with respect to GND (V <sub>SS</sub> )) | -0.5V to +7V   |
| V <sub>CC</sub>     | V <sub>CC</sub> Supply Voltage (with respect to GND (V <sub>SS</sub> )) | -0.5V to +7V   |
| V <sub>INA</sub>    | Input Voltage (Except EA)                                               | -0.5V to +7V   |
| V <sub>INB</sub>    | Input Voltage (Only EA)                                                 | -0.5V to +13V  |
| P <sub>D</sub>      | Power Dissipation (Ta=25°C)                                             | 1.5W           |
| T <sub>SOLDER</sub> | Soldering Temperature (Soldering Time 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    |

## DC CHARACTERISTICS

TA=0°C to 70°C, V<sub>CC</sub>=V<sub>DD</sub>=+5V±10%, V<sub>SS</sub>=0V, Unless Otherwise Noted.

| SYMBOL                           | PARAMETER                                                   | TEST CONDITIONS                                        | MIN. | TYP. | MAX.            | UNIT |
|----------------------------------|-------------------------------------------------------------|--------------------------------------------------------|------|------|-----------------|------|
| V <sub>IL</sub>                  | Input Low Voltage                                           |                                                        | -0.5 | -    | 0.8             | V    |
| V <sub>IH</sub>                  | Input High Voltage<br>(Except XTAL1, XTAL2, RESET)          |                                                        | 2.0  | -    | V <sub>CC</sub> | V    |
| V <sub>IHL</sub>                 | Input High Voltage<br>(XTAL1, XTAL2, RESET)                 |                                                        | 3.8  | -    | V <sub>CC</sub> | V    |
| V <sub>OL</sub>                  | Output Low Voltage (BUS)                                    | I <sub>OL</sub> =2.0mA                                 | -    | -    | 0.45            | V    |
| V <sub>OL1</sub>                 | Output Low Voltage<br>(RD, WR, PSEN, ALE)                   | I <sub>OL</sub> =1.8mA                                 | -    | -    | 0.45            | V    |
| V <sub>OL2</sub>                 | Output Low Voltage (PROG)                                   | I <sub>OL</sub> =1.0mA                                 | -    | -    | 0.45            | V    |
| V <sub>OL3</sub>                 | Output Low Voltage<br>(For other output pins)               | I <sub>OL</sub> =1.6mA                                 | -    | -    | 0.45            | V    |
| V <sub>OH</sub>                  | Output High Voltage (BUS)                                   | I <sub>OH</sub> =-400μA                                | 2.4  | -    | -               | V    |
| V <sub>OH1</sub>                 | Output High Voltage<br>(RD, WR, PSEN, ALE)                  | I <sub>OH</sub> =-100μA                                | 2.4  | -    | -               | V    |
| V <sub>OH2</sub>                 | Output High Voltage<br>(For tothe output pins)              | I <sub>OH</sub> =-40μA                                 | 2.4  | -    | -               | V    |
| I <sub>LI</sub>                  | Input Leak Current (T1, INT)                                | V <sub>SS</sub> ≤V <sub>IN</sub> ≤V <sub>CC</sub>      | -    | -    | ±10             | μA   |
| I <sub>LI1</sub>                 | Input Leak Current<br>(P10-17, P20-P27, EA, SS)             | V <sub>SS</sub> +0.45≤V <sub>IN</sub> ≤V <sub>CC</sub> | -    | -    | -500            | μA   |
| I <sub>LO</sub>                  | Output Leak Current (BUS, TO)<br>(High impedance condition) | V <sub>SS</sub> +0.45≤V <sub>IN</sub> ≤V <sub>CC</sub> | -    | -    | ±10             | μA   |
| I <sub>DD</sub>                  | V <sub>DD</sub> Supply Current                              |                                                        | -    | -    | 50              | mA   |
| I <sub>DD</sub> +I <sub>CC</sub> | Total Supply Current                                        |                                                        | -    | -    | 170             | mA   |



INTEGRATED CIRCUIT



TECHNICAL DATA

TMP8049P/8049P-6/8049PI-6

TMP8039P/8039P-6/8039PI-6

## AC CHARACTERISTICS

TA=0°C to 70°C, V<sub>CC</sub>=V<sub>DD</sub>=+5V±10%, V<sub>SS</sub>=0V, Unless Otherwise Noted

| SYMBOL           | PARAMETER                             | TEST CONDITION                   | TMP8049P/<br>TMP8039P |      | TMP8049P-6/<br>TMP8039P-6 |      | UNI |
|------------------|---------------------------------------|----------------------------------|-----------------------|------|---------------------------|------|-----|
|                  |                                       |                                  | MIN.                  | MAX. | MIN.                      | MAX. |     |
| t <sub>LL</sub>  | ALE Pulse Width                       |                                  | 150                   | -    | 400                       | -    | n   |
| t <sub>AL</sub>  | Address Setup Time (ALE)              |                                  | 70                    | -    | 150                       | -    | n   |
| t <sub>LA</sub>  | Address Hold Time (ALE)               |                                  | 50                    | -    | 80                        | -    | n   |
| t <sub>CC</sub>  | Control Pulse Width<br>(PSEN, RD, WR) |                                  | 300                   | -    | 700                       | -    | n   |
| t <sub>DW</sub>  | Data Setup Time (WR)                  |                                  | 250                   | -    | 500                       | -    | n   |
| t <sub>WD</sub>  | Data Hold Time (WR)                   | C <sub>L</sub> =20pF             | 40                    | -    | 120                       | -    | n   |
| t <sub>CY</sub>  | Cycle Time                            | 11MHz XTAL<br>(6MHz XTAL for -6) | 1.36                  | 15.0 | 2.5                       | 15.0 | μ   |
| t <sub>DR</sub>  | Data Hold Time (PSEN, RD)             |                                  | 0                     | 100  | 0                         | 200  | n   |
| t <sub>RD</sub>  | Data Input Read Time<br>(PSEN, RD)    |                                  | -                     | 200  | -                         | 500  | n   |
| t <sub>AW</sub>  | Address Setup Time (WR)               |                                  | 200                   | -    | 230                       | -    | n   |
| t <sub>AD</sub>  | Address Setup Time<br>(Data Input)    |                                  | -                     | 400  | -                         | 950  | n   |
| t <sub>AFC</sub> | Address Float Time<br>(RD, PSEN)      |                                  | -10                   | -    | 0                         | -    | n   |
| t <sub>CP</sub>  | Port Control Setup Time<br>(PROG)     |                                  | 100                   | -    | 110                       | -    | n   |
| t <sub>PC</sub>  | Port Control Hold Time<br>(PROG)      |                                  | 60                    | -    | 130                       | -    | n   |
| t <sub>PR</sub>  | Port 2 Input Data Set Time<br>(PROG)  |                                  | -                     | 650  | -                         | 810  | n   |
| t <sub>DP</sub>  | Output Data Setup Time<br>(PROG)      |                                  | 200                   | -    | 220                       | -    | n   |
| t <sub>PD</sub>  | Output Data Hold Time<br>(PROG)       |                                  | 20                    | -    | 65                        | -    | n   |
| t <sub>PF</sub>  | Port 2 Input Data Hold Time<br>(PROG) |                                  | 0                     | 150  | 0                         | 150  | n   |
| t <sub>PP</sub>  | PROG Pulse Width                      |                                  | 700                   | -    | 1510                      | -    | n   |
| t <sub>PL</sub>  | Port 2 I/O Data Setup Time            |                                  | 250                   | -    | 500                       | -    | n   |
| t <sub>LP</sub>  | Port 2 I/O Data Hold Time             |                                  | 120                   | -    | 150                       | -    | n   |

Control Outputs : C<sub>L</sub>=80pF, BUS Outputs : C<sub>L</sub>=150pF

Toshiba

## INTEGRATED CIRCUIT

TMP8049P/8049P-6/8049PI-6

TMP8039P/8039P-6/8039PI-6



## TECHNICAL DATA

[TMP8049PI-6/8039PI-6 : INDUSTRIAL SPECIFICATION.]

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL              | ITEM                                                                    | RATING         |
|---------------------|-------------------------------------------------------------------------|----------------|
| V <sub>DD</sub>     | V <sub>DD</sub> Supply Voltage (with respect to GND (V <sub>SS</sub> )) | -0.5V to +7V   |
| V <sub>CC</sub>     | V <sub>CC</sub> Supply Voltage (with respect to GND (V <sub>SS</sub> )) | -0.5V to +7V   |
| V <sub>INA</sub>    | Input Voltage (Except EA)                                               | -0.5V to +7V   |
| V <sub>INB</sub>    | Input Voltage (Only EA)                                                 | -0.5V to +13V  |
| P <sub>D</sub>      | Power Dissipation (Ta=25°C)                                             | 1.5W           |
| T <sub>SOLDER</sub> | Soldering Temperature (Soldering Time 10 sec.)                          | 260°C          |
| T <sub>STG</sub>    | Storage Temperature                                                     | -55°C to 150°C |
| T <sub>OPR</sub>    | Operating Temperature                                                   | -40°C to 85°C  |

## DC CHARACTERISTICS

TA=-40°C to 85°C, V<sub>CC</sub>=V<sub>DD</sub>=+5V±10%, V<sub>SS</sub>=0V, Unless Otherwise Noted.

| SYMBOL                           | PARAMETER                                                   | TEST CONDITIONS                                        | MIN. | TYP. | MAX.            | UNIT |
|----------------------------------|-------------------------------------------------------------|--------------------------------------------------------|------|------|-----------------|------|
| V <sub>IL</sub>                  | Input Low Voltage                                           |                                                        | -0.5 | -    | 0.6             | V    |
| V <sub>IH</sub>                  | Input High Voltage<br>(Except XTALL, XTAL2, RESET)          |                                                        | 2.2  | -    | V <sub>CC</sub> | V    |
| V <sub>IH1</sub>                 | Input High Voltage<br>(XTALL, XTAL2, RESET)                 |                                                        | 3.8  | -    | V <sub>CC</sub> | V    |
| V <sub>OL</sub>                  | Output Low Voltage (BUS)                                    | I <sub>OL</sub> =1.6mA                                 | -    | -    | 0.45            | V    |
| V <sub>OL1</sub>                 | Output Low Voltage<br>(RD, WR, PSEN, ALE)                   | I <sub>OL</sub> =1.6mA                                 | -    | -    | 0.45            | V    |
| V <sub>OL2</sub>                 | Output Low Voltage (PROG)                                   | I <sub>OL</sub> =0.8mA                                 | -    | -    | 0.45            | V    |
| V <sub>OL3</sub>                 | Output Low Voltage<br>(For other output pins)               | I <sub>OL</sub> =1.2mA                                 | -    | -    | 0.45            | V    |
| V <sub>OH</sub>                  | Output High Voltage (BUS)                                   | I <sub>OH</sub> =-80μA                                 | 2.4  | -    | -               | V    |
| V <sub>OH1</sub>                 | Output High Voltage<br>(RD, WR, PSEN, ALE)                  | I <sub>OH</sub> =-80μA                                 | 2.4  | -    | -               | V    |
| V <sub>OH2</sub>                 | Output High Voltage<br>(For other output pins)              | I <sub>OH</sub> =-30μA                                 | 2.4  | -    | -               | V    |
| I <sub>LI</sub>                  | Input Leak Current (T1, INT)                                | V <sub>SS</sub> ≤V <sub>IN</sub> ≤V <sub>CC</sub>      | -    | -    | ±10             | μA   |
| I <sub>LI1</sub>                 | Input Leak Current<br>(P10-17, P20-P27, EA, SS)             | V <sub>SS</sub> +0.45≤V <sub>IN</sub> ≤V <sub>CC</sub> | -    | -    | -700            | μA   |
| I <sub>LO</sub>                  | Output Leak Current (BUS, TO)<br>(High impedance condition) | V <sub>SS</sub> +0.45≤V <sub>IN</sub> ≤V <sub>CC</sub> | -    | -    | ±10             | μA   |
| I <sub>DD</sub>                  | V <sub>DD</sub> Supply Current                              |                                                        | -    | -    | 50              | mA   |
| I <sub>DD</sub> +I <sub>CC</sub> | Total Supply Current                                        |                                                        | -    | -    | 170             | mA   |

## AC CHARACTERISTICS

TA=-40°C to 85°C, V<sub>CC</sub>=V<sub>D</sub>DD=+5V±10%, V<sub>SS</sub>=0V, Unless otherwise Noted.

| SYMBOL           | PARAMETER                              | TEST CONDITIONS      | MIN. | TYP. | MAX. | UNIT |
|------------------|----------------------------------------|----------------------|------|------|------|------|
| t <sub>LL</sub>  | ALE Pulse Width                        |                      | 200  | -    | -    | ns   |
| t <sub>AL</sub>  | Address Setup Time (ALE)               |                      | 120  | -    | -    | ns   |
| t <sub>LA</sub>  | Address Hold Time (ALE)                |                      | 80   | -    | -    | ns   |
| t <sub>CC</sub>  | Control Pulse Width (PSEN, RD, WR)     |                      | 400  | -    | -    | ns   |
| t <sub>DW</sub>  | Data Setup Time (WR)                   |                      | 420  | -    | -    | ns   |
| t <sub>WD</sub>  | Data Hold Time (WR)                    | C <sub>L</sub> =20pF | 80   | -    | -    | ns   |
| t <sub>CY</sub>  | Cycle Time                             |                      | 2.5  | -    | 15.0 | μs   |
| t <sub>DR</sub>  | Data Hold Time (PSEN, RD)              |                      | 0    | -    | 200  | ns   |
| t <sub>RD</sub>  | Data Input Read Time (PSEN, RD)        |                      | -    | -    | 400  | ns   |
| t <sub>AW</sub>  | Address Setup Time (WR)                |                      | 230  | -    | -    | ns   |
| t <sub>AD</sub>  | Address Setup Time (Data Input)        |                      | -    | -    | 600  | ns   |
| t <sub>AFC</sub> | Address Float Time (RD, PSEN)          |                      | -40  | -    | -    | ns   |
| t <sub>CA</sub>  | Internal between Control Pulse and ALE |                      | 10   | -    | -    | ns   |
| t <sub>CP</sub>  | Port Control Setup Time (PROG)         |                      | 115  | -    | -    | ns   |
| t <sub>PC</sub>  | Port Control Hold Time (PROG)          |                      | 65   | -    | -    | ns   |
| t <sub>PR</sub>  | Port 2 Input Data Set Time (PROG)      |                      | -    | -    | 860  | ns   |
| t <sub>DP</sub>  | Output Data Setup Time (PROG)          |                      | 230  | -    | -    | ns   |
| t <sub>PD</sub>  | Output Data Hold Time (PROG)           |                      | 25   | -    | -    | ns   |
| t <sub>PF</sub>  | Port 2 Input Data Hold Time (PROG)     |                      | 0    | -    | 160  | ns   |
| t <sub>PP</sub>  | PROG Pulse Width                       |                      | 920  | -    | -    | ns   |
| t <sub>PL</sub>  | Port 2 I/O Data Setup Time             |                      | 300  | -    | -    | ns   |
| t <sub>LP</sub>  | Port 2 I/O Data Hold Time              |                      | 120  | -    | -    | ns   |

Note : t<sub>CY</sub>=2.5μs, Control Output: C<sub>L</sub>=80pF, BUS Output: C<sub>L</sub>=150pF, PORT 20-23:  
C<sub>L</sub>=80pF.

## TIMING WAVEFORM

## A. Instruction Fetch from External Program Memory



## B. Read from External Data Memory



## C. Write into External Data Memory



**D. Timing of Port 2 during Expander Instruction Execution**

**TYPICAL CHARACTERISTICS**


## PROGRAM TAPE FORMAT

TMP8049 programs are delivered in the form of paper tape with the following format and it is required to attach the tape list. The format of paper tape is same as the Intel type object tape (hexadecimal tape output by Intel MDS system, PROMPT 48 Development Tool, etc.)

## (1) Tape Format



## (2) Example of Tape List

```

TOSHIBA MICRO COMPUTER TLCS-84
:100000000665CD79CF50F3F951FED55A8FF16E570
:1000100088884DDE67D31F5D8ABA6DF292F113F5C1
:100020004FF1FB5DFFDA96A99CF7DF94A346B7C09
:10003000197352F729F12F79AA9C057C5B851EED77

```

```

:1003C0005DFDBE556A67277F61A51C631CF9F0E80
:1003D000BD2F6F20E8BB1977E3FB5AD1F41FDAA7E2
:1003E000B53D42E0EC32546025B7308CDD52063D1D
:1003F000B4BE9E9E345B6138060B20VC372BF60BD6
.:00000001FF

```

Toshiba

東芝

# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8049P/8049P-6/8049PI-6

TMP8039P/8039P-6/8039PI-6

### OUTLINE DRAWING



Note : 1. This dimension shows the center of curvature of leads.

2. This dimension shows spread of leads.

3. The pitch of leads is 2.54 and the tolerance is ±0.25 from the theoretical center of each lead obtained having No.1 lead and No. 40 lead as the reference.

Note : Toshiba does not assume any responsibility for use of any circuitry described; no circuit patent licenses are implied, and Toshiba reserves the right, at any time without notice, to change said circuitry.

© June 1981 Toshiba Corporation

## INPUT/OUTPUT EXPANDER

## GENERAL DESCRIPTION

The TMP8243P is an input/output expander designed specifically to provide a low cost means of I/O expansion for the TLCS-84 family.

The I/O ports of the TMP8243P serve as a direct extension of the resident I/O facilities of the TLCS-84 microcomputers and are accessed by their own MOVD, ANLD, and ORLD instructions.

## FEATURES

- o Low cost
- o Simple interface to TLCS-84 microcomputers
- o Four 4-bit I/O ports
- o AND and OR directly to ports
- o Single 5V supply
- o High output drive
- o Direct extension of resident TMP8048P/TMP8049P I/O ports.
- o Compatible with intel's 8243
- o -40°C to +85°C Operation (TMP8243PI: Industrial Specification)

## PIN CONNECTION (TOP VIEW)



## BLOCK DIAGRAM



#### PIN NAMES AND PIN DESCRIPTION

##### PROG (Input)

Clock Input. A high to low transition on PROG signifies that address and control are available on P20-23, and a low to high transition signifies that data is available on P20-23.

##### CS (Input)

Chip Select Input. A high on CS inhibits any change of output or internal status.

##### P20-23 (Input/Output, 3-state)

Four (4) bit bi-directional port contains the address and control bits on a high to low transition of PROG. During a low to high transition contains the data for a selected output port if a write operation, or the data from a selected port before the low to high transition if a read operation.

##### P40-43, P50-53, P60-63, P70-73 (Input/Output, 3-state)

Four (4) bit bi-directional I/O ports. May be programmed to be input (during read), low impedance latched output (after write) or a 3-state (after read). Data on pins P20-23 may be directly written, ANDed or ORed with previous data.

##### V<sub>CC</sub> (Power)

+5 volt supply

##### GND (Power)

0 volt supply

#### FUNCTIONAL DESCRIPTION

##### General Operation

The TMP8243P contains four 4-bit I/O ports which serve as an extension of the on-chip I/O and are addressed as ports 4-7. The following operations may be performed on these ports.

- o Transfer accumulator to port
- o Transfer port to accumulator
- o AND accumulator to port
- o OR accumulator to port

All communication between the TMP8048P and the TMP8243P occurs over Port 2 (P20-23) with timing provided by an output pulse on the PROG pin of the processor. Each transfer consists of two 4-bit nibbles.

A high to low transition of the PROG line indicates that address is present while a low to high transition indicates the presence of data. Additional TMP8243P'S may be added to the 4-bit bus and chip selected using additional output lines from the TMP8048P/8035P.

#### Power On Initialization

Initial application of power to the device forces input/output ports 4, 5, 6, and 7 to the tri-state and port 2 to the input mode. The PROG pin may be either high or low when power is applied. The first high to low transition of PROG causes device to exit power on mode. The power on sequence is initiated if VCC drops below 1V.

| P21 | P20 | Address Code | P23 | P22 | Instruction Code |
|-----|-----|--------------|-----|-----|------------------|
| 0   | 0   | Port 4       | 0   | 0   | Read             |
| 0   | 1   | Port 5       | 0   | 1   | Write            |
| 1   | 0   | Port 6       | 1   | 0   | ORLD             |
| 1   | 1   | Port 7       | 1   | 1   | ANLD             |

#### Write Modes

The device has three write modes. MOVD Pi, A directly writes new data into the selected port and old data is lost. ORLD Pi, A takes new data, OR's it with the old data and then writes it to the port. ANLD Pi, A takes new data AND's it with the old data and then writes it to the port. Operation code and port address are latched from the input port 2 on the high to low transition of the PROG pin. On the low to high transition of PROG data on port 2 is transferred to the logic block of the specified output port.

After the logic manipulation is performed, the data is latched and outputed. The old data remains latched until new valid outputs are entered.



## Read Mode

The device has one read mode. The operation code and port address are latched from the input port 2 on the high to low transition of the PROG pin. As soon as the read operation and port address are decoded, the appropriate outputs are 3-stated, and the input buffers switched on. The read operation is terminated by a low to high transition of the PROG pin. The port (4, 5, 6 or 7) that was selected is switched to the 3-stated mode while port 2 is returned to the input mode.

Normally, a port will be in an output (write mode) or input (read mode). If modes are changed during operation, the first read following a write should be ignored; all following reads are valid. This is to allow the external driver on the port to settle after the first read instruction removes the low impedance drive from the TMP8243P output. A read of any port will leave that port in a high impedance state.



### Sink Capability

The TMP8243P can sink 5 mA@.45V on each of its 16 I/O lines simultaneously. If, however, all lines are not sinking simultaneously or all lines are not fully loaded, the drive capability of any individual line increases as is shown by the accompanying curve.

For example, if only 5 of the 16 lines are to sink current at one time, the curve shows that each of those 5 lines is capable of sinking 9 mA@.45V (if any lines are to sink 9 mA the total  $I_{OL}$  must not exceed 45 mA or five 9 mA loads).

Example: How many pins can drive 5 TTL loads (1.6 mA) assuming remaining pins are unloaded?

$$I_{OL} = 5 \times 1.6 \text{ mA} = 8 \text{ mA}$$

$\epsilon I_{OL} = 60 \text{ mA}$  from curve

$$\# \text{pins} = 60 \text{ mA} \div 8 \text{ mA/pin} = 7.5 = 7$$

In this case, 7 lines can sink 8 mA for a total of 56 mA. This leaves 4 mA sink current capability which can be divided in any way among the remaining 9 I/O lines of the TMP8243P.

Example: This examples shows now the use of the 20 mA sink capability of port 7 affects the sinking capability of the other I/O lines.

An TMP8243P will drive the following loads simultaneously.

2 loads - 20 mA@1V (port 7 only)

8 loads - 4 mA@.45V

6 loads - 3.2 mA@.45V

Is this within the specified limits?

$\epsilon I_{OL} = (2 \times 20) + (8 \times 4) + (6 \times 3.2) = 91.2 \text{ mA}$ . From the curve:

for  $I_{OL} = 4 \text{ mA}$ ,  $\epsilon I_{OL} = 93 \text{ mA}$  since  $91.2 \text{ mA} < 93 \text{ mA}$  the loads are within specified limits.

Although the 20 mA@1V. load are used in calculating  $\epsilon I_{OL}$ , it is the largest current required @.45V which determines the maximum allowable  $\epsilon I_{OL}$ .



## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP8243P/TMP8243PI

TMP8243P

## ABSOLUTE MAXIMUM RATINGS

| Symbol              | Item                                               | Rating          |
|---------------------|----------------------------------------------------|-----------------|
| V <sub>CC</sub>     | V <sub>CC</sub> Supply Voltage with Respect to GND | -0.5V to +7.0V  |
| V <sub>IN</sub>     | Input Voltage with Respect to GND                  | -0.5V to +7.0V  |
| V <sub>OUT</sub>    | Output Voltage with Respect to GND                 | -0.5V to +7.0V  |
| P <sub>D</sub>      | Power Dissipation                                  | 800mW           |
| T <sub>SOLDER</sub> | Soldering Temperature (Soldering Time 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    |

D.C. CHARACTERISTICS TA = 0°C to 70°C, V<sub>CC</sub> = 5V ± 10%

| Symbol           | Parameter                                | 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.0  |      | V <sub>CC</sub> + 0.5 | V    |
| V <sub>OЛ1</sub> | Output Low Voltage Ports 4-7             | I <sub>OL</sub> = 5mA*                 |      |      | 0.45                  | V    |
| V <sub>OЛ2</sub> | Output Low Voltage Port 7                | I <sub>OL</sub> = 20mA                 |      |      | 1                     | V    |
| V <sub>OЛ3</sub> | Output Low Voltage Port 2                | I <sub>OL</sub> =0.6mA                 |      |      | 0.45                  | V    |
| V <sub>OH1</sub> | Output High Voltage Ports 4-7            | I <sub>OH</sub> =-240μA                | 2.4  |      |                       | V    |
| V <sub>OH2</sub> | Output High Voltage Port 2               | I <sub>OH</sub> =-100μA                | 2.4  |      |                       |      |
| I <sub>IL1</sub> | Input Leakage Port 4-7                   | 0V ≤ V <sub>IN</sub> ≤ V <sub>CC</sub> | -10  |      | 20                    | μA   |
| I <sub>IL2</sub> | Input Leadage Port 2, CS, PROG           | 0V ≤ V <sub>IN</sub> ≤ V <sub>CC</sub> | -10  |      | 10                    | μA   |
| I <sub>CC</sub>  | V <sub>CC</sub> Supply Current           |                                        |      |      | 10                    | mA   |
| I <sub>OL</sub>  | Sum of all I <sub>OL</sub> of 16 Outputs | 5 mA Each Pin                          |      |      | 80                    | mA   |

\* See following graph for additional sink current capability

A.C. CHARACTERISTICS TA = 0°C to 70°C, V<sub>CC</sub> = 5V ± 10%

| Symbol           | Parameter                         | Test Condition         | Min. | Typ. | Max. | Unit |
|------------------|-----------------------------------|------------------------|------|------|------|------|
| t <sub>A</sub>   | Code Valid Before PROG            | C <sub>L</sub> = 80pF  | 100  |      |      | ns   |
| t <sub>B</sub>   | Code Valid After PROG             | C <sub>L</sub> = 20pF  | 60   |      |      | ns   |
| t <sub>C</sub>   | Data Valid Before PROG            | C <sub>L</sub> = 80pF  | 200  |      |      | ns   |
| t <sub>D</sub>   | Data Valid After PROG             | C <sub>L</sub> = 20pF  | 20   |      |      | ns   |
| t <sub>H</sub>   | Floating After PROG               | C <sub>L</sub> = 20pF  | 0    |      | 150  | ns   |
| t <sub>K</sub>   | PROG Negative Pulse Width         |                        | 700  |      |      | ns   |
| t <sub>CS</sub>  | CS Valid Before/After PROG        |                        | 50   |      |      | ns   |
| t <sub>PO</sub>  | Ports 4-7 Valid After PROG        | C <sub>L</sub> = 100pF |      |      | 700  | ns   |
| t <sub>LPI</sub> | Ports 4-7 Valid Before/After PROG |                        | 100  |      |      | ns   |
| t <sub>ACC</sub> | Port 2 Valid After PROG           | C <sub>L</sub> = 80pF  |      |      | 650  | ns   |

## TMP8243PI : INDUSTRIAL SPECIFICATION

## ABSOLUTE MAXIMUM RATINGS

| Symbol       | Item                                           | Rating          |
|--------------|------------------------------------------------|-----------------|
| $V_{CC}$     | $V_{CC}$ Supply Voltage with Respect to GND    | -0.5V to +7.0V  |
| $V_{IN}$     | Input Voltage with Respect to GND              | -0.5V to +7.0V  |
| $V_{OUT}$    | Output Voltage with Respect to GND             | -0.5V to +7.0V  |
| $P_D$        | Power Dissipation                              | 800mW           |
| $T_{SOLDER}$ | Soldering Temperature (Soldering Time 10 sec.) | 260°C           |
| $T_{STG}$    | Storage Temperature                            | -55°C to +150°C |
| $T_{OPR}$    | Operating Temperature                          | -40°C to +85°C  |

D.C. CHARACTERISTICS TA=-40°C to 85°C,  $V_{CC}=5V\pm10\%$ 

| Symbol    | Parameter                                    | Test Condition               | Min. | Typ. | Max.         | Units   |
|-----------|----------------------------------------------|------------------------------|------|------|--------------|---------|
| $V_{IL}$  | Input Low Voltage                            |                              | -0.5 |      | 0.8          | V       |
| $V_{IH}$  | Input High Voltage                           |                              | 2.0  |      | $V_{CC}+0.5$ | V       |
| $V_{OL1}$ | Output Low Voltage Ports 4-7                 | $I_{OL}=4.5mA$               |      |      | 0.45         | V       |
| $V_{OL2}$ | Output Low Voltage Port 7                    | $I_{OL}=20mA$                |      |      | 1            | V       |
| $V_{OL3}$ | Output Low Voltage Port 2                    | $I_{OL}=0.6mA$               |      |      | 0.45         | V       |
| $V_{OH1}$ | Output High Voltage Ports 4-7                | $I_{OH}=-240\mu A$           | 2.4  |      |              | V       |
| $V_{OH2}$ | Output High Voltage Port 2                   | $I_{OH}=-100\mu A$           | 2.4  |      |              |         |
| $I_{IL1}$ | Input Leakage Ports 4-7                      | $0V \leq V_{IN} \leq V_{CC}$ | -10  |      | 20           | $\mu A$ |
| $I_{IL2}$ | Input Leakage Port 2, $\overline{CS}$ , PROG | $0V \leq V_{IN} \leq V_{CC}$ | -10  |      | 10           | $\mu A$ |
| $I_{CC}$  | $V_{CC}$ Supply Current                      |                              |      | 10   | 20           | mA      |
| $I_{OL}$  | Sum of all $I_{OL}$ of 16 outputs            | 4.5mA each pin               |      |      | 72           | mA      |

\* See following graph for additional sink current capability

A.C. CHARACTERISTICS TA=-40°C to 85°C,  $V_{CC}=5V\pm10\%$ 

| Symbol    | Parameter                               | Test Condition | Min. | Typ. | Max. | Units |
|-----------|-----------------------------------------|----------------|------|------|------|-------|
| $t_A$     | Code Valid before PROG                  | $C_L = 80pF$   | 100  |      |      | ns    |
| $t_B$     | Code Valid after PROG                   | $C_L = 20pF$   | 60   |      |      | ns    |
| $t_C$     | Data Valid before PROG                  | $C_L = 80pF$   | 200  |      |      | ns    |
| $t_D$     | Data Valid after PROG                   | $C_L = 20pF$   | 20   |      |      | ns    |
| $t_H$     | Floating after PROG                     | $C_L = 20pF$   | 0    |      | 150  | ns    |
| $t_K$     | PROG Negative Pulse Width               |                | 700  |      |      | ns    |
| $t_{CS}$  | $\overline{CS}$ Valid before/after PROG |                | 50   |      |      | ns    |
| $t_{PO}$  | Ports 4-7 Valid after PROG              | $C_L = 100pF$  |      |      | 700  | ns    |
| $t_{LP1}$ | Ports 4-7 Valid before/after PROG       |                | 100  |      |      | ns    |
| $t_{ACC}$ | Port 2 Valid after PROG                 | $C_L = 80pF$   |      |      | 650  | ns    |

**TIMING WAVEFORM**


## OUTLINE DRAWINGS

Unit in mm



Note: Each lead pitch is 2.54mm. All leads are located within 0.25mm of their true longitudinal position with respect to No.1 and No.24 leads.

All dimensions are in millimeters.



# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8022P

### GENERAL DESCRIPTION

The TMP8022P is one version of the TLCS-84 family, which is an 8-bit single chip microcomputer containing A/D converter.

The CPU, data memory (RAM), program memory (ROM), I/O port, and timer, which are basic functions as a computer, and further, A/D converter, comparator input port, zero-cross detection circuit, etc. are all integrated on single chip.

### FEATURES

- Compatible with Intel's 8022
- 2K × 8 ROM, 64 × 8 RAM, 28 I/O Lines
- 8 Bit Interval Timer/Event Counter
- On-chip 8 Bit A/D Converter; Two Input Channels
- 8 Comparator Inputs (PORT0)
- Zero Cross Detection Capability
- High Current Drive Capability ( $V_{OL} < 2.5V$  @  $I_{OL} = 7mA$ )
- 8 Level Subroutine Nesting
- Two Interrupts - External and Timer
- Instructions - 8048 Subset
- 8.38 sec Cycles; All Instructions 1 or 2 Cycles
- Single 5V Supply (4.5V to 6.5V)

## PIN CONNECTIONS (TOP VIEW)



## PIN NAMES AND DESCRIPTION

| Pin Name       | Pin No.  | Input/Output | Function                                                                                                                       |
|----------------|----------|--------------|--------------------------------------------------------------------------------------------------------------------------------|
| XTAL1<br>XTAL2 | 22<br>23 | Input        | A terminal for connecting the oscillator or an input terminal for the external clock.                                          |
| RESET          | 24       | Input        | High active signal and initializes the chip. When a low level voltage is applied to this pin, a program starts from address 0. |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

| Pin Name             | Pin No. | Input/<br>Output | Function                                                                                                                                                                                                                                            |
|----------------------|---------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| T0                   | 8       | Input            | Eternal interrupt input.<br>Since this pin is of a level interrupt type, it is required to be held at low level until an interrupt is accepted. Further, this pin serves as a test flag input for the conditional jump instructions (JT1 and JNT1). |
| T1                   | 19      | Input            | This pin is an external clock input for the timer counter at the time of the event counter mode, and has a built-in zero-cross detection circuit. Further, it serves as a test flag input for the conditional jump instructions (JT1 and JNT1).     |
| ALE                  | 18      | Output           | Address Latch Enable pin.<br>This pin is a clock output that regards 1 machine cycle (clock cycle x 30) as a cycle. (It is also used for the address latch in the test mode 2.)                                                                     |
| PROG                 | 37      | Output           | Output strobe for the I/O expander 8243.                                                                                                                                                                                                            |
| P00 ~ P07<br>(PORT0) | 10~17   | I/O              | 8-bit open drain port.<br>Since this pin has a built-in comparator which regards the voltage applied to VTH pin as a comparison voltage, it can change the input inverse level.<br>It contains a mask option with a pull-up resistor.               |

Toshiba



## INTEGRATED CIRCUIT

## TECHNICAL DATA

| Pin Name             | Pin No.               | Input/<br>Output | Function                                                                                                                                                                                                        |
|----------------------|-----------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P10 ~ P27<br>(PORT1) | 25~32                 | I/O              | 8-bit quasi-bidirectional port.                                                                                                                                                                                 |
| P20 ~ P27<br>(PORT2) | 33~36<br>38,39<br>1,2 | I/O              | 8-bit-bidirectional port.<br>The lower order 4-bit pins P20 to P23 serve as lines connecting the 4-bit I/O expander 8243.                                                                                       |
| VTH                  | 9                     | Input            | PORT0 threshold reference pin.                                                                                                                                                                                  |
| ANO, AN1             | 6,5                   | Input            | Analog input to A/D converter.<br>This pin switches the channels by use of soft according to SEL AN0 and SEL AN1 instructions. (2 channels)                                                                     |
| V <sub>AREF</sub>    | 4                     | Input            | The reference voltage of A/D Converter<br>Establishes the upper limit of A/D conversion range.                                                                                                                  |
| AVCC                 | 3                     | Power supply     | +5V (For A/D converter section)                                                                                                                                                                                 |
| AVSS                 | 7                     | "                | +5V (For A/D converter section)                                                                                                                                                                                 |
| VCC                  | 40                    | "                | +5V                                                                                                                                                                                                             |
| VSS                  | 20                    | "                | +0V                                                                                                                                                                                                             |
| SUBST                | 21                    | Output           | Substrate potential output pin.<br>This pin is used for the purpose of connecting a bypass capacitor across the VSS pin for improving the accuracy of the A/D converter by stabilizing the substrate potential. |

**BLOCK DIAGRAM**
**8022 Block Diagram**


## DESCRIPTION OF INSTRUCTIONS

- o The table of instructions for the TMP8022P is described by use of the following symbols and abbreviations.

|       |   |                                    |
|-------|---|------------------------------------|
| A     | : | Accumulator                        |
| AC    | : | Auxiliary carry                    |
| addr  | : | Lower order 8-bit address          |
| C     | : | Carry                              |
| CRR   | : | A/D conversion result register     |
| data  | : | 8-bit data                         |
| Pp    | : | Port      p=0, 1, 2    or P=4 ~ 7  |
| PC    | : | Program counter                    |
| Rr    | : | Register   r=0, 1   or r=0 ~ 7     |
| SP    | : | Stack pointer                      |
| T     | : | Timer                              |
| TF    | : | Timer flag                         |
| T0    | : | Test 0                             |
| T1    | : | Test 1                             |
| (x)   | : | Contents of x                      |
| ((x)) | : | Contents of address indicated by x |
| ^     | : | AND                                |
| ∨     | : | Logical OR                         |
| ⊻     | : | Exclusive OR                       |

## TMP8022 Instruction List (I)

| Classi-<br>fication        | Mnemonics     | Functional description                                | Effect ed |    | Bytes | Cycles | Operation<br>Code<br>(Hexadecimal) |
|----------------------------|---------------|-------------------------------------------------------|-----------|----|-------|--------|------------------------------------|
|                            |               |                                                       | Flag<br>C | AC |       |        |                                    |
| Accumulator<br>Instruction | ADD A, Rr     | $(A) \leftarrow (A) + (Rr)$ r=0-7                     | ○         | ○  | 1     | 1      | 68-6F                              |
|                            | ADD A, @Rr    | $(A) \leftarrow (A) + ((Rr))$ r=0,1                   | ○         | ○  | 1     | 1      | 60, 61                             |
|                            | ADD A, #data  | $(A) \leftarrow (A) + \text{data}$                    | ○         | ○  | 2     | 2      | 03                                 |
|                            | ADDC A, Rr    | $(A) \leftarrow (A) + (Rr) + (C)$ r=0-7               | ○         | ○  | 1     | 1      | 78-7F                              |
|                            | ADDC A, @Rr   | $(A) \leftarrow (A) + ((Rr)) + (C)$ r=0, 1            | ○         | ○  | 1     | 1      | 70-71                              |
|                            | ADDC A, #data | $(A) \leftarrow (A) + \text{data} + (C)$              | ○         | ○  | 2     | 2      | 13                                 |
|                            | ANL A, Rr     | $(A) \leftarrow (A) \wedge (Rr)$ r=0-7                | -         | -  | 1     | 1      | 58-5F                              |
|                            | ANL A, @Rr    | $(A) \leftarrow (A) \wedge ((Rr))$ r=0, 1             | -         | -  | 1     | 1      | 50-51                              |
|                            | ANL A, #data  | $(A) \leftarrow (A) \wedge \text{data}$               | -         | -  | 2     | 2      | 53                                 |
|                            | ORL A, Rr     | $(A) \leftarrow (A) \vee (Rr)$ r=0-7                  | -         | -  | 1     | 1      | 48-4F                              |
|                            | ORL A, @Rr    | $(A) \leftarrow (A) \vee ((Rr))$ r=0, 1               | -         | -  | 1     | 1      | 40-41                              |
|                            | ORL A, #data  | $(A) \leftarrow (A) \vee \text{data}$                 | -         | -  | 2     | 2      | 43                                 |
|                            | XRL A, Rr     | $(A) \leftarrow (A) \rightleftharpoons (Rr)$ r=0-7    | -         | -  | 1     | 1      | D8-DF                              |
|                            | XRL A, @Rr    | $(A) \leftarrow (A) \rightleftharpoons ((Rr))$ r=0, 1 | -         | -  | 1     | 1      | D0-D1                              |
|                            | XRL A, #data  | $(A) \leftarrow (A) \rightleftharpoons \text{data}$   | -         | -  | 2     | 2      | D3                                 |
|                            | INC A         | $(A) \leftarrow (A) + 1$                              | -         | -  | 1     | 1      | 17                                 |
|                            | DEC A         | $(A) \leftarrow (A) - 1$                              | -         | -  | 1     | 1      | 07                                 |
|                            | CLR A         | $(A) \leftarrow 0$                                    | -         | -  | 1     | 1      | 27                                 |
|                            | CPL A         | $(A) \leftarrow \text{NOT}(A)$                        | -         | -  | 1     | 1      | 37                                 |
|                            | DA A          | Decimal adjust A                                      | ○         | -  | 1     | 1      | 57                                 |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

| Classification             | Mnemonics     | Functional Description                                                                      | Effectuated |      | Bytes | Cycles | Operation Code<br>(Hexadecimal)  |
|----------------------------|---------------|---------------------------------------------------------------------------------------------|-------------|------|-------|--------|----------------------------------|
|                            |               |                                                                                             | Flag        | C AC |       |        |                                  |
| Instruction<br>Accumulator | SWAP A        | $(A_{4-7}) \leftrightarrow (A_{0-3})$                                                       | -           | -    | 1     | 1      | 47                               |
|                            | RL A          | $(A_{n+1}) \leftarrow (A_n), (A_0) \leftarrow (A_7)$<br>$n=0-6$                             | -           | -    | 1     | 1      | E7                               |
|                            | RLC A         | $(A_{n+1}) \leftarrow (A_n), (C) \leftarrow (A_7)$<br>$n=0-6, (A_0) \leftarrow (C)$         | ○           | -    | 1     | 1      | F7                               |
|                            | RR A          | $(A_n) \leftarrow (A_{n+1}), (A_7) \leftarrow (A_0)$                                        | -           | -    | 1     | 1      | 77                               |
|                            | RRC A         | $(A_n) \leftarrow (A_{n+1}), (C) \leftarrow (A_0)$<br>$n=0-6$<br>$(A_7) \leftarrow (C)$     | ○           | -    | 1     | 1      | 67                               |
| Instruction<br>I/O         | IN A, Pp      | $(A) \leftarrow (P_p)$<br>$p=0,1,2$                                                         | -           | -    | 1     | 2      | 08, 09, 0A                       |
|                            | OUTL Pp, A    | $(P_p) \leftarrow (A)$<br>$p=0,1,2$                                                         | -           | -    | 1     | 2      | 90, 39, 3A                       |
|                            | MOVD A, Pp    | $(A_{0-3}) \leftarrow (P_p)$<br>$(A_{4-7}) \leftarrow 0$                                    | -           | -    | 1     | 2      | 0C-0F                            |
|                            | MOVD Pp, A    | $(P_p) \leftarrow (A_{0-3})$<br>$p=4-7$                                                     | -           | -    | 1     | 2      | 3C-3F                            |
|                            | ANLD Pp, A    | $(P_p) \leftarrow (P_p) \wedge (A_{0-3})$<br>$p=4-7$                                        | -           | -    | 1     | 2      | 9C-9F                            |
|                            | ORLD Pp, A    | $(P_p) \leftarrow (P_p) \vee (A_{0-3})$<br>$p=4-7$                                          | -           | -    | 1     | 2      | 8C-8F                            |
| Register<br>Instruction    | INC Rr        | $(R_r) \leftarrow (R_r) + 1$<br>$r=0-7$                                                     | -           | -    | 1     | 1      | 18-1F                            |
|                            | INC @Rr       | $((R_r)) \leftarrow ((R_r)) + 1$<br>$r=0,1$                                                 | -           | -    | 1     | 1      | 10-11                            |
| Branch<br>Instruction      | JMP addr      | $(PC_{0-7}) \leftarrow$ Upper 3-bit of Operation code                                       | -           | -    | 2     | 2      | 04, 24, 44, 64<br>84, A4, C4, E4 |
|                            | JMPP @A       | $(PC_{0-7}) \leftarrow ((A))$                                                               | -           | -    | 1     | 2      | B3                               |
|                            | DJNZ Rr, addr | $(R_r) \leftarrow (R_r) - 1, \text{ If } (r) \neq 0$<br>$(PC_{0-7}) \leftarrow \text{addr}$ | -           | -    | 2     | 2      | E8-EF                            |
|                            | JC addr       | IF $(C)=1, (PC_{0-7}) \leftarrow \text{addr}$                                               | -           | -    | 2     | 2      | F6                               |



## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

| Classification         | Mnemonics     | Functional Description                                                             | Effectected Flag |    | Bytes | Cycles | Operation Code (Hexadecimal)     |
|------------------------|---------------|------------------------------------------------------------------------------------|------------------|----|-------|--------|----------------------------------|
|                        |               |                                                                                    | C                | AC |       |        |                                  |
| Branch Instruction     | JNC addr      | If (C)=0, (PC0-7)←addr                                                             | -                | -  | 2     | 2      | E6                               |
|                        | JZ addr       | If (A)=0, (PC0-7)←addr                                                             | -                | -  | 2     | 2      | C6                               |
|                        | JNZ addr      | If (A)≠0, (PC0-7)←addr                                                             | -                | -  | 2     | 2      | 96                               |
|                        | JTO addr      | If T0=1, (PC0-7) ← addr                                                            | -                | -  | 2     | 2      | 36                               |
|                        | JNT0 addr     | If T0=0, (PC0-7) ← addr                                                            | -                | -  | 2     | 2      | 26                               |
|                        | JT1 addr      | If T1=1, (PC0-7) ← addr                                                            | -                | -  | 2     | 2      | 56                               |
|                        | JNT1 addr     | If T1=0, (PC0-7) ← addr                                                            | -                | -  | 2     | 2      | 46                               |
|                        | JTF addr      | If TF=1, (PC0-7) ← addr                                                            | -                | -  | 2     | 2      | 16                               |
| Subroutine Instruction | CALL addr     | ((SP))←(PC), (SP)←(SP)+1<br>(PC0-7)←addr<br>(PC8-10)←Upper 3-bit of operation code | -                | -  | 1     | 2      | 14, 34, 54, 74<br>94, B4, D4, F4 |
|                        | RET           | (SP) ← (SP)-1<br>(PC) ← ((SP))                                                     | -                | -  | 1     | 2      | 83                               |
| Flags Instruction      | CLR C         | (C)←0                                                                              | ○                | -  | 1     | 1      | 97                               |
|                        | CPL C         | (C)←NOT(C)                                                                         | ○                | -  | 1     | 1      | A7                               |
| Data Moves Instruction | MOV A,Rr      | (A) ← (Rr) r=0-7                                                                   | -                | -  | 1     | 1      | F8-FF                            |
|                        | MOV A,@Rr     | (A) ← ((Rr)) r=0,1                                                                 | -                | -  | 1     | 1      | F0-F1                            |
|                        | MOV A,#data   | (A) ← data                                                                         | -                | -  | 2     | 2      | 23                               |
|                        | MOV Rr,A      | (Rr) ← (A) r=0-7                                                                   | -                | -  | 1     | 1      | A8-AF                            |
|                        | MOV @Rr,A     | ((Rr)) ← (A) r=0,1                                                                 | -                | -  | 1     | 1      | A0-A1                            |
|                        | MOV Rr,#data  | (Rr) ← data r=0-7                                                                  | -                | -  | 2     | 2      | B8-8F                            |
|                        | MOV @Rr,#data | ((Rr)) ← data r=0,1                                                                | -                | -  | 2     | 2      | B0-B1                            |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

| Classifi-cation           | Mnemonics  | Functional Description                                                  | Effect ed |    | Bytes | Cycles | Operation Code (Hexadecimal) |
|---------------------------|------------|-------------------------------------------------------------------------|-----------|----|-------|--------|------------------------------|
|                           |            |                                                                         | Flag C    | AC |       |        |                              |
| Data Moves Instruction    | XCH A,Rr   | (A) $\leftarrow$ (Rr) r=0-7                                             | -         | -  | 1     | 1      | 28-2F                        |
|                           | XCH A,@Rr  | (A) $\leftarrow$ ((Rr)) r=0,1                                           | -         | -  | 1     | 1      | 20-21                        |
|                           | XCHD a,@Rr | (A <sub>0-3</sub> ) $\leftarrow$ ((Rr)) r=0,1                           | -         | -  | 1     | 1      | 30-31                        |
|                           | MOV P A,@A | (PC <sub>0-7</sub> ) $\leftarrow$ (A) [Note]<br>(A) $\leftarrow$ ((PC)) | -         | -  | 1     | 2      | A3                           |
| Timer/Counter Instruction | MOV A,T    | (A) $\leftarrow$ (T)                                                    | -         | -  | 1     | 1      | 42                           |
|                           | MOV T,A    | (T) $\leftarrow$ (A)                                                    | -         | -  | 1     | 1      | 62                           |
|                           | STRT T     | Start timer                                                             | -         | -  | 1     | 1      | 55                           |
|                           | STRT CNT   | Start counter                                                           | -         | -  | 1     | 1      | 45                           |
|                           | STOP TCNT  | Stop timer/counter                                                      | -         | -  | 1     | 1      | 65                           |
| A/D Converter Instruction | RAD        | (A) $\leftarrow$ (CRR)                                                  | -         | -  | 1     | 2      | 80                           |
|                           | SEL AN0    | AN0 Selection, Conversion restart                                       | -         | -  | 1     | 1      | 85                           |
|                           | SNL AN1    | AN1 " "                                                                 | -         | -  | 1     | 1      | 95                           |
| Interrupts Instruction    | EI 1       | Enable external interrupt                                               | -         | -  | 1     | 1      | 05                           |
|                           | DIS 1      | Disable external interrupt                                              | -         | -  | 1     | 1      | 15                           |
|                           | EN TCNT1   | Enable timer/counter interrupt                                          | -         | -  | 1     | 1      | 25                           |
|                           | DIS TCNT1  | Disable timer/counter interrupt                                         | -         | -  | 1     | 1      | 35                           |
|                           | RETI       | (SP) $\leftarrow$ (SP) - 1<br>(PC) $\leftarrow$ ((SP))                  | -         | -  | 1     | 2      | 93                           |
|                           | NOP        | No Operation                                                            | -         | -  | 1     | 1      | 00                           |

Note) MOV P A, @A loads the contents of address indicated by accumulator A in the page, into accumulator A. After the execution, the contents of PC indicate the next address.



## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

## TMP8022P Instruction List (I)

| <del>IRO-3<br/>IRO4-7</del> | 0                     | 1                     | 2                   | 3                    | 4              | 5    | 6                     | 7          | 8         | 9         | A         | B         | C         | D         | E         | F |
|-----------------------------|-----------------------|-----------------------|---------------------|----------------------|----------------|------|-----------------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|---|
| 0                           | NOP                   |                       |                     | ADD A, <sup>#</sup>  | JMP ENI        |      | DEC A                 | IN A,PO    | IN A,P1   | IN A,P2   |           | MOVD A,P4 | MOVD A,P5 | MOVD A,P6 | MOVD A,P7 |   |
| 1                           | INC @R0               | INC @R1               |                     | ADDC A, <sup>#</sup> | CALL DISI      | JTF  | INC A,RO              | INC R1     | INC R2    | INC R3    | INC R4    | INC R5    | INC R6    | INC R7    |           |   |
| 2                           | XCH A,@H              | XCH A,@R1             |                     | MOV A, <sup>#</sup>  | JMP BN TCNTI   | JNTO | CLR XCH A, RO         | XCH A,R1   | XCH A,R2  | XCH A,R3  | XCH A,R4  | XCH A,R5  | XCH A,R6  | XCH A,R7  |           |   |
| 3                           | XCHD A,@H             | XCHD A,@R1            |                     |                      | CALL DIS TCNTI | JTO  | CPL A                 | OUTL P1,A  | OUTL P2,A |           | MOVD P4,A | MOVD P5,A | MOVD P6,A | MOVD P7,A |           |   |
| 4                           | ORL A,GR0             | ORL A,@BU             | MOV A,T             | ORL A, <sup>#</sup>  | JMP STRT CNT   | JNT1 | SWAP A,RO             | ORL A,R1   | ORL A,R2  | ORL A,R3  | ORL A,R4  | ORL A,R5  | ORL A,R6  | ORL A,R7  |           |   |
| 5                           | ANL A,@R0             | ANL A,@R1             |                     | ANL A, <sup>#</sup>  | CALL STRT T    | JT1  | DA A,RO               | ANL A,R1   | ANL A,R2  | ANL A,R3  | ANL A,R4  | ANL A,R5  | ANL A,R6  | ANL A,R7  |           |   |
| 6                           | ADD A,@H              | ADD A,@R1             | MOV A, <sup>#</sup> |                      | JMP STOP TCNT  |      | RRC A,RO              | ADD A,R1   | ADD A,R2  | ADD A,R3  | ADD A,R4  | ADD A,R5  | ADD A,R6  | ADD A,R7  |           |   |
| 7                           | ADDC A,@D             | ADDC A,@R1            |                     |                      | CALL           |      | RR A,RO               | ADDC A,R1  | ADDC A,R2 | ADDC A,R3 | ADDC A,R4 | ADDC A,R5 | ADDC A,R6 | ADDC A,R7 |           |   |
| 8                           | RAD                   |                       |                     | RET                  | JMP SEL ANO    |      |                       |            |           |           |           | ORLD P4,A | ORLD P5,A | ORLD P6,A | ORLD P7,A |   |
| 9                           | OUTL PO,A             |                       |                     | RETI                 | CALL SEL AN1   | JNZ  | CLR C                 |            |           |           |           | ANLD P4,A | ANLD P5,A | ANLD P6,A | ANLD P7,A |   |
| A                           | MOV @R0,A             | MOV @R1,A             |                     | MOV A, <sup>#</sup>  | JMP JMF        | CALL |                       | CPL C,RO,A | MOV R1,A  | MOV R2,A  | MOV R3,A  | MOV R4,A  | MOV R5,A  | MOV R6,A  | MOV R7,A  |   |
| B                           | MOV @R0, <sup>#</sup> | MOV @R1, <sup>#</sup> |                     | MOV @A               |                |      |                       | MOV R0,#   | MOV R1,#  | MOV R2,#  | MOV R3,#  | MOV R4,#  | MOV R5,#  | MOV R6,#  | MOV R7,#  |   |
| C                           |                       |                       |                     |                      | JMP            | JZ   |                       |            |           |           |           |           |           |           |           |   |
| D                           | XRL A,@H              | XRL A,@R1             |                     | XRL A, <sup>#</sup>  | CALL           |      | XRL A,RO              | XRL A,R1   | XRL A,R2  | XRL A,R3  | XRL A,R4  | XRL A,R5  | XRL A,R6  | XRL A,R7  |           |   |
| E                           |                       |                       |                     |                      | JMP            | JNC  | RL A,RO, <sup>#</sup> | DJNZ R1,#  | DJNZ R2,# | DJNZ R3,# | DJNZ R4,# | DJNZ R5,# | DJNZ R6,# | DJNZ R7,# |           |   |
| F                           | MOV AF@R0             | MOV AF@R1             |                     |                      | CALL           | JC   | RLC A,RO              | MOV A,R1   | MOV A,R2  | MOV A,R3  | MOV A,R4  | MOV A,R5  | MOV A,R6  | MOV A,R7  |           |   |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL           | PARAMETER                               | RATING      | UNIT |
|------------------|-----------------------------------------|-------------|------|
| VCC              | Supply Voltage                          | -0.5 ~ + 7  | V    |
| VINA             | Input Voltage (Except PRESET, PROG, T1) | -0.5 ~ + 7  | V    |
| VINB             | Input Voltage (Only PRESET, PROG, T1)   | -0.5 ~ + 13 | V    |
| P <sub>D</sub>   | Power Dissipation                       | 1.0         | W    |
| T <sub>opr</sub> | Operating Temperature                   | 0 ~ 70      | °C   |
| T <sub>stg</sub> | Storage Temperature                     | -55 ~ 150   | °C   |

DC CHARACTERISTICS    T<sub>opr</sub> = °C ~ 70°C, VCC = 5.5V ± 1V, VSS = 0V

| SYMBOL | PARAMETER                                                 | TEST CONDITION           | MIN.        | TYP. | MAX.        | UNIT |
|--------|-----------------------------------------------------------|--------------------------|-------------|------|-------------|------|
| VIL    | Input Low Voltage                                         | VTH Open                 | -0.5        |      | 0.8         | V    |
| VIL    | Input Low Voltage (PORTO)                                 |                          | -0.5        |      | VTH<br>-0.1 | V    |
| VIH    | Input High Voltage (All Except XTAL, RESET)               | VCC=5.0V±10%<br>VTH Open | 2.0         |      | VCC         | V    |
| VIH1   | Input High Voltage (All Except XTAL, RESET)               | VCC=5.5V±1V<br>VTH Open  | 3.0         |      | VCC         | V    |
| VIH2   | Input High Voltage (PORTO)                                |                          | VTH<br>+0.1 |      | VCC         | V    |
| VIH3   | Input High Voltage (PRESET, XTAL)                         |                          | 3.0         |      | VCC         | V    |
| VTH    | PORTO Threshold Comparison Voltage                        |                          | 0           |      | 0.4<br>VCC  | V    |
| VOL    | Output Low Voltage                                        | IOL = 1.6mA              |             |      | 0.45        | V    |
| VOL1   | Output Low Voltage (P10, P11)                             | IOL = 7 mA               |             |      | 2.5         | V    |
| VOH    | Output High Voltage (All unless Open Drain Option-Port 0) | IOH = -50µA              | 2.4         |      |             | V    |
| IL1    | Input Current (T <sub>1</sub> )                           | VSS=0.45V≤VIN≤VCC        |             |      | ±200        | µA   |
| IL0    | Output Leak Current (Open Drain Option-Port 0)            | VSS=0.45V≤VIN≤VCC        |             |      | ±10         | µA   |
| ICC    | VCC Supply Current                                        |                          | 50          |      | 100         | mA   |



# INTEGRATED CIRCUIT

## TECHNICAL DATA

AC CHARACTERISTICS 1     $T_a = 0^\circ\text{C} \sim 70^\circ\text{C}$     $V_{CC} = 5.5\text{V} \pm 1\text{V}$ ,  $V_{SS} = 0\text{V}$

| SYMBOL   | PARAMETER                            | TEST CONDITION                | MIN. | MAX.      | UNIT          |
|----------|--------------------------------------|-------------------------------|------|-----------|---------------|
| $t_{CY}$ | Cycle Time                           | At 3MHz XTAL 10 $\mu\text{s}$ | 8.38 | 50.0      | $\mu\text{s}$ |
| $V_{ZX}$ | Zero-cross Detection Input (T1)      |                               | 1    | 3         | VACPP         |
| $A_{ZX}$ | Zero-cross Accuracy                  | 60Hz Sinewave                 |      | $\pm 135$ | mV            |
| $F_{ZX}$ | Zero-cross Detection Input Frequency |                               | 0.05 | 1         | KHz           |

AC CHARACTERISTICS 2     $T_a = 0^\circ \sim 70^\circ\text{C}$     $V_{CC} = 5.5\text{V} \pm 1\text{V}$ ,  $V_{SS} = 0\text{V}$

| SYMBOL    | PARAMETER                                      | CONDITION                        | MIN. | MAX. | UNIT          |
|-----------|------------------------------------------------|----------------------------------|------|------|---------------|
| $t_{CP}$  | Port Control Setup Before Falling Edge of Prog |                                  | 0.5  |      | $\mu\text{s}$ |
| $t_{PC}$  |                                                |                                  | 0.8  |      | $\mu\text{s}$ |
| $t_{PR}$  | Prog to Time P2 Input must be Valid            |                                  |      | 1.0  | $\mu\text{s}$ |
| $t_{DP}$  | Output Data Setup Time                         |                                  | 7.0  |      | $\mu\text{s}$ |
| $t_{PD}$  | Output Data Hold Time                          |                                  | 8.3  |      | $\mu\text{s}$ |
| $t_{PF}$  | Input Data Hold Time                           |                                  | 0    | 150  | $\mu\text{s}$ |
| $t_{PP}$  | PROG Pulse Width                               |                                  | 8.3  |      | $\mu\text{s}$ |
| $t_{PRL}$ | ALE to Time P2 Input must be Valid             |                                  |      | 3.6  | $\mu\text{s}$ |
| $t_{PL}$  |                                                |                                  | 0.8  |      | $\mu\text{s}$ |
| $t_{LP}$  | Output Data Hold Time                          |                                  | 1.6  |      | $\mu\text{s}$ |
| $t_{PFL}$ | Input Data Hold Time                           |                                  | 0    |      | $\mu\text{s}$ |
| $t_{LL}$  | ALE Pulse Width                                | Max. at $t_{CY}=8.38\mu\text{s}$ | 3.9  | 23.0 | $\mu\text{s}$ |

Test Condition     $t_{CY} = 8.38 \mu\text{s}$      $C_L = 80 \text{ pF}$



## INTEGRATED CIRCUIT

## TECHNICAL DATA

A/D CONVERTER CHARACTERISTICS       $T_a=0^{\circ}\text{C}$     $70^{\circ}\text{C}$ ,  $V_{CC}=5.5\text{V}\pm1\text{V}$ ,  $V_{SS}=0\text{V}$ ,  $AV_{CC}=5.5\pm1\text{V}$ ,  
 $AV_{SS}=0\text{V}$ ,  $AV_{CC}/2 \leq V_{AREF} \leq AV_{CC}$

| PARAMETER                                            | MIN. | TYP. | MAX.                 | UNIT           | REMARK  |
|------------------------------------------------------|------|------|----------------------|----------------|---------|
| Resolution                                           | 8    |      |                      | Bits           |         |
| Absolute Accuracy                                    |      |      | .8% FST $\pm$ 1/2LSB | LSB            | Note 1) |
| Sample Setup Before Falling Edge of ALE ( $t_{SS}$ ) |      | 0.20 |                      | $\mu\text{CY}$ |         |
| Sample Hold After Falling Edge of ALE ( $t_{SH}$ )   |      | 0.10 |                      | $\mu\text{CY}$ |         |
| Input Capacitance                                    |      | 1    |                      | pF             |         |
| Conversion Time                                      | 4    |      | 4                    | $\mu\text{CY}$ |         |

Note 1) It is required that the analog input terminal is kept at a constant voltage during the smapling time ( $t_{SS} + t_{SH}$ ).

**TIMING DIAGRAM**
**A. NORMAL INSTRUCTION**

**B. EXPANDER INSTRUCTION**

**C. ANALOG INPUT**




## PROGRAM DELIVERY OF TMP8022P

The program delivery of the TMP8022P is performed by using a paper tape of the following format. At the same time, it is required that mask options should be clearly designated. The format of the paper tape is the same as the Intel's type object tape (hexadecimal tape output by Intel MDS system, PROMPT 48 Development Tool, etc.)

## (1) Mask Option

It is required that the presence of pull-up resistors is designated as to the 8 bits of PORT0, and the T1 terminal.

It is required that a mask option designation form attached to the ES Order Instruction Sheet is used for designation of mask option.

It is required that the mask option designation form is submitted together with the ES Order Instruction Manual within two weeks before the submission date of tape.

## Example of mask option designation

0 : Without pull-up register      1 : With pull-up register

| Terminal name<br>Option designation | PORT0 |   |   |   |   |   |   |   | T1 |
|-------------------------------------|-------|---|---|---|---|---|---|---|----|
|                                     | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |    |
| Presence of pull-up resistor        | 1     | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1  |

In this case, the presence of pull-up resistors is as follows:

Pins with pull-up resistors ..... P07, P03, P02 and T1

Pins without pull-up resistors ... P06, P05, P04, P01 and P00

## (2) Tape Format



## (3) Example of Tape List

```

TOSHIBA MICRO COMPUTER TLSC-84
:100000000665C7D79CF50F3F951FED55A8FF16E570
:10001000088884de67D31F5D8ABA6DF292F113F5C1
:100020004FF1FB5DFFFDA96A99CF7DF94A346B7C09
:10003000197352F729F12F79AA9C057C5B851EED77
:
:
:
:1003C0005DFDB5E556A67277F61A51C631CF9FOE80
:1003D0000BD2F6F20E8BB1977E3FB5AD1E41FDAE7E2
:1003E000B53D42E0EC32546025B7308CDD52063D1D
:1003F000B4BE9E9E345B6138060B20BC372BF60BD6
:00000001FF

```

UNIT : mm



- Note:
1. This dimension shows the center of curvature of leads.
  2. This dimension shows spread of leads.
  3. The pitch of leads is 2.54 and the tolerance is  $\pm 0.25$  from the theoretical center of each lead obtained No.40 lead as the reference.

**Toshiba****INTEGRATEDCIRCUIT****東芝****TECHNICAL DATA****8-BIT SINGLE-CHIP MICROCOMPUTER****PRELIMINAR.**

TOSHIBA MOS TYPE DIGITAL

INTEGRATED CIRCUIT

TMP80C49P-6, TMP80C39P-6

Silicon Monolithic

CMOS Silicon Gate

**GENERAL DESCRIPTION**

The TMP80C49P-6 is a single chip microcomputer fabricated in Silicon Gate CMOS technology which provides internal 8-bit parallel architecture.

The following basic architectural functions of a computer have been included in a single chip; an 8-bit CPU, 128 × 8 RAM data memory, 2K × 8 ROM program memory, 27 I/O lines and an 8-bit timer/event counter.

The TMP80C49P-6 is particularly efficient as a controller. It has extensive bit handling capability as well as facilities for both binary and BCD arithmetic.

The TMP80C39P-6 is the equivalent of a TMP80C49P-6 without ROM program memory on chip. By using this device with external EPROM or RAM, software debugging becomes easy.

**FEATURES**

- Software compatible with TMP8049P/i8049
- CMOS/LSI for low power dissipation – less than 50 mW at 5V, 6MHz
- High Noise Immunity
- 2.5 $\mu$ s Instruction Cycle
- Extended temperature operation:  
-40°C to +85°C
- Single power supply
- 2K × 8 masked ROM
- 128 × 8 RAM
- 27 I/O lines
- Interval Timer/Event Counter
- Power Down Mode

**PIN CONNECTIONS (TOP VIEW)**

## BLOCK DIAGRAM



東芝

# INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP80C49P-6

TMP80C39P-6

PRELIMINARY

### PIN NAMES AND PIN DESCRIPTION

V<sub>SS</sub> (Power Supply)  
Circuit GND potential

V<sub>CC</sub> (Power Supply)  
+5V during operation

$\overline{PS}$  (Input)  
The control signal for the power saving at the power down mode  
(Active Low)

PROG (Output)  
Output strobe for the TMP8243P I/O expander.

P10-P17 (Input/Output) Port 1  
8-bit quasi-bidirectional port (Internal Pullup  $\approx$  50K $\Omega$ ).

P20-P27 (Input/Output) Port 2  
8-bit quasi-bidirectional port (Internal Pullup  $\approx$  50K $\Omega$ ).

P20-P23 contain the four high order program counter bits during an external program memory fetch and serve as a 4-bit I/O expander bus for the TMP8243P.

DB0-DB7 (Input/Output, Tri-State)  
True bidirectional port which can be written or read synchronously using the RD, WR strobes. The port can also be statically latched. Contains the 8 low order program counter bits during an external program memory fetch, and receives the addressed instruction under the control of PSEN. Also contains the address and data during an external RAM data store instruction, under control of ALE, RD, and WR.

T<sub>0</sub> (Input/Output)  
Input pin testable using the conditional transfer instructions JTO and JNT0. T<sub>0</sub> can be designated as a clock output using ENTO CLK instruction. T<sub>0</sub> is also used during programming.

T<sub>1</sub> (Input)  
Input pin testable using the JT1 and JNT1 instruction. Can be designated the event counter input using the timer/STRT CNT instruction.

INT (Input)  
External interrupt input. Initiates an interrupt if interrupt is enabled. Interrupt is disabled after a reset. Also testable with conditional jump instruction. (Active low)

$\overline{RD}$  (Output)  
Output strobe activated during a Bus read. Can be used to enable data onto the Bus from an external device. Used as a Read Strobe to External Data Memory (Active Low).

TMP80C49P-6

TMP80C39P-6

**WR** (Output)

Output strobe during a Bus write (Active Low). Used as a Write Strobe to External Data Memory.

**RESET** (Input)

Active Low signal which is used to initialize the Processor. Also used during the power down mode.

**ALE** (Output)

Address Latch Enable. This signal occurs once during each cycle and is useful as a clock output. The negative edge of ALE strobes address into external data and program memory.

**PSEN** (Output)

Program Store Enable. This output occurs only during a fetch to external program memory (Active Low).

**SS** (Input)

Single step input can be used in conjunction with ALE to "single step" processor through each instruction when SS is low the CPU is placed into a wait state after it has completed the instruction being executed. Also used during the power down mode.

**EA** (Input)

External Access input which forces all program memory fetches to reference external memory. Useful for emulation and debug and essential for testing and program verification. (Active High)

**XTAL 1** (Input)

One side of crystal input for internal oscillator. Also input for external source.

**XTAL 2** (Input)

Other side of crystal input.



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP80C49P-6

TMP80C39P-6

PRELIMINARY

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL              | ITEM                                                                    | RATING                         |
|---------------------|-------------------------------------------------------------------------|--------------------------------|
| V <sub>CC</sub>     | V <sub>CC</sub> Supply Voltage (with respect to GND (V <sub>SS</sub> )) | -0.5V to +7V                   |
| V <sub>INA</sub>    | Input Voltage (Except EA)                                               | -0.5V to V <sub>CC</sub> +0.5V |
| V <sub>INB</sub>    | Input Voltage (Only EA)                                                 | -0.5V to +13V                  |
| P <sub>D</sub>      | Power Dissipation (Ta=85°C)                                             | 250mW                          |
| T <sub>SOLDER</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                                                   | -40°C to 85°C                  |

DC CHARACTERISTICS (I) T<sub>OPR</sub>=-40°C to 85°C, V<sub>CC</sub>=+5V±10%, V<sub>SS</sub>=0V, unless otherwise noted.

| SYMBOL            | PARAMETER                                                                         | TEST CONDITIONS                                                                                                                       | MIN.                    | TYP. | MAX.            | UNIT |
|-------------------|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------|-----------------|------|
| V <sub>IL</sub>   | Input Low Voltage                                                                 |                                                                                                                                       | -0.5                    | -    | 0.8             | V    |
| V <sub>IH</sub>   | Input High Voltage (Except XTAL1, XTAL2, RESET, T <sub>0</sub> , T <sub>1</sub> ) |                                                                                                                                       | 2.2                     | -    | V <sub>CC</sub> | V    |
| V <sub>IH1</sub>  | Input High Voltage (XTAL1, XTAL2, RESET)                                          |                                                                                                                                       | 0.7V <sub>CC</sub>      | -    | V <sub>CC</sub> | V    |
| V <sub>IH2</sub>  | Input High Voltage (T <sub>0</sub> , T <sub>1</sub> )                             |                                                                                                                                       | 0.5V <sub>CC</sub>      | -    | V <sub>CC</sub> | V    |
| V <sub>OL</sub>   | Output Low Voltage (Except P10-P17, P20-P27)                                      | I <sub>OL</sub> =1.6mA                                                                                                                | -                       | -    | 0.45            | V    |
| V <sub>OL1</sub>  | Output Low Voltage (P10-P17, P20-P27)                                             | I <sub>OL</sub> =1.2mA                                                                                                                | -                       | -    | 0.45            | V    |
| V <sub>OH11</sub> | Output High Voltage (Except P10-P17, P20-P27)                                     | I <sub>OH</sub> =-1.6mA                                                                                                               | 2.4                     | -    | -               | V    |
| V <sub>OH12</sub> | Output High Voltage (Except P10-P17, P20-P27)                                     | I <sub>OH</sub> =-400μA                                                                                                               | V <sub>CC</sub><br>-0.8 | -    | -               | V    |
| V <sub>OH21</sub> | Output High Voltage (P10-P17, P20-P27)                                            | I <sub>OH</sub> =-50μA                                                                                                                | 2.4                     | -    | -               | V    |
| V <sub>OH22</sub> | Output High Voltage (P10-P17, P20-P27)                                            | I <sub>OH</sub> =-25μA                                                                                                                | V <sub>CC</sub><br>-0.8 | -    | -               | V    |
| I <sub>LI</sub>   | Input Leak Current (T <sub>1</sub> , INT, EA, PS)                                 | V <sub>SS</sub> ≤V <sub>IN</sub> ≤V <sub>CC</sub>                                                                                     | -                       | -    | ±10             | μA   |
| I <sub>L11</sub>  | Input Leak Current (SS, RESET)                                                    | V <sub>SS</sub> ≤V <sub>IN</sub> ≤V <sub>CC</sub>                                                                                     | -                       | -    | -50             | μA   |
| I <sub>L12</sub>  | Input Leak Current (P10-P17, P20-P27)                                             | V <sub>SS</sub> +0.45V≤V <sub>IN</sub> ≤V <sub>CC</sub>                                                                               | -                       | -    | -500            | μA   |
| I <sub>LO</sub>   | Output Leak Current (BUS, TO) (High impedance condition)                          | V <sub>SS</sub> +0.45V≤V <sub>IN</sub> ≤V <sub>CC</sub>                                                                               | -                       | -    | ±10             | μA   |
| I <sub>CC</sub>   | V <sub>CC</sub> Supply Current                                                    | V <sub>CC</sub> =5V, f <sub>Xtal</sub> =6MHz<br>V <sub>IH</sub> =V <sub>CC</sub> -0.2V<br>V <sub>IL</sub> =0.2V, C <sub>X2</sub> =0pF | -                       | -    | 10              | mA   |



## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP80C49P-6

TMP80C39P-6

PRELIMINARY

## DC CHARACTERISTICS (II)

 $T_{OPR} = -40^\circ\text{C}$  to  $85^\circ\text{C}$ ,  $V_{CC} = +5V \pm 20\%$ ,  $V_{SS} = 0V$ , Unless otherwise noted.

| SYMBOL     | PARAMETER                                                          | TEST CONDITIONS                                                                                       | MIN.             | TYP. | MAX.                  | UNIT          |
|------------|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|------------------|------|-----------------------|---------------|
| $V_{IL}$   | Input Low Voltage                                                  |                                                                                                       | -0.5             | -    | 0.15<br>$V_{CC}$      | V             |
| $V_{IH}$   | Input High Voltage (Except XTAL1, XTAL2, RESET, T0, T1)            |                                                                                                       | 0.5 $V_{CC}$     | -    | $V_{CC}$              | V             |
| $V_{IH1}$  | Input High Voltage (XTAL1, XTAL2, RESET)                           |                                                                                                       | 0.7 $V_{CC}$     | -    | $V_{CC}$              | V             |
| $V_{IH2}$  | Input High Voltage (T0, T1)                                        |                                                                                                       | 0.5 $V_{CC}$     | -    | $V_{CC}$              | V             |
| $V_{OL}$   | Output Low Voltage (Except P10-P17, P20-P27)                       | $I_{OL}=1.6\text{mA}$                                                                                 | -                | -    | 0.45                  | V             |
| $V_{OL1}$  | Output Low Voltage (P10-P17, P20-P27)                              | $I_{OL}=1.2\text{mA}$                                                                                 | -                | -    | 0.45                  | V             |
| $V_{OH12}$ | Output High Voltage (Except P10-P17, P20-P27)                      | $I_{OH}=-400\mu\text{A}$                                                                              | $V_{CC}$<br>-0.8 | -    | -                     | V             |
| $V_{OH22}$ | Output High Voltage (P10-P17, P20-P27)                             | $I_{OH}=-25\mu\text{A}$                                                                               | $V_{CC}$<br>-0.8 | -    | -                     | V             |
| $I_{LI}$   | Input Leak Current (T1, INT, EA, PS)                               | $V_{SS} \leq V_{IN} \leq V_{CC}$                                                                      | -                | -    | $\pm 10$              | $\mu\text{A}$ |
| $I_{LI1}$  | Input Leak Current ( $\overline{SS}$ , $\overline{\text{RESET}}$ ) | $V_{SS} \leq V_{IN} \leq V_{CC}$                                                                      | -                | -    | $-\frac{V_{CC}}{0.1}$ | $\mu\text{A}$ |
| $I_{LI2}$  | Input Leak Current (P10-P17, P20-P27)                              | $V_{SS}+0.45V \leq V_{IN} \leq V_{CC}$                                                                | -                | -    | $-\frac{V_{CC}}{0.1}$ | $\mu\text{A}$ |
| $I_{LO}$   | Output Leak Current (BUS, T0) (High impedance condition)           | $V_{SS}+0.45V \leq V_{IN} \leq V_{CC}$                                                                | -                | -    | $\pm 10$              | $\mu\text{A}$ |
| $I_{CC}$   | $V_{CC}$ Supply Current                                            | $V_{CC}=5V$ , $f_{XTAL}=6\text{MHz}$<br>$V_{IH}=V_{CC}-0.2V$ ,<br>$V_{IL}=0.2V$ , $C_{X2}=0\text{pF}$ | -                | -    | 10                    | mA            |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP80C49P-6

TMP80C39P-6

PRELIMINARY

## AC CHARACTERISTICS

 $T_{OPR} = -40^\circ\text{C to } 85^\circ\text{C}$ ,  $V_{CC} = +5V \pm 20\%$ ,  $V_{SS} = 0V$ , Unless Otherwise Noted.

| SYMBOL    | PARAMETER                                                      | TEST CONDITIONS     | MIN. | TYP. | MAX. | UNITS         |
|-----------|----------------------------------------------------------------|---------------------|------|------|------|---------------|
| $t_{LL}$  | ALE Pulse Width                                                |                     | 400  | -    | -    | ns            |
| $t_{AL}$  | Address Setup Time (ALE)                                       |                     | 150  | -    | -    | ns            |
| $t_{LA}$  | Address Hold Time (ALE)                                        |                     | 80   | -    | -    | ns            |
| $t_{CC}$  | Control Pulse Width ( $\bar{PSEN}$ , $\bar{RD}$ , $\bar{WR}$ ) |                     | 700  | -    | -    | ns            |
| $t_{DW}$  | Data Setup Time ( $\bar{WR}$ )                                 |                     | 500  | -    | -    | ns            |
| $t_{WD}$  | Data Hold Time ( $\bar{WR}$ )                                  | $C_L = 20\text{pF}$ | 120  | -    | -    | ns            |
| $t_{CY}$  | Cycle Time                                                     |                     | 2.5  | -    | 15.0 | $\mu\text{s}$ |
| $t_{DR}$  | Data Hold Time ( $\bar{PSEN}$ , $\bar{RD}$ )                   |                     | 0    | -    | 200  | ns            |
| $t_{RD}$  | Data Input Read Time ( $\bar{PSEN}$ , $\bar{RD}$ )             |                     | -    | -    | 500  | ns            |
| $t_{AW}$  | Address Setup Time ( $\bar{WR}$ )                              |                     | 230  | -    | -    | ns            |
| $t_{AD}$  | Address Setup Time (Data Input)                                |                     | -    | -    | 950  | ns            |
| $t_{AFC}$ | Address Float Time ( $\bar{RD}$ , $PSEN$ )                     |                     | 0    | -    | -    | ns            |
| $t_{CP}$  | Port Control Setup Time (PROG)                                 |                     | 110  | -    | -    | ns            |
| $t_{PC}$  | Port Control Hold Time (PROG)                                  |                     | 130  | -    | -    | ns            |
| $t_{PR}$  | Port 2 Input Data Set Time (PROG)                              |                     | -    | -    | 310  | ns            |
| $t_{DP}$  | Output Data Setup Time (PROG)                                  |                     | 220  | -    | -    | ns            |
| $t_{PD}$  | Output Data Hold Time (PROG)                                   |                     | 65   | -    | -    | ns            |
| $t_{PF}$  | Port 2 Input Data Hold Time (PROG)                             |                     | 0    | -    | 150  | ns            |
| $t_{PP}$  | PROG Pulse Width                                               |                     | 1510 | -    | -    | ns            |
| $t_{PL}$  | Port 2 I/O Data Setup Time                                     |                     | 600  | -    | -    | ns            |
| $t_{LP}$  | Port 2 I/O Data Hold Time                                      |                     | 150  | -    | -    | ns            |

Note :  $t_{CY} = 2.5\mu\text{s}$  ( $f_X = 6\text{MHz}$ )Control Outputs :  $C_L = 80\text{pF}$ , BUS Outputs ;  $C_L = 150\text{pF}$

## TIMING WAVEFORM

## A. Instruction Fetch from External Program Memory



## B. Read from External Data Memory



**C. Write into External Data Memory**

**D. Timing of Port 2 during Expander Instruction Execution**


## POWER DOWN MODE (I) ----- Data Hold Mode in RAM

The operation of oscillation circuit is suspended by setting  $\overline{PS}$  terminal to low level after  $\overline{RESET}$  terminal has been set to low level. Consequently, all the data in RAM area can be held in low power consumption.

The minimum hold voltage of  $V_{CC}$  in this mode is 2V.

$\overline{PS}$  terminal is set to high level to resume osillation after  $V_{CC}$  has been reset to 5V, and then  $\overline{RESET}$  terminal is set to high level, thus, the normal mode is restarted from the initialize operation (address 0).

DC CHARACTERISTICS ( $T_{OPR}=-40^{\circ}\text{C}$  to  $85^{\circ}\text{C}$ ,  $V_{SS}=0\text{V}$ )

| SYMBOL    | PARAMETER          | TEST CONDITION                                                    | MIN. | TYP. | MAX. | UNIT          |
|-----------|--------------------|-------------------------------------------------------------------|------|------|------|---------------|
| $V_{SB1}$ | Standby Voltage(1) |                                                                   | 2.0  | -    | 6.0  | V             |
| $I_{SB1}$ | Standby Current(1) | $V_{CC}=5\text{V}, V_{IH}=V_{CC}-0.2\text{V}, V_{IL}=0.2\text{V}$ | -    | 0.5  | 10   | $\mu\text{A}$ |

AC CHARACTERISTICS ( $T_{OPR}=-40^{\circ}\text{C}$  to  $85^{\circ}\text{C}$ ,  $V_{CC}=5\text{V}\pm20\%$ ,  $V_{SS}=0\text{V}$ )

| SYMBOL     | PARAMETER                                    | TEST CONDITION | MIN. | TYP. | MAX. | UNIT               |
|------------|----------------------------------------------|----------------|------|------|------|--------------------|
| $t_{PSHR}$ | Power Save Hold Time ( $\overline{RESET}$ )  |                | 10   | -    | -    | $\mu\text{s}$      |
| $t_{PSSR}$ | Power Save Setup Time ( $\overline{RESET}$ ) |                | 10   | -    | -    | $\text{m}\text{s}$ |
| $t_{VH}$   | $V_{CC}$ Hold Time ( $\overline{PS}$ )       |                | 5    | -    | -    | $\mu\text{s}$      |
| $t_{VS}$   | $V_{CC}$ Setup Time ( $\overline{PS}$ )      |                | 5    | -    | -    | $\mu\text{s}$      |

Note :  $t_{cy}=2.5\mu\text{s}$  ( $f_x=6\text{MHz}$ )

## TIMING WAVEFORM



## POWER DOWN MODE (II) ----- All Data Hold Mode

The operation of oscillation circuit is suspended by setting  $\overline{PS}$  terminal to low level after  $\overline{SS}$  terminal has been set to low level. Consequently, all data can be held in low power consumption.

The minimum hold voltage of  $V_{CC}$  in this mode is 3V.

$\overline{PS}$  terminal is set to high level to resume oscillation after  $V_{CC}$  has been reset to 5V, and then  $\overline{SS}$  terminal is set to high level, thus, the normal mode is restarted continuously from the state just before the power down mode (II).

DC CHARACTERISTICS ( $T_{OPR}=-40^{\circ}\text{C}$  to  $85^{\circ}\text{C}$ ,  $V_{SS}=0\text{V}$ )

| SYMBOL    | PARAMETER          | TEST CONDITION                                                    | MIN. | TYP. | MAX. | UNIT          |
|-----------|--------------------|-------------------------------------------------------------------|------|------|------|---------------|
| $V_{SB2}$ | Standby Voltage(2) |                                                                   | 3.0  | -    | 6.0  | V             |
| $I_{SB2}$ | Standby Current(2) | $V_{CC}=5\text{V}, V_{IH}=V_{CC}-0.2\text{V}, V_{IL}=0.2\text{V}$ | -    | 0.5  | 10   | $\mu\text{A}$ |

AC CHARACTERISTICS ( $T_{OPR}=-40^{\circ}\text{C}$  to  $85^{\circ}\text{C}$ ,  $V_{CC}=5\text{V}\pm20\%$ ,  $V_{SS}=0\text{V}$ )

| SYMBOL     | PARAMETER                                 | TEST CONDITION | MIN. | TYP. | MAX. | UNIT               |
|------------|-------------------------------------------|----------------|------|------|------|--------------------|
| $t_{PSHS}$ | Power Save Hold Time ( $\overline{SS}$ )  |                | 5    | -    | -    | $\mu\text{s}$      |
| $t_{PSSS}$ | Power Save Setup Time ( $\overline{SS}$ ) |                | 10   | -    | -    | $\text{m}\text{s}$ |
| $t_{VH}$   | $V_{CC}$ Hold Time ( $\overline{PS}$ )    |                | 5    | -    | -    | $\mu\text{s}$      |
| $t_{VS}$   | $V_{CC}$ Setup Time ( $\overline{PS}$ )   |                | 5    | -    | -    | $\mu\text{s}$      |

Note :  $t_{cy}=2.5\mu\text{s}$  ( $f_x=6\text{MHz}$ )

## TIMING WAVEFORM



## PIN STATUS IN THE POWER DOWN MODE

Each pin status in the power down mode (I)/(II) is shown in the following table.

| PIN NAME       | POWER DOWN MODE (I)                                                     | POWER DOWN MODE (II)                                                    |
|----------------|-------------------------------------------------------------------------|-------------------------------------------------------------------------|
| DB0 - DB7      | High Impedance<br>Input Disabled                                        | High Impedance<br>Input Disabled                                        |
| P20 - P23      | Output "0" (at EA=1)<br>High Impedance (at EA=0)<br>Input Disabled      | Output PC <sub>H</sub>                                                  |
| P24 - P27      | High Impedance<br>Input Disabled                                        | Output the data Contained<br>in the Port (Open Drain)                   |
| P10 - P17      | High Impedance<br>Input Disabled                                        | Output the data Contained<br>in the Port (Open Drain)                   |
| T <sub>0</sub> | High Impedance<br>Input Disabled                                        | High Impedance<br>Input Disabled                                        |
| T <sub>1</sub> | Input Disabled                                                          | Input Disabled                                                          |
| XTAL1<br>XTAL2 | High Impedance                                                          | High Impedance                                                          |
| RESET, SS      | Input Disabled when oscillator is stopped Pull-up transistor turned off | Input Disabled when oscillator is stopped Pull-up transistor turned off |
| INT, EA        | Input Disabled when oscillator is stopped                               | Input Disabled when oscillator is stopped                               |
| RD, WR         | Output "1"                                                              | Output "1"                                                              |
| ALE            | Output "0"                                                              | Output "1"                                                              |
| PROG           | Output "1"                                                              | Output "1"                                                              |
| PSEN           | Output "0" (at EA=1)<br>Output "1" (at EA=0)                            | Output "1"                                                              |

**OUTLINE DRAWING**


- 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.42 leads.

## INPUT/OUTPUT EXPANDER

## GENERAL DESCRIPTION

The TMP82C43P is an input/output expander designed specifically to provide a low cost means of I/O expansion for the TLCS-84C family.

The I/O ports of the TMP82C43P serve as a direct extension of the resident I/O facilities of the TLCS-84C microcomputers and are accessed by their own MOVD, ANLD, and ORLD instructions.

## FEATURES

- CMOS LSI for low power dissipation
- Low cost
- Simple interface to TLCS-84C microcomputers
- Four 4-bit I/O ports
- AND and OR directly to ports
- Single 5V supply
- High output drive
- Direct extension of resident TMP80C49P-6 I/O ports.
- PIN compatible with intel's 8243
- Extended operation temperature range -40°C to 85°C

## BLOCK DIAGRAM

## PIN CONNECTION (TOP VIEW)



### PIN NAMES AND PIN DESCRIPTION

#### PROG (Input)

Clock input. A high to low transition on PROG signifies that address and control are available on P20-23, and a low to high transition signifies that data is available on P20-23.

#### $\overline{CS}$ (Input)

Chip Select Input. A high on  $\overline{CS}$  inhibits any change of output or internal status.

#### P20-23 (Input/Output, 3-state)

Four (4) bit bi-directional port contains the address and control bits on a high to low transition of PROG. During a low to high transition contains the data for a selected output port if a write operation, or the data from a selected port before the low to high transition if a read operation.

#### P40-43, P50-53, P60-63, P70-73 (Input/Output, 3-state)

Four (4) bit bi-directional I/O ports. May be programmed to be input (during read), low impedance latched output (after write) or a 3-state (after read). Data on pins P20-23 may be directly written, ANDed or ORed with previous data.

#### $V_{CC}$ (Power)

+5 volt supply

#### GND (Power)

0 volt supply

### FUNCTIONAL DESCRIPTION

#### General Operation

The TMP82C43P contains four 4-bit I/O ports which serve as an extension of the on-chip I/O and are addressed as ports 4-7. The following operations may be performed on these ports.

- Transfer accumulator to port
- Transfer port to accumulator
- AND accumulator to port
- OR accumulator to port

All communication between the microcomputer (TMP80C49P-6) and the TMP82C43P occurs over Port 2 (P20-23) with timing provided by an output pulse on the PROG pin of the processor. Each transfer consists of two 4-bit nibbles.

A high to low transition of the PROG line indicates that address is present while a low to high transition indicates the presence of data. Additional TMP82C43P's may be added to the 4-bit bus and chip selected using additional output lines from the microcomputer.

#### Power On Initialization

Initial application of power to the device forces input/output ports 4, 5, 6, and 7 to the tri-state and port 2 to the input mode. The PROG pin may be either high or low when power is applied. The first high to low transition of PROG causes device to exit power on mode. The power on sequence is initiated if V<sub>CC</sub> drops below 1V.

| P21 | P20 | Address Code | P23 | P22 | Instruction Code |
|-----|-----|--------------|-----|-----|------------------|
| 0   | 0   | Port 4       | 0   | 0   | Read             |
| 0   | 1   | Port 5       | 0   | 1   | Write            |
| 1   | 0   | Port 6       | 1   | 0   | ORLD             |
| 1   | 1   | Port 7       | 1   | 1   | ANLD             |

#### Write Modes

The device has three write modes. MOVD Pi, A directly writes new data into the selected port and old data is lost. ORLD Pi, A takes new data, OR's it with the old data and then writes it to the port. ANLD Pi, A takes new data AND's it with the old data and then writes it to the port. Operation code and port address are latched from the input port 2 on the high to low transition of the PROG pin. On the low to high transition of PROG data on port 2 is transferred to the logic block of the specified output port.

After the logic manipulation is performed, the data is latched and outputed. The old data remains latched until new valid outputs are entered.



## Read Mode

The device has one read mode. The operation code and port address are latched from the input port 2 on the high to low transition of the PROG pin. As soon as the read operation and port address are decoded, the appropriate outputs are 3-stated, and the input buffers switched on. The read operation is terminated by a low to high transition of the PROG pin. The port (4, 5, 6 or 7) that was selected is switched to the 3-stated mode while port 2 is returned to the input mode.

Normally, a port will be in an output (write mode) or input (read mode). If modes are changed during operation, the first read following a write should be ignored; all following reads are valid. This is to allow the external driver on the port to settle after the first read instruction removes the low impedance drive from the TMP82C43P output. A read of any port will leave that port in a high impedance state.



TMP8243P

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL       | ITEM                                           | RATING                 |
|--------------|------------------------------------------------|------------------------|
| $V_{CC}$     | $V_{CC}$ Supply Voltage with Respect to GND    | -0.5V to +7.0V         |
| $V_{IN}$     | Input Voltage with Respect to GND              | -0.5V to $V_{CC}+0.5V$ |
| $V_{OUT}$    | Output Voltage with Respect to GND             | -0.5V to $V_{CC}+0.5V$ |
| $P_D$        | Power Dissipation                              | 250mW                  |
| $T_{SOLDER}$ | Soldering Temperature (soldering Time 10 sec.) | 260°C                  |
| $T_{STG}$    | Storage Temperature                            | -65°C to +150°C        |
| $T_{OPR}$    | Operating Temperature                          | -40°C to +85°C         |

D.C. CHARACTERISTICS (I)  $T_{OPR}=-40^\circ\text{C} \sim 85^\circ\text{C}$ ,  $V_{CC}=5\text{V}\pm10\%$ ,  $V_{SS}=0\text{V}$ 

| SYMBOL     | PARAMETER                                    | TEST CONDITION                                                                                          | MIN.         | TYP. | MAX.     | UNITS         |
|------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------|--------------|------|----------|---------------|
| $V_{IL}$   | Input Low Voltage                            |                                                                                                         | -0.5         |      | 0.8      | V             |
| $V_{IH}$   | Input High Voltage                           |                                                                                                         | 2.2          |      |          | V             |
| $V_{OL1}$  | Output Low Voltage Ports 4-7                 | $I_{OL}=5\text{mA}$                                                                                     |              |      | 0.45     | V             |
| $V_{OL2}$  | Output Low Voltage Port 7                    | $I_{OL}=20\text{mA}$                                                                                    |              |      | 1.0      | V             |
| $V_{OL3}$  | Output Low Voltage Port 2                    | $I_{OL}=0.8\text{mA}$                                                                                   |              |      | 0.45     | V             |
| $V_{OH11}$ | Output High Voltage Ports 4-7                | $I_{OH}=-1.2\text{mA}$                                                                                  | 2.4          |      |          | V             |
| $V_{OH21}$ | Output High Voltage Port 2                   | $I_{OH}=-0.6\text{mA}$                                                                                  | 2.4          |      |          | V             |
| $V_{OH12}$ | Output High Voltage Ports 4-7                | $I_{OH}=-0.6\text{mA}$                                                                                  | $V_{CC}-0.8$ |      |          | V             |
| $V_{OH22}$ | Output High Voltage Port 2                   | $I_{OH}=-0.3\text{mA}$                                                                                  | $V_{CC}-0.8$ |      |          | V             |
| $I_{IL1}$  | Input Leakage Port 4-7                       | $V_{SS} \leq V_{IN} \leq V_{CC}$                                                                        |              |      | $\pm 10$ | $\mu\text{A}$ |
| $I_{IL2}$  | Input Leakage Port 2, $\overline{CS}$ , PROG | $V_{SS} \leq V_{IN} \leq V_{CC}$                                                                        |              |      | $\pm 10$ | $\mu\text{A}$ |
| $I_{CC1}$  | Power Supply Current (1)                     | $V_{CC}=5\text{V}$ , $V_{IL}=0.2\text{V}$<br>$V_{IH}=V_{CC}-0.2\text{V}$<br>PROG PERIOD=5 $\mu\text{s}$ |              |      | 2        | mA            |
| $I_{CC2}$  | Power Supply Current (2)                     | $V_{CC}=5\text{V}$ , $V_{IL}=0.2\text{V}$<br>$V_{IH}=V_{CC}-0.2\text{V}$<br>PROG=V <sub>CC</sub> -0.2V  |              |      | 10       | $\mu\text{A}$ |
| $I_{OL}$   | Sum of all $I_{OL}$ of 16 Outputs            | 5mA Each pin                                                                                            |              |      | 80       | mA            |

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP82C43P

D.C. CHARACTERISTICS (II)  $T_{OPR} = -40^\circ\text{C}$  to  $85^\circ\text{C}$ ,  $V_{CC} = 5\text{V} \pm 20\%$ ,  $V_{SS} = 0\text{V}$ 

| SYMBOL     | PARAMETER                         | TEST CONDITION                             | MIN.         | TYP. | MAX.         | UNITS |
|------------|-----------------------------------|--------------------------------------------|--------------|------|--------------|-------|
| $V_{IL}$   | Input Low Voltage                 | $4.0\text{V} \leq V_{CC} \leq 4.5\text{V}$ | -0.5         |      | $0.15V_{CC}$ | V     |
| $V_{IH}$   | Input High Voltage                | $5.5\text{V} \leq V_{CC} \leq 6.0\text{V}$ | $0.5V_{CC}$  |      | $V_{CC}$     | V     |
| $V_{OLL}$  | Output Low Voltage Ports 4-7      | $I_{OL}=4\text{mA}$                        |              |      | 0.45         | V     |
| $V_{OL2}$  | Output Low Voltage Port 7         | $I_{OL}=15\text{mA}$                       |              |      | 1.0          | V     |
| $V_{OL3}$  | Output Low Voltage Port 2         | $I_{OL}=0.6\text{mA}$                      |              |      | 0.45         | V     |
| $V_{OH12}$ | Output High Voltage Ports 4-7     | $I_{OH}=-200\mu\text{A}$                   | $V_{CC}-0.8$ |      |              | V     |
| $V_{OH22}$ | Output High Voltage Port 2        | $I_{OH}=-100\mu\text{A}$                   | $V_{CC}-0.8$ |      |              | V     |
| $I_{OL}$   | Sum of all $I_{OL}$ of 16 outputs | 4mA Each Pin                               |              |      | 64           | mA    |

A.C. CHARACTERISTICS  $T_{OPR} = -40^\circ\text{C}$  to  $80^\circ\text{C}$ ,  $V_{CC} = 5\text{V} \pm 20\%$ ,  $V_{SS} = 0\text{V}$ 

| SYMBOL    | PARAMETER                               | TEST CONDITION     | MIN. | TYP. | MAX. | UNITS |
|-----------|-----------------------------------------|--------------------|------|------|------|-------|
| $t_A$     | Code Valid Before PROG                  | $C_L=80\text{pF}$  | 100  |      |      | ns    |
| $t_B$     | Code Valid After PROG                   | $C_L=20\text{pF}$  | 60   |      |      | ns    |
| $t_C$     | Data Valid Before PROG                  | $C_L=80\text{pF}$  | 200  |      |      | ns    |
| $t_D$     | Data Valid After PROG                   | $C_L=20\text{pF}$  | 20   |      |      | ns    |
| $t_H$     | Floating After PROG                     | $C_L=20\text{pF}$  | 0    |      | 150  | ns    |
| $t_K$     | PROG Negative Pulse Width               |                    | 700  |      |      | ns    |
| $t_{CS}$  | $\overline{CS}$ Valid Before/After PROG |                    | 50   |      |      | ns    |
| $t_{PO}$  | Ports 4-7 Valid After PROG              | $C_L=100\text{pF}$ |      |      | 700  | ns    |
| $t_{IP}$  | Ports 4-7 Valid Before/After PROG       |                    | 100  |      |      | ns    |
| $t_{ACC}$ | Port 2 Valid After PROG                 | $C_L=80\text{pF}$  |      |      | 650  | ns    |



## TIMING WAVEFORM



## OUTLINE DRAWINGS

## PLASTIC PACKAGE

Unit in mm



Note : Each lead pitch is 2.54mm. All leads are located within 0.25mm of their true longitudinal position with respect to No.1 and No.24 leads.

**8BIT MICROPROCESSOR**

**TLCS-85A(NMOS)**



## 8-BIT SINGLE CHIP MICROPROCESSOR

## GENERAL DESCRIPTION

The TMP8085AP, from here on referred to as the TMP8085A, is a new generation, complete 8 bit parallel central processing unit (CPU). Its instruction set is 100% software compatible with the TMP9080A (8080A) microprocessor, and it is designed to improve the present 9080's performance by higher system speed. Its high level of system integration allows a minimum system of three IC's : TMP8085A (CPU), TMP8155P/TMP8156P (RAM/IO) and TMP8755AC (EPROM/IO) / TMP8355P (ROM/IO). The 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/TMP8156P/TMP8755AC/TMP8355P memory products allow a direct interface with TMP8085P.

## FEATURES

- 100% Software Compatible with TMP9080A
- 1.3 s Instruction Cycle
- Single +5V Power Supply
- On-Chip Clock Generator (with External Crystal or RC Network)
- On-Chip System Controller; Advanced Cycle status information available for Large System Control
- 4 Vectored Interrupts (One is Non-Maskable) Plus an TMP9080A compatible interrupt
- Decimal, Binary and Double Precision Arithmetic
- Serial In/Serial Out Port
- Direct Addressing Capability to 64K Bytes of Memory
- Compatible with Intel's 8085A

PIN CONNECTION  
(TOP VIEW)FIGURE 2. TMP8085A PINOUT  
DIAGRAM

## BLOCK DIAGRAM

DATA/ADDRESS BUS  
AD0 - 7ADDRESS BUS  
A<sub>8</sub> - 15FIGURE 2. TMP8085A  
PINOUT DIAGRAM



## PIN NAME AND PIN DESCRIPTION

X<sub>1</sub>, X<sub>2</sub> (Input)

Crystal, LC, or RC network are connected to X<sub>1</sub> and X<sub>2</sub> to drive the internal clock generator. X<sub>1</sub> and X<sub>2</sub> can also be driven from an externally derived frequency 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 X<sub>1</sub>, X<sub>2</sub> input period.

## RESET IN (Input)

The RESET Input initialize 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. RESET IN is a Schmitt-triggered input, allowing connection to an RC network for power on RESET delay. The TMP8085A is held in the reset condition as long as RESET IN 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 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{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. They may be individually masked out 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 any mask or Interrupt Enable. It has the highest priority of any interrupt.

**AD0 - AD7** (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.

**A8 - A15**(Output, 3-state)

The most significant 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.

**S0, S1, and IO/M** (Output)

Machine cycle status:

| IO/M | S1 | S0 | 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   | X  | X  | Hold                  |
| TS   | X  | X  | 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 on-chip latch of peripherals. The falling edge of ALE can be used to strobe the status information. ALE is never 3-stated.

WR (Output, 3-state)

WRITE control: A low level on 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 WR. It is 3-stated during Hold and Halt modes and during RESET.

RD (Output, 3-state)

READ control: A low level on 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 absent (low), indicating the external operation is not complete, the processor will enter the Wait state. It will wait an integral number of clock cycles for READY to go high before completing the read or write cycle.

## HOLD (Input)

The Hold input allows an external signal to cause the processor to relinquish 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, RD, WR, and IO/M lines into their high-impedance state. Internal processing can continue. The Holding device can then utilize the address and data buses without interference. The processor can regain the bus only after the Hold is removed.

## HLDA (Output)

The Hold Acknowledge output signal is a response to a Hold input. It indicates that the processor has received the HOLD request and it will relinquish the bus in the next cycle. HLDA goes low after the Hold request is moved. The processor takes the bus one half clock cycle after HLDA goes low.

V<sub>CC</sub>  
+5 volt supply

V<sub>SS</sub>  
Ground Reference

## FUNCTIONAL DESCRIPTION

The TMP8085A is a complete 8-bit parallel central processor. Its basic clock speed is 3 MHz. Also it is designed to fit into a minimum system of three IC's: The CPU (TMP8085A), a RAM I/O (TMP8155P or TMP8156P), and a ROM or EPROM I/O chip (TMP8355P or TMP8755AC).

The TMP8085A is provided with internal 8-bit registers and 16-bit registers. The 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 more 16-bit registers. The TMP8085A register set is as follows:

- The accumulator (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 the TMP8085A CPU are shown below:

| (MSB)          |                |                |                |                |                |                |                |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| D <sub>7</sub> | 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> |
| S              | Z              |                | AC             |                | P              |                | C              |

- The carry flag (C) is set and reset by arithmetic operations. An addition 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.

In the TMP8085A microprocessor are contained the functions of clock generation, system bus control, and interrupt priority selection, in addition to execution of the instruction set. The 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.

### INTERRUPT AND SERIAL I/O

The TMP8085A has 5 interrupt inputs: INTR, RST 5.5, RST 6.5, RST 7.5, and TRAP. INTR is identical in function to 9080A INT. Each of three RESTART inputs 5.5, 6.5, 7.5, has a programmable mask. TRAP is also a RESTART interrupt but it is nonmaskable.

The three RESTART interrupts cause the internal execution of RESTART if the interrupts are enabled and if the interrupt mask is not set. The nonmaskable TRAP causes internal execution independent of the state of the interrupt enable or masks.

There are two different types of inputs in the restart interrupts. RST 5.5 and RST 6.5 are high levelsensitive 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 RESET IN to the 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 out.

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.

TABLE 1. INTERRUPT PRIORITY, RESTART ADDRESS, AND SENSITIVITY

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

- 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 the TMP8085A when the interrupt is acknowledged.

The TRAP interrupt is special in that it disables 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.

### BASIC TIMING

The execution of each instruction by the TMP8085A consists of a sequence of from one to five machine cycles, and each 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 opicode 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, the TMP8085A sends out three status signals (IO/M, S1, S0) that define what type of machine cycle is about to take place. The 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<sub>1</sub> of every machine cycle. Control lines RD (INTA) and WR become active later, at the time when the transfer of data is to take place. Figure 3 shows an instruction fetch, memory read and I/O write cycle (as would occur during processing of the OUT instruction).

**TABLE 2. TMP8085A MACHINE CYCLE CHART**

| MACHINE CYCLE        | IO/ $\bar{M}$ | S <sub>1</sub> | S <sub>0</sub> | $\bar{RD}$ | $\bar{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    |
| BUS IDLE : DAD       | 0             | 1              | 0              | 1          | 1          | 1    |
| ACK. OF<br>RST, TRAP | 1             | 1              | 1              | 1          | 1          | 1    |
| HALT                 | TS            | 0              | 0              | TS         | TS         | 1    |

NOTE: 0 = Logic "0", 1 = Logic "1", TS = High Impedance

**TABLE 3. TMP8085A MACHINE STATE CHART**

| MACHINE STATE      | S <sub>1</sub> , S <sub>0</sub> | IO/ $\bar{M}$ | A <sub>8</sub> -A <sub>15</sub> | AD <sub>0</sub> -AD <sub>7</sub> | $\bar{RD}, \bar{WR}$ | INTA | ALE |
|--------------------|---------------------------------|---------------|---------------------------------|----------------------------------|----------------------|------|-----|
| T <sub>1</sub>     | X                               | X             | X                               | X                                | 1                    | 1    | 1°  |
| T <sub>2</sub>     | X                               | X             | X                               | X                                | X                    | X    | 0   |
| T <sub>WAIT</sub>  | X                               | X             | X                               | X                                | X                    | X    | 0   |
| T <sub>3</sub>     | X                               | X             | X                               | X                                | X                    | X    | 0   |
| T <sub>4</sub>     | 1                               | 0†            | X                               | TS                               | 1                    | 1    | 0   |
| T <sub>5</sub>     | 1                               | 0†            | X                               | TS                               | 1                    | 1    | 0   |
| T <sub>6</sub>     | 1                               | 0†            | X                               | TS                               | 1                    | 1    | 0   |
| T <sub>RESET</sub> | X                               | TS            | TS                              | TS                               | TS                   | 1    | 0   |
| T <sub>HALT</sub>  | 0                               | TS            | TS                              | TS                               | TS                   | 1    | 0   |
| T <sub>HOLD</sub>  | X                               | TS            | TS                              | TS                               | TS                   | 1    | 0   |

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/ $\bar{M}$  = 1 during T<sub>4</sub> - T<sub>6</sub> of INA machine cycle



FIGURE 3. TMP8085A BASIC SYSTEM TIMING

## DRIVING THE X1 AND X2 INPUTS

You may drive the clock inputs of the TMP8085A with a crystal, an LC tuned circuit, an RC network or an external clock source. The driving frequency must be at least 1 MHz, and must be twice the desired internal clock frequency.

## A. 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



Note a value of the external capacitors  $C_1$  and  $C_2$  between X1, X2 and ground. In case of the crystal frequency above 4 MHz, it is recommended that you choose a value of 10pF for  $C_1$  and  $C_2$  and less than 4 MHz, 20pF capacitors are recommended.

## B. LC Turned Circuit Clock Driver

A parallel-resonant LC circuit may be used as the frequency-determining network for the 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.



## C. RC Circuit Clock Driver

An RC circuit may be used as the frequency - determining network for the TMP 8085A if maintaining a precise clock frequency is of no importance. 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.



## D. External clock Driver Circuit



## POWER ON AND RESET IN

The TMP 8085A is not guaranteed to work until 10 ms after V<sub>CC</sub> reaches 4.75 V.  
It is suggested that RESET IN 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.75 V level.

## INSTRUCTION SET

## Symbols and Abbreviations

| <u>SYMBOLS</u> | <u>DEFINITION</u>                                                                             |               |                             |
|----------------|-----------------------------------------------------------------------------------------------|---------------|-----------------------------|
| ddd,sss        | The bit pattern designating one of the registers A,B,C,D,E,H,L (ddd=destination, sss=source): |               |                             |
|                | ddd or sss                                                                                    | REGISTER NAME |                             |
|                | 111                                                                                           | A             |                             |
|                | 000                                                                                           | B             |                             |
|                | 001                                                                                           | C             |                             |
|                | 010                                                                                           | D             |                             |
|                | 011                                                                                           | E             |                             |
|                | 100                                                                                           | H             |                             |
|                | 101                                                                                           | L             |                             |
|                | 110                                                                                           | M (Memory)    |                             |
| r,r1,r2        | One of the registers A,B,C,D,E,H,L                                                            |               |                             |
| d8             | 8-bit data quantity                                                                           |               |                             |
| d16            | 16-bit data quantity                                                                          |               |                             |
| addr8          | 8-bit address of an I/O device                                                                |               |                             |
| addr           | 16-bit address quantity                                                                       |               |                             |
| RP             | The bit pattern designating one of the register pairs B,D,H,SP:                               |               |                             |
|                | RP                                                                                            | rp            | REGISTER PAIR<br>(rpH)(rpL) |
|                | 00                                                                                            | B             | B-C                         |
|                | 01                                                                                            | D             | D-E                         |
|                | 10                                                                                            | H             | H-L                         |
|                | 11                                                                                            | SP            | SP                          |
| B <sub>2</sub> | The second byte of the instruction                                                            |               |                             |
| B <sub>3</sub> | The third byte of the instruction                                                             |               |                             |
| O              | Affected                                                                                      |               |                             |
| S              | Set                                                                                           |               |                             |
| R              | Reset                                                                                         |               |                             |
| -              | Not affected                                                                                  |               |                             |

## Data Transfer

| Mnemonic    | Instruction Code |                |                |                |                |                |                |                | Operation                                                                                      | Bytes | States | Flag  |       |       |       |
|-------------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|------------------------------------------------------------------------------------------------|-------|--------|-------|-------|-------|-------|
|             | D <sub>7</sub>   | 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> |                                                                                                |       |        | C     | Z     | S     | P     |
| MOV r1, r2  | 0                | 1              | d              | d              | d              | s              | s              | s              | (r1) ← (r2)                                                                                    | 1     | 4      | ----- | ----- | ----- | ----- |
| MOV M, r    | 0                | 1              | 1              | 1              | 0              | s              | s              | s              | [ (H)(L) ] ← (r)                                                                               | 1     | 7      | ----- | ----- | ----- | ----- |
| MOV r, M    | 0                | 1              | d              | d              | d              | 1              | 1              | 0              | (r) ← [ (H)(L) ]                                                                               | 1     | 7      | ----- | ----- | ----- | ----- |
| MVI r, d8   | 0                | 0              | d              | d              | d              | 1              | 1              | 0              | (r) ← (B <sub>2</sub> )                                                                        | 2     | 7      | ----- | ----- | ----- | ----- |
|             |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                |       |        |       |       |       |       |
| MVI M, d8   | 0                | 0              | 1              | 1              | 0              | 1              | 1              | 0              | [ (H)(L) ] ← (B <sub>2</sub> )                                                                 | 2     | 10     | ----- | ----- | ----- | ----- |
|             |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                |       |        |       |       |       |       |
| LDA addr    | 0                | 0              | 1              | 1              | 1              | 0              | 1              | 0              | (A) ← [(B <sub>3</sub> )(B <sub>2</sub> )]                                                     | 3     | 13     | ----- | ----- | ----- | ----- |
|             |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                |       |        |       |       |       |       |
|             |                  |                |                |                |                | B <sub>3</sub> |                |                |                                                                                                |       |        |       |       |       |       |
| LDAX B      | 0                | 0              | 0              | 0              | 1              | 0              | 1              | 0              | (A) ← [(B)(C)]                                                                                 | 1     | 7      | ----- | ----- | ----- | ----- |
| LDAX D      | 0                | 0              | 0              | 1              | 1              | 0              | 1              | 0              | (A) ← [(D)(E)]                                                                                 | 1     | 7      | ----- | ----- | ----- | ----- |
| LHLD addr   | 0                | 0              | 1              | 0              | 1              | 0              | 1              | 0              | (L) ← [(B <sub>3</sub> )(B <sub>2</sub> )]<br>(H) ← [(B <sub>3</sub> )(B <sub>2</sub> )+1]     | 3     | 16     | ----- | ----- | ----- | ----- |
|             |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                |       |        |       |       |       |       |
|             |                  |                |                |                |                | B <sub>3</sub> |                |                |                                                                                                |       |        |       |       |       |       |
| LXI H, d16  | 0                | 0              | 1              | 0              | 0              | 0              | 0              | 1              | (H) ← (B <sub>3</sub> )<br>(L) ← (B <sub>2</sub> )                                             | 3     | 10     | ----- | ----- | ----- | ----- |
|             |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                |       |        |       |       |       |       |
|             |                  |                |                |                |                | B <sub>3</sub> |                |                |                                                                                                |       |        |       |       |       |       |
| LXI D, d16  | 0                | 0              | 0              | 1              | 0              | 0              | 0              | 1              | (D) ← (B <sub>3</sub> )<br>(E) ← (B <sub>2</sub> )                                             | 3     | 10     | ----- | ----- | ----- | ----- |
|             |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                |       |        |       |       |       |       |
|             |                  |                |                |                |                | B <sub>3</sub> |                |                |                                                                                                |       |        |       |       |       |       |
| LXI B, d16  | 0                | 0              | 0              | 0              | 0              | 0              | 0              | 1              | (B) ← (B <sub>3</sub> )<br>(C) ← (B <sub>2</sub> )                                             | 3     | 10     | ----- | ----- | ----- | ----- |
|             |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                |       |        |       |       |       |       |
|             |                  |                |                |                |                | B <sub>3</sub> |                |                |                                                                                                |       |        |       |       |       |       |
| LXI SP, d16 | 0                | 0              | 1              | 1              | 0              | 0              | 0              | 1              | (SP) <sub>H</sub> ← (B <sub>3</sub> )<br>(SP) <sub>L</sub> ← (B <sub>2</sub> )                 | 3     | 10     | ----- | ----- | ----- | ----- |
|             |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                |       |        |       |       |       |       |
|             |                  |                |                |                |                | B <sub>3</sub> |                |                |                                                                                                |       |        |       |       |       |       |
| SHLD addr   | 0                | 0              | 1              | 0              | 0              | 0              | 1              | 0              | [ (B <sub>3</sub> )(B <sub>2</sub> ) ] ← (L)<br>[ (B <sub>3</sub> )(B <sub>2</sub> )+1 ] ← (H) | 3     | 16     | ----- | ----- | ----- | ----- |
|             |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                |       |        |       |       |       |       |
|             |                  |                |                |                |                | B <sub>3</sub> |                |                |                                                                                                |       |        |       |       |       |       |
| STA addr    | 0                | 0              | 1              | 1              | 0              | 0              | 1              | 0              | [ (B <sub>3</sub> )(B <sub>2</sub> ) ] ← (A)                                                   | 3     | 13     | ----- | ----- | ----- | ----- |
|             |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                |       |        |       |       |       |       |
|             |                  |                |                |                |                | B <sub>3</sub> |                |                |                                                                                                |       |        |       |       |       |       |

| Mnemonic  | Instruction Code |                |                |                |                |                |                |                | Operation                          | Bytes | States | Flag      |   |   |   |    |
|-----------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|------------------------------------|-------|--------|-----------|---|---|---|----|
|           | D <sub>7</sub>   | 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> |                                    |       |        | C         | Z | S | P | AC |
| STAX B    | 0                | 0              | 0              | 0              | 0              | 0              | 1              | 0              | [ (B)(C) ] ← (A)                   | 1     | 7      | - - - - - |   |   |   |    |
| STAX D    | 0                | 0              | 0              | 1              | 0              | 0              | 1              | 0              | [ (D)(E) ] ← (A)                   | 1     | 7      | - - - - - |   |   |   |    |
| SPHL      | 1                | 1              | 1              | 1              | 1              | 0              | 0              | 1              | (SP) ← (H)(L)                      | 1     | 6      | - - - - - |   |   |   |    |
| XCHG      | 1                | 1              | 1              | 0              | 1              | 0              | 1              | 1              | (H) ← (D)<br>(L) ← (E)             | 1     | 4      | - - - - - |   |   |   |    |
| XTHL      | 1                | 1              | 1              | 0              | 0              | 0              | 1              | 1              | (L) ← [ (SP) ]<br>(H) ← [ (SP)+1 ] | 1     | 16     | - - - - - |   |   |   |    |
| IN addr8  | 1                | 1              | 0              | 1              | 1              | 0              | 1              | 1              | (A) ← (data)                       | 2     | 10     | - - - - - |   |   |   |    |
|           |                  |                |                | B <sub>2</sub> |                |                |                |                |                                    |       |        |           |   |   |   |    |
| OUT addr8 | 1                | 1              | 0              | 1              | 0              | 0              | 1              | 1              | (data) ← (A)                       | 2     | 10     | - - - - - |   |   |   |    |
|           |                  |                |                | B <sub>2</sub> |                |                |                |                |                                    |       |        |           |   |   |   |    |

Branch

| Mnemonic | Instruction Code |                |                |                |                |                |                |                | Operation                                                                             | Bytes                                                                                 | States | Flag      |           |   |   |    |  |
|----------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|---------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--------|-----------|-----------|---|---|----|--|
|          | D <sub>7</sub>   | 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> |                                                                                       |                                                                                       |        | C         | Z         | S | P | AC |  |
| JMP addr | 1                | 1              | 0              | 0              | 0              | 0              | 1              | 1              | (PC) ← (B <sub>3</sub> )(B <sub>2</sub> )                                             | 3                                                                                     | 10     | - - - - - |           |   |   |    |  |
|          |                  |                |                | B <sub>2</sub> |                |                |                |                |                                                                                       |                                                                                       |        |           |           |   |   |    |  |
|          |                  |                |                | B <sub>3</sub> |                |                |                |                |                                                                                       |                                                                                       |        |           |           |   |   |    |  |
| JNZ addr | 1                | 1              | 0              | 0              | 0              | 0              | 0              | 1              | 0                                                                                     | If Z = 0<br>(PC) ← (B <sub>3</sub> )(B <sub>2</sub> ),<br>If Z = 1<br>(PC) ← (PC) + 3 | 3      | 7/10      | - - - - - |   |   |    |  |
|          |                  |                |                | B <sub>2</sub> |                |                |                |                |                                                                                       |                                                                                       |        |           |           |   |   |    |  |
|          |                  |                |                | B <sub>3</sub> |                |                |                |                |                                                                                       |                                                                                       |        |           |           |   |   |    |  |
| JZ addr  | 1                | 1              | 0              | 0              | 1              | 0              | 1              | 0              | If Z = 1<br>(PC) ← (B <sub>3</sub> )(B <sub>2</sub> ),<br>If Z = 0<br>(PC) ← (PC) + 3 | 3                                                                                     | 7/10   | - - - - - |           |   |   |    |  |
|          |                  |                |                | B <sub>2</sub> |                |                |                |                |                                                                                       |                                                                                       |        |           |           |   |   |    |  |
|          |                  |                |                | B <sub>3</sub> |                |                |                |                |                                                                                       |                                                                                       |        |           |           |   |   |    |  |
| JNC addr | 1                | 1              | 0              | 1              | 0              | 0              | 1              | 0              | If C = 0<br>(PC) ← (B <sub>3</sub> )(B <sub>2</sub> ),<br>If C = 1<br>(PC) ← (PC) + 3 | 3                                                                                     | 7/10   | - - - - - |           |   |   |    |  |
|          |                  |                |                | B <sub>2</sub> |                |                |                |                |                                                                                       |                                                                                       |        |           |           |   |   |    |  |
|          |                  |                |                | B <sub>3</sub> |                |                |                |                |                                                                                       |                                                                                       |        |           |           |   |   |    |  |
| JC addr  | 1                | 1              | 0              | 1              | 1              | 0              | 1              | 0              | If C = 1<br>(PC) ← (B <sub>3</sub> )(B <sub>2</sub> ),<br>If C = 0<br>(PC) ← (PC) + 3 | 3                                                                                     | 7/10   | - - - - - |           |   |   |    |  |
|          |                  |                |                | B <sub>2</sub> |                |                |                |                |                                                                                       |                                                                                       |        |           |           |   |   |    |  |
|          |                  |                |                | B <sub>3</sub> |                |                |                |                |                                                                                       |                                                                                       |        |           |           |   |   |    |  |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8085AP

| Mnemonic  | Instruction Code |                |                |                |                |                |                |                | Operation                                                                                                              | Bytes | States | Flag      |   |   |   |    |  |
|-----------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|------------------------------------------------------------------------------------------------------------------------|-------|--------|-----------|---|---|---|----|--|
|           | D <sub>7</sub>   | 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> |                                                                                                                        |       |        | C         | Z | S | P | AC |  |
| JPO addr  | 1                | 1              | 1              | 0              | 0              | 0              | 1              | 0              | If P = 0<br>(PC) ← (B <sub>3</sub> )(B <sub>2</sub> ),<br>If P = 1<br>(PC) ← (PC) + 3                                  | 3     | 7/10   | - - - - - |   |   |   |    |  |
| JPE addr  | 1                | 1              | 1              | 0              | 1              | 0              | 1              | 0              | If P = 1<br>(PC) ← (B <sub>3</sub> )(B <sub>2</sub> ),<br>If P = 0<br>(PC) ← (PC) + 3                                  | 3     | 7/10   | - - - - - |   |   |   |    |  |
| JP addr   | 1                | 1              | 1              | 1              | 0              | 0              | 1              | 0              | If S = 0<br>(PC) ← (B <sub>3</sub> )(B <sub>2</sub> ),<br>If S = 1<br>(PC) ← (PC) + 3                                  | 3     | 7/10   | - - - - - |   |   |   |    |  |
| JM addr   | 1                | 1              | 1              | 1              | 1              | 0              | 1              | 0              | If S = 1<br>(PC) ← (B <sub>3</sub> )(B <sub>2</sub> ),<br>If S = 0<br>(PC) ← (PC) + 3                                  | 3     | 7/10   | - - - - - |   |   |   |    |  |
| CALL addr | 1                | 1              | 0              | 0              | 1              | 1              | 0              | 1              | [ (SP)-1] ← (PCH)<br>[ (SP)-2] ← (PCL)<br>(SP) ← (SP) - 2<br>(PC) ← (B <sub>3</sub> )(B <sub>2</sub> )                 | 3     | 18     | - - - - - |   |   |   |    |  |
| CNZ addr  | 1                | 1              | 0              | 0              | 0              | 1              | 0              | 0              | If Z = 0,<br>the actions<br>specified in the<br>CALL instruction<br>are performed.<br><br>If Z = 1<br>(PC) ← (PC) + 3  | 3     | 9/18   | - - - - - |   |   |   |    |  |
| CZ addr   | 1                | 1              | 0              | 0              | 1              | 1              | 0              | 0              | If Z = 1,<br>the actions<br>specified in the<br>CALL instruction<br>are performed.<br><br>If Z = 0,<br>(PC) ← (PC) + 3 | 3     | 9/18   | - - - - - |   |   |   |    |  |

| Mnemonic | Instruction Code |                |                |                |                |                |                |                | Operation                                                                                                                        | Bytes | States | Flag      |   |   |   |    |  |
|----------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------------------------------------------------------------------------------------------------------------------------|-------|--------|-----------|---|---|---|----|--|
|          | D <sub>7</sub>   | 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> |                                                                                                                                  |       |        | C         | Z | S | P | AC |  |
| CNC addr | 1                | 1              | 0              | 1              | 0              | 1              | 0              | 0              | If C = 0,<br>the actions<br>specified in the<br>CALL instruction<br>are performed.<br><br>If C = 1<br>(PC) $\leftarrow$ (PC) + 3 | 3     | 9/18   | - - - - - |   |   |   |    |  |
| CC addr  | 1                | 1              | 0              | 1              | 1              | 1              | 0              | 0              | If C = 1,<br>the actions<br>specified in the<br>CALL instruction<br>are performed.<br><br>If C = 0<br>(PC) $\leftarrow$ (PC) + 3 | 3     | 9/18   | - - - - - |   |   |   |    |  |
| CPO addr | 1                | 1              | 1              | 0              | 0              | 1              | 0              | 0              | If P = 0,<br>the actions<br>specified in the<br>CALL instruction<br>are performed.<br><br>If P = 1<br>(PC) $\leftarrow$ (PC) + 3 | 3     | 9/18   | - - - - - |   |   |   |    |  |
| CPE addr | 1                | 1              | 1              | 0              | 1              | 1              | 0              | 0              | If P = 1,<br>the actions<br>specified in the<br>CALL instruction<br>are performed.<br><br>If P = 0<br>(PC) $\leftarrow$ (PC) + 3 | 3     | 9/18   | - - - - - |   |   |   |    |  |
| CP addr  | 1                | 1              | 1              | 1              | 0              | 1              | 0              | 0              | If S = 0,<br>the actions<br>specified in the<br>CALL instruction<br>are performed.<br><br>If S = 1<br>(PC) $\leftarrow$ (PC) + 3 | 3     | 9/18   | - - - - - |   |   |   |    |  |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8085AP

| Mnemonic | Instruction Code |                |                |                |                |                |                |                | Operation                                                                                                                        | Bytes | States | Flag      |   |   |   |    |
|----------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------------------------------------------------------------------------------------------------------------------------|-------|--------|-----------|---|---|---|----|
|          | D <sub>7</sub>   | 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> |                                                                                                                                  |       |        | C         | Z | S | P | AC |
| CM addr  | 1                | 1              | 1              | 1              | 1              | 1              | 0              | 0              | If S = 1,<br>the actions<br>specified in the<br>CALL instruction<br>are performed.<br><br>If S = 0<br>$(PC) \leftarrow (PC) + 3$ | 3     | 9/18   | - - - - - |   |   |   |    |
| RET      | 1                | 1              | 0              | 0              | 1              | 0              | 0              | 1              | $(PCL) \leftarrow [(SP)]$<br>$(PCH) \leftarrow [(SP)+1]$<br>$(SP) \leftarrow (SP) + 2$                                           | 1     | 10     | - - - - - |   |   |   |    |
| RNZ      | 1                | 1              | 0              | 0              | 0              | 0              | 0              | 0              | If Z = 0,<br>the actions<br>specified in the<br>RET instruction<br>are performed.<br><br>If Z = 1<br>$(PC) \leftarrow (PC) + 1$  | 1     | 6/12   | - - - - - |   |   |   |    |
| RZ       | 1                | 1              | 0              | 0              | 1              | 0              | 0              | 0              | If Z = 1,<br>the actions<br>specified in the<br>RET instruction<br>are performed.<br><br>If Z = 0<br>$(PC) \leftarrow (PC) + 1$  | 1     | 6/12   | - - - - - |   |   |   |    |
| RNC      | 1                | 1              | 0              | 1              | 0              | 0              | 0              | 0              | If C = 0,<br>the actions<br>specified in the<br>RET instruction<br>are performed.<br><br>If C = 1<br>$(PC) \leftarrow (PC) + 1$  | 1     | 6/12   | - - - - - |   |   |   |    |

| Mnemonic | Instruction Code<br>D <sub>7</sub> 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> | Operation                                                                                                                       | Bytes | States | Flag |   |   |   |    |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-------|--------|------|---|---|---|----|
|          |                                                                                                                                             |                                                                                                                                 |       |        | C    | Z | S | P | AC |
| RC       | 1 1 0 1 1 0 0 0                                                                                                                             | If C = 1,<br>the actions<br>specified in the<br>RET instruction<br>are performed.<br><br>If C = 0<br>$(PC) \leftarrow (PC) + 1$ | 1     | 6/12   | -    | - | - | - | -  |
| RPO      | 1 1 1 0 0 0 0 0                                                                                                                             | If P = 0,<br>the actions<br>specified in the<br>RET instruction<br>are performed.<br><br>If P = 1<br>$(PC) \leftarrow (PC) + 1$ | 1     | 6/12   | -    | - | - | - | -  |
| RPE      | 1 1 1 0 1 0 0 0                                                                                                                             | If P = 1,<br>the actions<br>specified in the<br>RET instruction<br>are performed.<br><br>If P = 0<br>$(PC) \leftarrow (PC) + 1$ | 1     | 6/12   | -    | - | - | - | -  |
| RP       | 1 1 1 1 0 0 0 0                                                                                                                             | If S = 0,<br>the actions<br>specified in the<br>RET instruction<br>are performed.<br><br>If S = 1<br>$(PC) \leftarrow (PC) + 1$ | 1     | 6/12   | -    | - | - | - | -  |
| RM       | 1 1 1 1 1 0 0 0                                                                                                                             | If S = 1,<br>the actions<br>specified in the<br>RET instruction<br>are performed.<br><br>If S = 0<br>$(PC) \leftarrow (PC) + 1$ | 1     | 6/12   | -    | - | - | - | -  |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8085AP

| Mnemonic | Instruction Code |                |                |                |                |                |                |                | Operation                                                                                | Bytes | States | Flag      |   |   |   |    |  |
|----------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|------------------------------------------------------------------------------------------|-------|--------|-----------|---|---|---|----|--|
|          | D <sub>7</sub>   | 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> |                                                                                          |       |        | C         | Z | S | P | AC |  |
| PCHL     | 1                | 1              | 1              | 0              | 1              | 0              | 0              | 1              | (PCH) ← (H)<br>(PCL) ← (L)                                                               | 1     | 6      | - - - - - |   |   |   |    |  |
| RST      | 1                | 1              | A              | A              | A              | 1              | 1              | 1              | [(SP)-1] ← (PCH)<br>[(SP)-2] ← (PCL)<br>(SP) ← (SP) - 2<br>(PC) ← (00000000<br>00AAA000) | 1     | 12     | - - - - - |   |   |   |    |  |

Arithmetic

| Mnemonic | Instruction Code |                |                |                |                |                |                |                | Operation                           | Bytes | States | Flag      |   |   |   |    |  |
|----------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------------------|-------|--------|-----------|---|---|---|----|--|
|          | D <sub>7</sub>   | 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> |                                     |       |        | C         | Z | S | P | AC |  |
| ADD r    | 1                | 0              | 0              | 0              | 0              | S              | S              | S              | (A) ← (A) + (r)                     | 1     | 4      | 0 0 0 0 0 |   |   |   |    |  |
| ADC r    | 1                | 0              | 0              | 0              | 1              | S              | S              | S              | (A) ← (A) + (r) + (C)               | 1     | 4      | 0 0 0 0 0 |   |   |   |    |  |
| ADD M    | 1                | 0              | 0              | 0              | 0              | 1              | 1              | 0              | (A) ← (A) + [(H)(L)]                | 1     | 7      | 0 0 0 0 0 |   |   |   |    |  |
| ADC M    | 1                | 0              | 0              | 0              | 1              | 1              | 1              | 0              | (A) ← (A) + [(H)(L)] + (C)          | 1     | 7      | 0 0 0 0 0 |   |   |   |    |  |
| ADI d8   | 1                | 1              | 0              | 0              | 0              | 1              | 1              | 0              | (A) ← (A) + (B <sub>2</sub> )       | 2     | 7      | 0 0 0 0 0 |   |   |   |    |  |
|          |                  |                |                |                | B <sub>2</sub> |                |                |                |                                     |       |        |           |   |   |   |    |  |
| ACI d8   | 1                | 1              | 0              | 0              | 1              | 1              | 1              | 0              | (A) ← (A) + (B <sub>2</sub> ) + (C) | 2     | 7      | 0 0 0 0 0 |   |   |   |    |  |
|          |                  |                |                |                | B <sub>2</sub> |                |                |                |                                     |       |        |           |   |   |   |    |  |
| DAD rp   | 0                | 0              | R              | P              | 1              | 0              | 0              | 1              | (H)(L) ← (H)(L)<br>+ (rH)(rL)       | 1     | 10     | 0 - - - - |   |   |   |    |  |
| SUB r    | 1                | 0              | 0              | 1              | 0              | S              | S              | S              | (A) ← (A) - (r)                     | 1     | 4      | 0 0 0 0 0 |   |   |   |    |  |
| SBB r    | 1                | 0              | 0              | 1              | 1              | S              | S              | S              | (A) ← (A) - (r) - (C)               | 1     | 4      | 0 0 0 0 0 |   |   |   |    |  |
| SUB M    | 1                | 0              | 0              | 1              | 0              | 1              | 1              | 0              | (A) ← (A) - [(H)(L)]                | 1     | 7      | 0 0 0 0 0 |   |   |   |    |  |
| SBB M    | 1                | 0              | 0              | 1              | 1              | 1              | 1              | 0              | (A) ← (A) - [(H)(L)] - (C)          | 1     | 7      | 0 0 0 0 0 |   |   |   |    |  |
| SUI d8   | 1                | 1              | 0              | 1              | 0              | 1              | 1              | 0              | (A) ← (A) - (B <sub>2</sub> )       | 2     | 7      | 0 0 0 0 0 |   |   |   |    |  |
|          |                  |                |                |                | B <sub>2</sub> |                |                |                |                                     |       |        |           |   |   |   |    |  |
| SBI d8   | 1                | 1              | 0              | 1              | 1              | 1              | 1              | 0              | (A) ← (A) - (B <sub>2</sub> ) - (C) | 2     | 7      | 0 0 0 0 0 |   |   |   |    |  |
|          |                  |                |                |                | B <sub>2</sub> |                |                |                |                                     |       |        |           |   |   |   |    |  |

| Mnemonic | Instruction Code |                |                |                |                |                |                |                | Operation                                                                                              | Bytes | States | Flag |   |   |   |    |
|----------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------------------------------------------------------------------------------------------------|-------|--------|------|---|---|---|----|
|          | D <sub>7</sub>   | 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> |                                                                                                        |       |        | C    | Z | S | P | AC |
| DAA      | 0                | 0              | 1              | 0              | 0              | 1              | 1              | 1              | The 8-bit number in the accumulator is adjusted to form two 4-bit BCD digits by the following process. | 1     | 4      | 0    | 0 | 0 | 0 | 0  |
|          |                  |                |                |                |                |                |                |                | Accumulator                                                                                            |       |        |      |   |   |   |    |
|          |                  |                |                |                |                |                |                |                |                       |       |        |      |   |   |   |    |
|          |                  |                |                |                |                |                |                |                | 1. If $Y \geq 10$ or $AC=1$ ,<br>$(A) \leftarrow (A) + 6$                                              |       |        |      |   |   |   |    |
|          |                  |                |                |                |                |                |                |                | 2. If $X \geq 10$ or $C=1$ ,<br>$(A)_{4-7} \leftarrow (A)_{4-7} + 6$                                   |       |        |      |   |   |   |    |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8085AP

Logical Instruction

| Mnemonic | Instruction Code |                |                |                |                |                |                |                | Operation                                                                                                   | Bytes | States | Flag      |
|----------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------------------------------------------------------------------------------------------|-------|--------|-----------|
|          | D <sub>7</sub>   | 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> |                                                                                                             |       |        |           |
| ANA r    | 1                | 0              | 1              | 0              | 0              | S              | S              | S              | (A) ← (A) Λ (r)                                                                                             | 1     | 4      | R 0 0 0 S |
| ANA M    | 1                | 0              | 1              | 0              | 0              | 1              | 1              | 0              | (A) ← (A) Λ [(H)(L)]                                                                                        | 1     | 7      | R 0 0 0 S |
| ANI d8   | 1                | 1              | 1              | 0              | 0              | 1              | 1              | 0              | (A) ← (A) Λ (B <sub>2</sub> )                                                                               | 2     | 7      | R 0 0 0 S |
|          |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                             |       |        |           |
| XRA r    | 1                | 0              | 1              | 0              | 1              | S              | S              | S              | (A) ← (A) ∨ (r)                                                                                             | 1     | 4      | R 0 0 0 R |
| XRA M    | 1                | 0              | 1              | 0              | 1              | 1              | 1              | 0              | (A) ← (A) ∨ [(H)(L)]                                                                                        | 1     | 7      | R 0 0 0 R |
| XRI d8   | 1                | 1              | 1              | 0              | 1              | 1              | 1              | 0              | (A) ← (A) ∨ (B <sub>2</sub> )                                                                               | 2     | 7      | R 0 0 0 R |
|          |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                             |       |        |           |
| ORA r    | 1                | 0              | 1              | 1              | 0              | S              | S              | S              | (A) ← (A) V (r)                                                                                             | 1     | 4      | R 0 0 0 R |
| ORA M    | 1                | 0              | 1              | 1              | 0              | 1              | 1              | 0              | (A) ← (A) V [(H)(L)]                                                                                        | 1     | 7      | R 0 0 0 R |
| ORI d8   | 1                | 1              | 1              | 1              | 0              | 1              | 1              | 0              | (A) ← (A) V (B <sub>2</sub> )                                                                               | 2     | 7      | R 0 0 0 R |
|          |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                             |       |        |           |
| CMP r    | 1                | 0              | 1              | 1              | 1              | S              | S              | S              | (A) - (r)                                                                                                   | 1     | 4      | 0 0 0 0 0 |
| CMP M    | 1                | 0              | 1              | 1              | 1              | 1              | 1              | 0              | (A) - [(H)(L)]                                                                                              | 1     | 7      | 0 0 0 0 0 |
| CPI d8   | 1                | 1              | 1              | 1              | 1              | 1              | 1              | 0              | (A) - (B <sub>2</sub> )                                                                                     | 2     | 7      | 0 0 0 0 0 |
|          |                  |                |                |                |                | B <sub>2</sub> |                |                |                                                                                                             |       |        |           |
| CMA      | 0                | 0              | 1              | 0              | 1              | 1              | 1              | 1              | (A) ← (Ā)                                                                                                  | 1     | 4      | - - - - - |
| RLC      | 0                | 0              | 0              | 0              | 0              | 1              | 1              | 1              | (A <sub>n+1</sub> ) ← (A <sub>n</sub> )<br>(A <sub>0</sub> ) ← (A <sub>7</sub> )<br>(C) ← (A <sub>7</sub> ) | 1     | 4      | 0 - - - - |
| RRC      | 0                | 0              | 0              | 0              | 1              | 1              | 1              | 1              | (A <sub>n</sub> ) ← (A <sub>n+1</sub> )<br>(A <sub>7</sub> ) ← (A <sub>0</sub> )<br>(C) ← (A <sub>0</sub> ) | 1     | 4      | 0 - - - - |
| RAL      | 0                | 0              | 0              | 1              | 0              | 1              | 1              | 1              | (A <sub>n+1</sub> ) ← (A <sub>n</sub> )<br>(C) ← (A <sub>7</sub> )<br>(A <sub>0</sub> ) ← (C)               | 1     | 4      | 0 - - - - |
| RAR      | 0                | 0              | 0              | 1              | 1              | 1              | 1              | 1              | (A <sub>n</sub> ) ← (A <sub>n+1</sub> )<br>(C) ← (A <sub>0</sub> )<br>(A <sub>7</sub> ) ← (C)               | 1     | 4      | 0 - - - - |

Toshiba

東芝

## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8085AP

Increment and Decrement

| Mnemonic | Instruction Code |    |    |    |    |    |    |    | Operation                          | Bytes | States | Flag |   |   |    |
|----------|------------------|----|----|----|----|----|----|----|------------------------------------|-------|--------|------|---|---|----|
|          | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                                    |       |        | C    | Z | S | AC |
| INR r    | 0                | 0  | d  | d  | d  | 1  | 0  | 0  | (r) $\leftarrow$ (r) + 1           | 1     | 4      | -    | 0 | 0 | 0  |
| INR M    | 0                | 0  | 1  | 1  | 0  | 1  | 0  | 0  | [(H)(L)] $\leftarrow$ [(H)(L)] + 1 | 1     | 10     | -    | 0 | 0 | 0  |
| INX rp   | 0                | 0  | R  | P  | 0  | 0  | 1  | 1  | (rH)(rL) $\leftarrow$ (rH)(rL) + 1 | 1     | 6      | -    | - | - | -  |
| DCR r    | 0                | 0  | d  | d  | d  | 1  | 0  | 1  | (r) $\leftarrow$ (r) - 1           | 1     | 4      | -    | 0 | 0 | 0  |
| DCR M    | 0                | 0  | 1  | 1  | 0  | 1  | 0  | 1  | [(H)(L)] $\leftarrow$ [(H)(L)] - 1 | 1     | 10     | -    | 0 | 0 | 0  |
| DCX rp   | 0                | 0  | R  | P  | 1  | 0  | 1  | 1  | (rH)(rL) $\leftarrow$ (rH)(rL) - 1 | 1     | 6      | -    | - | - | -  |

Stack

| Mnemonic | Instruction Code |    |    |    |    |    |    |    | Operation                                                                                                                                                                                                                                                                                                                                                                                      | Bytes | States | Flag |    |   |    |   |   |   |    |   |   |   |   |
|----------|------------------|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|------|----|---|----|---|---|---|----|---|---|---|---|
|          | D7               | D6 | D5 | D4 | D3 | D2 | D1 | D0 |                                                                                                                                                                                                                                                                                                                                                                                                |       |        | C    | Z  | S | AC |   |   |   |    |   |   |   |   |
| PUSH rp  | 1                | 1  | R  | P  | 0  | 1  | 0  | 1  | [(SP)-1] $\leftarrow$ (rH)<br>[(SP)-2] $\leftarrow$ (rL)<br>(SP) $\rightarrow$ (SP) - 2<br>Note: Register pair rp=SP may not be specified.                                                                                                                                                                                                                                                     | 1     | 12     | -    | -  | - | -  |   |   |   |    |   |   |   |   |
| PUSH PSW | 1                | 1  | 1  | 1  | 0  | 1  | 0  | 1  | [(SP)-1] $\leftarrow$ (A)<br>[(SP)-2] $\leftarrow$ D <sub>7</sub> 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><br><table border="1" style="display: inline-table; vertical-align: middle;"><tr><td>S</td><td>Z</td><td>X</td><td>AC</td><td>X</td><td>P</td><td>X</td><td>C</td></tr></table><br>MSB<br>(SP) $\leftarrow$ (SP) - 2 | S     | Z      | X    | AC | X | P  | X | C | 1 | 12 | - | - | - | - |
| S        | Z                | X  | AC | X  | P  | X  | C  |    |                                                                                                                                                                                                                                                                                                                                                                                                |       |        |      |    |   |    |   |   |   |    |   |   |   |   |
| POP rp   | 1                | 1  | R  | P  | 0  | 0  | 0  | 1  | (rL) $\leftarrow$ [(SP)]<br>(rH) $\leftarrow$ [(SP)+1]<br>(SP) $\leftarrow$ (SP)+2                                                                                                                                                                                                                                                                                                             | 1     | 10     | -    | -  | - | -  |   |   |   |    |   |   |   |   |
| POP PSW  | 1                | 1  | 1  | 1  | 0  | 0  | 0  | 1  | (C) $\leftarrow$ [(SP)] <sub>0</sub><br>(P) $\leftarrow$ [(SP)] <sub>2</sub><br>(AC) $\leftarrow$ [(SP)] <sub>4</sub><br>(Z) $\leftarrow$ [(SP)] <sub>6</sub><br>(S) $\leftarrow$ [(SP)] <sub>7</sub><br>(A) $\leftarrow$ [(SP)+1]<br>(SP) $\leftarrow$ (SP) + 2                                                                                                                               | 1     | 10     | 0    | 0  | 0 | 0  |   |   |   |    |   |   |   |   |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8085AP

Control

| Mnemonic | Instruction Code |                |                |                |                |                |                |                | Operation                                                                                                                                                                                                                          | Bytes | States | Flag      |   |   |   |    |
|----------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-----------|---|---|---|----|
|          | D <sub>7</sub>   | 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> |                                                                                                                                                                                                                                    |       |        | C         | Z | S | P | AC |
| HLT      | 0                | 1              | 1              | 1              | 0              | 1              | 1              | 0              | Halt                                                                                                                                                                                                                               | 1     | 5      | - - - - - |   |   |   |    |
| STC      | 0                | 0              | 1              | 1              | 0              | 1              | 1              | 1              | (C) ← 1                                                                                                                                                                                                                            | 1     | 4      | 0 - - - - |   |   |   |    |
| CMC      | 0                | 0              | 1              | 1              | 1              | 1              | 1              | 1              | (C) ← (C̄)                                                                                                                                                                                                                         | 1     | 4      | 0 - - - - |   |   |   |    |
| EI       | 1                | 1              | 1              | 1              | 1              | 0              | 1              | 1              | Enable interrupts<br>Note: Interrupts<br>are not recognized<br>during the EI in-<br>struction.                                                                                                                                     | 1     | 4      | - - - - - |   |   |   |    |
| DI       | 1                | 1              | 1              | 1              | 0              | 0              | 1              | 1              | Disable interrupts<br>Note: Interrupts<br>are not recognized<br>during the DI in-<br>struction.                                                                                                                                    | 1     | 4      | - - - - - |   |   |   |    |
| NOP      | 0                | 0              | 0              | 0              | 0              | 0              | 0              | 0              | No operation is<br>performed.                                                                                                                                                                                                      | 1     | 4      | - - - - - |   |   |   |    |
| RIM      | 0                | 0              | 1              | 0              | 0              | 0              | 0              | 0              | (A) ←<br><br>d <sub>7</sub> = SID<br><br>d <sub>6</sub> = I7<br><br>d <sub>5</sub> = I6<br><br>d <sub>4</sub> = I5<br><br>d <sub>3</sub> = IE<br><br>d <sub>2</sub> = M7<br><br>d <sub>1</sub> = M6<br><br>d <sub>0</sub> = M5     | 1     | 4      | - - - - - |   |   |   |    |
| SIM      | 0                | 0              | 1              | 1              | 0              | 0              | 0              | 0              | IF(A) <sub>6</sub> = 1;<br><br>SOD ← (A) <sub>7</sub><br><br>, IF(A) <sub>3</sub> = 1;<br><br>M7 ← (A) <sub>2</sub><br><br>M6 ← (A) <sub>1</sub><br><br>M5 ← (A) <sub>0</sub><br><br>, IF(A) <sub>4</sub> = 1;<br><br>RST7.5 RESET | 1     | 4      | - - - - - |   |   |   |    |

Toshiba



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8085AP

## ABSOLUTE MAXIMUM RATINGS

| Symbol       | Item                                           | Ratings        |
|--------------|------------------------------------------------|----------------|
| $V_{CC}$     | $V_{CC}$ Supply Voltage                        | -0.5V to 7.0V  |
| $V_{IN}$     | Input Voltage with Respect to $V_{SS}$         | -0.5V to 7.0V  |
| $V_{OUT}$    | Output Voltage with Respect to $V_{SS}$        | -0.5V to 7.0V  |
| $P_D$        | Power Dissipation                              | 1.5W           |
| $T_{solder}$ | Soldering Temperature (Soldering Time 10 sec.) | 260°C          |
| $T_{stg}$    | Storage Temperature                            | -55°C to 150°C |
| $T_{opr}$    | Operating Temperature                          | 0°C to 70°C    |

## DC CHARACTERISTICS

 $T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{CC} = 5\text{V}\pm 5\%$ 

| Symbol    | Parameter                | Test Conditions                 | Min. | Typ. | Max.                  | Units         |
|-----------|--------------------------|---------------------------------|------|------|-----------------------|---------------|
| $V_{IL}$  | Input Low Voltage        |                                 | -0.5 |      | 0.8                   | V             |
| $V_{IH}$  | Input High Voltage       |                                 | 2.0  |      | $\frac{V_{CC}}{+0.5}$ | V             |
| $V_{OL}$  | Output Low Voltage       | $I_{OL} = 2\text{mA}$           |      |      | 0.45                  | V             |
| $V_{OH}$  | Output High Voltage      | $I_{OH} = -400\mu\text{A}$      | 2.4  |      |                       | V             |
| $I_{CC}$  | Power Supply Current     |                                 |      |      | 170                   | mA            |
| $I_{IL}$  | Input Leakage            | $V_{IN} = V_{CC}$               |      |      | $\pm 10$              | $\mu\text{A}$ |
| $I_{LO}$  | Output Leakage           | $0.45 \leq V_{OUT} \leq V_{CC}$ |      |      | 10                    | $\mu\text{A}$ |
| $V_{ILR}$ | Input Low Level (RESET)  |                                 | -0.5 |      | 0.8                   | V             |
| $V_{IHR}$ | Input High Level (RESET) |                                 | 2.4  |      | $\frac{V_{CC}}{+0.5}$ | V             |
| $V_{HY}$  | Hysteresis (RESET)       |                                 | 0.25 |      |                       | V             |

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP8085AP

## AC CHARACTERISTICS

TA = 0°C to 70°C, V<sub>CC</sub> = 5V ± 5%, V<sub>SS</sub> = 0V, Unless Otherwise Noted.

| Symbol             | Parameter                                                      | Test Conditions                                  | Min. | Typ. | Max. | Units |
|--------------------|----------------------------------------------------------------|--------------------------------------------------|------|------|------|-------|
| t <sub>CYC</sub>   | CLK Cycle Period                                               | C <sub>L</sub> =150pF<br>t <sub>CYC</sub> =320ns | 320  |      | 2000 | ns    |
| t <sub>L</sub>     | CLK Low Time - Standard 150pF Loading<br>- Lightly Loaded [2]  |                                                  | 80   |      |      | ns    |
| t <sub>H</sub>     | CLK High Time - Standard 150pF Loading<br>- Lightly Loaded [2] |                                                  | 100  |      |      | ns    |
| t <sub>r, tf</sub> | CLK Rise and Fall Time                                         |                                                  | 120  |      |      | ns    |
| t <sub>XKR</sub>   | X <sub>1</sub> Rising to CLK Rising                            |                                                  | 150  |      |      | ns    |
| t <sub>XKF</sub>   | X <sub>1</sub> Rising to CLK Falling                           |                                                  |      | 30   |      | ns    |
| t <sub>AC</sub>    | A <sub>8-15</sub> Valid to Leading Edge of Control[1]          |                                                  |      | 120  |      | ns    |
| t <sub>ACL</sub>   | A <sub>0-7</sub> Valid to Leading of Control                   |                                                  |      | 150  |      | ns    |
| t <sub>AD</sub>    | A <sub>0-15</sub> Valid to Valid Data In                       |                                                  |      |      | 575  | ns    |
| t <sub>AFR</sub>   | Address Float after Leading Edge of READ (INTA)                |                                                  |      |      | 0    | ns    |
| t <sub>AL</sub>    | A <sub>8-15</sub> Valid before Trailing Edge of ALE[1]         |                                                  | 115  |      |      | ns    |
| t <sub>ALL</sub>   | A <sub>0-7</sub> Valid before Trailing Edge of ALE             |                                                  | 90   |      |      | ns    |
| t <sub>ARY</sub>   | READY Valid from Address Valid                                 |                                                  |      | 220  |      | ns    |
| t <sub>CA</sub>    | Address (A <sub>8 - A15</sub> ) Valid after Control            |                                                  | 120  |      |      | ns    |
| t <sub>CC</sub>    | Width of Control Low (RD, WR, INTA) Edge of ALE                |                                                  | 400  |      |      | ns    |
| t <sub>TCL</sub>   | Trailing Edge of Control to Leading Edge of ALE                |                                                  | 50   |      |      | ns    |
| t <sub>DW</sub>    | Data Valid to Trailing Edge of WRITE                           |                                                  | 420  |      |      | ns    |
| t <sub>HABE</sub>  | HLDA to Bus Enable                                             |                                                  |      | 210  |      | ns    |
| t <sub>HABF</sub>  | Bus Float after HLDA                                           |                                                  |      | 210  |      | ns    |
| t <sub>HACK</sub>  | HLDA Valid to Trailing Edge of CLK                             |                                                  | 110  |      |      | ns    |
| t <sub>HDH</sub>   | HOLD Hold Time                                                 |                                                  | 0    |      |      | ns    |
| t <sub>HDS</sub>   | HOLD Setup Time to Trailing Edge of CLK                        |                                                  | 170  |      |      | ns    |
| t <sub>INH</sub>   | INTR Hold Time                                                 |                                                  | 0    |      |      | ns    |

| Symbol    | Parameter                                             | Test Conditions | Min. | Typ. | Max. | Units |
|-----------|-------------------------------------------------------|-----------------|------|------|------|-------|
| $t_{INS}$ | INTR, RST and TRAP Setup Time to Falling Edge of CLK  |                 | 160  |      |      | ns    |
| $t_{LA}$  | Address Hold Time after ALE                           |                 | 100  |      |      | ns    |
| $t_{LC}$  | Trailing Edge of ALE to Leading Edge of Control       |                 | 130  |      |      | ns    |
| $t_{LCK}$ | ALE Low during CLK High                               |                 | 100  |      |      | ns    |
| $t_{LDR}$ | ALE to Valid Data during Read                         |                 |      | 460  |      | ns    |
| $t_{LDW}$ | ALE to Valid Data during Write                        |                 |      | 200  |      | ns    |
| $t_{LL}$  | ALE Width                                             |                 | 140  |      |      | ns    |
| $t_{LRY}$ | ALE to READY Stable                                   |                 |      | 110  |      | ns    |
| $t_{RAE}$ | Trailing Edge of READ to Re-Enabling of Address       |                 | 150  |      |      | ns    |
| $t_{RD}$  | READ (or INTA) to Valid Data                          |                 |      | 300  |      | ns    |
| $t_{RV}$  | Control Trailing Edge to Leading Edge of Next Control |                 | 400  |      |      | ns    |
| $t_{RDH}$ | Data Hold Time After READ INTA                        |                 | 0    |      |      | ns    |
| $t_{RYH}$ | READY Hold Time                                       |                 | 0    |      |      | ns    |
| $t_{RYS}$ | READY Setup Time to Leading Edge of CLK               |                 | 110  |      |      | ns    |
| $t_{WD}$  | Data Valid After Trailing Edge of WRITE               |                 | 100  |      |      | ns    |
| $t_{WDL}$ | LEADING Edge of WRITE to Data Valid                   |                 |      | 40   |      | ns    |

- Notes:
1. A8-15 address specs apply to  $I_0/\bar{M}$ ,  $S_0$  and  $S_1$  except A8-15 are undefined during  $T_4 - T_6$  of OF cycle whereas  $I_0/\bar{M}$ ,  $S_0$ , and  $S_1$  are stable.
  2. Loading equivalent to 50 pF + 1 TTL input.
  3. All timings are measured at output voltage  $V_L = 0.8 \text{ V}$ ,  $V_H = 2.0 \text{ V}$ .
  4. To calculate timing specifications at other value of  $t_{CYC}$  use Table 4.

TABLE 4. BUS TIMING SPECIFICATION AS A  $t_{CYC}$  DEPENDENT

|            |                     |     |
|------------|---------------------|-----|
| $t_{AL}$   | (1/2) $T - 45$      | MIN |
| $t_{LA}$   | (1/2) $T - 60$      | MIN |
| $t_{LL}$   | (1/2) $T - 20$      | MIN |
| $t_{LCK}$  | (1/2) $T - 60$      | MIN |
| $t_{LC}$   | (1/2) $T - 30$      | MIN |
| $t_{AD}$   | (5/2 + N) $T - 225$ | MAX |
| $t_{RD}$   | (3/2 + N) $T - 180$ | MAX |
| $t_{RAE}$  | (1/2) $T - 10$      | MIN |
| $t_{CA}$   | (1/2) $T - 40$      | MIN |
| $t_{DW}$   | (3/2 + N) $T - 60$  | MIN |
| $t_{WD}$   | (1/2) $T - 60$      | MIN |
| $t_{CC}$   | (3/2 + N) $T - 80$  | MIN |
| $t_{CL}$   | (1/2) $T - 110$     | MIN |
| $t_{ARY}$  | (3/2) $T - 260$     | MAX |
| $t_{HACK}$ | (1/2) $T - 50$      | MIN |
| $t_{HABF}$ | (1/2) $T + 50$      | MAX |
| $t_{HABE}$ | (1/2) $T + 50$      | MAX |
| $t_{AC}$   | (2/2) $T - 50$      | MIN |
| $t_L$      | (1/2) $T - 80$      | MIN |
| $t_H$      | (1/2) $T - 40$      | MIN |
| $t_{RV}$   | (3/2) $T - 80$      | MIN |
| $t_{LDR}$  | (4/2) $T - 180$     | MAX |

Note: N is equal to the total WAIT states.

$T = t_{CYC}$



FIGURE 4. CLOCK TIMING WAVEFORM



FIGURE 5. READ OPERATION



FIGURE 6. WRITE OPERATION



FIGURE 7. READ OPERATION WITH WAIT CYCLE (TYPICAL)

- SAME READY TIMING APPLIES TO WRITE OPERATION



FIGURE 8. INTERRUPT AND HOLD TIMING

## OUTLINE DRAWING

40 Pins Plastic Package

40 39 38 37 36 35 34 33 32 31 30 29 28 27 26 25 24 23 22 21

Unit in mm



- Notes:
1. This dimension shows the center of curvature of leads.
  2. This dimension shows spread of leads.
  3. All dimensions are in millimeters.



# **8BIT MICROPROCESSOR**

## **PERIPHERALS(NMOS)**





# INTEGRATED CIRCUIT

## TECHNICAL DATA

TOSHIBA MOS DIGITAL INTEGRATED CIRCUIT

TMP8155P

TMP8156P

N-CHANNEL SILICON GATE MOS

2048 BIT STATIC MOS RAM WITH I/O PORTS AND TIMER

### GENERAL DESCRIPTION

The TMP 8155P/8156P are RAM including I/O ports and counter/timer on the chip for using in the TLCS-85A microcomputer system. The RAM portion is designed with 2K bit static cells organized as 256 x 8. The 14 bit programmable counter/timer is the down counter. It provides either a square wave or terminal count pulse for the cpu system depending on timer mode.

The I/O portion is consists of 2 programmable 8 bit I/O ports and 1 programmable 6 bit I/O port. The programmable I/O ports can be operated by BASIC MODE and STROBE MODE.

### FEATURES

- Compatible with Intel's 8155/8516
- Single +5 V Power Supply
- Access Time: 400 ns (MAX.)
- Internal Address Latch
- 2 Programmable 8 Bit I/O Ports and 1 Programmable 6 Bit I/O Port.
- 256 Word x 8 Bits RAM
- Programmable 14 Bit Binary Counter/Timer
- Multiplexed Address and Data Bus
- Chip Enable Active High (TMP8156P) or Low (TMP8155P)
- 40 pin DIP

### PIN CONNECTION (TOP VIEW)



### BLOCK DIAGRAM



FIGURE 2 TMP8155P/8156P FUNCTIONAL BLOCK DIAGRAM

FIGURE 1 TMP8155P/8156P PINOUT DIAGRAM



## PIN NAMES AND PIN DESCRIPTION

## RESET (INPUT)

The Reset signal is a pulse provided by the TMP8085A to initialize the system. Input high on this line resets the chip and initializes the three I/O ports to input mode. The width of RESET pulse should typically be two TMP8085A clock cycle times.

AD<sub>0~7</sub> (INPUT / OUTPUT, 3-STATE)

These are 3-state Address/Data lines that interface with the CPU lower 8-bit Address/Data Bus. The 8-bit address is latched into the address latch on the falling edge of the ALE. The address can be applied to the memory section or the I/O section depending on the polarity of the IO/M input signal. The 8-bit data is either written into the chip or read from the chip depending on the status of WR or RD input signal.

CE OR CE (INPUT)

Chip Enable: On the TMP8155P, this pin is CE and is ACTIVE LOW. On the TMP8156P, this pin is CE and is ACTIVE HIGH.

## RD (INPUT)

Input low on this line with the Chip Enable active enables the AD<sub>0~7</sub> buffers. If IO/M pin is low, the RAM content will be read out to the AD bus. Otherwise the content of the selected I/O port or command/status register will be read to the AD bus.

## WR (INPUT)

Input low on this line with the Chip Enable active causes the data on the AD lines to be written to the RAM or I/O ports and command/status register depending on the polarity of IO/M.

## ALE (INPUT)

Address Latch Enable: This control signal latches both the address on the AD<sub>0~7</sub> lines and the state of the Chip Enable and IO/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 and command/status register if high.

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

### PB0~7 (INPUT/OUTPUT, 3-STATE)

These 8 pins are general purpose I/O pins. The in/out direction is selected by programming the Command Register.

### PC0~5 (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 PC0~5 are used as control signals, they are defined the following:

- PC<sub>0</sub> - A INTR (Port A Interrupt)
- PC<sub>1</sub> - A BF (Port A Buffer Full)
- PC<sub>2</sub> - A STB (Port A Strobe)
- PC<sub>3</sub> - B INTR (Port B Interrupt)
- PC<sub>4</sub> - B BF (Port B Buffer Full)
- PC<sub>5</sub> - B STB (Port B Strobe)

### TIMER IN (INPUT)

This is the input to the counter-timer.

### TIMER OUT (OUTPUT)

This pin is the timer output. This output can be either a square wave or a pulse depending on the timer mode.

V<sub>CC</sub> (Power)

+5 volt supply

V<sub>SS</sub> (Power)

Ground Reference

### FUNCTIONAL DESCRIPTION

#### PROGRAMMING OF THE COMMAND REGISTER

The command register consists of eight latches. Four bits (0-3) define the mode of the ports, two bits (4-5) enable or disable the interrupt from port C when it 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 XXXX00 during a WRITE operation. The function of each bit of the command byte is defined in FIGURE 3.



FIGURE 3 COMMAND REGISTER BIT ASSIGNMENT

## 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 XXXXX000). Status word format is shown in FIGURE 4.

Note that you may never write to the status register since the command register shares the same I/O address and the command register is selected when a write to that address is issued.



FIGURE 4 STATUS REGISTER BIT ASSIGNMENT

**INPUT/OUTPUT SECTION****COMMAND/STATUS REGISTER (C/S)**

Both register have the common address xxxx000. 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 AD0-7 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 XXXX001.
- 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 XXXX010.
- PC Register — This register has the address XXXX011 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 AD2 and AD3 bits of the C/S register.

When PC<sub>0-5</sub> 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 TMP8155P/8156P 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 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:

| MODE        | CONTROL | BF   | INTR          | STB |
|-------------|---------|------|---------------|-----|
| INPUT MODE  | Low     | Low  | Input Control |     |
| OUTPUT MODE | Low     | High | Input Control |     |



To summarize, the register's assignments are shown TABLE 1.

TABLE 1 I/O PORT ADDRESSING SCHEME

| I/O ADDRESS    |                |                |                |                |                |                |                | PINOUTS           | SELECTION                           | NO. OF BITS |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------|-------------------------------------|-------------|
| A <sub>7</sub> | 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> |                   |                                     |             |
| X              | X              | X              | X              | X              | 0              | 0              | 0              | Internal          | Command/Status Register             | 8           |
| X              | X              | X              | X              | X              | 0              | 0              | 1              | PA <sub>0-7</sub> | General Purpose I/O Port A          | 8           |
| X              | X              | X              | X              | X              | 0              | 1              | 0              | PB <sub>0-7</sub> | General Purpose I/O Port B          | 8           |
| X              | X              | X              | X              | X              | 0              | 1              | 1              | PC <sub>0-7</sub> | General Purpose I/O Port or Control | 6           |
| X              | X              | X              | X              | X              | 1              | 0              | 0              |                   | Low-Order 8 bits of Timer Count     |             |
| X              | X              | X              | X              | X              | 1              | 0              | 1              |                   | High 6 bits/2 bits of Timer Count   |             |

TABLE 2 TABLE OF 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 $\overline{STB}$ (Port A strobe) | A $\overline{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 $\overline{STB}$ (Port B Strobe) |

## 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 the I/O address XXXXX100 for the low order byte of the register and the I/O address XXXXX101 for the high order byte 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.



FIGURE 5 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.



FIGURE 6 ASYMMETRICAL SQUARE-WAVE OUTPUT RESULTING FROM COUNT OF 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. (NOP if timer has not started)                                                                                                                  |
| 1   | 1   | START: Load mode and count length and start immediately after loading (if timer is not presently running). If timer is running, start the new mode and count length immediately after present TC is reached. |

Note that while the counter is counting, you may load a new count and mode into the count length registers. Before the new count and mode will be used by the counter, you must issue a START command to the counter. This applies even though you may only want to change the count and use the previous mode.

The counter in the TMP8155P/8156P is not initialized to any particular mode or count when hardware RESET occurs, but RESET does stop the counting. Therefore you must issue a START command via the C/S register, because counting cannot begin following RESET.

Please note that the timer circuit on the TMP8155P/8156P chip is designed to be a square-wave timer, not an event counter. To achieve this, it counts down by twos twice in completing one cycle. Thus, its registers do not contain values directly representing the number of TIMER IN pulses received. You cannot load an initial value of 1 into the count register and cause the timer to operate, 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, perform the following operations 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-1 if full count is odd.)

Note: If you started with an odd count and you read the count length register before the third count pulse occurs, you will not be able to discern whether one or two counts has occurred. Regardless of this, the TMP8155P/8156P always counts out the right number of pulses in generating the TIMER OUT waveforms.

## ABSOLUTE MAXIMUM RATINGS

| Symbol              | Item                                                           | Rating          |
|---------------------|----------------------------------------------------------------|-----------------|
| V <sub>CC</sub>     | V <sub>CC</sub> Supply Voltage with Respect to V <sub>SS</sub> | -0.5V to +7.0V  |
| V <sub>IN</sub>     | Input Voltage with Respect to V <sub>SS</sub>                  | -0.5V to +7.0V  |
| V <sub>OUT</sub>    | Output Voltage with Respect to V <sub>SS</sub>                 | -0.5V to +7.0V  |
| P <sub>D</sub>      | Power Dissipation                                              | 1.5W            |
| T <sub>SOLDER</sub> | Soldering Temperature (Soldering Time 10 sec.)                 | 260°C           |
| T <sub>STG</sub>    | Storage Temperature                                            | -55°C to +150°C |
| TOPR                | Operating Temperature                                          | 0°C to +70°C    |

## D.C. CHARACTERISTICS

T<sub>A</sub> = 0°C to +70°C, V<sub>CC</sub> = +5V ± 5%

| Symbol              | Parameter                           | Test Conditions                            | Min. | Typ. | Max.                 | Units    |
|---------------------|-------------------------------------|--------------------------------------------|------|------|----------------------|----------|
| V <sub>IL</sub>     | 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μA                   | 2.4  |      |                      | V        |
| I <sub>IL</sub>     | Input Leakage                       | V <sub>IN</sub> = V <sub>CC</sub> to 0V    |      |      | ±10                  | μA       |
| I <sub>LO</sub>     | Output Leakage Current              | 0.45V ≤ V <sub>OUT</sub> ≤ V <sub>CC</sub> |      |      | ±10                  | μA       |
| I <sub>CC</sub>     | V <sub>CC</sub> Supply Current      |                                            |      |      | 180                  | mA       |
| I <sub>IL(CE)</sub> | Chip Enable Leakage<br>8155<br>8156 | V <sub>IN</sub> = V <sub>CC</sub> to 0V.   |      |      | +100<br>-100         | μA<br>μA |

## A.C. CHARACTERISTICS

TA=0°C to +70°C, V<sub>CC</sub>=+5V±5%

| Symbol           | Parameters                             | Test Condition | Min. | Typ. | Max. | Units |
|------------------|----------------------------------------|----------------|------|------|------|-------|
| t <sub>AL</sub>  | Address to Latch Set Up Time           | 150pF Load     | 50   |      |      | ns    |
| t <sub>LA</sub>  | Address Hold Time after Latch          |                | 80   |      |      | ns    |
| t <sub>LC</sub>  | Latch to READ/WRITE Control            |                | 100  |      |      | ns    |
| t <sub>RD</sub>  | Valid Data out Delay from READ Control |                |      |      | 170  | ns    |
| t <sub>AD</sub>  | Address Stable to Data Out Valid       |                |      |      | 400  | ns    |
| t <sub>LL</sub>  | Latch Enable Width                     |                | 100  |      |      | ns    |
| t <sub>RDF</sub> | Data Bus Float After READ              |                | 0    |      | 100  | ns    |
| t <sub>CL</sub>  | READ/WRITE control Latch Enable        |                | 20   |      |      | ns    |
| t <sub>CC</sub>  | READ/WRITE Control Width               |                | 250  |      |      | ns    |
| t <sub>DW</sub>  | Data In to WRITE Set Up Time           |                | 150  |      |      | ns    |
| t <sub>WD</sub>  | Data in Hold Time After WRITE          |                | 0    |      |      | ns    |
| t <sub>RV</sub>  | Recovery Time Between Controls         |                | 300  |      |      | ns    |
| t <sub>WP</sub>  | WRITE to Port Output                   |                |      |      | 400  | ns    |
| t <sub>PR</sub>  | Port Input Setup Time                  |                | 70   |      |      | ns    |
| t <sub>RP</sub>  | Port Input Hold Time                   |                | 50   |      |      | ns    |
| t <sub>SBF</sub> | Strobe to Buffer Full                  |                |      |      | 400  | ns    |
| t <sub>SS</sub>  | Strobe Width                           |                | 200  |      |      | ns    |
| t <sub>RBE</sub> | READ to Buffer Empty                   |                |      |      | 400  | ns    |
| t <sub>SI</sub>  | Strobe to INTR On                      |                |      |      | 400  | ns    |
| t <sub>RDI</sub> | READ to INTR Off                       |                |      |      | 400  | ns    |
| t <sub>PSS</sub> | Port Setup Time to Strobe              |                | 50   |      |      | ns    |
| t <sub>PHS</sub> | Port Hold Time After Strobe            |                | 120  |      |      | ns    |
| t <sub>SBE</sub> | Strobe to Buffer Empty                 |                |      |      | 400  | ns    |
| t <sub>WBF</sub> | WRITE to Buffer Full                   |                |      |      | 400  | ns    |
| t <sub>WI</sub>  | WRITE to INTR Off                      |                |      |      | 400  | ns    |
| t <sub>TL</sub>  | TIMER-IN to TIMER-OUT Low              |                |      |      | 400  | ns    |
| t <sub>TH</sub>  | TIMER-IN to TIMER-OUT High             |                |      |      | 400  | ns    |
| t <sub>RDE</sub> | Data Bus Enable from READ Control      |                | 10   |      |      | ns    |
| t <sub>L</sub>   | TIMER-IN Low Time                      |                | 80   |      |      | ns    |
| t <sub>H</sub>   | TIMER-IN High Time                     |                | 120  |      |      | ns    |

**TIMING WAVEFORMS**
**A. READ CYCLE**

**B. WRITE CYCLE**


FIGURE 7 READ/WRITE TIMING DIAGRAMS

A. BASIC INPUT MODE



B. BASIC OUTPUT MODE



FIGURE 8 BASIC I/O TIMING WAVEFORM

## A. STROBED INPUT MODE



## B. STROBED OUTPUT MODE



FIGURE 9 STROBED I/O TIMING WAVEFORM



Note 1: The timer output is periodic  
if in an automatic  
reload mode ( $M_1$  Mode Bit = 1)

FIGURE 10 TIMER OUTPUT WAVEFORM COUNTDOWN FROM 5 TO 1

## OUTLINE DRAWING

40 Pins Plastic Package



- Note: 1. This dimension shows the center of curvature of leads.  
2. This dimension shows spread of leads.  
3. All dimensions are in millimeters.

**16,384 BIT ROM WITH I/O PORTS**
**GENERAL DESCRIPTION**

The TMP8355P is a ROM and I/O chip to be used in the TLCS-85A microcomputer system. The ROM portion is organized as 2,048 words by 8 bits. The I/O portion consists of 2 general purpose I/O ports. Each I/O port has 8 port lines, and each I/O port line is individually programmable as input or output.

**FEATURES**

- 2048 words x 8 bits ROM
- Single + 5V Power Supply
- Internal Address Latch
- 2 General Purpose 8-Bit I/O Ports
- Access Time : 400 ns (MAX.)
- Each I/O Port Line Individually Programmable as Input or Output
- Multiplexed Address and Data Bus
- 40 pin DIP
- Compatible with Inptel's 8355

**PIN CONNECTIONS (TOP VIEW)**

**FIGURE 1** TMP8355P PINOUT DIAGRAM

**FIGURE 2** TMP8355P FUNCTIONAL BLOCK DIAGRAM

## PIN NAMES AND PIN DESCRIPTION

### ALE (INPUT)

When Address Latch Enable goes high, AD<sub>0-7</sub>, IO/M, A<sub>8-10</sub>, CE<sub>2</sub>, and  $\overline{CE}_1$ , enter the address latches. The signals (AD<sub>0-7</sub>, IO/M, A<sub>8-10</sub>, CE<sub>2</sub>,  $\overline{CE}_1$ ) are latched in at the trailing edge of ALE.

### AD<sub>0-7</sub> (INPUT/OUTPUT, 3-STATE)

Bi-directional Address/Data bus. The lower 8-bits of the ROM or I/O address are applied to the bus lines when ALE is high. During an I/O cycle, Port A or B are selected based on the latched value of AD<sub>0</sub>. If RD or  $\overline{IOR}$  is low when the latched Chip Enables are active, the output buffers present data on the bus.

### A<sub>8-10</sub> (INPUT)

These are the high order bits of the ROM address. They do not affect I/O operations.

### $\overline{CE}_1$ , CE<sub>2</sub> (INPUT)

CHIP ENABLE INPUTS: $\overline{CE}_1$  is active low and CE<sub>2</sub> is active high. Both chip enables must be active to permit accessing the ROM.

### IO/M (INPUT)

If the latched IO/M is high when  $\overline{RD}$  is low, the output data comes from an I/O port. If it is low the output data comes from the ROM.

### $\overline{RD}$ (INPUT)

If the latched Chip Enables are active when  $\overline{RD}$  goes low, the AD<sub>0-7</sub> output buffers are enabled and output either the selected ROM location or I/O port. When both  $\overline{RD}$  and  $\overline{IOR}$  are high, the AD<sub>0-7</sub> output buffers are 3-stated.

### $\overline{IOW}$ (INPUT)

If the latched Chip Enables are active, a low on  $\overline{IOW}$  causes the output port pointed to by the latched value of AD<sub>0</sub> to be written with the data on AD<sub>0-7</sub>. The state of IO/M is ignored.

### CLK (INPUT)

The CLK is used to force the READY into its high state after it has been forced low by  $\overline{CE}_1$  low, CE<sub>2</sub> high, and ALE high.

**READY (OUTPUT, 3-STATE)**

READY is a 3-state output controlled by  $\overline{CE}_1$ ,  $CE_2$ , ALE and CLK.

READY is forced low when the Chip Enables are active during the time ALE is high, and remains low until the rising edge of the next CLK.

**PA<sub>0</sub> - PA<sub>7</sub> (INPUT/OUTPUT, 3-STATE)**

These are general purpose I/O pins. Their input/output direction is determined by the contents of Data Direction Register (DDR). Port A is selected for write operations when the Chip Enables are active, and  $\overline{IOW}$  is low and a 0 was previously latched from AD<sub>0</sub>.

Read operation is selected by either  $\overline{IOR}$  low, active Chip Enables and AD<sub>0</sub> low, or IO/M high, RD low, active Chip Enables, and AD<sub>0</sub> low.

**PB<sub>0</sub> - PB<sub>7</sub> (INPUT/OUTPUT, 3-STATE)**

This general purpose I/O port is identical to Port A except that it is selected by a 1 latched from AD<sub>0</sub>.

**RESET (INPUT)**

In normal operation, an input high on RESET causes all pins in Ports A and B to assume input mode (clear DDR register).

 **$\overline{IOR}$  (INPUT)**

When the Chip Enables are active, a low on  $\overline{IOR}$  will output the selected I/O port onto the AD bus.  $\overline{IOR}$  low performs the same function as the combination of IO/M high and RD low. When  $\overline{IOR}$  is not used in a system,  $\overline{IOR}$  should be tied to V<sub>CC</sub> "1".

**V<sub>CC</sub> (POWER)**

+5 volt supply.

**V<sub>SS</sub> (POWER)**

Ground Reference



## FUNCTIONAL DESCRIPTION

## ROM SECTION

The TMP8355P contains an 8-bit address latch which allows it to interface directly to TLCS-85A microcomputer system without additional hardware.

The ROM portion of the chip is addressed by the 11-bit address (A8-10, AD<sub>0-7</sub>) and CE. The address, IO/ $\bar{M}$ , CE<sub>2</sub> and  $\bar{CE}_1$  are latched into the address latches on falling edge of ALE. If the Chip Enables (CE<sub>2</sub> and  $\bar{CE}_1$ ) are active and IO/ $\bar{M}$  is low when  $\bar{RD}$  goes low, the contents of the ROM location addressed by the latched address are put out on the AD<sub>0-7</sub> lines.

## I/O SECTION

The I/O port portion consists of two 8-bit I/O ports and two 8-bit Data Direction Registers (DDR). The I/O portion of the chip is addressed by the latched value of AD<sub>0</sub> and AD<sub>1</sub>. Contents of Port A and Port B can be read and written, but the contents of DDR's cannot be read. The contents of the selected I/O port can be read out when the latched Chip Enable are active and either  $\bar{RD}$  goes low with IO/ $\bar{M}$  high, or  $\bar{IOR}$  goes low.

The two 8-bit DDR's (DDRA and DDRB) are used to determine the input/output status of each pin in the corresponding port.

A '0' specifies an input mode and a '1' specifies an output mode.

The two 8-bit DDR's are cleared by RESET signal. The table 1 summarize Port and DDR designation.

TABLE 1, SELECTION OF PORT AND DDR DESIGNATION

| AD <sub>1</sub> | AD <sub>0</sub> | Selection                              |
|-----------------|-----------------|----------------------------------------|
| 0               | 0               | Port A                                 |
| 0               | 1               | Port B                                 |
| 1               | 0               | Port A Data Direction Register (DDR A) |
| 1               | 1               | Port B Data Direction Register (DDR B) |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8355P

## ABSOLUTE MAXIMUM RATINGS

| Symbol              | Item                                                           | Rating          |
|---------------------|----------------------------------------------------------------|-----------------|
| V <sub>CC</sub>     | V <sub>CC</sub> Supply Voltage with Respect to V <sub>SS</sub> | -0.5V to 7.0V   |
| V <sub>IN</sub>     | Input Voltage with Respect to V <sub>SS</sub>                  | -0.5V to 7.0V   |
| V <sub>OUT</sub>    | Output Voltage with Respect to V <sub>SS</sub>                 | -0.5V to 7.0V   |
| P <sub>D</sub>      | Power Dissipation                                              | 1.5W            |
| T <sub>SOLDER</sub> | Soldering Temperature (Soldering Time 10sec.)                  | 260°C           |
| T <sub>STG</sub>    | Storage Temperature                                            | -55°C to +150°C |
| T <sub>OPR</sub>    | Operating Temperature                                          | 0°C to +70°C    |

## D.C. CHARACTERISTICS

T<sub>A</sub> = 0°C to 70°C, V<sub>CC</sub> = 5V ± 5%

| Symbol          | Parameter                      | Test Conditions                           | Min. | Typ. | Max.                 | Units |
|-----------------|--------------------------------|-------------------------------------------|------|------|----------------------|-------|
| V <sub>IL</sub> | 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μA                  | 2.4  |      |                      | V     |
| I <sub>IL</sub> | Input Leakage Current          | V <sub>IN</sub> = V <sub>CC</sub> to OV   |      |      | ± 10                 | μA    |
| I <sub>LO</sub> | Output Leakage Current         | 0.45 ≤ V <sub>out</sub> ≤ V <sub>CC</sub> |      |      | ± 10                 | μA    |
| I <sub>CC</sub> | V <sub>CC</sub> Supply Current |                                           |      |      | 180                  | mA    |

## A.C. CHARACTERISTICS

 $T_A = 0^\circ\text{C}$  to  $70^\circ\text{C}$ ,  $V_{CC} = 5\text{V} \pm 5\%$ 

| Symbol     | Parameter                              | Test Conditions | Min. | Typ. | Max. | Units |
|------------|----------------------------------------|-----------------|------|------|------|-------|
| $t_{CYC}$  | Clock Cycle Time                       | 150pF<br>Load   | 320  |      |      | ns    |
| $t_L$      | CLK Low Width                          |                 | 80   |      |      | ns    |
| $t_H$      | CLK High Width                         |                 | 120  |      |      | ns    |
| $t_r, t_f$ | CLK Rise and Fall Time                 |                 |      | 30   |      | ns    |
| $t_{AL}$   | Address to Latch Set Up Time           |                 | 50   |      |      | ns    |
| $t_{LA}$   | Address Hold Time after Latch          |                 | 80   |      |      | ns    |
| $t_{LC}$   | Latch to READ/WRITE Control            |                 | 100  |      |      | ns    |
| $t_{RD}$   | Valid Data Out Delay from READ Control |                 |      | 170  |      | ns    |
| $t_{AD}$   | Address Stable to Data Out Valid       |                 |      | 400  |      | ns    |
| $t_{LL}$   | Latch Enable Width                     |                 | 100  |      |      | ns    |
| $t_{RDF}$  | Data Bus Float after READ              |                 | 0    | 100  |      | ns    |
| $t_{CL}$   | READ/WRITE Control to Latch Enable     |                 | 20   |      |      | ns    |
| $t_{CC}$   | READ/WRITE Control Width               |                 | 250  |      |      | ns    |
| $t_{DW}$   | Data In to WRITE Set Up Time           |                 | 150  |      |      | ns    |
| $t_{WD}$   | Data In Hold Time after WRITE          |                 | 10   |      |      | ns    |
| $t_{WP}$   | WRITE to Port Output                   |                 |      | 400  |      | ns    |
| $t_{PR}$   | Port Input Set Up Time                 |                 | 50   |      |      | ns    |
| $t_{RP}$   | Port Input Hold Time                   |                 | 50   |      |      | ns    |
| $t_{RYH}$  | READY Hold Time                        |                 | 0    | 160  |      | ns    |
| $t_{ARY}$  | ADDRESS (CE) to READY                  |                 |      | 160  |      | ns    |
| $t_{RV}$   | Recovery Time between Controls         |                 | 300  |      |      | ns    |
| $t_{RDE}$  | Data Out Delay from READ Controls      |                 | 10   |      |      | ns    |
| $t_{LCK}$  | ALE Low during CLK High                |                 | 100  |      |      | ns    |

## TIMING WAVEFORMS



FIGURE 3 PROM READ, I/O READ, AND WRITE TIMING



FIGURE 4 CLOCK SPECIFICATION FOR TMP8355P



FIGURE 5 WAIT STATE TIMING (READY = 0)

## A. INPUT MODE



## B. OUTPUT MODE



FIGURE 6 I/O PORT TIMING

## PROGRAM TAPE FORMAT

TMP8355P programs are delivered in the form of punched paper tape or the 8755A from which to copy. In case of the 8755A, Toshiba needs two pieces.

## (1) Tape Format



## (2) Example of Tape List

TOSHIBA MICRO COMPUTER TLCS-84  
 :100000000665C7D79CF50F3F951FED55A8FF16E570  
 :1000100088884DDE67D31F5D8ABA6DF292F113F5C1  
 :100020004FF1FB5DFFDA96A99CF7DF94A346B7C09  
 :10003000197352F729F12F79AA9C057C5B851EED77

...

:1003C0005DFDB5E556A67277F61A51C631CF9F0E80  
 :1003D000BD2F6F20E8BB1977E3FB5AD1F41FDAA7E2  
 :1003E000B53D42E0EC32546025B7308CDD52063D1D  
 :1003F000B4BE9E9E345B6138060B20VC372BF60BD6  
 :00000001FF

**OUTLINE DRAWING**

40 Pins Plastic Package

Unit in mm



- Note:
1. This dimension shows the center of curvature of leads.
  2. This dimension shows spread of leads.
  3. All dimensions are in millimeters.

Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

16,384 BIT EPROM WITH I/O PORTS

## GENERAL DESCRIPTION

The TMP8755AC is an erasable and electrically reprogrammable ROM (EPROM) and I/O chip to be used in the TLCS-85A microcomputer system. The PROM portion is organized as 2,048 words by 8 bits.

## FEATURES

- U.V. Erasable and Electrically Reprogrammable ROM (2,048 x 8)
- Single +5V Power Supply (VCC)
- Internal Address Latch
- 2 General Purpose 8 bit I/O Ports
- Access Time: 450 ns (MAX.)

TOSHIBA MOS DIGITAL INTEGRATED CIRCUIT

TMP8755AC

N-CHANNEL SILICON GATE MOS

The I/O portion consists of two general purpose I/O ports. Each I/O port has eight port lines, and each I/O port line is individually programmable as input or output.

## PIN CONNECTIONS (TOP VIEW)

|                      |    |    |                 |
|----------------------|----|----|-----------------|
| PROG/CE <sub>1</sub> | 1  | 40 | VCC             |
| CE <sub>2</sub>      | 2  | 39 | PB <sub>7</sub> |
| CLK                  | 3  | 38 | PB <sub>6</sub> |
| RESET                | 4  | 37 | PB <sub>5</sub> |
| VDD                  | 5  | 36 | PB <sub>4</sub> |
| READY                | 6  | 35 | PB <sub>3</sub> |
| IO/M                 | 7  | 34 | PB <sub>2</sub> |
| IOW                  | 8  | 33 | PB <sub>1</sub> |
| RD                   | 9  | 32 | PB <sub>0</sub> |
| IOW                  | 10 | 31 | PA <sub>7</sub> |
| ALE                  | 11 | 30 | PA <sub>6</sub> |
| AD <sub>0</sub>      | 12 | 29 | PA <sub>5</sub> |
| AD <sub>1</sub>      | 13 | 28 | PA <sub>4</sub> |
| AD <sub>2</sub>      | 14 | 27 | PA <sub>3</sub> |
| AD <sub>3</sub>      | 15 | 26 | PA <sub>2</sub> |
| AD <sub>4</sub>      | 16 | 25 | PA <sub>1</sub> |
| AD <sub>5</sub>      | 17 | 24 | PA <sub>0</sub> |
| AD <sub>6</sub>      | 18 | 23 | A <sub>10</sub> |
| AD <sub>7</sub>      | 19 | 22 | A <sub>9</sub>  |
| VSS                  | 20 | 21 | A <sub>8</sub>  |

FIGURE 1 TMP8755AC PINOUT DIAGRAM

## BLOCK DIAGRAM



FIGURE 2 TMP8755AC FUNCTIONAL BLOCK DIAGRAM



## PIN NAMES AND PIN DESCRIPTION

## ALE (Input)

When Address Latch Enable goes high, AD<sub>0-7</sub>, IO/M, A<sub>8-10</sub>, CE<sub>2</sub>, and CE<sub>1</sub> enter the address latches. The signals (AD<sub>0-7</sub>, IO/M, A<sub>8-10</sub>, CE) are latched in at the trailing edge of ALE.

AD<sub>0-7</sub> (Input/Output, 3-state)

Bi-directional Address/Data bus. The lower 8-bit of the PROM or I/O address are applied to the bus lines when ALE is high. During an I/O cycle, Port A or B are selected based on the latched value of AD<sub>0</sub>. If RD or IOR is low when the latched Chip Enables are active, the output buffers present data on the bus.

A<sub>8-10</sub> (Input)

These are the high order bits of the PROM address. They do not affect I/O operations.

PROG/CE<sub>1</sub>, CE<sub>2</sub> (Input)

CHIP ENABLE INPUTS: CE<sub>1</sub> is active low and CE<sub>2</sub> is active high. Both chip enables must be active to permit accessing the PROM. CE<sub>1</sub> is also used as a programming pin.

## IO/M (Input)

If the latched IO/M is high when RD is low, the output data comes from an I/O port. If it is low the output data comes from the PROM.

## RD (Input)

If the latched Chip Enables are active when RD goes low, the AD<sub>0-7</sub> output buffers are enabled and output either the selected PROM location or I/O ports. When both RD and IOR are high, the AD<sub>0-7</sub> output buffers are 3-stated.

## IOW (Input)

If the latched Chip Enables are active, a low on IOW causes the output port pointed to by the latched value of AD<sub>0</sub> to be written with the data on AD<sub>0-7</sub>. The state of IO/M is ignored.

## CLK (Input)

The CLK is used to force the READY into its high state after it has been forced low by CE<sub>1</sub> low, CE<sub>2</sub> high, and ALE high.



## READY (Output, 3-state)

READY is a 3-state output controlled by  $\overline{CE}_1$ ,  $CE_2$ , ALE and CLK.  
READY is forced low when the Chip Enables are active during the time ALE  
is high, and remains low until the rising edge of the next CLK.

## PA0 - PA7 (Input/Output, 3-state)

These are general purpose I/O pins. Their input/output direction is  
determined by the contents of Data Direction Register (DDR). Port A is  
selected for write operations when the Chip Enables are active and  $IOW$   
is low and a 0 was previously latched from  $AD_0$ ,  $AD_1$ .  
Read operation is selected by either  $IOR$  low and active Chip Enables and  
 $AD_0$  and  $AD_1$  low, or  $IO/M$  high,  $RD$  low, active Chip Enables, and  $AD_0$  and  $AD_1$  low.

## PB0 - PB7 (Input/Output, 3-state)

This general purpose I/O port is identical to Port A except that it is  
selected by a 1 latched from  $AD_0$  and a 0 from  $AD_1$ .

## RESET (Input)

In normal operation, an input high on RESET causes all pins in Ports A and  
B to assume input mode (clear DDR register).

 $\overline{IOR}$  (Input)

When the Chip Enables are active, a low on  $\overline{IOR}$  will output the selected I/O  
port onto the AD bus.  $\overline{IOR}$  low performs the same function as the combination  
of  $IO/M$  high and  $RD$  low. When  $IOR$  is not used in a system,  $IOR$  should be  
tied to VCC "1".

 $V_{CC}$  (Power)  
+5 volt supply $V_{SS}$  (Power)  
Ground Reference $V_{DD}$  (Power)

$V_{DD}$  is a programming voltage and must be tied to +5V when the TMP8755AC is  
being read. For programming, a high voltage is supplied with  $V_{DD}=25V$ , typical.



## FUNCTIONAL DESCRIPTION

PROM SECTION

The TMP8755AC contains an 8-bit address latch which allows it to interface directly to TLCS-85A microcomputer system without additional hardware. The PROM portion of the chip is addressed by the 11-bit address (A8-10,AD<sub>0-7</sub>) and CE. The address, IO/M and CE are latched into the address latches on the falling edge of ALE. If the Chip Enables (CE<sub>2</sub> and  $\overline{CE}_1$ ) are active and IO/M is low when RD goes low, the contents of the EPROM location addressed by latched address are output onto the AD<sub>0-7</sub> lines.

I/O SECTION

The I/O port portion consists of two 8-bit I/O ports and two 8-bit Data Direction Registers (DDR).

The I/O portion of the chip is addressed by the latched value of AD<sub>0</sub> and AD<sub>1</sub>.

Contents of Port A and Port B can be read and written, but those of DDR's cannot be read. A port can be read out when the latched Chip Enables are active and either RD goes low with IO/M high, or  $\overline{IOR}$  goes low.

The two 8-bit DDR's (DDRA and DDRB) are used to determine the input/output status of each pin in the corresponding port.

A '0' specifies an input mode and a '1' specifies an output mode.

The two 8-bit DDR's are cleared by RESET signal. The table 1 summarizes Port and DDR designation.

TABLE 1 SELECTION OF PORT AND DDR DESIGNATION

| AD <sub>1</sub> | AD <sub>0</sub> | Selection                              |
|-----------------|-----------------|----------------------------------------|
| 0               | 0               | Port A                                 |
| 0               | 1               | Port B                                 |
| 1               | 0               | Port A Data Direction Register (DDR A) |
| 1               | 1               | Port B Data Direction Register (DDR B) |

### ERASURE CHARACTERISTICS

The TMP8755AC can be erased by applying light with wavelengths shorter than 4000 Å. ( $\lambda = 10^{-8}$  cm). Sunlight and the fluorescent lamps may include 3000 ~ 4000 Å wavelength components consequently when used under such lighting for extended periods of time, an opaque seal will be required to protect the TMP8755AC. Generally, ultraviolet light with a wavelength of 2537 Å is recommended for TMP8755AC-erasing, and in this case the integrated dose (ultraviolet light intensity [ $\mu\text{W}/\text{cm}^2$ ] × time [sec]) should be over 15 [ $\mu\text{W} \cdot \text{sec}/\text{cm}^2$ ].

If the Toshiba sterilizing lamp GL-15 is used and the device is exposed at a distance of 1-cm from the lamp surface, erasure should be completed in about 60 minutes.

And using a lamp whose ultraviolet light intensity is a 12000 [ $\mu\text{W}/\text{cm}^2$ ] will reduce the exposure time to about 20 minutes. (In this case the integrated dose should be 12000 [ $\mu\text{W}/\text{cm}^2$ ] × (20 × 60)[sec] ≈ 15 [ $\mu\text{W} \cdot \text{sec}/\text{cm}^2$ ].)

### PROGRAMMING

Initially when received by customers all bits of the TMP8755AC are in the "1" state which is the erased state. Therefore programming is carried out by electrically writing in the "0" state at the desired bit locations. A programmed "0" can only be changed to a "1" by ultraviolet erasure. The program mode itself consists of programming a single address at a time, giving a single 50 ms pulse for every address. Preliminary timing diagrams and parameter values pertaining to the TMP8755AC programming operation are contained in Figure 7.



## ABSOLUTE MAXIMUM RATINGS

| Symbol                     | Item                                                                                      | Rating          |
|----------------------------|-------------------------------------------------------------------------------------------|-----------------|
| V <sub>CC</sub>            | V <sub>CC</sub> Supply Voltage with Respect to V <sub>SS</sub>                            | -0.5V to +7.0V  |
| V <sub>D<sup>D</sup></sub> | V <sub>D<sup>D</sup></sub> Supply Voltage for Programming with Respect to V <sub>SS</sub> | -0.5V to +26.5V |
| V <sub>IN</sub>            | Input Voltage with Respect to V <sub>SS</sub>                                             | -0.5V to +7.0V  |
| V <sub>OUT</sub>           | Output Voltage with Respect to V <sub>SS</sub>                                            | -0.5V to +7.0V  |
| P <sub>D</sub>             | Power Dissipation                                                                         | 1.5 W           |
| T <sub>SOLDER</sub>        | Soldering Temperature (Soldering Time 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    |

## D.C. CHARACTERISTICS

TA = 0°C to 70°C, V<sub>CC</sub> = 5V ± 5%, V<sub>D<sup>D</sup></sub> = V<sub>CC</sub> ± 0.6V

| Symbol          | Parameter                      | Test Conditions                           | Min. | Typ. | Max. | Units                |
|-----------------|--------------------------------|-------------------------------------------|------|------|------|----------------------|
| V <sub>IL</sub> | Input Low Voltage              |                                           | -0.5 |      | 0.8  | V                    |
| V <sub>IH</sub> | Input High Voltage             |                                           |      | 2.0  |      | V <sub>CC</sub> +0.5 |
| 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μA                  | 2.4  |      |      | V                    |
| I <sub>IL</sub> | Input Leakage Current          | V <sub>IN</sub> = V <sub>CC</sub> to 0V   |      |      | ±10  | μA                   |
| I <sub>LO</sub> | Output Leakage Current         | 0.45 ≤ V <sub>out</sub> ≤ V <sub>CC</sub> |      |      | ±10  | μA                   |
| I <sub>CC</sub> | V <sub>CC</sub> Supply Current |                                           |      |      | 180  | mA                   |



## A.C. CHARACTERISTICS

TA = 0°C to 70°C , V<sub>CC</sub> = 5V ± 5% V<sub>DD</sub> = V<sub>CC</sub> ± 0.6V

| Symbol                          | Parameter                              | Test Condition | Min. | Typ. | Max. | Units |
|---------------------------------|----------------------------------------|----------------|------|------|------|-------|
| t <sub>CYC</sub>                | Clock Cycle time                       | 150pF Load     | 320  |      |      | ns    |
| t <sub>L</sub>                  | CLK Low Width                          |                | 80   |      |      | ns    |
| t <sub>H</sub>                  | CLK High Width                         |                | 120  |      |      | ns    |
| t <sub>r</sub> , t <sub>f</sub> | CLK Rise and Fall Time                 |                |      | 30   |      | ns    |
| t <sub>AL</sub>                 | Address to Latch Set Up Time           |                | 50   |      |      | ns    |
| t <sub>LA</sub>                 | Address Hold Time after Latch          |                | 80   |      |      | ns    |
| t <sub>LC</sub>                 | Latch to READ/WRITE Control            |                | 100  |      |      | ns    |
| t <sub>RD</sub>                 | Valid Data Out Delay from READ Control |                |      | 170  |      | ns    |
| t <sub>AD</sub>                 | Address Stable to Data Out Valid       |                |      | 450  |      | ns    |
| t <sub>LL</sub>                 | Latch Enable Width                     |                | 100  |      |      | ns    |
| t <sub>RDF</sub>                | Data Bus Float after READ              |                | 0    | 100  |      | ns    |
| t <sub>CL</sub>                 | READ/WRITE Control to Latch Enable     |                | 20   |      |      | ns    |
| t <sub>CC</sub>                 | READ/WRITE Control Width               |                | 250  |      |      | ns    |
| t <sub>DW</sub>                 | Data In to WRITE Set Up time           |                | 150  |      |      | ns    |
| t <sub>WD</sub>                 | Data In Hold Time after WRITE          |                | 30   |      |      | ns    |
| t <sub>WP</sub>                 | WRITE TO Port Output                   |                |      | 400  |      | ns    |
| t <sub>PR</sub>                 | Port Input Set Up Time                 |                | 50   |      |      | ns    |
| t <sub>RP</sub>                 | Port Input Hold Time                   |                | 50   |      |      | ns    |
| t <sub>TRYH</sub>               | READY Hold Time                        |                | 0    | 160  |      | ns    |
| t <sub>ARY</sub>                | Address (CE) to READY                  |                |      | 160  |      | ns    |
| t <sub>RV</sub>                 | Recovery Time between Controls         |                | 300  |      |      | ns    |
| t <sub>RDDE</sub>               | Data Out Delay from READ Controls      |                | 10   |      |      | ns    |
| t <sub>LD</sub>                 | ALE to Data Out Valid                  |                |      | 350  |      | ns    |
| t <sub>LCK</sub>                | ALE Low during CLK high                |                | 100  |      |      | ns    |



## D.C. CHARACTERISTICS FOR PROGRAMMING

TA = 25°C ± 5°C , V<sub>CC</sub> = 5V ± 5% , V<sub>SS</sub> = 0V

| Symbol          | Parameter                      | Min. | Typ. | Max. | Units |
|-----------------|--------------------------------|------|------|------|-------|
| V <sub>DD</sub> | Supply Voltage for programming | 24   | 25   | 26   | V     |
| I <sub>DD</sub> | Supply Current                 |      |      | 30   | mA    |

## A.C. CHARACTERISTICS FOR PROGRAMMING

TA = 25°C ± 5°C , V<sub>CC</sub> = 5V ± 5% , V<sub>SS</sub> = 0V

| Symbol           | Parameter                 | Min. | Typ. | Max. | Units |
|------------------|---------------------------|------|------|------|-------|
| t <sub>PS</sub>  | Data Set Up Time          | 10   |      |      | ns    |
| t <sub>PD</sub>  | Data Hold Time            | 0    |      |      | ns    |
| t <sub>S</sub>   | Program Pulse Set Up Time | 2    |      |      | μs    |
| t <sub>H</sub>   | Program Pulse Hold Time   | 2    |      |      | μs    |
| t <sub>PR</sub>  | Program Pulse Rise Time   | 10   | 2000 |      | ns    |
| t <sub>PF</sub>  | Program Pulse Fall Time   | 10   | 2000 |      | ns    |
| t <sub>PRG</sub> | Program Pulse Width       | 45   | 50   |      | ms    |

**TIMING WAVEFORMS**


Note:  $\overline{CE_1}$  must remain low for the entire cycle.

FIGURE 3 PROM READ, I/O READ, AND WRITE TIMING



FIGURE 4 CLOCK SPECIFICATION FOR TMP8755AC



FIGURE 5 WAIT STATE TIMING (READY= 0)

#### A. INPUT MODE



#### B. OUTPUT MODE



FIGURE 6 I/O PORT TIMING



\* VERIFY CYCLE IS A REGULAR MEMORY READ CYCLE  
(WITH V<sub>DD</sub> = 5V FOR TMP8755AC)

FIGURE 7 PROGRAM MODE TIMING DIAGRAM

## OUTLINE DRAWING

40 Pins Ceramic Package



Note 1. This dimension shows spread of leads.

2. All dimensions are in millimeters.

Toshiba

# INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TOSHIBA MOS TYPE DIGITAL  
INTEGRATED CIRCUIT

TMP8259AP

Silicon Monolithic  
N Channel Silicon Gate MOS

### PROGRAMMABLE INTERRUPT CONTROLLER

#### GENERAL DESCRIPTION

The TMP8259AP is a programmable interrupt controller designed for use with the TLCS-85A microcomputer system. It handles up to eight vectored priority interrupts for the CPU. It is cascadable for up to 64 vectored priority interrupts without additional circuitry.

#### FEATURES

- o Eight Level Priority Controller.
- o Expandable to 64 Level.
- o Interrupt Modes, Interrupt Mask, Vectored Address Programmable.
- o Single +5V Power Supply.
- o 8085A, 8086 Microcomputer System Compatible.
- o Compatible with Intel's 8259A.

#### PIN CONNECTIONS (TOP VIEW)



## PIN NAMES AND PIN DESCRIPTION

| Pin Name     | Input/Output | Function                                                                                                                                                                                                                                                                                   |
|--------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>CS</u>    | Input        | Chip Select Input. A low on this pin enables <u>RD</u> and <u>WR</u> communication between the CPU and the 8259A. <u>INTA</u> functions are independent of <u>CS</u> .                                                                                                                     |
| <u>WR</u>    | Input        | Write Control Input. A low on this pin when <u>CS</u> is low enables the 8259A to accept command words from CPU.                                                                                                                                                                           |
| <u>RD</u>    | Input        | Read Control Input. A low on this pin when <u>CS</u> is low enables the 8259A to release status onto the data bus for the CPU.                                                                                                                                                             |
| D0 ~ D7      | Input/Output | Bidirectional Data Bus. Command status and interrupt-vector information is transferred via this bus.                                                                                                                                                                                       |
| CAS0 ~ CAS2  | Input/Output | Cascade Lines. The CAS lines form a private 8259A bus to control a multiple 8259A structure. These pins are outputs for a master 8259A and inputs for a slave 8259A.                                                                                                                       |
| <u>SP/EN</u> | Input/Output | Slave Program/Enable Buffer. This is a dual function pin. When in the buffered mode it can be used as an output to control buffer transceivers ( <u>EN</u> ). When not in the buffered mode it is used as an input to designate a master 8259A ( <u>SP</u> =1) or a slave ( <u>SP</u> =0). |
| INT          | Output       | Interrupt Request Output. This pin goes high whenever a valid interrupt request is asserted. It is used to interrupt the CPU. Thus it is connected to CPU's interrupt pin.                                                                                                                 |

| Pin Name  | Input/Output | Function                                                                                                                                                                                                                                      |
|-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IR0 ~ IR7 | 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 an IR input (Level Triggered Mode).           |
| INTA      | Input        | Interrupt Acknowledge Input. This pin is used to enable 8259A interrupt-vector data onto the data bus by a sequence of interrupt acknowledge pulses issued by the CPU.                                                                        |
| A0        | Input        | A0 Address Line. This pin acts in conjunction with the CS, WR, and RD pins. It is used by the 8259A to decipher various command words the CPU writes and status the CPU wishes to read. It is typically connected to the CPU A0 address line. |
| VCC       |              | +5V Power Supply                                                                                                                                                                                                                              |
| VSS       |              | Ground                                                                                                                                                                                                                                        |

**BLOCK DIAGRAM**


Toshiba

## INTEGRATED CIRCUIT

東芝

## TECHNICAL DATA

TMP8259AP

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL           | ITEM                                                                    | RATING         |
|------------------|-------------------------------------------------------------------------|----------------|
| V <sub>CC</sub>  | V <sub>CC</sub> Supply Voltage (with respect to GND (V <sub>SS</sub> )) | -0.5V to +7V   |
| V <sub>IN</sub>  | Input Voltage                                                           | -0.5V to +7V   |
| P <sub>D</sub>   | Power Dissipation                                                       | 1W             |
| T <sub>SOL</sub> | Soldering Temperature                                                   | 260°C          |
| T <sub>STG</sub> | Storage Temperature                                                     | -65°C to 150°C |
| T <sub>OPR</sub> | Operating Temperature                                                   | 0°C to 70°C    |

DC CHARACTERISTICS T<sub>OPR</sub>=0°C to 70°C, V<sub>CC</sub>=+5V±10%, V<sub>SS</sub>=0V, Unless otherwise noted.

| SYMBOL               | PARAMETER                      | TEST CONDITIONS                           | MIN. | TYP. | MAX.                 | UNIT |
|----------------------|--------------------------------|-------------------------------------------|------|------|----------------------|------|
| V <sub>IL</sub>      | 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> = 2.2mA                   | -    | -    | 0.45                 | V    |
| V <sub>OH</sub>      | Output High Voltage            | I <sub>OH</sub> = -400μA                  | 2.4  | -    | -                    | V    |
| V <sub>OH(INT)</sub> | Output High Voltage (INT)      | I <sub>OH</sub> = -100μA                  | 3.5  | -    | -                    | V    |
|                      |                                | I <sub>OH</sub> = -400μA                  | 2.4  | -    | -                    | V    |
| I <sub>LI</sub>      | Input Leak Current             | 0V ≤ V <sub>IN</sub> ≤ V <sub>CC</sub>    | -    | -    | ±10                  | μA   |
| I <sub>LOL</sub>     | Output Leak Current            | 0.45V < V <sub>IN</sub> < V <sub>CC</sub> | -    | -    | ±10                  | μA   |
| I <sub>CC</sub>      | V <sub>CC</sub> Supply Current |                                           | -    | -    | 85                   | mA   |
| I <sub>LIR</sub>     | Input Current (IR)             | V <sub>IN</sub> = 0V                      | -    | -    | -300                 | μA   |
|                      |                                | V <sub>IN</sub> = V <sub>CC</sub>         | -    | -    | 10                   | μA   |



## INTEGRATED CIRCUIT

## TECHNICAL DATA

TMP8259AP

AC CHARACTERISTICS  $T_{opr}=0^{\circ}\text{C} \sim 70^{\circ}\text{C}$ ,  $V_{CC}=5\text{V}\pm10\%$ ,  $V_{SS}=0\text{V}$ , Unless otherwise noted.

## TIMING REQUIREMENTS

| SYMBOL | PARAMETER                                            | MIN. | MAX. | UNIT |
|--------|------------------------------------------------------|------|------|------|
| TAHRL  | A0/CS Setup Time ( $\bar{RD}/\bar{INTA}^+$ )         | 0    | -    | ns   |
| TRHAX  | A0/CS Hold Time ( $\bar{RD}/\bar{INTA}^+$ )          | 0    | -    | ns   |
| TRLRH  | $\bar{RD}$ Pulse Width                               | 235  | -    | ns   |
| TAHWL  | A0/ $\bar{CS}$ Setup Time ( $\bar{WR}^+$ )           | 0    | -    | ns   |
| TWHAX  | A0/ $\bar{CS}$ Hold Time ( $\bar{WR}^+$ )            | 0    | -    | ns   |
| TWLWH  | $\bar{WR}$ Pulse Width                               | 290  | -    | ns   |
| TDVWH  | D0 - D7 Setup Time ( $\bar{WR}^+$ )                  | 240  | -    | ns   |
| TWHDX  | D0 - D7 Hold Time ( $\bar{WR}^+$ )                   | 0    | -    | ns   |
| TJLJH  | Interrupt Request Pulse Width (LOW)                  | 100  | -    | ns   |
| TCVIAL | Cascade Setup Time (Second or Third $\bar{INTA}^+$ ) | 55   | -    | ns   |
| TRHRL  | $\bar{RD}^+$ to Next Command                         | 160  | -    | ns   |
| TWHRL  | $\bar{WR}^+$ to Next Command                         | 190  | -    | ns   |

## RESPONSE CHARACTERISTICS

| SYMBOL | PARAMETER                                    | TEST CONDITIONS                     | MIN. | TYP. | MAX. | UNIT |
|--------|----------------------------------------------|-------------------------------------|------|------|------|------|
| TRLDV  | Valid Data Delay ( $\bar{RD}/\bar{INTA}^+$ ) | $D_0 - D_7$<br>$C_L = 100\text{pF}$ | -    | -    | 200  | ns   |
| TRHDZ  | Data Floating ( $\bar{RD}/\bar{INTA}^+$ )    |                                     | -    | -    | 100  | ns   |
| TJHIH  | Interrupt Output Delay ( $IR^+$ )            |                                     | -    | -    | 350  | ns   |
| TIALCV | Valid Cascade Delay ( $\bar{INTA}^+$ )       |                                     | -    | -    | 565  | ns   |
| TRLEL  | Enable Active ( $\bar{RD}/\bar{INTA}^+$ )    |                                     | -    | -    | 125  | ns   |
| TRHEH  | Enable Inactive ( $\bar{RD}/\bar{INTA}^+$ )  |                                     | -    | -    | 150  | ns   |
| TAHDV  | Valid Data Delay (A0/ $\bar{CS}$ )           |                                     | -    | -    | 200  | ns   |
| TCVDV  | Valid Data Delay ( $CAS_0-CAS_2$ )           |                                     | -    | -    | 300  | ns   |

NOTE: AC TESTING. Inputs are driven at  $V_L = 0.45\text{V}$  and  $V_H = 2.4\text{V}$ .  
 Measurements are made at  $V_L = 0.8\text{V}$  and  $V_H = 2.0\text{V}$ .

## TECHNICAL DATA

## TIMING WAVEFORMS

## WRITE OPERATION



## READ AND INTA OPERATION



## INTA SEQUENCE



## OTHER TIMING



**OUTLINE DRAWING**

UNIT : mm



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.42 leads.

# **MICROCOMPUTER APPLICATION DEVELOPMENT TOOL**





**MICROCOMPUTER**

TECHNICAL DESCRIPTION

Microcomputer Technical Description

MICROCOMPUTER APPLICATION DEVELOPMENT TOOL

GENERAL DESCRIPTION

## DEVECOPMENT TOOLS

Toshiba's single-chip microcomputer development tool has the TDS400 microcomputer application development system and the dedicated debugging system.

## MICROCOMPUTER APPLICATION DEVELOPMENT SYSTEM TDS400

By exchanging portions of the control board and software, the TDS400 system can be changed into the following development systems:

- (1) TDS400/43 TLCS-43 Application Development System
- (2) TDS400/46 TLCS-46A Application Development System
- (3) TDS400/84 TLCS-84 Application Development System

The TDS400 system is hereinafter described under the name of the TDS400/xx (xx denotes the name of the microcomputer series of 43, 46 or 84).

## DEDICATED DEBUGGING SYSTEM

The dedicated debugging system can be realized by combining the debugging board and the emulation board, consisting of the following products.

- (1) BM4304 TLCS-43 debugging board + BM4303 TLCS-43 emulation board
- (2) BM4604 TLCS-46A debugging board + BM4603B TLCS-46A emulation board
- (3) BM8404 TLCS-84 debugging board + BM8403 TLCS-84 emulation board

## 1. MICROCOMPUTER APPLICATION DEVELOPMENT SYSTEM TDS400

### 1.1 SYSTEM CONCEPT

The TDS400/xx system is the application program development support system of Toshiba's single-chip microcomputer. Microcomputer application program development is divided into two main categories, programming and real time debugging. These functions can be performed consecutively through the TDS400/xx system.

- o Programming:

- (1) Programming and editing of source program
- (2) Assembling source program (converting to machine code)
- (3) Loading, modifying and writing into EPROM in the object program

- o Real time debugging:

- (1) Allows to execute and debug program at a state with the application circuit. (direct modification with machine codes)
- (5) Monitoring and revising of internal status during program execution.
- (6) Data exchange with EPROM (read/write)

The following manuals are available as system documents relative to the functions and operating instructions of the TDS400/xx:

- (A) Operating Instructions (Description of the functions and operations of the above-mentioned (1) to (6)).
- (B) Instruction Manuals (configuration description of hardware).



# MICROCOMPUTER

## TECHNICAL DESCRIPTION

### 1.2 HARDWARE CONFIGURATION

The TDS400/xx is a system which a microcomputer consists of TMP8085A MPU, 16 K-byte ROM, and 48K-byte RAM has been equipped with various auxiliary memories and input/output interfaces. To ensure a more useful development system, it is provided with 16K EPROM writer, emulation board, program memory (4 K-byte RAM) which can be substituted with ROM, and dedicated debugging console.

The TDS400/xx hardware configuration is given in Fig.1, and its conceptual system view in Fig.2, respectively. In Fig.1 solid line boxes show basic configuration units, while dotted line boxes indicate optional units. The units enclosed with broken lines are supplied by users, as required. Shaded boxes indicate the specific units depending on the series of a microcomputer. Other units are common to both.

When used as a programming system, this system requires a minimum of one console I/O device for input/output of commands and application program data. When the system is used as a real-time debugging tool, operation is made through the attached debugging console. Real time execution can be obtained by removing the single chip microprocessor from the application circuit (user system) and plugging in the DIP socket from the emulation board.



Fig. 1 TDS400/xx Hardware Configuration

Solid line boxes: basic configuration   Dotted lines: Optional units  
 Broken lines: user-supplied   Shaded line boxes: specific to  
 microcomputer



Fig. 2 Conceptual System View of TDS400/xx System



# MICROCOMPUTER

## TECHNICAL DESCRIPTION

### 1.3 SOFTWARE CONFIGURATION

As shown in Fig. 3, the TDS400/xx system software consists of a programming system segment and debugging console control segment. Shaded portions indicate the specific program depending on the microcomputer series. Other programs are common to both.

These programs are firmwared in 16 K-byte ROM within the main memory of the TMP8085A system; therefore, no loading of system programs is required, thus programs being able to be immediately operated. However, for operating option programs, such as assembler programs, the programs must be separately loaded.

The system program uses a 2 K-byte as dedicated data area. Furthermore, a 4K-byte RAM is designated as dedicated area (called the back-up memory) for internal save and transmission in the program memory. The remaining 42 K-byte RAM area is a free area used as user programs, symbol tables, current file, or assembler program. (See Fig. 4)

### 1.4 PROCESS FLOW OF APPLICATION PROGRAM DATA

Fig. 5 shows a conceptual flow chart of the application program data for application program development and evaluation by using the TDS400/xx system (as programming system or debugging console)

### 1.5 PROGRAMMING SYSTEM

The programming system is provided for facilitating the programming work (development) of application software.



Fig. 3 TDS400/xx System Program Configuration  
Shaded element: Portions depending to microcomputer series

| <u>Address<br/>(hexadecimal)</u> | <u>Purpose of using main memory</u>                                                      |               |
|----------------------------------|------------------------------------------------------------------------------------------|---------------|
| 0000                             | System program<br>(16 K-byte ROM)                                                        | ROM 16K bytes |
| 3FFF                             | System data<br>(2K bytes)                                                                |               |
| 4000                             |                                                                                          |               |
| 47FF                             |                                                                                          |               |
| 4800                             | User program,<br>Symbol table,<br>Current files, or<br>Assembler program,<br>(42K Bytes) | RAM 48K bytes |
| FFFF                             |                                                                                          |               |
| F000                             |                                                                                          |               |
| FFFF                             | Back-up memory<br>(4K bytes)                                                             |               |

Fig. 4 TDS400/xx Main Memory Configuration



Fig. 5 Data Flow of Application Program

\* : Operation from the debugging console.

o : Operation through the porgramming system.



# MICROCOMPUTER

## TECHNICAL DESCRIPTION

The TDS400/xx programming system operates according to an input command from the input/output device. The following outline shows the outline of utilization form at each step in application software programming.

- (1) In making a source program by expressing the control processing contents of application system in assembler language, the source program is entered directly through the keyboard or via paper tape, etc., revised and edited statement (line) by statement (line). If the program was structured into blocks, when it was written, the program can be easily edited into a single program and then punched onto paper tape, etc.
- (2) In assembling the source program, the assembler program is activated. Each pass of the program listing, object tape output, and generation of object program (machine code) in the main memory can be selected from the commands of input/output device.
- (3) At the machine code level, the following functions can be implemented: object program loading, transmission, modifying, dumping, format change on the paper tape and writing into 16K EPROM.

The entire programming system can be operated from a single input/output device<sup>1)</sup>, but for performing the operation at high-speed, multiple input/output devices can also be utilized.

Note 1) Can use teletype, CRT display, or TV+keyboard



- (a) 64 K-byte indirect memory --- can be used as a temporary file memory. For example, if the paper tape source program is once stored in this memory, the program will become much faster and easier to execute. The source program, however, is restricted to about 1.5 ~ 2 K-byte because of memory capacity.
- (b) Floppy disk --- a file memory (random file) similar to indirect memory. Memory capacity is approximately 250 K-byte. Each disc can store 6 K~8 K-step source program. The processing rate is lower than that of indirect memory.
- (c) Paper tape reader and Paper tape punch --- allows faster processing of paper tape.  
Printer -- speeds up program listing output  
CRT display -- convenient for editing and modifying application programs.
- (d) Digital cassette --- can be used as a sequential file, instead of paper tape. This eliminates the bother of rewinding and remounting paper tape, improving speed and ease of handling.
- (e) Television receiver and simple keyboard --- useful as low cost input/output devices.

#### 1.6 DEBUGGING CONSOLE

The debugging console is designed for easy real time debugging of the application system.

The debugging console, mounted in the front panel of the TDS400, is a dedicated console. Major functions performed by this console are as follows:

- (1) Real time emulation can be performed. For application program memory, the user can select either program memory (RAM) within the TDS400/xx or external memory (EPROM) within the emulation board.
- (2) Program memory read and write is done directly through the debugging console.
- (3) Loading to program memory:
  - (i) The program can be loaded directly from program EPROM.
  - (ii) The program can also be loaded from the back-up memory within the development system<sup>Note 2)</sup>.
- (4) Contents of the program memory:
  - (i) Can be written directly into 16K EPROM.
  - (ii) Can be compared with the contents of programmed EPROM.
  - (iii) Can be transferred and saved to the back-up memory
- (5) Direct read and write can be performed with RAM or register built into the single-chip microcomputer just as with program memory.
- (6) Application programs can be initiated from any address.
- (7) Application programs may be stopped at any time while in operation.
- (8) Address-stop function provided.

Note 2) The back-up memory is a point of contact between the debugging console function and the programming system function. The programming system can load the back-up memory with an object program, and the contents of the back-up memory can be put out onto paper tape, etc. (in various formats).



# MICROCOMPUTER



## TECHNICAL DESCRIPTION

- (9) Single-step operation possible.
- (10) Dummy interrupt signal can be entered through the debugging console.
- (11) Logical levels of all pins of microcomputer chip are always indicated. Voltage of the threshold value can be see at any level.

### 1.7 EMULATION BOARD

In the last step of application system development, it becomes extremely important to be able to check the system operations as close to the end product as possible. For answering this need, emulation board (BM4303/BM603B/BM8403) is available, as shown in Table 1. These emulation board are integrated with the evaluator chip and are designed to use EPROM in the program memory section. Fig. 6 shows the conceptualized drawings of these emulation boards.

Besides the circuits attached to the evaluator chip, the emulation board has interface circuits for connecting to the application development system TDS400 and free space for mounting a small number of peripheral circuits. Fot the program memory, 24-pin DIP sockets are provided so as to make it possible to use 16K EPROM TMM323 (2716) unit.

When this emulation board is connected with the TDS400, the user can choose to put the application program either into program memory (RAM) within the TDS400/xx or into EPROM on the emulation board. The former freely permits reading and reloading of program memory contents through the TDS400/xx debugging console, making debugging of the application program during development very convenient.



# MICROCOMPUTER

## TECHNICAL DESCRIPTION

The latter does not permit reading and writing of the application program contents. However, in either case the application program can easily be checked by using the function of the debugging console of TDS400/xx while monitoring or changing internal status of the microcomputer.

When the emulation board is disconnected from the TDS400, EPROM within the board is automatically used as program memory and the board can be used as an independent emulation board.

The BM4302/4602A makes a compact emulation boards, equipped with one/two 16K EPROM TMM323 -(2716) as program memory. This board is useful for field-testing the applied product, but lacks free space and an interface to TDS400.

Each emulation board provides each microcomputer chip and a DIP-type equivalent connector. With the microcomputer chip removed from the application circuit (user system) and this connector connected with its place, operations can be performed as if a single-chip microcomputer were mounted.

When the application circuit is simple and no application circuit board has been provided, system development and evaluation can be accomplished by mounting a peripheral circuit in the free space on the emulation board.

Fig. 7 illustrates a conceptualized view of each using situation of these emulation boards. Optimum emulation board and evaluation means can be selected according to the evaluation objectives of the application system.

Table 1 Single-chip Microcomputer Emulation Board

| Board Name | Evaluator Chip | Program memory EPROM |               | Oscil-lator (Hz) | Free Space | Power Supply Required | Remarks                                         |
|------------|----------------|----------------------|---------------|------------------|------------|-----------------------|-------------------------------------------------|
|            |                | EPROM                | Qt. of Socket |                  |            |                       |                                                 |
| BM4303     | TMP4300C       | 16 K (one)           | 1             | I F T (455K)     | Yes        | 5V                    | Can be used inividually or connected TDS400/43  |
| BM4603B    | TCP4600AC      | 16 K (two)           | 2             | I F T (400K)     | Yes        | 5V                    | Can be used individually or connected TDS400/46 |
| BM8403     | TMP8039-6      | 16 K (two)           | 2             | Crystal 6M       | Yes        | 5V                    | Can be used individually or connected TDS400/84 |



Fig. 6 Emulation Boards --- Conceptualized Drawings

(Note: Ev-chip is an abbreviation of evaluator chip.)

|                                                                                                                                             |                                                                                                                                                                                                                     |                                                                                                                                                               |
|---------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>Plugging in the TDS400</p> <p>Type of mounting for the application circuit<br/>(Peripheral circuit)</p>                                  | <p>For plugging in the TDS400 to verify operations.</p> <p>To mount application program in:</p> <ul style="list-style-type: none"> <li>o TDS400 program memory (RAM) or</li> <li>o Emulation board EPROM</li> </ul> | <p>For verifying operations of the application system by use of the emulation board alone or for making field test.</p>                                       |
| <p>Verifying or debugging operations of systems by replacing the microcomputer chip within the application circuit board.</p>               | <p>Plugging in TDS400</p>  <p>Application circuit board</p> <p>Micro-computer</p> <p>Power Supply</p>                              |  <p>Application circuit board</p> <p>Micro-computer</p> <p>Power Supply</p> |
| <p>For verifying or debugging operations by mounting the microcomputer peripheral circuit of the application circuit on the free space.</p> | <p>Plugging in TDS400</p>  <p>Peripheral circuit of the application system</p> <p>Power Supply</p>                                | <p>Peripheral circuit of the application system</p>  <p>Power Supply</p>   |

Fig. 7 Examples of Emulation Board Usage



## 2. DEDICATED DEBUGGING SYSTEM

### 2.1 SYSTEM CONCEPT

The dedicated debugging system is formed by a combination of the debugging board (BM4304/4604/8404) and emulation board.

The debugging board is a low cost development tool for debugging application software and hardware to which Toshiba's single-chip microcomputer is applied. For assembling a program, other means must be utilized.

Fig. 8 shows the conceptualized drawing of this development system. In this drawing, the portions enclosed with solid lines are the units of minimum requirement for program debugging, while those enclosed with broken lines are the units supplied by user as required. The shaded portions which the cable connecting the debugging board to emulation board has been removed, indicate the structure to make it possible to execute application programs through EPROM on the emulation board.

Major functions of the debugging board are as follows:

- (1) Real-time emulation possible. The program memory (RAM 4K bytes) of the debugging board is used as an application program memory.
- (2) The contents of the program memory can be read and written directly from the console.
- (3) The program loading can be performed from the written EPROM to the program memory.
- (4) Direct read and write can be performed to RAM, register and I/O device contained in the single-chip microcomputer in the same way as the program memory.

- (5) Application programs can be initiated from any address.
- (6) Application programs can be stopped at any time while in operation.
- (7) Address-stop function provided.
- (8) Single-step operation possible.
- (9) Pseudo interrupt signal can be entered through the debugging console.



# MICROCOMPUTER

## TECHNICAL DESCRIPTION



Fig. 8 Conceptualized Drawing of Dedicated Debugging System

### 3. PRODUCTS CONFIGURATION FOR APPLICATION DEVELOPMENT SUPPORT SYSTEM

Depending on the user's needs, the TDS400 and emulation board can be converted or expanded. For example, conversion of the TDS400/43 system to the TDS400/46 system can be accomplished by replacing BM4301A + BM4303 + SW4323 with BM4601A + BM4603B + SW 4623, and vice versa.

The optional I/O interface boards are common to all the TDS400 development systems. These interfaces can be attached directly to the supposed standard I/O equipment and/or auxiliary memory devices (See Fig. 1). Further, these equipment and devices are so designed as to be used without modification of the system software.

Therefore, it is very convenient for user to keep various kinds of several emulation boards at hand in order to forward verification work of application systems smoothly.



## MICROCOMPUTER

### TECHNICAL DESCRIPTION

#### PRODUCTS CONFIGURATION FOR APPLICATION DEVELOPMENT TOOL

| Family    | Model No. | Description                                                  | Configuration of Products                                                             | Accompanying Materials         | Remarks                                                                     |
|-----------|-----------|--------------------------------------------------------------|---------------------------------------------------------------------------------------|--------------------------------|-----------------------------------------------------------------------------|
| Common to | TDS400    | Microcomputer application system 400 (Toshiba MDS model 400) | BM4006A + SW4006A<br>Optional board (BM4001 ~ 5)                                      | Refer to each system component | Products name of combined system, peripheral equipment is supplied by user. |
|           | SW0051    | Paper tape output program/ACOS (PT output program on ACOS)   | Card image magnetic tape (9 tracks) of source program (FORTRAN)                       | SW0051 Instruction manual      | For object output of cross assembler (SWxx53)                               |
|           | SW0061    | Paper tape output program/NOVA (PT output program on NOVA)   | Paper tape (ASCII code) of source program (FORTRAN)                                   | SW0061 Instruction manual      | For object output of cross assembler (SWxx63)                               |
|           | BM4001    | 64KB Indirect memory                                         | Board module (1)                                                                      | BM4001 Instruction manual      | Mounted on BM4006A                                                          |
|           | BM4002    | General I/O interface                                        | Board module (1), intra-board connection cable (2), connector board(1)                | BM4002 Instruction manual      | Ditto<br>RS232C, PTR, PTP & Printer                                         |
|           | BM4003    | TV·Keyboard interface                                        | Board module (1), keyboard (1), intra-board connection cable (2), connector board (1) | BM4003 Instruction manual      | Ditto<br>Connected to NTSC type of TV set                                   |
|           | BM4004    | Floppy disk interface                                        | Board module (1), intra-board connection cable (1) connector board (1)                | BM4004 Instruction manual      | Ditto<br>Can be connected to two FD drives of single-sided single density   |

| Family    | Model No. | Description                     | Configuration of Products                                               | Accompanying Materials                                             | Remarks                                                                     |
|-----------|-----------|---------------------------------|-------------------------------------------------------------------------|--------------------------------------------------------------------|-----------------------------------------------------------------------------|
| Common to | BM4005    | Digital cassette interface      | Board module (1), intra-board connection cable (2), connector board (1) | BM4005 Instruction manual                                          | Mounted on BM4006A<br>Can be connected to two 10"/sec DC handlers           |
|           | BM4006A   | TDS400 hardware main frame      | A set of TDS400 basic hardware with power supply in cabinet             | BM4006A Instruction manual                                         | EPROM writer with debugging console, serial port (1)                        |
|           | SW4006A   | TDS400 system A monitor program | EPROM (8) (monitor program, 16K bytes)                                  | TDS400 System A operation manual, SW4006A instruction manual       | System control program packed in main memory region of BM4006A              |
| 43        | TDS400/43 | Toshiba MDS400 for TLCS-43      | TDS400 + BM4301A + BM4303 + SW4323                                      | Refer to each system component                                     | Products name of combined system. Peripheral equipment is supplied by user  |
|           | BM4301A   | TDS400/43 controller            | Board module (1), EPROM (1), (control program, 2K bytes)                | TDS400/43 debugger operation manual, BM4301A Instruction manual    | EPROM is replaced with a part of SW4006A in main memory area                |
|           | BM4303    | TLCS-43 emulation board         | Board module (1), EPROM (1), Cables (2) to LSI socket                   | BM4303 Instruction manual                                          | Board with functions equivalent to LSI of TLCS-43. With interface to TDS400 |
|           | BM4304    | TLCS-43 debugging board         | Board module (1), cable (1) connecting with BM4303                      | BM4303 debugging board operation manual. BM4303 instruction manual | Used for debugging by connecting with BM4303                                |

| Family | Model No.          | Description                      | Configuration of Products                                                                            | Accompanying Materials                                             | Remarks                                                                     |
|--------|--------------------|----------------------------------|------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-----------------------------------------------------------------------------|
| 43     | SW4323             | TLCS-43 assembler on TDS400      | EPROM (3) (Assembler program 6K bytes)                                                               | TLCS-43 assembly language manual.<br>SW4323 Instruction manual     | Loaded from EPROM writer (/reader) of TDS400                                |
|        | SW4353             | TLCS-43 cross assembler on ACOS  | Card image magnetic tape (9 tracks) of source program (FORTRAN)                                      | TLCS-43 assembly language manual.<br>SW4353 Instruction manual     | Used together with SW0051                                                   |
|        | SW4363             | TLCS-43 cross assembler on NOVA  | Paper tape(ASCII code) of source program (FORTRAN)                                                   | TLCS-43 assembly language manual.<br>SW4363 Instruction manual     | Used together with SW0061                                                   |
|        | SW4393S<br>SW4393D | TLCS-43 assembler/<br>IMDS       | Diskette(1) (ISIS-II file)<br>S: single side<br>single density.<br>D: single side<br>double density. | TLCS-43 assembly language manual.<br>SW4393S, D instruction manual | Operates under ISIS-II                                                      |
| 46A    | TDS400/46          | TLCS-46A application development | TDS400 + BM4601A + BM4603B + SW4623                                                                  | Refer to each system component                                     | Products name of combined system, peripheral equipment is supplied by user. |
|        | BM4601A            | TDS400/46 controller             | Board module (1),<br>EPROM (1) (control porgram 2K bytes)                                            | TDS400/46 debugger operation manual.<br>BM4601A instruction manual | EPROM is replaced with a part of SW4006A in main memory area                |

| Fam-<br>ily | Model No.          | Description                      | Configuration of<br>Products                                                                    | Accompanying<br>Materials                                          | Remarks                                                                      |
|-------------|--------------------|----------------------------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|------------------------------------------------------------------------------|
| 46A         | BM4603B            | TLCS-46A emulation board         | Board module (1), EPROM (2), Cable (1) to LSI socket                                            | BM4603B Instruction manual                                         | Board with functions equivalent to LSI of TLCS-46A. With interface to TDS400 |
|             | BM4604             | TLCS-46A debugging board         | Board module (1), Cable (1) to BM4603B                                                          | BM4604 debugging board Operation manual. BM4604 instruction manual | Used for debugging by connecting with BM4603B                                |
|             | SW4623             | TLCS-46A assembler on TDS400     | EPROM (3) (assembler program 6K bytes)                                                          | TLCS-46A assembly language manual. SW4623 instruction manual       | Loaded from EPROM writer (/reader) of TDS400                                 |
|             | SW4653             | TLCS-46A cross assembler on ACOS | Card image magnetic tape (9 tracks) of source program (FORTRAN)                                 | TLCS-46A assembly language manual. SW4653 instruction manual       | Used together with SW0051                                                    |
|             | SW4663             | TLCS-46A cross assembler on NOVA | Paper tape (ASCII code) of source program (FORTRAN)                                             | TLCS-46A assembly language manual. SW4663 instruction manual       | Used together with SW0061                                                    |
|             | SW4693S<br>SW4693D | TLCS-46A assembler on iMDS       | Diskette (1) (ISIS-II file)<br>S: single side single density.<br>D: single side double density. | TLCS-46A assembly language manual. SW4693S, D instruction manual   | Operates under ISIS-II                                                       |
| 84          | TDS400/84          | Toshiba MDS400 for TLCS-84       | TDS400 + BM8401A + BM8403 + SW8423A                                                             | Refer to each system component                                     | Products name of combined system peripheral equipment is supplied by user.   |


  
**MICROCOMPUTER**  
 TECHNICAL DESCRIPTION

| Fam-<br>ily | Model No. | Description                          | Configuration of<br>Products                                               | Accompanying<br>Materials                                                        | Remarks                                                                               |
|-------------|-----------|--------------------------------------|----------------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| 84          | BM8401A   | TDS400/84 controller                 | Board module (1),<br>EPROM (1) (control<br>program 2K bytes)               | TDS400/84 debug-<br>ging operation<br>manual.<br>BM8401A instruc-<br>tion manual | EPROM is replaced with<br>a part of SW4006A in<br>main memory region                  |
|             | BM8403    | TLCS-84 emulation<br>board           | Board module (1),<br>EPROM (1). Cable<br>(1) to LSI socket                 | BM8403 Instruc-<br>tion manual                                                   | Board with functions<br>equivalent to TMP8048,<br>8049-6. With interface<br>to TDS400 |
|             | BM8404    | TLCS-84 debugging<br>board           | Board module (1),<br>Cable (1) to<br>BM8403                                | BM8404 debugging<br>board operation<br>manual. BM8404<br>instruction manual      | Used for debugging by<br>connecting with BM8403                                       |
|             | SW8423A   | TLCS-84 assembler<br>on TDS400       | EPROM (5) (assembler<br>program 10K bytes)                                 | TLCS-84 assembly<br>language manual.<br>SW8423A instruc-<br>tion manual          | Loaded from EPROM<br>writer (/reader) of<br>TDS400                                    |
|             | SW8453    | TLCS-84 cross as-<br>sembler on ACOS | Card image magne-<br>tic tape (9 tracks)<br>of source program<br>(FORTRAN) | TLCS-84 assembly<br>language manual.<br>SW8453 instruc-<br>tion manual           | Used together with<br>SW0051                                                          |
| 85          | SW8553    | TLCS-85 cross as-<br>sembler on ACOS | Card image magne-<br>tic tape (9 tracks)<br>of source program<br>(FORTRAN) | TLCS-85 assembly<br>language manual.<br>SW8553 instruc-<br>tion manual           | Used together with<br>SW0051                                                          |

## SW0051 PAPER TAPE OUTPUT PROGRAM / ACOS

### GENERAL DESCRIPTION

This program outputs the object program translated with a cross assembler to the paper tape with various formats.  
The program can be loaded on the general-purpose computer ACOS600 or 700.

### PRODUCT CONFIGURATION

- o Magnetic tape (9 tracks) 1  
(Card (IBM29 code) image of a source program written in FORTRAN (JIS7000, partially GMAP)).
- o SW0051 Instruction manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) Using this program, paper tapes can be made up to be used for various EPROM writers, production system of masked ROMs, and application development system.
- (2) The formats of the object paper tape are divided broadly into 1-bit BNPF format and 4-bit hexadecimal expressing format.
- (3) For the hexadecimal format, 8 formats can be specified by selecting the output system such as start and end symbols of data, and addressing and checksum modes.
- (4) Output range and block length can be specified.

### OPERATING ENVIRONMENT (Host Machine)

Processing unit: ACOS600/700 with more than 64K words (more than 17-bit words)

Operating system: ACOS-6

Peripheral equipment: Magnetic disk, magnetic tape, line printer, card reader, paper tape punch, etc.

### OPERATING PROCEDURE

Compile the program first and load it in the host system. According to OS from the host machine, specify the file and output format to operate the program.

### TECHNICAL MATERIALS

- (1) SW4353, SW4653, SW8453, SW8553 Instruction Manuals
- (2) ACOS600/700 FORTRAN Language Description
- (3) ACOS600/700 Job Control Language (JCL) Description
- (4) ACOS600/700 IMCV Editing Program Manual

## SW0061 PAPER TAPE OUTPUT PROGRAM / NOVA

### GENERAL DESCRIPTION

This program outputs the object program translated with a cross assembler to the paper tape with various formats.  
The program can be loaded on the micromputer NOVA.

### PRODUCT CONFIGURATION

- o Magnetic tape (ASCII code) 1  
(Source program written in FORTRAN  
(JIS7000))
- o SW0061 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) Using this program, paper tapes can be made up to be used for various EPROM writers, production system of masked ROMs, and application development systems.
- (2) The formats of the object paper tape are divided broadly into 1-bit BNPF format and 4-bit hexadecimal expressing format.
- (3) For the hexadecimal format, 8 formats can be specified by selecting the output systems such as start and end symbols of data, and addressing and checksum modes.
- (4) Output range and block length can be specified.

### OPERATING ENVIRONMENT (Host Machine)

Processing unit: NOVA with more than 64K words (more than 16-bit words)  
Operating system: RDOS  
Peripheral equipment: Magnetic disk, line printer, console typewriter, paper tape reader, paper tape punch, etc.

### OPERATING PROCEDURE

Compile the program first and load it in the host system. According to OS from the host machine, specify the file and output format to operate the program.

### TECHNICAL MATERIALS

- (1) SW4363, SW4663 Instruction Manuals
- (2) NOVA FORTRAN IV Description Manual (Data General)
- (3) NOVA RDOS Description Manual, CLI Series (Ditto)
- (4) NOVA RDOS Description Manual, System Utility Series (Ditto)

## BM4001 64KB INDIRECT MEMORY

### GENERAL DESCRIPTION

A memory board of 64,536 bytes (64KB) to be mounted in TDS400 (BM4006A). Generally this board is used as an auxiliary memory.

### PRODUCT CONFIGURATION

- o Board module 1
- o BM4001 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) This memory can be used as a high-speed file memory.
- (2) Assembling or the like is simple and fast if this memory is used as a file to store a source program or an object program.
- (3) OS can specify this memory as a main memory.
- (4) Thirty-two 16K dRAMs (TMM416P-3) are provided for BM4001.
- (5) Module dimensions are 180mm × 230mm × approx. 15mm with edge connector of 144 pins.
- (6) Approx. power dissipation is 5V × 1A, -5V × 1mA, or 12V × 0.1A.

### OPERATING CONDITIONS

The indirect memory is inserted in the slot "MEM2" within the TDS400 (BM4006A), being operated by OS (control program) from SW4006A or the like.

### TECHNICAL MATERIALS

- (1) TDS400 System A Operation Manual
- (2) BM4006A Instruction Manual

## BM4002 GENERAL I/O INTERFACE

### GENERAL DESCRIPTION

An interface board through which RS232C type I/O device, PTR, PTP, and printer are connected to the TDS400. The connectors for four I/O devices are provided separately.

### PRODUCT CONFIGURATION

- o Board module 1
- o Connector board 1
- o Inter-board connection cable 2
- o BM4002 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) Processing capability of the TDS400 can be sharply increased by the high-speed I/O device.
- (2) RS232C ports are available for console I/O devices.
- (3) 15 versions (50 - 9600 baud) can be selected for the baud rate of RS232C ports.
- (4) RS232C type I/O devices (e.g. ADD's Model ADDS580) can be directly connected.
- (5) Paper tape reader PTR-400 (Ricoh Denshi Industry Co.) can be directly connected.
- (6) Paper tape punch TP-60 (Ricoh Denshi Industry Co.) can be directly connected.
- (7) Printer 1200Hy Type 1 (Diablo System Inc.) can be directly connected.
- (8) Module dimensions are 180mm × 230mm × approx. 15mm with edge connector of 144 pins.
- (9) Approx. power dissipation is 5V × 0.7A, 12V × 0.1A, or -12V × 0.1A.

### OPERATING CONDITIONS

The interface board is inserted in the slot "GIO" within the TDS400 (BM4006A). Mount the connector board on the back panel of the TDS400 and connect each unit with the inter-board connection cable. Each I/O device must be connected to the connector board with the dedicated cable (user's supplied connector for the TDS400 has 25 pins). The interface board is operated by OS (control program) of SW4006A or the like.

### TECHNICAL MATERIALS

- (1) TDS400 System A Operation Manual
- (2) BM4006A Instruction Manual
- (3) CRT Terminal Model 580 Instruction Manual (Matsushita Electric Trading Co.)
- (4) RICOM PTR-400 READER Specifications (Ricoh Denshi Industry Co.)
- (5) RICOM TP-60 PERFORATOR Specification and Operating Manual (Ricoh Denshi Industry Co.)
- (6) Model 1200 Hytype 1 Printer Maintenance Manual (Diablo System Inc.)

## BM4003 TV・KEYBOARD INTERFACE

### GENERAL DESCRIPTION

An interface board through which the NTSC system TV screen and a full keyboard are connected to the TDS400. That is, a CRT input/output device can be configured at low cost.

### PRODUCT CONFIGURATION

- o Board module 1
- o Connector board with RF module 1
- o Inter-board connection cable 2
- o Full keyboard with a cable 1
- o BM4003 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) A low cost CRT input/output device usable for a console can be configured.
- (2) Using BM4003, NTSC system home TV set or a monitoring TV set can be directly connected to the TDS400.
- (3) Full keyboard (KB-2) with touch-key system is packed. (ACSI specification)
- (4) Module dimensions are 180mm × 230mm × approx. 15mm with edge connector of 144 pins.
- (5) Keyboard dimensions are 176mm × 345mm × 55mm.
- (6) Approx. power dissipation is 5V × 0.7A, -5V × 30mA, or 12V × 50mA.

### OPERATING CONDITIONS

The interface board is inserted in the slot "TV" within the TDS400 (BM4006A). The connector board is installed on the back panel of the TDS400 to connect each unit with the inter-board connection cables. Then user's TV set (the cable is user-supplied) and full keyboard are connected. This makes the TDS400 operate as a console I/O device or TV (similar to CRT display) output device.

### TECHNICAL MATERIALS

- (1) TDS400 System A Operation Manual
- (2) BM4006A Instruction Manual
- (3) Toshiba Color TV 20G600 Instruction Manual

## BM4004 FLOPPY DISK INTERFACE

### GENERAL DESCRIPTION

An interface board through which two floppy disk drives (standard 8" single-sided single density) are connected to the TDS400.

### PRODUCT CONFIGURATION

- o Board module 1
- o Connector Board 1
- o Inter-board connection cable 1
- o BM4004 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) Mass storage (256K bytes/disk) random file can be made up by using BM4004 floppy disk interface.
- (2) BM4004 controls two sets of floppy disk drive ND-10 (standard 8" single-sided single density).
- (3) At least four sets of floppy disk drive can be controlled by using two boards of BM4004. However, the drivers, to the number of two, can be used for SW4006A.
- (4) Available is a couple of floppy disk drive AFD-002 (Asia Mfg. Co.) which can be directly connected to the TDS400.
- (5) Module dimensions are 180mm × 230mm × approx. 15mm with edge connector of 144 pins.
- (6) Approx. power dissipation is 5V × 0.5A.

### OPERATING CONDITIONS

The interface board is inserted in the slot "FDC1" within the TDS400 (BM4006A). The connector board is installed on the back panel of the TDS400 to connect each unit with the inter-board connection cable. The drive units, such as AFD-002A, are connected to the TDS400. The drive units are operated by a command from the console I/O device.

### TECHNICAL MATERIALS

- (1) TDS400 System A Operation Manual
- (2) BM4006A Instruction Manual
- (3) AFD-002A Instruction Manual (Asia Mfg. Co.)

## BM4005 DIGITAL CASSETTE INTERFACE

### GENERAL DESCRIPTION

An interface board through which two digital cassette handlers (10"/sec) are connected to the TDS400.

### PRODUCT CONFIGURATION

- o Board module 1
- o Connector board 1
- o Inter-board connection cable 2
- o BM4005 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) Mass storage sequential file can be made up by using BM4005 digital cassette interface.
- (2) Two sets of digital cassette handlers CP-100EB (Toshiba-Ampex 800BPI, 10"/sec) can be controlled by using the BM4005.
- (3) Available is a couple of digital cassette handler ADC-001A (Asia Mfg. Co.) which can be directly connected to the TDS400.
- (4) Module dimensions are 180mm × 230mm × approx. 15mm with edge connector of 144 pins.
- (5) Approx. power dissipation is 5V × 0.8A.

### OPERATING CONDITIONS

The interface board is inserted in the slot "DCC" within the TDS400 (BM4006A). The connector board is installed on the back panel of TDS400 to connect each unit with the inter-board connection cable. Then the handler, such as model ADC-001A, is connected to the TDS400. The handler is operated by a command from the console I/O device.

### TECHNICAL MATERIALS

- (1) TDS400 System A Operation Manual
- (2) BM4006A Instruction Manual
- (3) ADC-001A Instruction Manual (Asia Mfg. Co.)

## BM4006A TDS400 HARDWARE MAINFRAME

### GENERAL DESCRIPTION

A basic hardware of microcomputer development system used for developing various microcomputer application system and application softwares. The system configuration is convenient for consecutively performing application software production, edit assembling, application system debugging, and test evaluation, etc.

### PRODUCT CONFIGURATION

- o Set of TDS400 basic hardware  
(mainframe, power cord, connector)
- o BM4006A Instruction Manual



1

### FEATURES AND MAIN SPECIFICATIONS

- (1) The control display panel of debugging console is provided in front of the mainframe.
- (2) Reader/writer for EPROM (equivalent to TMM323, 2714) is equipped with the TDS400.
- (3) Console I/O interface (serial transmission, 50 ~ 9,600 baud) is provided in the TDS400.
- (4) The main memory consists of 48K-byte RAM and 16K-byte EPROM (socket). A monitor program (e.g. SW4006, option) is mounted in the EPROM.
- (5) By installing optional interface boards, various peripheral equipment can be connected to the mainframe.
- (6) Real-time debugging of application system, such as TLCS-43/46A/84, is available by exchanging some interface boards of EPROMs (control programs).
- (7) Frame dimensions are 470mm (W) × 580mm (L) × 295mm (H).
- (8) Approx. power dissipation is AC100V (50 or 60Hz), 350VA (Max.).

### OPERATING CONDITIONS

By loading TDS400 monitor program (SW4006A) for system control, and by connecting the console I/O device such as teletypewriter (user-supplied), a minimum system can be configured. A system more usable can be built up by mounting various interface boards and by connecting peripheral equipment.

### TECHNICAL MATERIALS

- (1) TDS400 System A Operation Manual
- (2) SW4006A Instruction Manual
- (3) BM4001, BM4002, BM4003, BM4004 and BM4005 Instruction Manuals
- (4) BM4301A, BM4601A and BM8401 Instruction Manuals
- (5) Typewriter MODEL-502 Type Specification (CASIO Computer)

## SW4006A TDS400 SYSTEM A MONITOR PROGRAM

### GENERAL DESCRIPTION

A resident program within the EPROM of the TDS400 main memory. This system program can be used for various processing operations according to the command from the console I/O device.

### PRODUCT CONFIGURATION

- o EPROM (TMM323) 8
- (16K-byte program)
- o TDS400 System A Operation Manual 1
- o SW4006A Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) This program facilitates creation, modification, and edit of source program for application systems.
- (2) Control programs for the peripheral equipment, such as floppy disk, are contained in the monitor program.
- (3) Assemblers and compilers are provided for various types of microcomputers (option).
- (4) Loading or modifying the object programs of application systems as well as reading or writing into EPROM can be performed.
- (5) This is a resident program within a main memory EPROM, so that it operates immediately after the power is turned on.

### OPERATING ENVIRONMENT

- Processor : BM4006A (48K-byte RAM) and optional board modules.  
Console I/O device : Teletypewriter, etc.  
Optional peripheral equipment: Floppy disk, CRT, printer, PTR, PTP, digital cassette, etc.

### OPERATING PROCEDURE

Insert the eight EPROMs in EPROM sockets, according to their corresponding numbers, on the BM4008 board of "MEM1" slot within BM 4006A. Select the I/O device used as a system console, and input the command from this console to control the operating system.

### TECHNICAL MATERIALS

- (1) BM4006A Instruction Manual
- (2) BM4001, BM4002, BM4003, BM4004 and BM4005 Instruction Manuals

## BM4301A TDS400/43 CONTROLLER

### GENERAL DESCRIPTION

A special module for making the TDS400 to the TDS400/43 debugger. It can debug the application systems (software and hardware) of the TLCS-43 by connecting BM4303 (TLCS-43 emulation board).

### PRODUCT CONFIGURATION

- o Board module 1
- o EPROM (TMM323) (Control program) 1
- o TDS400/43 debugger operation manual 1
- o BM4301A Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) Application program can be executed with real-time operation by loading it in the dedicated program memory (RAM) within this board or in the EPROM on BM4303.
- (2) Programs can be transmitted to and from EPROM or the back-up memory (a part of TDS400 main memory). Information stored in the back-up memory can be output to the paper tape, etc. in various formats (TDS400 function).
- (3) Direct read/write of the registers and RAMs contained in the CPU, and program memory (corresponding to ROM) within this board can be performed.
- (4) Various functions, such as execution and halt of programs, address stopping, single-step operation, and dummy interrupt signal input, are provided.
- (5) Module dimensions are 180mm × 230mm × approx. 15mm with edge connector of 144 pins.
- (6) Approx. power dissipation is 5V × 1.3A, -5V × 30mA, or 12V × 50mA.

### OPERATING CONDITIONS

This board is inserted in slot "43C/46C" within the TDS400 (BM4006A). The control program is loaded in the BM4008 board of slot "MEM1" where EPROM No. 7 is mounted after having removed EPROM. BM4303 and application system (board) are connected to this board, which is operated by controlling the TDS400 debugging console.

### TECHNICAL MATERIALS

- (1) BM4006A Instruction Manual
- (2) BM4303 Instruction Manual
- (3) TDS400 System A Operation Manual

## BM4303 TLCS-43 EMULATION BOARD

### GENERAL DESCRIPTION

This is an emulation board that can be performed as equivalent to the single-chip microcomputer LSI of TLCS-43 series. Interface circuit is provided in this board for being connected to the host system (TDS400, BM4304). EPROM (for 2K bytes) can be installed as a program ROM.

### PRODUCT CONFIGURATION

- o Board module 1
- o EPROM (TMM323) 1
- o LSI socket connection cable 2
- o BM4303 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) This is an emulation board that can be replaced directly with TMP4310, TMP4315 or TMP4320.
- (2) 2 K-byte EPROM can be installed as a program ROM.
- (3) Interface circuit to be connected to the TDS400 (BM4301A) or BM4304, and free space (for mounting application system circuit or interface) are provided in the board.
- (4) As a program memory, this emulation board can select EPROM within the board or memory in the host system to execute the application program stored on these units.
- (5) This emulation board has a function capable of executing the application program while monitoring or modifying the internal status on of the microcomputer under the control by the host system.
- (6) When the emulation board is disconnected from the host system, it is also operated as an independent emulation board.
- (7) Module dimensions are 230mm × 230mm × approx. 30mm.
- (8) Power dissipation is less than 5V ( $\pm 5\%$ ) × 0.5A. (Extra 12V and -5V power supplies are required when using 8K-bit EPROM.)

### OPERATING CONDITIONS

EPROM, in which the application program has been written, is mounted on this board, and two cables from the board is inserted in the sockets of the microcomputer LSI of application system. The power supply (user-supplied) and host system (TDS400 or BM4304) are connected to the board for operation.

### TECHNICAL MATERIALS

- (1) TLCS-43 Integrated Circuit Technical Data
- (2) TLCS-43 System Manual
- (3) TDS400/43 Debugger Operation Manual, BM4301A Instruction Manual
- (4) BM4304 Debugging Board Operation Manual, BM4304 Instruction Manual

## BM4304 TLCS-43 DEBUGGING BOARD

### GENERAL DESCRIPTION

This board is a control board for debugging of the application system (or program) of the TLCS-43. The debugging system of the TLCS-43 is made up by connecting it to the BM4303 (TLCS-43 emulation board).

### PRODUCT CONFIGURATION

- o Board module 1
- o BM4303 connection cable 1
- o BM4304 debugging board operation Manual 1
- o BM4304 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) BM4304 board is provided with a console unit consisting of a display for addresses, data and system condition, and 32 keys.
- (2) Application program is executed by emulator chip (TMP4300) of BM4303 after having been transmitted to the EPROM program memory within this board via the EPROM socket.
- (3) Direct read/write of register or RAM within the microcomputer LSI is available.
- (4) Application program can be modified with machine code level.
- (5) Application program can be started with any address and stopped at any time.
- (6) Address stop and single step operation functions are provided.
- (7) Dummy interrupt signals can be generated from the console on the board.
- (8) Module dimensions are 300mm × 300mm × approx. 30mm.
- (9) Power dissipation is less than 5V ( $\pm 5\%$ ) × 2.5A.

### OPERATING CONDITIONS

This board is connected with BM4303 that have been connected to the application system. The application program is written in EPROM, and EPROM is installed on the BM4304 board. The power (user-supplied) is turned on and the instructions from the console on BM4304 board are given to operate the system.

### TECHNICAL MATERIALS

- (1) BM4303 Instruction Manual

## SW4323 TLCS-43 ASSEMBLER/TDS400

### GENERAL DESCRIPTION

A cross assembler used for developing the application program of the TLCS-43. The TDS400 (Microcomputer Developing System 400) is used for operating this assembler.

### PRODUCT CONFIGURATION

- |                                         |   |
|-----------------------------------------|---|
| o EPROM (TMM323)<br>(Assembler program) | 3 |
| o TLCS-43 Assembler Language Manual     | 1 |
| o SW4323 Instruction Manual             | 1 |



### FEATURES AND MAIN SPECIFICATIONS

- (1) Up to approx 950 symbols (name) each of which consists of less than 6 characters can be defined.
- (2) Decimal and hexadecimal constants can be handled.
- (3) 16 reserved symbols are provided for register name or the like.
- (4) + and - are available for operators.
- (5) Provided are 7 assembler directives and 35 instructions.
  
- (6) Source program can be input from any input device.
- (7) Assemble list can be output to any output device.
- (8) Object program is created as a ROM image in the TDS400. The TDS400 can output this program in various formats. Direct write in the EPROM is also available.

### OPERATING ENVIRONMENT

Processor : TDS400 (48K-byte RAM)  
Operating system : System A monitor program (SW4006A)  
Peripheral equipment: Console I/O device (e.g. teletypewriter), optional floppy disk, CRT, printer, PTR, PTP, etc.

### OPERATING PROCEDURE

This assembler is operated by a command sent to the TDS400 from the console I/O device (or other devices). This assembler program itself should be loaded in the EPROM writer socket on the front panel of the TDS400.

### TECHNICAL MATERIALS

- (1) TLCS-43 Integrated Circuit Technical Data
- (2) TLCS-43 System Manual
- (3) TLCS-43 Collected subprograms
- (4) TDS400 System A Operation Manual

## SW4353 TLCS-43 CROSS ASSEMBLER/ACOS

### GENERAL DESCRIPTION

This cross assembler is used when developing the application program of the TLCS-43. General-purpose computer ACOS600 or 700 can be used to load the program.

### PRODUCT CONFIGURATION

- |                                                                                                                             |   |
|-----------------------------------------------------------------------------------------------------------------------------|---|
| o Magnetic tape (9 tracks)<br>(Card (IBM29 code) image of source<br>program written in FORTRAN<br>(JIS7000, partially GMAP) | 1 |
| o TLCS-43 Assembler Language Manual                                                                                         | 1 |
| o SW4354 Instruction Manual                                                                                                 | 1 |



### FEATURES AND MAIN SPECIFICATIONS

- (1) Up to approx. 500 symbols (name) each of which consists of less than 6 characters can be defined.
- (2) Binary, octal, decimal, and hexadecimal constants can be handled.
- (3) 16 reserved symbols are provided for register name or the like.
- (4) + and - are available for operators.
- (5) Provided are 11 assembler directives and 38 instructions.
  
- (6) Punched card or paper tape can be used for the input medium of the source program.
- (7) Assemble list can be output to a line printer.
- (8) Object program is created in the host system. Using the paper tape output program ACOS (SW0051), this program can be output to paper tapes in various formats.

### OPERATING ENVIRONMENT

Processor : ACOS600 or 700 with more than 64K-words  
(more than 17-bit words)  
Operating system : ACOS-6  
Peripheral equipment: Magnetic disk, magnetic tape, line printer, card reader, paper tape reader, (and paper tape punch), etc.

### OPERATING PROCEDURE

First compile this cross assembler to load in the host system. According to the OS of the host machine, define various files, and specify the input and output conditions to perform assembling.

### TECHNICAL MATERIALS

- (1) TLCS-43 Integrated Circuit Technical Data
- (2) TLCS-43 System Manual
- (3) TLCS-43 Collected subprograms
- (4) SW0051 Instruction Manual
- (5) ACOS600/700 FORTRAN Language Description
- (6) ACOS600/700 Job Control Language (JCL) Description
- (7) ACOS600/700 IMCV Edit Program Description

## SW4363 TLCS-43 CROSS ASSEMBLER/NOVA

### GENERAL DESCRIPTION

This cross assembler is used when developing the application program of the TLCS-43. Mini-computer NOVA can be used to load the program.

### PRODUCT CONFIGURATION

- o Paper tape (ASCII code) 1  
(Source program written in  
FORTRAN (JIS7000))
- o TLCS-43 Assembler Language Manual 1
- o SW4363 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) Up to 100 symbols (name) each of which consists of less than 6 characters can be defined.
- (2) Binary, octal, decimal, and hexadecimal constants can be handled.
- (3) 16 reserved symbols are provided for register name or the like.
- (4) + and - are available for operators.
- (5) Provided are 11 assembler directives and 38 instructions.
  
- (6) Punched card or paper tape can be used for the input medium of the source program.
- (7) Assemble list can be output to a line printer.
- (8) Object program is created in the host system. Using the different paper tape output program/NOVA (SW0061), this program can be output to paper tapes in various formats.

### OPERATING ENVIRONMENT

Processor : NOVA with more than 32K-words. (16-bit words)  
Operating system : RDOS  
Peripheral equipment: Magnetic disk, line printer, console typewriter, paper tape reader, (and paper tape punch), etc.

### OPERATING PROCEDURE

First compile this cross assembler to load in the host system. According to the OS of the host machine, specify various files to perform assembling.

### TECHNICAL MATERIALS

- (1) TLCS-43 Integrated Circuit Technical Data
- (2) TLCS-43 System Manual
- (3) TLCS-43 Collected Subprograms
- (4) SW0061 Instruction Manual
- (5) NOVA FORTRAN IV Description Manual (Japan Data General)
- (6) NOVA RDOS Description Manual, CLI Series (Ditto)
- (7) NOVA RDOS Description Manual, System Utility Series (Ditto)

## SW4393S, SW4393D TLCS-43 ASSEMBLER/iMDS

### GENERAL DESCRIPTION

A cross assembler used for developing the application program of the TLCS-43. The intellec MDS is used for operating this assembler.

### PRODUCT CONFIGURATION

- o Diskette (Note)  
(Assembler program ISIS-II file) 1
- o TLCS-43 Assembler Language Manual 1
- o SW4393S, SW4393D Instruction Manual 1

Note) SW4393S is of single-sided single density.  
SW4393D is of single-sided double density.



### FEATURES AND MAIN SPECIFICATIONS

- (1) Up to approx. 600 symbols (name) each of which consists of less than 6 characters can be defined.
- (2) Decimal and hexadecimal constants can be handled.
- (3) 16 reserved symbols are provided for register name or the like.
- (4) + and - are available for operators.
- (5) Provided are 7 assembler directives and 35 instructions.
  
- (6) The source program is input from ISIS-II diskette file.
- (7) Assemble list can be output to any output device.
- (8) The object program is created on the diskette in format I (Intel hexadecimal format) or format M (masked ROM production format). This program can be punched out to the paper tape by COPY command from ISIS-II, and also can be directly written in the EPROM.

### OPERATING ENVIRONMENT

Processor : iMDS with more than 32K bytes  
Operating system : ISIS-II  
Peripheral equipment: Console I/O device (e.g. teletypewriter), floppy disk, optional CRT, printer, PTR, PTP, PROM programmer, etc.

### OPERATING PROCEDURE

Copy the program to the system diskette. Then specify the file and assembler parameter according to the OS from the host machine.

### TECHNICAL MATERIALS

- (1) TLCS-43 Integrated Circuit Technical Data
- (2) TLCS-43 System Manual
- (3) TLCS-43 Collected Subprograms
- (4) ISIS-II System User's Guide (Intel)

## BM4601A TDS400/46 CONTROLLER

### GENERAL DESCRIPTION

A special module for making the TDS400 to the TDS400/46 debugger. It can debug the application systems (software and hardware) of the TLCS-46A by connecting BM4603B (TLCS-46 emulation board).

### PRODUCT CONFIGURATION

- o Board module 1
- o EPROM (TMM323)  
(Control program) 1
- o TDS400/46 Debugger Operation Manual 1
- o BM4601A Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) Application program can be executed with real-time operation by loading it in the dedicated program memory (RAM) within this board or in the EPROM on BM4603B.
- (2) Programs can be transmitted to and from EPROM or the back-up memory (a part of TDS400 main memory). Information stored in the back-up memory can be output to the paper tape, etc. in various formats (TDS400 function).
- (3) Direct read/write of the registers and RAM contained in the CPU, and program memory (corresponding to ROM) within this board can be performed.
- (4) Various functions, such as execution and halt of programs, address stopping, single-step operation, and dummy interrupt signal input, are provided.
- (5) Module dimensions are 180mm × 230mm × approx. 15mm with edge connector of 144 pins.
- (6) Approx. power dissipation is 5V × 1.3A, -5V × 30mA, or 12V × 50mA.

### OPERATING CONDITIONS

This board is inserted in slot "43C/46C" within the TDS400 (BM4006A). The control program is loaded in the BM4008 board of slot "MEM1" where EPROM No. 7 is mounted after having removed EPROM. BM4603B and application system (board) are connected to this board, which is operated by controlling the TDS400 debugging console.

### TECHNICAL MATERIALS

- (1) BM4006A Instruction Manual
- (2) BM4603B Instruction Manual
- (3) TDS400 System A Operation Manual

## BM4603B TLCS-46A EMULATION BOARD

### GENERAL DESCRIPTION

This is an emulation board that can be performed as equivalent to the single-chip microcomputer LSI of TLCS-46A series. Interface circuit is provided in this board for being connected to the host system (TDS400, BM4604). EPROM (for 4K bytes) can be installed as a program ROM.

### PRODUCT CONFIGURATION

- o Board module 1
- o EPROM (TMM323) 2
- o LSI socket connection cable 1
- o BM4603B Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) This is an emulation board that can be replaced directly with TCP4620A, TCP4630A or TCP4620B.
- (2) 4K-byte EPROM can be installed as a program ROM.
- (3) Interface circuit to be connected to the TDS400 (BM4601A) or BM4604, and free space (for mounting application system circuit or interface) are provided in the board.
- (4) As a program memory, this emulation board can select EPROM within the board or memory in the host system to execute the application program stored on these units.
- (5) This emulation board has a function capable of executing the application program while monitoring or modifying the internal status on of the microcomputer under the control by the host system.
- (6) When the emulation board is disconnected from the host system, it is also operated as an independent emulation board.
- (7) Module dimensions are 230mm × 230mm × approx. 30mm.
- (8) Power dissipation is less than 5V ( $\pm 5\%$ ) × 0.5A. (Extra 12V and -5V power supplies are required when using 8K-bit EPROM.)

### OPERATING CONDITIONS

EPROM, in which the application program has been written, is mounted on this board, and two cables from the board is inserted in the sockets of the microcomputer LSI of application system. The power supply (user-supplied) and host system (TDS400 or BM4604 are connected to the board for operation.

### TECHNICAL MATERIALS

- (1) TLCS-46A Integrated Circuit Technical Data
- (2) TLCS-46A System Manual
- (3) TDS400/46 Debugger Operation Manual, BM4601A Instruction Manual
- (4) BM4604 Debugging Board Operation Manual, BM4604 Instruction Manual

## BM4604 TLCS-46A DEBUGGING BOARD

### GENERAL DESCRIPTION

This board is a control board for debugging of the application system (or program) of the TLCS-46A. The debugging system of the TLCS-46A is made up by connecting it to the BM4603B (TLCS-46A emulation board).

### PRODUCT CONFIGURATION

- o Board Module 1
- o BM4603B Connection cable 1
- o BM4604 Debugging board 1
- o BM4604 Operation manual 1
- o BM4604 Instruction manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) BM4604 board is provided with a console unit consisting of a display for addresses, data and system condition, and 32 keys.
- (2) Application program is executed by emulator chip (TCP4600A) of BM4603B after having been transmitted to the EPROM program memory within this board via the EPROM socket.
- (3) Direct read/write of register or RAM within the microcomputer LSI is available.
- (4) Application program can be modified with machine code level.
- (5) Application program can be started with any address and stopped at any time.
- (6) Address stop and single step operation functions are provided.
- (7) Pseudo interrupt signal can be generated from the console on the board.
- (8) Module dimensions are 300mm × 300mm × approx. 30mm.
- (9) Power dissipation is less than 5V ( $\pm 5\%$ ) × 2.5A.

### OPERATING CONDITIONS

This board is connected with BM4603B that have been connected to the application system. The application program is written in EPROM, and EPROM is installed on the BM4604 board. The power (user-supplied) is turned on and the instructions from the console on BM4604 board are given to operate the system.

### TECHNICAL MATERIALS

- (1) BM4604B Instruction Manual

## GENERAL DESCRIPTION

A cross assembler used for developing the application program of the TLCS-46A. TDS400 (Microcomputer Developing System 400) is used for operating this assembler.

## PRODUCT CONFIGURATION

- o EPROM (TMM323) 3  
(Assembler program)
- o TLCS-46A Assembly 1  
language manual
- o SW4623 Instruction manual 1



## FEATURES AND MAIN SPECIFICATIONS

- (1) Up to approx. 950 symbols (name) each of which consists of less than 6 characters can be defined.
- (2) Decimal and hexadecimal constants can be handled.
- (3) 13 reserved symbols are provided for I/O port name or the like.
- (4) + and - are available for operators.
- (5) Provided are 6 assembler directives and 53 instructions.
- (6) Source program can be input from any input device.
- (7) Assemble list can be output to any output device.
- (8) Object program is created as a ROM image in the TDS400. The TDS400 can output this program in various formats. Direct write in the EPROM is also available.

## OPERATING ENVIRONMENT

Processor : TDS400 (48K-byte RAM)  
 Operating system : System A monitor program (SW4006A)  
 Peripheral equipment: Console I/O device (e.g. teletypewriter), optional floppy disk, CRT, printer, PTR, PTP, etc.

## OPERATING PROCEDURE

This assembler is operated by a command sent to the TDS400 from the console I/O device (or other devices). This assembler program itself should be loaded in the EPROM writer socket on the front panel of the TDS400.

## TECHNICAL MATERIALS

- (1) TLCS-46A Integrated Circuit Technical Data
- (2) TLCS-46A System Manual
- (3) TLCS-46A Collected Subprograms
- (4) TDS400 System A Operation Manual

## SW4653 TLCS-46A CROSS ASSEMBLER/ACOS

### GENERAL DESCRIPTION

This cross assembler is used when developing the application program of the TLCS-46A. General-purpose computer ACOS600 or 700 can be used to load the program.

### PRODUCT CONFIGURATION

- o Magnetic tape (9 tracks) 1  
(Card (IBM29 code) image of source program written in FORTRAN (JIS700, partially GMAP))
- o TLCS-46A Assembly Language Manual 1
- o SW4653 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) Up to approx. 500 symbols (name) each of which consists of less than 6 characters can be defined.
- (2) Binary, octal, decimal, and hexadecimal constants can be handled.
- (3) 16 reserved symbols are provided for I/O port name or the like.
- (4) + and - are available for operators.
- (5) Provided are 11 assembler directives and 53 instructions.
- (6) Punched card or paper tape can be used for the input medium of the source program.
- (7) Assemble list can be output to a line printer.
- (8) Object program is created in the host system. Using the paper tape output program ACOS (SW0051), this program can be output to paper tapes in various formats.

### OPERATING ENVIRONMENT

- Processor : ACOS600 or 700 with more than 64K-words  
(more than 17-bit words)
- Operating system : ACOS-6
- Peripheral equipment: Magnetic disk, magnetic tape, line printer, card reader, paper tape reader, (and paper tape punch), etc.

### OPERATING PROCEDURE

First compile this cross assembler to load in the host system. According to the OS of the host machine, define various files, and specify the input and output conditions to perform assembling.

### TECHNICAL MATERIALS

- (1) TLCS-46A Integrated Circuit Technical Data
- (2) TLCS-46A System Manual
- (3) TLCS-46A Collected Subprograms
- (4) SW0051 Instruction Manual
- (5) ACOS600/700 FORTRAN Language Description
- (6) ACOS600/700 Job Control Language (JCL) Description
- (7) ACOS600/700 IMCV Edit Program Description

## SW4663 TLCS-46A CROSS ASSEMBLER/NOVA

### GENERAL DESCRIPTION

This cross assembler is used when developing the application program of the TLCS-46A. Mini-computer NOVA can be used to lead the program.

### PRODUCT CONFIGURATION

- o Paper tape (ASCII code) 1  
(Source program written in FORTRAN (JIS7000))
- o TLCS-46A Assembly Language Manual 1
- o SW4363 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) Up to 100 symbols (name) each of which consists of less than 6 characters can be defined.
- (2) Binary, octal, decimal, and hexadecimal constants can be handled.
- (3) 13 reserved symbols are provided for I/O port name or the like.
- (4) + and - are available for operators.
- (5) Provided are 11 assembler directives and 53 instructions.
- (6) Punched card or paper tape can be used for the input medium of the source program.
- (7) Assemble list can be output to a line printer.
- (8) Object program is created in the host system. Using the different paper tape output program/NOVA (SW0061), this program can be output to paper tapes in various formats.

### OPERATING ENVIRONMENT

Processor : NOVA with more than 32K-words. (16-bit words)  
Operating system : RDOS  
Peripheral equipment: Magnetic disk, line printer, console typewriter, paper tape reader, (and paper tape punch), etc.

### OPERATING PROCEDURE

First compile this cross assembler to load in the host system. According to the OS of the host machine, specify various files to perform assembling.

### TECHNICAL MATERIALS

- (1) TLCS-46A Integrated Circuit Technical Data
- (2) TLCS-46A System Manual
- (3) TLCS-46A Collected Subprograms
- (4) SW0061 Instruction Manual
- (5) NOVA FORTRAN IV Description Manual (Data General)
- (6) NOVA RDOS Description Manual, CLI Series (Ditto)
- (7) NOVA RDOS Description Manual, System Utility Series (Ditto)

## SW4693S, 4693D TLCS-46A ASSEMBLER/iMDS

### GENERAL DESCRIPTION

A cross assembler used for developing the application program of the TLCS-46A. The intellec MDS is used for operating this assembler.

### PRODUCT CONFIGURATION

- |                                                   |   |
|---------------------------------------------------|---|
| o Diskette<br>(Assembler program<br>ISIS-II file) | 1 |
| o TLCS-46A Assembly<br>Language Manual            | 1 |
| o SW46935, SW4693D Instruction<br>Manual          | 1 |

Note) SW4693A is of single-sided  
single density.  
SW4693D is of single-sided  
double density.



### FEATURES AND MAIN SPECIFICATIONS

- (1) Up to approx. 600 symbols (name) each of which consists of less than 6 characters can be defined.
- (2) Decimal and hexadecimal constants can be handled.
- (3) 13 reserved symbols are provided for I/O port name or the like.
- (4) + and - are available for operators.
- (5) Provided are 6 assembler directives and 53 instructions.
  
- (6) The source program is input from ISIS-II diskette file.
- (7) Assemble list can be output to any output device.
- (8) The object program is created on the diskette in format I (Intel hexadecimal format) or format M (masked ROM production format). This program can be punched out to the paper tape by COPY command from ISIS-II, and also can be directly written in the EPROM.

### OPERATING ENVIRONMENT

Processor : iMDS with more than 32K bytes  
Operating system : ISIS-II  
Peripheral equipment: Console I/O device (e.g. teletypewriter), floppy disk, optional CRT, printer, PTR, PTP, PROM programmer, etc.

### OPERATING PROCEDURE

Copy the program to the system diskette. Then specify the file and assembler parameter according to the OS from the host machine.

### TECHNICAL MATERIALS

- (1) TLCS-46A Integrated Circuit Technical Data
- (2) TLCS-46A System Manual
- (3) TLCS-46A Collected Subprograms
- (4) ISIS-II System User's Guide (Intel)

## BM8401A TDS400/84 CONTROLLER

### GENERAL DESCRIPTION

A special module for making the TDS400 to the TDS400/84 debugger. It can debug the application systems (software and hardware) of the TLCS-84 by connecting BM8403 (TLCS-84 emulation board).

### PRODUCT CONFIGURATION

- o Board module 1
- o EPROM (TMM323)  
(Control program) 1
- o TDS400/84 Debugger operation manual 1
- o BM8401A Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) Application program can be executed with real-time operation by loading it in the dedicated program memory (RAM) within this board or in the EPROM on BM8403.
- (2) Programs can be transmitted to and from EPROM or the back-up memory (a part of TDS400 main memory). Information stored in the back-up memory can be output to the paper tape, etc. in various formats (TDS400 function).
- (3) Direct read/write of the registers and RAM contained in the CPU, and program memory (corresponding to ROM) within this board can be performed.
- (4) Various functions, such as execution and halt of programs, address stopping, single-step operation, and dummy interrupt signal input, are provided.
- (5) Module dimensions are 180mm × 230mm × approx. 15mm with edge connector of 144 pins.
- (6) Approx. power dissipation is 5V × 1A.

### OPERATING CONDITIONS

This board is inserted in slot "43C/46C" within the TDS400 (BM4006A). The control program is loaded in the BM4008 board of slot "MEM1" where EPROM No. 7 is mounted after having removed EPROM. BM8403 and application system (board) are connected to this board, which is operated by controlling the TDS400 debugging console.

### TECHNICAL MATERIALS

- (1) BM4006A Instruction Manual
- (2) BM8403 Instruction Manual
- (3) TDS400 System A Operation Manual

## BM8403 TLCS-84 EMULATION BOARD

### GENERAL DESCRIPTION

This is an emulation board that can be performed as equivalent to the single-chip microcomputer LSI of TLCS-84 series. Interface circuit is provided in this board for being connected to the host system (TDS400, EM8404). EPROM (for 4K bytes) can be installed as a program ROM.

### PRODUCT CONFIGURATION

- o Board module 1
- o EPROM (TMM323) 1
- o LSI socket connection cable 2
- o BM8403 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) This is an emulation board that can be replaced directly with TM8048 or TMP8049. The emulator chip is TMP8039-6.
- (2) 4K-byte EPROM can be installed as a program ROM.
- (3) Interface circuit to be connected to the TDS400 (BM8401A) or BM8404, and free space (for mounting application system circuit or interface) are provided in the board.
- (4) As a program memory, this emulation board can select EPROM within the board or memory in the host system to execute the application program stored on these units.
- (5) This emulation board has a function capable of executing the application program while monitoring or modifying the internal status on of the microcomputer under the control by the host system.
- (6) When the emulation board is disconnected from the host system, it is also operated as an independent emulation board.
- (7) Module dimensions are 180mm × 230mm × approx. 30mm.
- (8) Power dissipation is less than 5V ( $\pm 5\%$ ) × 0.5A.

### OPERATING CONDITIONS

EPROM, in which the application program has been written, is mounted on this board, and two cables from the board is inserted in the sockets of the microcomputer LSI of application system. The power supply (user-supplied) and host system (TDS400 or BM8404) are connected to the board for operation.

### TECHNICAL MATERIALS

- (1) TLCS-84 Integrated Circuit Technical Data
- (2) TDS400/84 Debugger Operation Manual, BM8401A Instruction Manual
- (3) BM8404 Debugging Board Operation Manual, BM8404 Instruction Manual

## BM8404 TLCS-84 DEBUGGING BOARD

### GENERAL DESCRIPTION

This board is a control board for debugging of the application system (or program) of the TLCS-84. The debugging system of the TLCS-84 is made up by connecting it to the BM8403 (TLCS-84 emulation board).

### PRODUCT CONFIGURATION

- o Board module 1
- o BM8403 Connection cable 1
- o BM8404 Debugging board 1
- o BM8404 Operation Manual 1
- o BM8404 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) BM8404 board is provided with a console unit consisting of a display for addresses, data and system condition, and 32 keys.
- (2) Application program is executed by emulator chip (TMP8035, TMP8039-6) of BM8403 after having been transmitted to the EPROM program memory within this board via the EPROM socket.
- (3) Direct read/write of register or RAM within the microcomputer LSI is available.
- (4) Application program can be modified with machine code level.
- (5) Application program can be started with any address and stopped at any time.
- (6) Address stop and single step operation functions are provided.
- (7) Dummy interrupt signals can be generated from the console on the board.
- (8) Module dimensions are 300mm × 300mm × approx. 30mm.
- (9) Power dissipation is less than 5V ( $\pm 5\%$ ) × 2.5A.

### OPERATING CONDITIONS

This board is connected with BM8403 that have been connected to the application system. The application program is written in EPROM, and EPROM is installed on the BM8404 board. The power (user-supplied) is turned on and the instructions from the console on BM8404 board are given to operate the system.

### TECHNICAL MATERIALS

- (1) BM8403 Instruction Manual

## SW8423A TLCS-84 ASSEMBLER/TDS400

### GENERAL DESCRIPTION

A cross assembler used for developing the application program of the TLCS-84. The TDS400 (Microcomputer Developing System 400) is under for operating this assembler.

### PRODUCT CONFIGURATION

- |                                         |   |
|-----------------------------------------|---|
| o EPROM (TMM323)<br>(Assembler program) | 5 |
| o TLCS-84 Assembly Language<br>Manual   | 1 |
| o SW8423A Instruction Manual            | 1 |



### FEATURES AND MAIN SPECIFICATIONS

- (1) Up to approx. 950 symbols (name) each of which consists of less than 6 characters can be defined.
- (2) Decimal and hexadecimal constants can be handled.
- (3) 34 reserved symbols are provided for register name or the like.
- (4) + and - are available for operators.
- (5) Provided are 6 assembler directives and 108 instructions.
  
- (6) Source program can be input from any input device.
- (7) Assemble list can be output to any output device.
- (8) Object program is created as a ROM image in the TDS400. The TDS400 can output this program in various formats. Direct write in the EPROM is also available.

### OPERATING ENVIRONMENT

Processor : TDS400 (48K-byte RAM)  
Operating system : System A monitor program (SW4006A)  
Peripheral equipment: Console I/O device (e.g. teletypewriter), optional floppy disk, CRT, printer, PTR, PTP, etc.

### OPERATING PROCEDURE

This assembler is operated by a command sent to the TDS400 from the console I/O device (or other devices). This assembler program itself should be loaded in the EPROM writer socket on the front panel of the TDS400.

### TECHNICAL MATERIALS

- (1) TLCS-84 Integrated Circuit Technical Data
- (2) TDS400 System A Operation Manual

## SW8453 TLCS-84 CROSS ASSEMBLER/ACOS

### GENERAL DESCRIPTION

This cross assembler is used when developing the application program of the TLCS-84. General-purpose computer ACOS600 or 700 can be used to load the program.

### PRODUCT CONFIGURATION

- o Magnetic tape (9 tracks) 1  
(Card (IBM29 code)  
image of source program written  
in FORTRAN (JIS7000,  
partially GMAP)
- o TLCS-84 Assembly Language Manual 1
- o SW8453 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) Up to approx. 500 symbols (name) each of which consists of less than 6 characters can be defined.
- (2) Binary, octal, decimal, and hexadecimal constants can be handled.
- (3) 34 reserved symbols are provided for register name or the like.
- (4) + and - are available for operators.
- (5) Provided are 11 assembler directives and 108 instructions.
  
- (6) Punched card or paper tape can be used for the input medium of the source program.
- (7) Assemble list can be output to a line printer.
- (8) Object program is created in the host system. Using the paper tape output program ACOS (SW0051), this program can be output to paper tapes in various formats.

### OPERATING ENVIRONMENT

- Processor : ACOS600 or 700 with more than 64K-words  
(more than 17-bit words)
- Operating system : ACOS-6
- Peripheral equipment: Magnetic disk, magnetic tape, line printer, card reader, paper tape reader, (and paper tape punch), etc.

### OPERATING PROCEDURE

First, compile this cross assembler to load in the host system. According to the OS of the host machine, define various files, and specify the input and output conditions to perform assembling.

### TECHNICAL MATERIALS

- (1) TLCS-84 Integrated Circuit Technical Data
- (2) SW0051 Instruction Manual
- (3) ACOS600/700 FORTRAN Language Description
- (4) ACOS600/700 Job Control Language (JCL) Description
- (5) ACOS600/700 IMCV Edit Program Description

## SW8553 TLCS-85 CROSS ASSEMBLER/ACOS

### GENERAL DESCRIPTION

This cross assembler is used when developing the application program of the TLCS-85. General-purpose computer ACOS600 or 700 can be used to load the program.

### PRODUCT CONFIGURATION

- o Magnetic tape (9 trucks) 1  
(Card (IBM29 code) image of source program written in FORTRAN (JIS 7000, partially GMAP))
- o TLCS-85 Assembly Language Manual 1
- o SW8553 Instruction Manual 1



### FEATURES AND MAIN SPECIFICATIONS

- (1) Up to approx. 500 symbols (name) each of which consists of less than 6 characters can be defined.
- (2) Binary, octal, decimal, and hexadecimal constants can be handled.
- (3) 10 reserved symbols are provided for register name or the like.
- (4) 11 arithmetic and logical operators are available.
- (5) Provided are 13 assembler directives and 113 instructions.
- (6) Punched card or paper tape can be used for the input medium of the source program.
- (7) Assemble list can be output to a line printer.
- (8) Object program is created in the host system. Using the paper tape output program ACOS (SW0051), this program can be output to paper tapes in various formats.

### OPERATING ENVIRONMENT

- Processor : ACOS600 or 700 with more than 64K-words  
(more than 17-bit words)
- Operating system : ACOS-6
- Peripheral equipment: Magnetic disk, magnetic tape, line printer, card reader, paper tape reader, (and paper tape punch), etc.

### OPERATING PROCEDURE

First, compile this cross assembler to load in the host system. According to the OS of the host machine, define various files, and specify the input and output conditions to perform assembling.

### TECHNICAL MATERIALS

- (1) TLCS-85 Integrated Circuit Technical Data
- (2) SW0051 Instruction Manual
- (3) ACOS600/700 FORTRAN Language Description
- (4) ACOS600/700 Job Control Language (JCL) Description
- (5) ACOS600/700 IMCV Edit Program Description



## OVERSEAS OFFICES

### U.S.A.:

#### TOSHIBA AMERICA, INC.

Chicago Office  
2900 MacArthur Boulevard, Northbrook, Ill.  
60062, U.S.A.  
Cable: TOSIBA CHICAGO, Telex: 35-4407,  
Tel: (312)564-1200  
Irvine Office  
2151 Michelson Drive, Suite 190, Irvine, Calif.  
92715, U.S.A.  
Telex: 910-595-1127 TSBIRIN,  
Tel: (714)955-1155

### WEST GERMANY:

#### TOSHIBA DEUTSCHLAND G.m.b.H.

Head Office  
Hammer Landstrasse 115, 4040 Neuss 1,  
F. R. Germany  
Telex: 8517926, Tel: (02101)1981

Muenchen Office  
Dom Pedrostrasse 17, 8000 Muenchen 19  
Telex: 05213363, Tel: (089)18 50 22

### UNITED KINGDOM:

#### TOSHIBA (UK) LTD.

Toshiba House, Frimley Road, Frimley,  
Cambridge, Surrey GU 16 5JJ, England  
Telex: 858798, Tel: Cambridge (0276)62222

### FRANCE:

TOSHIBA CORPORATION — Paris Office  
Tour Neptune 23rd Floor, Cedex No. 20,  
92086 Paris La Defense, France  
Telex: 613351 F, Tel: 773-7272

### SWEDEN:

TOSHIBA CORPORATION — Stockholm Office  
Banergatan 23, S-115 22 Stockholm, Sweden  
Telex: 14169 TSB STK S, Tel: 08-616265

### HONG KONG:

TOSHIBA ELECTRONICS HONG KONG LTD.  
Suite 423-5, Ocean Centre, Canton Road,  
Kowloon, Hong Kong  
Cable: TSBEHK, Telex: 38501 TSBEH HX,  
Tel: 3-671141

### TAIWAN:

TSU-RONG CORPORATION  
Rm N-813, Chia Hsin 2-Bldg., 96 Sec. 2,  
Chung Shan N. Rd., Taipei, Taiwan  
Telex: 26874 TRCTP, Tel: 531-3934

### SINGAPORE:

TOSHIBA SINGAPORE PTE., LTD.  
2405/6 Orchard Towers, 400 Orchard Road,  
Singapore 0923  
Telex: RS 23892, Tel: 7373911

### KOREA:

KOREA ELECTRONICS CO., LTD.  
189-2 Guro-Dong, Guro-Gu, Seoul, Korea  
Cable: KOREA TOSHIBA COM.  
Telex: KE COS K27424, Tel: 853-3161

### AUSTRALIA:

TOSHIBA CORPORATION — Sydney Office  
14th Floor, Gold Fields, House No. 1,  
Alfred Street, Sydney Cove, Box R219, Sydney  
N.S.W. 2000, Australia  
Cable: TOSHIBA SYDNEY, Telex: 22268,  
Tel: 27-4301~5

### BRASIL:

TOSHIBA BRASILEIRA REPRESENTACOES  
LTDA.  
Rua Peixoto Gomide, No. 996-1, Andar,  
Conj:130/140, Jardim Paulista, São Paulo, Brasil  
Cable: TOSHIBA SPO, Telex: 011-22298.  
Tel: 283-4511, 4714, 4964

The information in this guide has been carefully checked and is believed to be reliable, however,  
no responsibility can be assumed for inaccuracies 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 license under the patent rights of Toshiba or any third parties.



# TOSHIBA

TOSHIBA CORPORATION TOKYO JAPAN

1-6, UCHISAIWAICHO 1-CHOME, CHIYODA-KU, TOKYO, 100, JAPAN

TELEX: J22587 TOSHIBA CABLE: TOSHIBA TOKYO TEL: 508-2704

PRINTED IN JAPAN