TOSHIBA MOS TYPE DIGITAL INTEGRATED CIRCUIT

TMP4740P TMP4720P

N-CHANNEL SILICON GATE DEPRESSION LOAD

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 (4,096 × 8) | 256 × 4   |

PREIMINARY

#### **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 seires
- · 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 precaler)
   Frequency applied for timer interrupt of divider is programmably selectable.
- High output current (Output ports)
   TYP. 20mA × 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

PREIMINARY

PIN CONNECTIONS (TOP VIEW)

TECHNICAL DATA



### 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_{23} \sim P_{20}$               | 4          | Output        | " ( " )                                 |
| $R_{43} \sim R_{40}$               | 4          | 1/0           | I/O port                                |
| $R_{53} \sim R_{50}$               | 4          | 1/0           | 11                                      |
| $R_{63} \sim R_{60}$               | 4          | 1/0           | **                                      |
| $R_{73} \sim R_{70}$               | 4          | 1/0           | "                                       |
| R <sub>83</sub> (T1)               | 1          | 1/0           | 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          | 1/0           | I/O port or interrupt input             |
| $R_{92}$ ( $\overline{SCK}$ )      | 1          | 1/0           | I/O port or shift clock for serial port |
| R <sub>91</sub> (SO)               | 1          | 1/0           | I/O port or serial output               |
| R <sub>90</sub> (SI)               | 1          | 1/0           | 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_{\mathrm{DD}}$                  | 1          | Power supply  | +5V                                     |
| $v_{\rm HH}$                       | 1          | Power supply  | +5V (Memory power supply)               |
| V <sub>SS</sub>                    | 1          | Power supply  | OV                                      |



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 assign- |  |  |  |
|                    | ment 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_1$ , $TC_2$    | 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                                |  |  |  |

TMP4740P

PREIMINARY

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

TECHNICAL DATA

- (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 (TC1, TC2)
- 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.

TMP4740P

PREIMINARY

### 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 "O" 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

### TMP4740P TMP4720P





Special example of branch caused by (BSS a)instrustion. Fig.1.1.1 Program Counter and Program Memory (ROM)

PREIMINAR

### 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 accululator. 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 \cdot 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.



| 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

TECHNICAL DATA

TMP4740P TMP4720P



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

TECHNICAL DATA

TMP4740P TMP4720P PREIMINARY

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_{73} \sim R_{40}$  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.

PREIMINARY





Fig. 1.3.1 H Register, L Register and Data Memory (RAM)



### 1.4 Data Memory (RAM)

TECHNICAL DATA

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 prpgram. 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.

TECHNICAL DATA

TMP4740P TMP4720P





\* : 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

# TECHNICAL DATA

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



|                    | MSB              |                  | LSB     |  |  |
|--------------------|------------------|------------------|---------|--|--|
| (Timer/Counter 2)  | TC2              |                  |         |  |  |
| (11mel/Godficel 2) | TC2 <sub>H</sub> | TC2 <sub>M</sub> | $TC2_L$ |  |  |
| (RAM Address)      | (FA)             | (F9)             | (F8)    |  |  |

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 \times 4$ -bit (addresses 00 - FF) capacity, and that contained in TMP4720P has a  $128 \times 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 00 - FF in a program, but the RAM equivalent to addresses 00 - 7F are assigned in the TMP4720P.



Fig. 1.4.4 RAM Capacity and Address

 $({}^{\text{TC}_1}, {}^{\text{TC}_2} \text{ and stack})$  5 level are used.

PREIMINARY

## TECHNICAL DATA

### 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  ${\tt 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 subraction 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 " $\overline{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)

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.

| 3  | 2  | 1  | 0  |  |
|----|----|----|----|--|
| CF | ZF | SF | GF |  |

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 "l", 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.

TECHNICAL DATA

TMP4740P TMP4720P



### 1.7 Port (PORT)

Data transfer to/from the external circuitry, and command/ status/data transfer between the built-in periferal circuitry are carried out by the input/output irstructions.

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

| Port     | Symbol    | Port, Register                                    |                                                                         |              | T          |           |            |           | SET  | @L  |
|----------|-----------|---------------------------------------------------|-------------------------------------------------------------------------|--------------|------------|-----------|------------|-----------|------|-----|
| ad-      | (Input/   | (Input/Output)                                    | IN %P, A                                                                | OUT A ,%P    |            |           | SET%P b    | TEST %P,b | CLR  | GT  |
| dress    |           | (Inpac/oucpuc)                                    |                                                                         | OUT@HL,%P    | OUT#K %P   | OUTB @HL  |            | TESTP%P,b | TEST | @L  |
| 00       |           | Ko Input port / P                                 | 0                                                                       | 00101111,701 | 001111,781 | OUTB CHE  | OLICOI , D | 0         |      |     |
| 01       | TPO1/0P01 | P <sub>1</sub> Output latch/P <sub>1</sub> Output | ő                                                                       | 0            | 0          |           | 0          | 0         |      |     |
| 02       | IP01/0P01 | P <sub>2</sub> " /P <sub>2</sub> "                | o o                                                                     | o o          | 0          |           | Ő          | 0         |      |     |
| 03       | IP02/0102 | 712                                               |                                                                         |              |            |           |            | -         |      |     |
| 04       | IP04/0P04 | R <sub>4</sub> I/O port                           | 0                                                                       | 0            | 0          |           | 0          | 0         | 0    |     |
| 05       | IP04/0P04 | R <sub>5</sub> "                                  | 0                                                                       | l ő          | 0          |           | ő          | 0         | 0    |     |
| 06       | IP06/0P06 | 14.5                                              | 0                                                                       | 0            | 0          |           | ő          | o l       | 0    | - 1 |
| 07       | IP00/OP00 |                                                   | 0                                                                       | 0            | 0          |           | 0          | 0         | 0    |     |
| 08       | IP08/0P08 |                                                   | ő                                                                       | 0            | 0          |           | 0          | 0         |      |     |
| 09       | IP08/0P08 |                                                   | 0                                                                       | 0            | 0          |           | 0          | o l       |      |     |
| 09<br>0A | IPOA/OPOA |                                                   |                                                                         |              |            |           |            |           |      |     |
| OB<br>OB | IPOB/OPOB |                                                   |                                                                         | 1            |            |           |            |           |      |     |
| OC OB    | IPOC/OPOC |                                                   |                                                                         | rial buffer  |            |           |            |           |      |     |
| OD       | IPOD/OPOD |                                                   | (**) Se:                                                                | rial buffer  | r registe  | r (Transm | ission)    |           |      |     |
| OE       |           | Status input/                                     | 0                                                                       | l            |            |           |            | 0         |      |     |
| OF       | IPOF/OPOF | (*) / (**)                                        | 0                                                                       | 0            | 0          |           |            |           |      | l   |
| 10       | /OP10     | /                                                 |                                                                         |              | -          |           |            |           |      | -   |
|          | · ·       | /P2.P1 output port                                |                                                                         |              |            |           |            |           |      |     |
| 11       | /OP11     | (8-bit output)                                    |                                                                         |              |            | 0         |            |           |      |     |
| 12       | /OP12     |                                                   |                                                                         |              |            |           |            |           |      |     |
| 13       | /OP13     |                                                   |                                                                         |              |            |           |            |           |      |     |
| 14       | /OP14     |                                                   |                                                                         |              |            |           |            |           |      | l   |
| 15       | /OP15     |                                                   |                                                                         |              | 1          |           |            |           |      |     |
| 16       | /OP16     |                                                   | (2) (2)                                                                 | 611+1        |            |           | 44.444     |           |      |     |
| 17       | /OP17     | /                                                 | (a) Control with timer interrupt of divider (b) Timer/Counter 1 control |              |            |           |            |           |      |     |
| 18       | /OP18     | /                                                 | (D) 11m                                                                 | er/counter   | 1 COULTO   | 1         |            |           |      | l   |
| 19       | /OP19     | / (a)                                             |                                                                         | 0            | I          |           |            |           |      |     |
| 1A       | /OP1A     | /                                                 | (c) Timer/Counter 2 control                                             |              |            |           | ł          |           |      |     |
| 1B       | /OP1B     |                                                   | (d) Serial port control                                                 |              |            |           |            |           |      |     |
| 1C       | /OP1C     | / (b)                                             | 0                                                                       |              |            |           |            |           |      |     |
| 1D       | /OP1D     | / (c)                                             |                                                                         | 0            |            |           |            |           |      | - 1 |
| 1E       | /OP1E     |                                                   |                                                                         |              |            |           |            |           |      | 1   |
| 1F       | /OP1F     | / (d)                                             |                                                                         | 0            |            |           |            |           |      |     |

Input/Output Instructions

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

TMP4740P

PREIMINARY

(1)  $K_0$  ( $K_{03} \sim K_{00}$ ) Port

This is a 4-bit port used for input.



(2)  $P_1 (P_{13} \circ P_{10}), P_2 (P_{23} \circ P_{20})$  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/OPO1, and IPO2/OPO2. 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 OP11 is automatically selected as the port address.



TECHNICAL DATA

Ports P1 and P2 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_4(R_{43} \circ R_{40})$ , $R_5(R_{53} \circ R_{50})$ , $R_6(R_{63} \circ R_{60})$ , $R_7(R_{73} \circ R_{70})$ 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 R73 - R40 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.

|         | Correspond-<br>ing Pin | Lregister 3 2 1 0 | Correspand-<br>ing Pin |
|---------|------------------------|-------------------|------------------------|
| 0000    | R40                    | 1000              | R <sub>60</sub>        |
| 0001    | R41                    | 1001              | R61                    |
| 0010    | R <sub>42</sub>        | 1010              | R62                    |
| 0011    | R43                    | 1 0 1 1           | R63                    |
| 0100    | R <sub>50</sub>        | 1 1 0 0           | R70                    |
| 0 1 0 1 | R <sub>51</sub>        | 1 1 0 1           | R71                    |
| 0110    | R52                    | 1 1 1 0           | R72                    |
| 0111    | R53                    | 1111              | R73                    |

Table 1.7.2 Correspondence of Individual

Bits of L Register and I/O Port

TECHNICAL DATA

TMP4740P





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_8 (R_{83} \sim R_{80})$ Port

This is a 4-bit  $\rm I/0$  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 R82 ( $\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 R80 ( $\overline{\text{INT2}}$ ) is used, INT2 interrupt request also takes place in the same manner as the case of pin R82, but the interrupt request is not accepted by merely resetting the LSB (EIR0) 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.

(Pin)

Fig. 1.7.4 R<sub>8</sub> Port

### (5) R9(R92 ~ R90) Port

Output data

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 Rg port is also used as serial port. The latch must be set to "1" when Rg port is used as serial port. The port used as normal I/O port is not entirely influenced by disabling the serial port. Pin Rg3 is not mounted in the port, but "1" is read by accessing to pin Rg3 in a program.



Fig. 1.7.5 R<sub>9</sub> Port



### 1.8 Interrupt control circuit (INTR)

TECHNICAL DATA

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<br>according<br>to hardware | Interrupt<br>Latch | Enable con-<br>dition accord-<br>ing to program | Vector<br>Address                    |     |
|------------|------------------------------------------|--------------------------------------|--------------------|-------------------------------------------------|--------------------------------------|-----|
| Exte       | ernal interrupt l                        | (INT1)                               | (Higher)<br>1      | INTL5                                           | (Note 1)<br>EIF = 1                  | 002 |
|            | Serial<br>Input/Output<br>interrupt      | (ISIO)                               | 2                  | INTL <sub>4</sub>                               | EIF·EIR3 = 1                         | 004 |
| interrupt  | Timer counter 1<br>Overflow<br>interrupt | (10VF1)                              | 3                  | INTL <sub>3</sub>                               | EIF EIR <sub>2</sub> = 1             | 006 |
| Internal i | Timer counter 2<br>Overflow<br>interrupt | (10VF2)                              | 4                  | INTL <sub>2</sub>                               | (Note 2) $EIF \cdot EIR_1 = 1$       | 008 |
| In         | Timer interrupt<br>of divider            | (ITMR)                               | 5                  | INTL <sub>1</sub>                               | (Note 2)<br>EIF·EIR <sub>1</sub> = 1 | 00A |
| Exte       | ernal interrupt 2                        | (INT2)                               | 6<br>(Lower)       | INTL <sub>O</sub>                               | EIF·EIR <sub>O</sub> = 1             | 00C |

EIF

| MSB  |                  |                  | LSB  |
|------|------------------|------------------|------|
| 3    | 2                | 1                | 0    |
| EIR3 | EIR <sub>2</sub> | EIR <sub>1</sub> | EIRO |

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

"AEI MINARY



Fig. 1.8.1 Interrupt Control Circuit



Fig. 1.8.2 Interrupt Acceptance Timing Chart (Example)



### (1) Interrupt processing

TECHNICAL DATA

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".
- 4 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".
- (6) 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.

## TMP4740P



- ① The contents of the program counter and flag are restored out of the stack.
- (2) 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.

PREIMINARY

Read/write operation is performed by use of the (XCH A, EIR) instruction. It is set to "O" at the initialization operation.

### Interrupt latch

The interrupt latches (INTL $_5$  - INTL $_0$ ) 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  $_{\!1}$  - FD  $_{\!18})$  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 resister.



(a) Structure of frequency divider



| Interrupt fre- | For example,   |  |
|----------------|----------------|--|
| quency (Hz)    | fc=4.194304MHz |  |
| fc/210         | 4,096 Hz       |  |
| fc/211         | 2,048 Hz       |  |
| fc/212         | 1,024 Hz       |  |
| fc/213         | 512 Hz         |  |

(b) Command register

Fig. 1.9.1 Frequency Divider

PARIMINAAL

### 1.10 Timer/Counter ( $TC_1$ , $TC_2$ )

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_{83}$  (T1),  $R_{81}$  (T2)].

TECHNICAL DATA

TMP4740P TMP4720P





(a) Command register

| 7-61-01-01                  |                            |                                                 |                                            |  |
|-----------------------------|----------------------------|-------------------------------------------------|--------------------------------------------|--|
| Internal Pulse<br>Rate (Hz) | Max. Setting<br>Time (SEC) | For example, fc=<br>Internal Pulse<br>Rate (Hz) | 4.194304 MHz<br>Max. Setting<br>Time (SEC) |  |
| fc/2 <sup>10</sup>          | 2 <sup>22</sup> /fc        | 4,096                                           | 1                                          |  |
| fc/2 <sup>14</sup>          | 2 <sup>26</sup> /fc        | 256                                             | 16                                         |  |
| fc/2 <sup>18</sup>          | 2 <sup>30</sup> /fc        | 16                                              | 256                                        |  |
| fc/2 <sup>22</sup>          | 2 <sup>34</sup> /fc        | 1                                               | 4,096                                      |  |

(b) Selection of timer rate

Fig. 1.10.2 Control of Timer/Counter

TMP4740P



### (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  $fc/2^{10}~{\rm Hz}$ : The count operation is inserted once every 128-instruction cycle time, so that the apparent speed is decreased by  $1/127 \cdots 0.8\%$  instruction execution speed. For example, the apparent speed is  $2.016 \cdots b$  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 = 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  $\ensuremath{\mathrm{R}}_{91}$  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
SB: 4-bit buffer register

SIOC: Serial port control circuit

φ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 "O" 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  $\overline{\text{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  $\overline{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  $\overline{SCK}$  pin signal.

#### Trailing edge shift mode

Data is received (receive mode) at the trailing edge of the  $\overline{\text{SCK}}$  pin signal.

The  $\overline{SCK}$  pin must be set to the "high" level when the serial transfer is started. In the internal clock mode, the  $\overline{SCK}$  pin is automatically set to the "high" level because it serves as an output.

TMP4740P



# (4) Operation mode

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

TMP4740P



Transmit mode

TECHNICAL DATA

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 SO 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 "O".

#### Internal clock operation

In case of  $fc/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  $\ensuremath{\text{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

PREIMINARY

#### Completion of transmission

When the buffer register becomes cmpty, 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 "O" 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 "O" 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 = O.

One word transfer can be terminated by ESIO = 0 in the interrupt service program on receipt of the interrupt caused by the buffer empty.

PREIMINARY





(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  $fc/2^7Hz$ , 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 "O".

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 "O" prior to the generation of the next shift clock, the ESIO can be reset to "O" in the interrupt service program which is loaded to read out the last data. Thereafter the last data is read.

PREIMMARY



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 "O" 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.

PREIMINARY

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 casued 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



Fig. 1.11.8 Receiving Start/Completion (at one word transfer)

PREIMINARY

# TECHNICAL DATA

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.

PREIMINARY



(a) Internal clock operation (with wait operation)



(b) External clock operation (at slow transfer rate)

PREIMINARY







(d) One-word transfer

Fig. 1.11.9 Receive (Leading Edge Shift) Mode

PREIMINARY

- 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 descreption 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 \, \, ^{ \vee} \, \, \text{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_{\rm IN}$ ,  $X_{\rm 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.

TECHNICAL DATA

TMP4740P TMP4720P



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  $\overline{\text{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.
- $\widehat{\mathbf{3}}$  The  $\widehat{\mathbf{RESET}}$  is held at the low level in at least three instruction cycle time.

# TMP4740P

PREIMINARY

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  $\overline{\text{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 200 k\Omega$  TYP., MOS-load resister).

#### 2.4 Memory Stand-by function

Even during the cut off of the main power supply ( $V_{\rm DD}$ ), the RAM data can be held with low power dissipation by connecting the back-up power supply to the  $V_{\rm HH}$  pin. This memory stand-by operation is performed by the following procedure.

- Weep the RESET pin at the low level in at least three instruction cycle time before the VDD power goes to the minimum operating voltage.
- 2 Hold the low level of the  $\overline{\text{RESET}}$  pin. At the same time, the level of the V<sub>HH</sub> 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 (INT1, INT2) are provided for the external interrupt input. Since these pins are common pins with  $R_8$  port, they can be used as I/O pins ( $R_{82}$ ,  $R_{80}$ ) respectively, if not used as the interrupt input pins.

The interrupt via  ${\rm INT_2}$  can be inhibited at any time by the program, but the interrupt via  ${\rm INT_1}$  is not inhibited by it independently. Therefore, when this pin is used for the  ${\rm R_{82}}$  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  ${\rm INT_1}$  is not used.

The interrupt latch is set by the falling edge of the external inputs (INT1, INT2), 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.

PREIMINARY



Fig. 2.5.1 Interrupt Timing (Dummy process of INT<sub>1</sub> 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.



317

TMP4740P



# TECHNICAL DATA

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

"IOCODE AA" is employed if not specified.

| Inpu                              | Input/Output Circuit Code (IOCODE) AA                                        |                                                                                                                                   |                                                                                                     |                                                                                                     |                                                                                                                                     |  |
|-----------------------------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|
| Port<br>Cir-<br>cuit              | Input<br>(K <sub>0</sub> )                                                   | Output<br>(P <sub>1</sub> ,P <sub>2</sub> )                                                                                       | 1/0<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 | $R = 1k^{\Omega} \text{ (TYP.)}$                                             | <b>→</b>                                                                                                                          | $R = 1k\Omega \text{ (TYP.)}$                                                                       | $R = 1k\Omega \text{ (TYP.)}$                                                                       | $R = 1k\Omega \text{ (TYP.)}$                                                                                                       |  |
| Remark                            | <ul> <li>High threshold input.</li> <li>No resistor is contained.</li> </ul> | <ul> <li>Sink open drain output.</li> <li>High output current.</li> <li>Output latch is initialized to the high level.</li> </ul> | <ul> <li>Sink open drain output.</li> <li>Output latch is initialized to the high level.</li> </ul> | <ul> <li>Sink open drain output.</li> <li>Output latch is initialized to the high level.</li> </ul> | <ul> <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  $\overline{\text{RESET}}$  pin and the pull-down resistor with TEST pin.).



# INTEGRATED CIRCUIT

# TECHNICAL DATA



| Inp                                    | Input/Output Circuit Code (IOCODE) AE                   |                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                           |                                                                                                      |  |  |
|----------------------------------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|--|
| Port<br>Cir<br>cuit                    | Input<br>(K <sub>o</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>cir-<br>cuit | $R_{IN=100k\Omega}(TYP.)$ $R = 1k\Omega$                | - <b>&gt;</b> ~                                                                                  | $\begin{array}{c} & & & & & \\ & & & & \\ & & & & \\ & & & & \\ & & & & \\ & & & & \\ & & & & \\ & & & & \\ & & & & \\ & & & & \\ & & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & \\ & & & \\ & & & \\ & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & & & \\ & &$ | $R = 1k\Omega \text{ (TYP.)}$                                             | $R = 1k\Omega \text{ (TYP.)}$                                                                        |  |  |
| Remark                                 | o High threshold input o Pull-up resistor is contained. | o Sink open drain output. o High output current. o Output latch is initialized to the high level | o Sink open drain output. o Pull-up resistor is contained. o Output latch is initialized to the high level.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | o Sink open drain output. o Output latch is initialized to the high level | o Schmitt cir- cuit input. o Sink open drain output. o Output latch is initialized to the high level |  |  |

| Inp                                    | Input/Output Circuit Code (IOCODE) AF                      |                                                                                                  |                                                                                                           |                                                                           |                                          |  |  |
|----------------------------------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|------------------------------------------|--|--|
| Port<br>Cir-<br>cuit                   | Input<br>(K <sub>o</sub> )                                 | Output<br>(P <sub>1</sub> .P <sub>2</sub> )                                                      | 1/0<br>(R <sub>4</sub> ,R <sub>5</sub> ,R <sub>6</sub> )                                                  | I/O<br>(R7)                                                               | I/O<br>(R <sub>8</sub> ,R <sub>9</sub> ) |  |  |
| I/O<br>equiv-<br>alent<br>cir-<br>cuit | RIN=100Ω (TYP.) R=1kΩ (TYP.)                               |                                                                                                  | $\begin{array}{c} V_{DD} \\ R_{L} \\ R \\ R_{L} = 5k\Omega \ (TYP.) \\ R = 1k\Omega \ (TYP.) \end{array}$ | $R = 1k\Omega \text{ (TYP.)}$                                             | $R = 1k\Omega \text{ (TYP.)}$            |  |  |
| Remark                                 | o High threshold input  o Pull-down resistor is contained. | o Sink open drain output. o High output current. o Output latch is initialized to the high level | 1 .                                                                                                       | o Sink open drain output. o Output latch is initialized to the high level |                                          |  |  |



# INTEGRATED CIRCUIT

TECHNICAL DATA



| Inpu                                   | t/Output Circuit                                            | Code (IOCODE)                                       | АН                                                                                                          |                                                                           |                                                                                                    |
|----------------------------------------|-------------------------------------------------------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|
| Port<br>Cir-<br>cuit                   | Input<br>(K <sub>0</sub> )                                  | Output<br>(P <sub>1</sub> ,P <sub>2</sub> )         | 1/0<br>(R <sub>4</sub> ,R <sub>5</sub> ,R <sub>6</sub> )                                                    | I/0<br>(R <sub>7</sub> )                                                  | I/O<br>(R <sub>8</sub> ,R <sub>9</sub> )                                                           |
| I/O<br>equiv-<br>alent<br>cir-<br>cuit | $\begin{array}{c} & & & & & & \\ & & & & & & \\ & & & & & $ | <b>∞</b>                                            | $VDD$ $RL=5k\Omega$ (TYP.) $R=1k\Omega$ (TYP.)                                                              | $R = 1k\Omega \text{ (TYP.)}$                                             | $R = 1k\Omega \text{ (TYP.)}$                                                                      |
| Remark                                 | o High threshold input o Pull-up resistor is contained.     | drain output. o High output current. o Output latch | o Sink open drain output.  o Pull-up resistor is contained.  o Output latch is initialized to the low level | o Sink open drain output. o Output latch is initialized to the high level | o Schmitt circuit input. o Sink open drain output. o Output latch is initialized to the high level |

| Inpu                                   | Input/Output Circuit Code (IOCODE) AI                      |                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                       |                                          |  |  |
|----------------------------------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|------------------------------------------|--|--|
| Port<br>Cir-<br>cuit                   | Input<br>(K₀)                                              | Output<br>(P <sub>1</sub> ,P <sub>2</sub> )                                                      | 1/0<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>cir-<br>cuit | R IN=100k $\Omega$ (TYP.) R=1k $\Omega$ (TYP.)             | <b>-</b> >∿                                                                                      | VDD $RL$ | $R = 1k\Omega \text{ (TYP.)}$                                                         | $R = 1k\Omega \text{ (TYP.)}$            |  |  |
| Remark                                 | o High threshold input  o Pull-down resistor is contained. | o Sink open drain output. o High output current. o Output latch is initialized to the high level | o Sink open drain output.  o Pull-up resistoris contained.  o Output latch is initialized to the low level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | o Sink open<br>drain output.<br>o Output latch<br>is initialized<br>to the high level | 1                                        |  |  |

PREIMINARY

#### TECHNICAL DATA

# 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<sub>8</sub> 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 tham 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}, SO, SI)$ , which are also used for the R9 port. These pins can be used as the pins of the R9 port (R92, R91, R90), 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 \mathrm{k}\Omega$  TYP., MOS-load resistor).

PARIMINARY

# 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 is 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.

|        | Total               | 90 |
|--------|---------------------|----|
| 2-byte | 2-cycle instruction | 39 |
| 1-byte | 2-cycle instruction | 11 |
| 1-byte | 1-cycle instruction | 40 |

#### (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 $_{\rm H}$ , ROM $_{\rm L}$ )       | (High-order 4 bits or low-order 4 bits are expressed by  |  |  |  |
|                                          | suffix H/L.)                                             |  |  |  |
| <b>+</b>                                 | Transfer                                                 |  |  |  |
| $\stackrel{\longleftarrow}{\rightarrow}$ | Exchange                                                 |  |  |  |
| +                                        | Addition                                                 |  |  |  |
| _                                        | Substraction                                             |  |  |  |
| Λ                                        | Logical AND of the corresponding bits                    |  |  |  |
| ٧                                        | Logical OR of the corresponding bits                     |  |  |  |
| $\forall$                                | 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></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 ( $\overset{\star}{**}$ ): Hexadecimal

| Item        | Assembler<br>Mnemonic | Object Code                                                                                                                                |                                      | Function $ \frac{\text{Flag(*)}}{\text{CF} ZF SF} (**) $                                                                                                                                                |
|-------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Class       | rinemonii c           | Binary                                                                                                                                     | (**)                                 | Functional Description                                                                                                                                                                                  |
|             | LD A, @HL             | 0 0 0 0 1 1 0 0                                                                                                                            | 0 C                                  | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                  |
| Instruction | 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> | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                  |
| Move Ins    | 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]$ $x'=x_7x_6x_5x_4x_3x_200$ 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                                  | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                  |





| Items            | Assembler<br>Mnemonic | Object Code                                                                                                                                  |                                      | Function   Flag(*)   (**                                                                                                                                                                                                                           |
|------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Class            | V                     | Binary                                                                                                                                       | (**)                                 | Functional Description                                                                                                                                                                                                                             |
|                  | 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)+ROML[(DC)]                                                                                                                                                                                                                                    |
| Move Instruction | LDH A,@DC+            | 0 0 1 1 0 0 1 0                                                                                                                              | 3 2                                  | (AC)+ROMH[(DC)], (DC)+(DC)+1 - Z 1 2  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] |
| re Inst          | ST A, @HL             | 0 0 0 0 1 1 1 1                                                                                                                              | O F                                  | $M[(H \cdot L)] \leftarrow AC$                                                                                                                                                                                                                     |
| Mov              | ST A,@HL+             | 0 0 0 1 1 0 1 0                                                                                                                              | 1 A                                  | $M[(H \cdot L)]_{\leftarrow}(AC)$ , $(LR)_{\leftarrow}(LR)+1$                                                                                                                                                                                      |
|                  | ST A,@HL-             | 0 0 0 1 1 0 1 1                                                                                                                              | 1 B                                  | $M[(H-L)]_{\leftarrow}(AC)$ , $(LR)_{\leftarrow}(LR)_{-1}$ $-$ Z $\overline{B}$ $1$ 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]     |
|                  | ST A, x               | 0 0 1 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<br>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>                                                                          | Fk                                   | $M[(H\cdot L)]+k$ , $(LR)+(LR)+1$                                                                                                                                                                                                                  |





| Items            | Assembler<br>Mnemonic | Object Code                                                                                                                                |                                      | Function Flag                                                                                                                                                                                 | (*)          | (**)     |
|------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------|
| Class            |                       | Binary                                                                                                                                     | (**)                                 | Functional Description                                                                                                                                                                        |              |          |
| 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] $\leftarrow$ k                                                                                                                                                                           | ed b         |          |
|                  | MOV H, A              | 0 0 0 1 0 0 0 0                                                                                                                            | 1 0                                  | (AC)+(HR) - Z Loads the contents of the H register accumulator.                                                                                                                               |              | l<br>he  |
|                  | MOV L, A              | 0 0 0 1 0 0 0 1                                                                                                                            | 11                                   | $(AC) \leftarrow (LR)$ - Z<br>Loads the contents of the L register<br>accumulator.                                                                                                            | l<br>in t    | 1<br>he  |
|                  | хсн а, н              | 0 0 1 1 0 0 0 0                                                                                                                            | 3 0                                  | Exchanges the contents of the accumul                                                                                                                                                         | ator<br>e 2] |          |
|                  | XCH A, L              | 0011 0001                                                                                                                                  | 3 1                                  | Exchanges the contents of the accumul                                                                                                                                                         | ator<br>e 2] | - 1      |
|                  | XCH A,EIR             | 0 0 0 1 0 0 1 1                                                                                                                            | 1 3                                  | (EIR)\$(AC)<br>Exchanges the contents of the accumul<br>those of the interrupt enable registe                                                                                                 |              | 1<br>for |
|                  | XCH A,@HL             | 0 0 0 0 1 1 0 1                                                                                                                            | O D                                  | M[(H·L)];(AC) - Z Exchanges the contents of the accumul those of the data memory specified by and L registers. [Not                                                                           | ator<br>the  | Н        |
|                  | 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>x <sub>H</sub> x <sub>L</sub> | Exchanges the contents of the accumul those of the data memory specified by                                                                                                                   |              | x        |
|                  | 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>x <sub>H</sub> x <sub>L</sub> | M[x]\$(LR),M[x'+1]\$(HR)  x'=x7x6x5x4x5x200  Exchanges the contents of the H and I ters for consecutive two-word content the data memory specified by the x' (mo x) of the instruction field. | s of         |          |



# INTEGRATED CIRCUIT

TECHNICAL DATA



|                           |                       | r                                                                                                                                          |                                      |                                                                                                                                                                                 |                    |          |
|---------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|----------|
| Items                     | Assembler<br>Mnemonic | Object Code Binary (***)                                                                                                                   |                                      |                                                                                                                                                                                 | Flag(*)<br>CFZFSF  | (**)     |
| Class                     |                       |                                                                                                                                            |                                      | Functional Description                                                                                                                                                          |                    |          |
| Compare Instruction       | CMPR A,@HL            | 0 0 0 1 0 1 1 0                                                                                                                            | 1 6                                  | null-M[(H·L)]-(AC) Compares the contents of the data ified by the H and L registers wi the accumulator.                                                                         |                    |          |
|                           | CMPR A, x             | 0 0 1 1 1 1 1 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 E<br>x <sub>H</sub> x <sub>L</sub> | nill-M[x]-(AC) Compares the contents of the data ified by the x of the instruction 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) Compares the immediate data k of struction field with the contents cumulator. Serves as the accumul instruction when k = 0.                                         | of the             |          |
|                           | 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) Compares the immediate data k of struction field with the contents register. Serves as the H regist struction when k = 0.                                           | of the             |          |
|                           | 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) Compares the immediate data k of struction field with the contents register. Serves as the L regist struction when k = 0.                                           | of the             |          |
|                           | 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]  Compares the immediate data k of struction field with the contents memory specified by the y (page 0 struction field. Serves as the d test instruction when k = 0. | of the<br>) of the | e in-    |
| Arithmetic<br>Instruction | INC A                 | 0000 1000                                                                                                                                  | 0 8                                  | (AC)+(AC)+1 Increments the contents of the ac                                                                                                                                   | - Z C              | l<br>or. |
|                           | INC L                 | 0001 1000                                                                                                                                  | 1 8                                  | (LR)←(LR)+1 Increments the contents of the L                                                                                                                                    | - Z C              | 1        |



# INTEGRATED CIRCUIT

TECHNICAL DATA



| Items            | Assembler  | Object Code                                                                            |            | Function                                                                                                                                                                                       | Flag(*)<br>CFZFSF                 | (**)              |  |
|------------------|------------|----------------------------------------------------------------------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-------------------|--|
| Class            | Mnemonic   | Binary                                                                                 | (**)       | Functional Description                                                                                                                                                                         |                                   |                   |  |
| Arithmetic Instr | INC @HL    | 0000 1010                                                                              | 0 A        | M[(H·L)] +M[(H·L)]+1 Increments the contents of the d specified by the H and L registe                                                                                                         |                                   | 1<br>ry           |  |
|                  | DEC A      | 0 0 0 0 1 0 0 1                                                                        | 0 9        | (AC)←(AC)-1<br>Decrements the contents of the a                                                                                                                                                | - Z B                             | or.               |  |
|                  | DEC L      | 0 0 0 1 1 0 0 1                                                                        | 1 9        | $(LR) \leftarrow (LR) - 1$ Decrements the contents of the L                                                                                                                                    | - Z B                             | 1<br>r.           |  |
|                  | DEC @HL    | 0 0 0 0 1 0 1 1                                                                        | 0 в        | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                         |                                   |                   |  |
|                  | ADDC A,@HL | 00010101                                                                               | 1 5        | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                         |                                   |                   |  |
|                  | ADD A,@HL  | 0001 0111                                                                              | 1 7        | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                         |                                   |                   |  |
|                  | 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 | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                         |                                   |                   |  |
|                  | 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 Adds the immediate data k of the field to the contents of the H r places the result in the H regis as the H register increment inst the decrement instruction when k respectively. | egister,<br>ter. Ser<br>ruction o | and<br>rves<br>or |  |



TECHNICAL DATA

TMP4740P TMP4720P REIMINARY

| E                      |             | Г                                                                                                                                         |            |                                                                                                                                                                   |
|------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Items                  | Assembler   | Object Code                                                                                                                               |            | Function $ \frac{ Flag(*) }{ CF ZF SF} (**) $                                                                                                                     |
| Class                  | THICHIOITE  | Binary                                                                                                                                    | (**)       | Functional Description                                                                                                                                            |
|                        | 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 $\overline{C}$ 2 Adds the immediate data k of the instruction field to the contents of the L register, and places the result in the L register. |
| uc                     | 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 | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                            |
| Arithmetic Instruction | ADD y,#k    | 0 0 1 0 1 1 1 1 1 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 | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                             |
| Ari                    | SUBRCA, @HL | 00010100                                                                                                                                  | 1 4        | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                            |
|                        | 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 | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                            |



TECHNICAL DATA

TMP4740P TMP4720P PAEIMINARY

| Items                     | Assembler  | Object Code                                                                            |            | Function Flag(*) (**)                                                                                            |  |  |  |  |
|---------------------------|------------|----------------------------------------------------------------------------------------|------------|------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Class                     | Mnemonic   | 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>4</sub> k <sub>0</sub> | 3 8<br>5 k | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                           |  |  |  |  |
|                           | ROLC A     | 0 0 0 0 0 1 0 1                                                                        | 0 5        | Rotates the contents of the accumulator and carry flag to the left by one bit. [Note 4]                          |  |  |  |  |
|                           | RORC A     | 00000111                                                                               | 0 7        | (rotate right) C Z C 1  Rotates the contents of the accumulator and carry flag to the right by one bit. [Note 4] |  |  |  |  |
| Logical Instruction       | AND A,@HL  | 0 0 0 1 1 1 1 0                                                                        | 1 E        | (AC)+(AC) $\Lambda$ M[(H·L)]                                                                                     |  |  |  |  |
| Logical In                | 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) $\Lambda k$                                                                                            |  |  |  |  |
|                           | 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 \cdot L)] \hookrightarrow M[(H \cdot L)] \land k$                                                          |  |  |  |  |





| Items                           | Assembler Object Code |                                                                                        |            | Function Flag(*) CFZFSF (**)                                                                                                                            |
|---------------------------------|-----------------------|----------------------------------------------------------------------------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Class                           | Mnemonic              | Binary                                                                                 | (**)       | Functional Description                                                                                                                                  |
|                                 | OR A, @HL             | 0 0 0 1 1 1 0 1                                                                        | 1 D        | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                  |
| Logical Instruction             | 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 | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                  |
|                                 | 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\cdot L)]+M[(H\cdot L)]vk$ $ Z$ $Z$ $Z$ $Z$ $Z$ $Z$ $Z$ $Z$ $Z$ $Z$                                                                                |
|                                 | XOR A, @HL            | 0 0 0 1 1 1 1 1                                                                        | 1 F        | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                  |
| а                               | TEST CF               | 0 0 0 0 0 1 1 0                                                                        | 0 6        | $(3F)+(\overline{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". |
| Bit Manipulation<br>Instruction | TEST A, b             | 0 1 0 1 1 1 b <sub>1</sub> b <sub>0</sub>                                              | 5 C+b      | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                  |
| Bit M<br>Ins                    | TEST @HL,b            | 0 1 0 1 1 0 b <sub>1</sub> b <sub>0</sub>                                              | 5 8+b      | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                  |



TECHNICAL DATA

TMP4740P TMP4720P PREIMINARY

| Items           | Assembler                   | Object Code                                                                                                      |                        | Function Flag(*) (**)                                                                                                                                                                                                                                             |
|-----------------|-----------------------------|------------------------------------------------------------------------------------------------------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Class           | Class Mnemonic Binary (***) |                                                                                                                  | Functional Description |                                                                                                                                                                                                                                                                   |
| :               | 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           | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                            |
| uo              | 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           | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                            |
| ion Instruction | TEST @L                     | 0011 0111                                                                                                        | 3 7                    | $(SF)+\overline{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 R4 - R7 (pin input) specified by the higher two bits of the L register, in the status flag. |
| Manipulation    | TESTP CF                    | 0 0 0 0 0 1 0 0                                                                                                  | 0 4                    | $(SF) \leftarrow (CF)$ , $(CF) \leftarrow 1$                                                                                                                                                                                                                      |
| Bit             | TESTP ZF                    | 00001110                                                                                                         | 0 E                    | (SF)+(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)+(GF)                                                                                                                                                                                                                                                         |
|                 | 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) \leftarrow 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                        | Assembler  | Object Code                                                                                                      |              | Function Flag(*) (**)                                                                                                                                                                                                                                                        |
|------------------------------|------------|------------------------------------------------------------------------------------------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Class                        | Mnemonic   | Binary                                                                                                           | (**)         | Functional Description                                                                                                                                                                                                                                                       |
|                              | 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 В<br>С+b Р | (SF)+P[p] <b></b> 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     | 00000011                                                                                                         | 0 3          | $(GF) \leftarrow 1$                                                                                                                                                                                                                                                          |
| tion                         | SET @HL, b | 0 1 0 1 0 0 b <sub>1</sub> b <sub>0</sub>                                                                        | 5 b          | $M[(H \cdot L)] < b > -1$                                                                                                                                                                                                                                                    |
| Bit Manipulation Instruction | 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 > \leftarrow 1$                                                                                                                                                                                                                                                    |
| t Manipula                   | 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> \leftrightarrow 1$                                                                                                                                                                                                                                                |
| Bi                           | SET @L     | 0011 0100                                                                                                        | 3 4          | P[(LR)<3:2>+4]<(LR)<1:0>>+1                                                                                                                                                                                                                                                  |
|                              | CLR GF     | 00000010                                                                                                         | 0 2          | (GF)+0                                                                                                                                                                                                                                                                       |
|                              | CLR @HL, b | 0 1 0 1 0 1 b <sub>1</sub> b <sub>0</sub>                                                                        | 5 4+b        | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                       |



TMP4740P TMP4720P PREIMINARY

| Items                    | Assembler  | Object Code                                                                                                      |                                        | Function Flag(*) CFZFSF (**)                                                                                                                                                                                                       |
|--------------------------|------------|------------------------------------------------------------------------------------------------------------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Class                    | Mnemonic   | Binary                                                                                                           | (**)                                   | Functional Description                                                                                                                                                                                                             |
|                          | 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                                                                                                                                                                                                                       |
| ction                    | 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                                                                                                                                                                                                                      |
| Manipulation Instruction | 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". |
| Manipul                  | 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> | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                             |
| Bit                      | 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, (1NTL)<5:0> $\Lambda$ r<5:0> - 1 2  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)                                                      |
|                          | 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> | (ETF)+0, (INTL)<5:0> $\Lambda$ r<5:0> 1 2  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)                                                  |
| 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                             | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                             |





|                                     |            | ·                                                                                                                                                                                                |                                                   |                                                                                                                                                                                                                                                                         |                |
|-------------------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Items                               | Assembler  | Object Code                                                                                                                                                                                      |                                                   | Function Flag(*) (*) CF ZF SF                                                                                                                                                                                                                                           | **)            |
| Class                               | тителюнте  | Binary                                                                                                                                                                                           | (**)                                              | Functional Description                                                                                                                                                                                                                                                  |                |
|                                     | 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 \cdot L)] \leftrightarrow P[p]$                                                                                                                                                                                                                                   | ata            |
|                                     | 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+2 <del>p</del> 4p                        | $P[p] \leftarrow (AC)$ , $P=P_4P_3P_2P_1P_0$                                                                                                                                                                                                                            |                |
| Instruction                         | OUT @HL,%P | 0 0 1 1 1 0 1 0<br>1 1 <del>P</del> 4 0 P3P2P1Po                                                                                                                                                 | 3 A<br>C+2 <del>p</del> 4p                        | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                   | 2<br>n         |
| Imput/Output Instruction            | 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] \leftrightarrow k$                                                                                                                                                                                                                                                | of             |
|                                     | OUTB @HL   | 0 0 0 1 0 0 1 0                                                                                                                                                                                  | 1 2                                               | Outputs the data (eight bits) of the programmory located in addresses FEO - FFF, whi use a five-bit data connecting the content of the data memory specified by the H and registers and those of the carry flag, as lower-order five-bit addresses, to the P2 P1 ports. | ich<br>ts<br>L |
| Branch<br>Subroutine<br>Instruction | BS a       | 0 1 1 0 a <sub>11</sub> 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 а <sub>Н</sub><br>а <sub>М</sub> а <sub>L</sub> | If SF=1 then (PC)+a else null 1 2 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.                                | 3              |





| Items                         | Assembler |                                                                                                                                                                                    |                               | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Flag(*)<br>CFZFSF                   | (**) |  |
|-------------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|------|--|
| Class                         | Mnemonic  | Binary                                                                                                                                                                             | (**)                          | Functional Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                     |      |  |
| 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_{ m H}d_{ m L}$          | If SF=1 then (PC)+a else null, a=(PC)<11.6 > .d  Carries out the branch within a page (64-byte) if the status flag is at "1"; bring the immediate value d of the instruction field into the lower-order six bits of the program counter. Since the updated value remains in the higher-order six bits, if this instruction is specified in the last address in the page, branching is carried out to the next page. If the status flag at "0", it sets the status flag only to "and moves to the next address. [Note 5] |                                     |      |  |
|                               | 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 аН<br>а <u>м</u> а <u>г</u> | and moves to the next address. [Note 5] $ \begin{array}{ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                            |                                     |      |  |
|                               | 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)<br>Carries out the short form subr<br>The operation is the same as th<br>"CALL" instruction except that<br>be set in the program counter i<br>ally defined by the n of the in<br>field.                                                                                                                                                                                                                                                                | at of the<br>the value<br>s automat | e to |  |
|                               | RET       | 0010 1011                                                                                                                                                                          | 2 A                           | (SPW)+(SPW)+1,(PC)+STACK[(SPW)] Returns from the subroutine to program; increments the stack p and restores the data of the re from the stack to the program c                                                                                                                                                                                                                                                                                                                                                          | the previ<br>ointer wo<br>turn addi | ord, |  |

TECHNICAL DATA

TMP4740P TMP4720P



| Assembler | nic              |     |                                                                                                                                                                                                                                                                                    | Flag(*)<br>CF ZF SF (**                                                                                                                                                                                                                                                                                             |  |  |
|-----------|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Mnemonic  |                  |     | Functional Description                                                                                                                                                                                                                                                             | on                                                                                                                                                                                                                                                                                                                  |  |  |
| RETI      | 0010 1011        | 2 В | (SPW)+(SPW)+1,<br>(FLAG•PC)+STACK[(SPW)], (EIF)+1 * * *                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                     |  |  |
|           |                  |     | Returns from the interrupt processing routing 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". |                                                                                                                                                                                                                                                                                                                     |  |  |
| NOP       | 000000000        | 0 0 |                                                                                                                                                                                                                                                                                    | 1<br>thout perfor                                                                                                                                                                                                                                                                                                   |  |  |
|           | Mnemonic<br>RETI |     | Mnemonic Binaty (**)  RETI 0 0 1 0 1 0 1 1 2 B                                                                                                                                                                                                                                     | Mnemonic  Binaty  (**)  Functional Description  (SPW)+(SPW)+1, (FLAG-PC)+STACK[(SPW)], (EIF)+1  Returns from the interrupt proces increments the stack pointer workstores the data of the return and the stack and the data of the flaprogram counter and the flag, read then, it sets the interrupt of F/F to "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", " $\overline{C}$ ", " $\overline{B}$ ", "Z", " $\overline{Z}$ ", "1", or "0" according to the data processing rusult. 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.



#### ELECTRICAL CHARACTERISTICS

#### ABSOLUTE MAXIMUM RATINGS (Vgg=0V)

|                   | 1 (17/1/101 (V/11/103 (155-01)                    |              |       |
|-------------------|---------------------------------------------------|--------------|-------|
| SYMBOL            | ITEM                                              | RATING       | UNITS |
| $v_{\mathrm{DD}}$ | C 1 W-1+                                          | -0.5 ∿ 7     | V     |
| $v_{HH}$          | Supply Voltage                                    | -0.5 % /     | V     |
| V <sub>IN</sub>   | Input Voltage                                     | -0.5 ∿ 7     | V     |
| v <sub>out1</sub> | Output Voltage (Except Open Drain Port)           | -0.5 ∿ 7     |       |
| V <sub>OUT2</sub> | Output Voltage (Open Drain Port)                  | -0.5 ∿ 10    | V     |
| IOUT              | Output Current (P <sub>1</sub> , P <sub>2</sub> ) | 30           | mA    |
| PD                | Power Dissipation (T <sub>opr</sub> =70°C)        | 850          | mW    |
| T <sub>sol</sub>  | Soldering Temperature · Time                      | 260 (10 sec) |       |
| T <sub>stg</sub>  | Storage Temperature                               | -55 ∿ 125    | °C    |
| Topr              | Operating Temperature                             | -30 ∿ 70     |       |

#### RECOMMENDED OPERATING CONDITIONS ( $v_{SS}$ =0v)

| SYMBOL             | ITEM                                             | CONDITION                        | MIN. | MAX.              | UNITS |
|--------------------|--------------------------------------------------|----------------------------------|------|-------------------|-------|
| Topr               | Operating Temperature                            |                                  | -30  | 70                | °C    |
| $v_{\mathrm{DD}}$  | 0 1 7 1                                          |                                  | 4.5  | 5.5               |       |
| $v_{\rm HH}$       | Supply Voltage                                   |                                  | 4.5  | ٠,٠               | v     |
| $v_{\rm HH1}$      | Supply Voltage (Memory Stand-by)                 |                                  | 3.5  | 5.5               |       |
| $v_{1H1}$          | High Level Input Voltage (R4 ∿ R7)               |                                  | 2.2  | $v_{\mathrm{DD}}$ |       |
| V <sub>IH2</sub>   | High Level Input Voltage(Except R4^R7)           |                                  | 3    | $v_{\mathrm{DD}}$ | v     |
| $v_{\mathrm{IL1}}$ | Low Level Input Voltage (Except K <sub>0</sub> ) |                                  | 0    | 0.8               | \ \   |
| $v_{\mathrm{IL2}}$ | Low Level Input Voltage (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(Note 1)             | V <sub>IN</sub> =V <sub>IH</sub> | 80   | _                 | nS    |
| t <sub>WCL</sub>   | Low Level Clock Pulse Width (Note 1)             | AIW=AÎT                          | 80   | -                 | 113   |

(Note 1) For external clock operation.



PREIMINARY

#### DC CHARACTERISTICS ( $V_{SS}=0V$ , $V_{DD}=V_{HH}=5V\pm10\%$ , $T_{opr}=-30$ $^{\circ}$ 70°C)

|                                  | <del></del>                                              | , 0p1                                                         |      | 757 - 45        |      |       |
|----------------------------------|----------------------------------------------------------|---------------------------------------------------------------|------|-----------------|------|-------|
| SYMBOL                           | PARAMETER                                                | CONDITION                                                     | MIN. | (Notel)<br>TYP. | MAX. | UNITS |
| V <sub>HS</sub>                  | Hysteresis Voltage<br>(Schmitt Circuit Input)            |                                                               | _    | 0.5             | _    | V     |
| I <sub>IN1</sub>                 | Input Current (Note 2) (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<br>(Open Drain R Port)                     | V <sub>DD</sub> =5.5V, V <sub>IN</sub> =5.5V                  | -    | _               | 20   | μA    |
| $I_{IL}$                         | Low Level Input Current (R Port with Pull-up Resistor)   | V <sub>DD</sub> =5.5V, V <sub>IN</sub> =0.4V                  | _    | -               | -2   | mA    |
| ILO                              | Output Leak Current<br>(Open Drain 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 (R Fort with Full-up Resistor) | V <sub>DD</sub> =4.5V, I <sub>OH</sub> =-200μA                | 2.4  | -               | _    | V     |
| V <sub>OL</sub>                  | Low Level Output Voltage (Except XOUT)                   | V <sub>DD</sub> =4.5V, I <sub>OL</sub> =1.6mA                 | -    | _               | 0.4  | V     |
| I <sub>OL</sub>                  | Low Level Output Current (P1, P2)                        | $V_{\rm DD}$ =5V, $V_{\rm OL}$ =1V                            | -    | 20              | -    | mA    |
| I <sub>DD</sub> +I <sub>HH</sub> | Supply Current                                           | V <sub>DD</sub> =V <sub>HH</sub> =5.5V                        | -    | 50              | 100  | mA    |
| I <sub>HH1</sub>                 | Supply Current(Memory Stand-by)                          | V <sub>DD</sub> =V <sub>SS</sub> , V <sub>HH</sub> =3.5V      | -    | 5               | 10   | mA    |

(Note 1) Typical values are at  $T_{\rm opr}$ =25°C,  $V_{\rm DD}$ = $V_{\rm 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\pm10\%, T\_{opr}=-30 \,\,^{\sim}\,70\,^{\circ}\text{C})

| SYMBOL           | PARAMETER              | CONDITION | MIN.       | TYP. | MAX. | UNITS |
|------------------|------------------------|-----------|------------|------|------|-------|
| t <sub>cy</sub>  | Instruction Cycle Time |           | 1.9        | _    | 20   | μS    |
| t <sub>SDH</sub> | Shift data hold time   | (Note 1)  | 0.5tcy-300 | -    | _    | nS    |

#### AC TIMING CHART

· Serial Port (Completion of transmission)







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.

TECHNICAL DATA

TMP4740P TMP4720P "REIMINARY

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 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 " $\overline{\text{IOCODE}}$  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, "IOCODE 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)

TŌSHIBA MICRŌCŌMPUTER TLCS-47 IŌCŌDE AA

- :100000000665C7D79CF50F3F951FED55A8FF16E570
- :1000100088884DDE67E31F5D8ABA6DF292F113F5C1
- :100020004FF1F

:

- :1007E000B53D42E0EC32546025B7308CDD52063D1D
- :1007F000B4BE9E9E345B6138060B20BC372BF60BD6
- :00000001FF



PRELIMINARY

Program tape format (Format I)





## TECHNICAL DATA

TMP4740P

CAELININARY

LIST OF INSTRUCTIONS

|                     |                                         |                                                      | Object Code                                                       |             |                     |                                                                                 |          | *   | -1       | /cie       |        |
|---------------------|-----------------------------------------|------------------------------------------------------|-------------------------------------------------------------------|-------------|---------------------|---------------------------------------------------------------------------------|----------|-----|----------|------------|--------|
| <u> </u>            | Assembler                               | Bina                                                 | ry                                                                | Hexad       | ecimal              | Punction                                                                        | F1       | ags | į        | ttop<br>Co |        |
| Classi-<br>fication | Mnemonic                                | 1st Byte                                             | 2nd Byte                                                          | 1st<br>Byte | 2nd<br>Byte         |                                                                                 | CF       | ZF  | sf       | Execution  |        |
|                     | LD A ,@HL                               | 00 00 11 00                                          |                                                                   | ос          |                     | (AC)←M[(H•L)]                                                                   |          | 2   | 1        | 1          |        |
|                     | LD A, X                                 |                                                      | x7x6x5x4x3x2x1x0                                                  | 3 C         | $x_H x_L$           | (AC)+M[x]                                                                       | - and    | Z   | 1        | 2          |        |
|                     | LD HL, X                                | 00 10 10 00                                          | x7x6x5x4x3x2x1x0                                                  | 2.8         | $x H \times \Gamma$ | $(LR) \leftarrow M[x'], (HR) \leftarrow M[x'+1], x'=x_7x_6x_5x_4x_3x_2U$        |          | -   | 1        | 2          |        |
|                     | LD A ,#k                                | 01 00 k3k2k1k                                        |                                                                   | 4 k         |                     | (AC)+k                                                                          | -        | Z   | 1        | 1          | 1      |
|                     | LD H ,#k                                | 11 00 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k | -0                                                                | Ck          |                     | (HB)+-k                                                                         |          | -   | 1        | 1          | 1      |
|                     | LD L ,#k                                | 11 10 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> ) | <sup>5</sup> 0                                                    | E k         |                     | (Lin)←k                                                                         |          |     | 1        | 1          | 1      |
| i                   | LDL A ,@DC                              | 00 11 00 11                                          |                                                                   | 3 3         |                     | (AC)←ROM <sub>L</sub> [(DC)]                                                    | -        |     | 1        | 2          | 1      |
|                     | LDH A ,@DC+                             | 00 11 00 10                                          |                                                                   | 3 2         |                     | (AC)←ROMH[(UC)],(UC)←(UC)+1                                                     | -        |     | 1        | 2          | 4      |
|                     | ST A ,@HL                               | 00 00 11 11                                          |                                                                   | 0 F         |                     | M[(H•L)]←(AC)                                                                   | -        |     | 1        | 1          | 1      |
|                     | ST A ,@HL+                              | 00 01 10 10                                          |                                                                   | 1 A         |                     | $M[(H \cdot L)] \leftarrow (AC), (LR) \leftarrow (LR) + 1$                      | -        |     | <u>c</u> | 1          | ×      |
|                     | ST A ,@HL-                              | 00 01 10 11                                          |                                                                   | 1 B         |                     | $M[(H \cdot L)] \leftarrow (AC), (LR) \leftarrow (LR) - 1$                      | -        |     | B        | 1          | *      |
|                     | ST A, X                                 |                                                      | $x_7x_6x_5x_4x_3x_2x_1x_0$                                        | 3 F         | × H × L             | M[x]←(AC)                                                                       | -        |     | 1        | 2          |        |
| Move                | ST #k,@HL+                              | 11 11 k3k2k1k                                        |                                                                   | Fx          |                     | M[(H•L)] ← k,(LR) ← (LR) + 1                                                    | -        |     | ē        | 1          | /*     |
| }                   | ST #k, y                                |                                                      | k3k2k1k0 y3y2y1 y0                                                | 2 0         | k v                 | M[y]←k                                                                          | -        | -   | 1        | 2          | 1      |
|                     | MOV H, A                                | 00 01 00 00                                          |                                                                   | 10          |                     | (AC)←(HR)<br>(AC)←(LR)                                                          | -        |     | 1        | 1          |        |
| -                   | XCH A, H                                | 00 01 00 01                                          |                                                                   | 3 0         |                     | (HR) ≠ (AC)                                                                     | -        |     |          | _          | 1.     |
| 1                   | XCH A, L                                | 00 11 00 00                                          |                                                                   | 3 1         |                     | (LR) = (AC)                                                                     | -        |     | 1        | 2          | 1      |
| 1                   | XCH A , BIR                             | 00 01 00 11                                          |                                                                   | 13          |                     | (BIR) ≓ (AC)                                                                    | -        |     | 1        | 2          | *      |
| 1                   | XCH A ,@HL                              | 00 01 00 11                                          |                                                                   | 0 D         |                     | M[(H•L)] = (AC)                                                                 | -        |     | 1        | 1          | *      |
|                     | XCH A, X                                |                                                      | x7x6x5x4x3x2x1x0                                                  | 3 D         |                     | M[x] = (AC)                                                                     |          |     | 1        | 2          | 1.*    |
|                     | XCH HL, X                               |                                                      | ×7×6×5×4×3×2×1×0                                                  | 2 9         | xHxT                | M[x']=(LR),M[x'+1]=(HR),x'=x7x6x5x4x3x200                                       | _        |     | 1        | 2          | 1 ^    |
|                     | CMPR A ,@HL                             | 00 01 01 10                                          | ~/*6~5~4~3~2~1~0                                                  | 1 6         | xHxL                | null ← M [(H+L)]-(AC)                                                           | B        |     | 고        | 1          | 1      |
| ì                   | CMPR A , x                              |                                                      | ×7×6×5×4×3×2×1×0                                                  | 3 E         | ×H×L                | nul1←M [x]-(AC)                                                                 | B        |     | 7        | 2          | 1      |
| 9 1                 | CMPR A ,#k                              | 11 01 k3k2k1k                                        |                                                                   | Dk          | -H. L               | null←k -(AC)                                                                    | B        |     | Z        | 1          | 1      |
| Compare             | CMPR H ,#k                              |                                                      | 11 01 k3k2k1k0                                                    | 3.8         | Dκ                  | null←k -(HR)                                                                    | _        |     | B        | 2          |        |
| Co                  | CMPR L ,#k                              |                                                      | 10 01 k3k2k1k0                                                    | 3 8         | 9 k                 | null ← k - (LR)                                                                 | _        |     | Б        | 2          | l      |
| - 1                 | CMPR y ,#k                              |                                                      | k3k2k1k0y3y2y1y0                                                  | 2 B         | kу                  | null←k -M[y]                                                                    | B        |     | z        | 2          | 1      |
|                     | INC A                                   | 00 00 10 00                                          |                                                                   | 0 8         |                     | (AC)←(AC)+1                                                                     | -        |     | ē        | 1          | 1      |
|                     | INC L                                   | 00 01 10 00                                          |                                                                   | 18          |                     | (LR)←(LR)+1                                                                     | -        | 2   | ⋷        | 1          |        |
|                     | INC @HL                                 | 00 00 10 10                                          |                                                                   | 0 A         |                     | M[(H•L)]←M[(H•I,)]+1                                                            | -        | z   | ੋ        | 1          |        |
| İ                   | DEC A                                   | 00 00 10 01                                          |                                                                   | 0 9         |                     | (AC)←(AC)-1                                                                     | -        | Z   | B        | 1          |        |
|                     | DEC L                                   | 00 01 10 01                                          |                                                                   | 19          |                     | (LR)←(LR) - 1                                                                   | -        | Z   | B        | .1         |        |
|                     | DEC @HL                                 | 00 00 10 11                                          |                                                                   | 0 B         |                     | $M[(H \cdot L)] \leftarrow M[(H \cdot L)] - 1$                                  |          | Z   | B        | 1          |        |
| 01.                 | ADDC A ,@HL                             | 00 01 01 01                                          |                                                                   | 1 5         |                     | $(AC) \leftarrow (AC) + M[(H \cdot L)] + (CF)$                                  | С        | Z   | Ē        | 1          |        |
| ae d                | ADD A ,@HL                              | 00 01 01 11                                          |                                                                   | 17          |                     | $(AC) \leftarrow (AC) + M[(H \cdot L)]$                                         | -        |     | c        | 1          |        |
| Arithmetic          | ADD A ,#k                               |                                                      | 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                                                                    | -        |     | C        | 2          |        |
| AF                  | ADD H ,#k                               |                                                      | 11 00 k <sub>3</sub> k <sub>2</sub> k <sub>1</sub> k <sub>0</sub> | 3 8         | C k                 | $(HR) \leftarrow (HH) + k$                                                      | -        |     | č        | 2          |        |
|                     | ADD L ,#k                               |                                                      | 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                                                                 | -        |     | c        | 2          |        |
|                     | ADD @HL,#k                              |                                                      | 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                                                             | -        |     | č        | 2          |        |
| 1                   | ADD y ,#k                               |                                                      | k3 k2 k1 k0 y3 y2 y1 y0                                           | 2 F         | kу                  | M[y] ← M[y] + k                                                                 | -        |     | Ē        | 2          | -      |
| 1                   | 7.0                                     |                                                      |                                                                   | 1 4         |                     | (AC)←M[(H+L)]-(AC)-( <del>CF</del> )                                            | B        |     | В        | 1          |        |
| i                   | SUBR A ,#k                              |                                                      | 00 01 k3k2k1k0                                                    | 3 8         | 1 k                 | (AC) ← k −(AC)                                                                  | -        |     | В        | 2          | 1      |
|                     | 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 \cdot L)] \leftarrow k - M[(H \cdot L)]$ CF - AC - (rotate left by 1 bit) | <br>C    |     | B        | 2          |        |
| !                   | RORC A                                  | 00 00 01 01                                          |                                                                   | 0 7         |                     | (rotate left by 1 bit)                                                          | C        |     | c        | 1          | *<br>* |
| -                   | AND A ,@HL                              | 00 00 01 11                                          |                                                                   | 1 E         |                     | (AC) ←(AC) ∧ M[(H·L)]                                                           | <u> </u> |     | 2        | 1          | 1 *    |
|                     | AND A ,##k                              |                                                      | 00 ll k3k2k1k0                                                    | 3 8         | 3 k                 | (AC)←(AC) / ME(H+D)]                                                            | _        |     | 2 2      | 2          |        |
| e o                 | AND @HL,#k                              |                                                      | 01 11 k3k2k1k0                                                    | 3 9         | 3 K                 | M[(H•L)]←M[(H•L)] / K                                                           | _        |     | 2        | 2          |        |
| 081                 | OR A ,@HL                               | 00 01 11 01                                          | ** "3"Z"1"00                                                      | 1 D         |                     | (AC)←(AC) VM[(H•L)]                                                             |          |     | Z        | î          | 1      |
| 1083                |                                         |                                                      |                                                                   |             |                     | (and) - (and) V ME(II-D) ]                                                      |          | 44  |          | ۸ ۱        | 1      |
| Logical             | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |                                                      | 00 10 kakakak                                                     |             | 2 1                 | (AC)←(AC) V ×                                                                   | _        | 2.  | 71       | 21         | 1      |
| Logi                | 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> | 38          | 2 k<br>6 k          | (AC) ← (AC) V k<br>M[(H•L)] ← M[(H•L)] V k                                      | -        |     | 2        | 2          |        |



#### TMP4740P TMP4720P

## PREIMINARY

#### TECHNICAL DATA

(continued)

| Classi            | Assembler -  |                                                                                                                                    |                               |                  |                |                                                           |                                                                                                                             | D1. | ags   | *1             | on         |            |
|-------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|------------------|----------------|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-----|-------|----------------|------------|------------|
| Class             |              | Віпагу                                                                                                                             |                               | Hexa             | iecıma         | 1                                                         | Function                                                                                                                    | 1   | raago |                | utio       |            |
| fication          | Mnemonic     | 1st Byte 2nd Byt                                                                                                                   | 2nd Byte                      |                  | 2nd<br>By to   |                                                           |                                                                                                                             | CF  | ZF    | SF             | Execution  |            |
|                   | TEST CF      | 00 00 01 10                                                                                                                        |                               | 0 6              |                |                                                           | $(SF) \leftarrow (\overline{CF}), (CF) \leftarrow 0$                                                                        | 0   |       | *              | 1          |            |
|                   | TEST A , b   | 01 01 11 b <sub>1</sub> b <sub>0</sub>                                                                                             |                               | 5 C+             |                |                                                           | (SF) ← (AC) <b></b>                                                                                                         | -   |       | *              | 1          |            |
|                   | TEST @HL, b  | 01 01 10 b <sub>1</sub> b <sub>0</sub>                                                                                             |                               | 5 84             |                |                                                           | $(SF) \leftarrow \overline{M(H \cdot L)} \times b >$                                                                        | -   | _     | *              | 1          |            |
| 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                                                       |                               | 3 9              |                | - 1                                                       | $(SF) \leftarrow \overline{M[y]}\langle b \rangle$                                                                          | -   | -     | *              | 2          |            |
| i i               | 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                                                       | 1 Po                          | 3 F              |                | р                                                         | (SF) ← P[p] <b></b>                                                                                                         | -   | _     | *              | 2          |            |
| L                 | TEST @L      | 00 11 01 11                                                                                                                        |                               | 3 7              |                | _                                                         | (SF) ← P[(LR)<3:2>+4]<(LR)<1:0>>>                                                                                           | -   | _     | *              | 2          |            |
| i i               | TESTP CF     | 00 00 01 00                                                                                                                        |                               | 0 4              |                |                                                           | (SF) ← (CF),(CF) ← 1                                                                                                        | 1   | _     | *              | 1          |            |
|                   | TESTP OF     | 00 00 11 10                                                                                                                        |                               | 0 F              |                |                                                           | (SF) ← (ZF)                                                                                                                 |     | -     | *              | 1          |            |
|                   |              |                                                                                                                                    |                               | 3 9              |                |                                                           | (SF) ← (GF)<br>(SF) ← M[y] <b></b>                                                                                          | -   | _     | *              | 1          |            |
| 1 2               | TESTP y , b  | 00 11 10 01 11 b1b0y3y23                                                                                                           |                               | 3 1              |                | - 1                                                       | (SF) ← M(y)<0><br>(SF) ← P[p] <b></b>                                                                                       | _   | _     | *              | 2          |            |
| 8 L               | SET GF       | 00 11 10 11 11 b <sub>1</sub> b <sub>0</sub> p <sub>3</sub> p <sub>2</sub>                                                         | 1 P0                          | 0 5              |                | μ                                                         | (SF) ← P[p] < 0>                                                                                                            | ΗΞ  | _     | * 1            | 1          |            |
| nd t              | SET @HL. b   | 01 01 00 b <sub>1</sub> b <sub>0</sub>                                                                                             |                               | 5 1              |                | i                                                         | M((H•L)   ⟨b⟩←1                                                                                                             | _   | _     | 1              | 1          |            |
| (an               | 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                                                       |                               | 3 9              |                |                                                           | M[v   <b>← 1</b>                                                                                                            | _   | _     | 1              | 2          |            |
|                   | SET %p , b   | 00 11 10 01 00 b1b0b3b2                                                                                                            |                               | 3 E              |                | - 1                                                       | M(y) (b) ← 1                                                                                                                |     | Ξ     | 1              | 2          | l          |
| er l              | SET @L       | 00 11 01 00                                                                                                                        | 110                           | 3 4              |                | P                                                         | P[(LR)<3:2>+4  <(LR)<1:0>>←1                                                                                                | _   | _     | 1              | 2          |            |
| ļ.,               | CLR GF       | 00 00 00 10                                                                                                                        |                               | 0 2              | -              | -                                                         | (GF) ← 0                                                                                                                    | -   | _     | 1              | 1          |            |
| 1                 | CLR @HL, b   | 01 01 01 b <sub>1</sub> b <sub>0</sub>                                                                                             |                               | 5 4+             |                |                                                           | M[(H•L)] <b>←0</b>                                                                                                          | _   | _     | 1              | 1          |            |
|                   | CLR V , b    | 00 11 10 01 01 b1b0y3y2                                                                                                            | 's Vo                         | 3 9              |                | v                                                         | M[y] <b>←0</b>                                                                                                              | -   | _     | 1              | 2          |            |
|                   | CLR %p , b   | 00 11 10 11 01 b1b0b3b21                                                                                                           |                               | 3 E              |                |                                                           | P[p]<0>←0                                                                                                                   | _   | _     | 1              | 2          |            |
|                   | CLR @L       | 00 11 01 01                                                                                                                        | 1.0                           | 3 8              |                | •                                                         | P[(LR)<3:2>+4]<(LR)<1:0>>→0                                                                                                 | _   | -     | 1              | 2          |            |
| 1 -               | CLR IL , r   | 00 11 01 10 11 r5r4r3r2                                                                                                            | ıro                           | 3 (              | C+ru           | Гг                                                        | (INTL)<5:0>←(INTL)<5:0>\r<5:0>                                                                                              | -   | _     | 1              | 2          |            |
|                   | BICLR IL , r | 00 11 01 10 01 r5r4r3r21                                                                                                           |                               | 3 6              |                |                                                           | (EIF) ←1, (INTL)<5:0> ←(INTL)<5:0> ∧r<5:0>                                                                                  | -   |       | 1              | 2          |            |
| -                 | DICLE IL , r | 00 11 01 10 10 r5r4r3r2                                                                                                            |                               | 3 6              |                | -                                                         | (EIF) ← 0,(INTL)<5:0> ← (INTL)<5:0> ∧r<5:0>                                                                                 | -   | -     | 1              | 2          |            |
|                   | IN %p, A     | 00 11 10 10 00 10 p3p2I                                                                                                            |                               | 3 /              | 2              | p                                                         | (AC) ← P[p]                                                                                                                 | -   | Z     | $\overline{z}$ | 2          |            |
| l ž               | IN %p ,@HL   | 00 11 10 10 01 10 p3p21                                                                                                            | 1P0                           | 3 /              | . 6            | р                                                         | $M[(H \cdot L)] \leftarrow P[p]$                                                                                            | -   | _     | Z              | 2          |            |
| 1 1               | OUT A ,%p    | 00 11 10 10 10 p40 p3p21                                                                                                           | 1P0                           | 3 /              | 8+2p           | 4 P                                                       | $p[p] \leftarrow (AC)$ , $p = p_4 p_3 p_2 p_1 p_0$                                                                          | -   | -     | 1              | 2          |            |
| 1 5 1             | OUT @HL,%p   | 00 11 10 10 11 P40 P3P21                                                                                                           | 1P0                           | 3 /              | 4 C+2p         | 4 p                                                       | $p[p] \leftarrow M[(H \cdot L)],  p = p_4 \cdot p_3 p_2 p_1 p_0$                                                            | -   | -     | 1              | 2          |            |
| nput/Output       | 00T #k ,%p   | 00 10 11 00 k3k2k1k0p3p2F                                                                                                          | 120                           | 2 0              | k              | p                                                         | p[p] ← k                                                                                                                    | -   | -     | 1              | 2          |            |
|                   | OUTB @HL     | 00 01 00 10                                                                                                                        |                               | 1 2              | 3              |                                                           | $P[2] \cdot P[1] \leftarrow ROM[F \cdot (E+(CF)) \cdot M[(H \cdot L)]]$                                                     | -   | -     | 1              | 2          |            |
|                   | BS a         | 01 10 amagagaga7a6a5a4a3a2                                                                                                         | a <sub>1</sub> a <sub>0</sub> | 6 a              | H am           | ı,                                                        | If SF=1 then(PC)←a else null.                                                                                               | -   | -     | 1              | 2          |            |
| ne l              | BSS a        | 10 d5d4d3d2d1d0                                                                                                                    |                               | 8+a <sub>H</sub> | d <sub>L</sub> |                                                           | If SF=1 then(PC) $\leftarrow$ a else null,a=(PC) $\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!$ | L-  | -     | 1              | 1          | <b>*</b> 5 |
| uti               | CALL a       | 00 10 0 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 | 2a1a0                         | 2 8              | H am           | ı,L                                                       | $STACK[(SPW)] \leftarrow (PC), (SPW) \leftarrow (SPW) - 1,$                                                                 | -   | -     | -              | 2          | <b>*</b> 5 |
| 101               |              |                                                                                                                                    |                               |                  |                |                                                           | (PC)←a,0∠a∠2,047                                                                                                            |     |       |                |            |            |
| Sur               | CALLS a      | 01 11 $n_3n_2n_1n_0$                                                                                                               | 7 1                           | 1                |                | $STACK[(SPW)] \leftarrow (PC), (SPW) \leftarrow (SPW)-1,$ | -                                                                                                                           |     | -     | 2              | <b>*</b> 5 |            |
| Branch Subroutine |              |                                                                                                                                    |                               |                  |                | _                                                         | (PC)←a,a=8n+6(n≒0),134(n=·)                                                                                                 |     |       |                |            |            |
| anc               | RET          | 00 10 10 10                                                                                                                        |                               | 2 /              | 1              |                                                           | $(SPW) \leftarrow (SPW) + 1$ , $(PC) \leftarrow STACK[(SPW)]$                                                               | -   | -     | -7             | 2          |            |
| Ä                 | RETI         | 00 10 10 11                                                                                                                        |                               | 2 I              | 3              |                                                           | $(SPW) \leftarrow (SPW) + 1$ , $(FLAG \cdot PC) \leftarrow STACK[(SPW)]$                                                    | *   | *     | *              | 2          |            |
| -                 |              |                                                                                                                                    |                               | _                |                |                                                           | (EIF)←1                                                                                                                     |     | _     |                |            |            |
| OTher             | 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

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 "l" 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", "C", "B", "Z", "Z", "l", or" o" according to the data processing rusult. 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.

The zero flag is set according to the data set in the accumulator.

Note 2. The zero flag is set according to the data set in the accumulator.

Note & The flags(2F,FF)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.

# TECHNICAL DATA

| higher | 0          | 1                               | 2           | 3    | 4              | 5               | 6             | 7          | 8         | 9           | A            | В                     | С     | D                    | R             | F            | 2nd byte<br>code(higher) | 36          | 38             | 39            | 3 A           | 3 B         |
|--------|------------|---------------------------------|-------------|------|----------------|-----------------|---------------|------------|-----------|-------------|--------------|-----------------------|-------|----------------------|---------------|--------------|--------------------------|-------------|----------------|---------------|---------------|-------------|
| 0      | NOP        | TESTP                           | CLR<br>OF   | SET  | TESTP          | ROLC            | TEST          | RORC       | I NC<br>A | DEC<br>A    | 1 NC<br>@HL: |                       |       | XCH<br>A,@HL         | TESTP<br>ZF   | ST<br>A,@HL  | 0                        |             | ADD<br>A, #k   |               |               |             |
| 1      |            | MOV<br>L,A                      | OUTB<br>@HL |      | SUBRC<br>A,@HL | CADDC<br>LA,@HL | CMPR<br>A,@HL |            |           | DEC<br>L    |              | ST<br>A <b>,@</b> HL~ |       | OR<br>A <b>,@</b> HL |               | XOR<br>A,@HL | 1                        |             | SUBR<br>A, #k  |               |               |             |
| 2      |            |                                 |             | CALI | i a            |                 |               |            |           | XCH<br>HL,x |              | RETI                  |       |                      | CMPR<br>y,#k  |              | 2                        |             | OB A, #k       | SET ●<br>y, b | IN<br>%p,A    | SET<br>%p,b |
| 3      | XCH<br>A,H | XCH<br>A,L                      |             |      |                | CLR<br>@L       | (0P36)        | TEST<br>@L | (OP38)    | (OP39)      | (OP3A)       | (OP3B)                |       |                      | CMPR<br>A,x   |              | 3                        |             | AND<br>A, #k   |               |               |             |
| 4      | LD A,#k    |                                 |             |      |                |                 |               |            |           |             |              | 4                     |       | ADD<br>@HL, #k       |               |              |                          |             |                |               |               |             |
| 5      |            | SET @HL, b CLR @HL, b TEST A, b |             |      |                |                 |               |            |           |             |              | 5                     | BICIR | SUBR<br>@HL, #k      | CLR           |              | CLR                      |             |                |               |               |             |
| 6      | BS a       |                                 |             |      |                |                 |               |            |           |             |              |                       | 6     | IL, r                | OR<br>@HL, #k | y, b         | IN<br>%p,@HL             | %p,b        |                |               |               |             |
| 7      |            |                                 |             |      |                |                 |               | CAL        | ₋s a      |             |              |                       |       |                      |               |              | 7                        |             | and<br>@HL, #k |               |               |             |
| 8      |            |                                 |             |      |                |                 |               |            |           |             |              |                       |       |                      |               |              | 8                        |             | ADD<br>L, #k   |               | OUT<br>A,%p   |             |
| S      |            |                                 |             |      |                |                 |               | BSS        | a         |             |              |                       |       |                      |               | - {          | 9                        | DICIR       | CMPR<br>L, #k  | TEST          |               | TEST        |
| A      |            |                                 |             |      |                |                 |               |            |           |             |              |                       |       |                      |               | }            | A                        | IL, r       |                | y, b          | ОUТ<br>А,%р   | %p,b        |
| В      |            |                                 |             |      |                |                 |               |            |           |             |              |                       |       |                      |               |              | В                        |             |                |               |               |             |
| с      |            |                                 |             |      |                |                 |               | LD         | 1         | , #k        |              |                       |       |                      |               |              | С                        |             | ADD<br>H, #k   |               | оит<br>@нь,%р |             |
| D      |            |                                 |             |      |                |                 |               | CMPI       |           | , #k        |              |                       |       |                      |               |              | D                        | CLR<br>1L,r | CMPR<br>H, #k  | TESTP<br>y, b |               | TESTP       |
| E      |            |                                 |             |      |                |                 |               | LD         | I         | , #k        |              |                       |       |                      |               | į            | E                        | 12,1        |                |               | OUT<br>@HL,%p |             |

#k , @HL+

(continued)

1st byte code

0P36

0P38

0P39

OPSA

OPSB

#### (caution)

Operation Code Map

- Blank codes are reserved.
- 2. \_\_\_\_\_ is indicated 2-byte instruction.