

**TOSHIBA**

USERS MANUAL

# 16-BIT MICROCONTROLLER TLCS-900 SERIES (1)

TMP96C141      TMP96C141A

TMP96CM40      TMP96C041A

TMP96PM40

**1994**



Western Micro Technology, Inc.  
12900 Saratoga Avenue  
Saratoga, CA 95070  
Phone (408) 725-1660  
Fax (408) 225-6491





The information contained herein is subject to change without notice.

The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA for any infringements of patents or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of TOSHIBA or others.

The products described in this document contain strategic products subject to COCOM regulations. They should not be exported without authorization from the appropriate governmental authorities.

These TOSHIBA products are intended for usage in general electronic equipments (office equipment, communication equipment, measuring equipment, domestic electrification, etc. ) . Please make sure that you consult with us before you use these TOSHIBA products in equipments which require high quality and/or reliability, and in equipments which could have major impact to the welfare of human life (atomic energy control, airplane, spaceship, traffic signal, combustion control, all types of safety devices, etc. ) . TOSHIBA cannot accept liability to any damage which may occur in case these TOSHIBA products were used in the mentioned equipments without prior consultation with TOSHIBA.

**PREFACE**

Thank you very much for making use of Toshiba microcomputer LSIs and development systems.

Toshiba has a broad range of microcomputer LSIs which are applicable to various fields ranging from consumer to industrial. This document describes the 16-bit microcontroller TLCS-900 series with regard to system architecture, electrical characteristics and package dimensions.

The TLCS-900 series is the original Toshiba microcontroller which has features in multifunction I/Os and large-capacity program and data areas.

The current market tends to be compact, and demands the systems be simple and reasonably priced. Additionally, one-chip I/O peripherals and high-performance microcontrollers are demanded. The TLCS-900 series has been developed to satisfy all these needs clearly.

Because Toshiba constantly modifies systems to meet specific requests, updated 16-bit microcontroller families will always be available.



## TABLE OF CONTENTS

## CHAPTER1 TLCS-900/900L CPU

## 900,900L CPU Core Different Points

|                                                                   |          |     |
|-------------------------------------------------------------------|----------|-----|
| 1. OUTLINE .....                                                  | 900CPU - | 2   |
| 2. CPU OPERATING MODES .....                                      | 900CPU - | 3   |
| 3. REGISTERS .....                                                | 900CPU - | 5   |
| 3.1 Register Structure .....                                      | 900CPU - | 5   |
| 3.2 Register Details .....                                        | 900CPU - | 8   |
| 3.2.1 General-purpose bank registers .....                        | 900CPU - | 8   |
| 3.2.2 32bit General-purpose registers .....                       | 900CPU - | 9   |
| 3.2.3 Status Register (SR) .....                                  | 900CPU - | 10  |
| 3.2.4 Program Counter (PC) .....                                  | 900CPU - | 13  |
| 3.2.5 Control Registers (CR) .....                                | 900CPU - | 14  |
| 3.3 Register Bank Switching .....                                 | 900CPU - | 15  |
| 3.4 Accessing General-purpose Registers .....                     | 900CPU - | 17  |
| 4. ADDRESSING MODES .....                                         | 900CPU - | 19  |
| 5. INSTRUCTIONS .....                                             | 900CPU - | 29  |
| 6. DATA FORMATS .....                                             | 900CPU - | 39  |
| 7. BASIC TIMINGS .....                                            | 900CPU - | 39  |
| Appendix A. Details of Instructions .....                         | 900CPU - | 47  |
| Appendix B. Instruction Lists .....                               | 900CPU - | 167 |
| Appendix C. Instruction Code Maps .....                           | 900CPU - | 178 |
| Appendix D. Differences between TLCS-90 and TLCS-900 Series ..... | 900CPU - | 182 |

## CHAPTER2 TLCS-900 LSI DEVICES

## TMP96C141F

|                                             |          |   |
|---------------------------------------------|----------|---|
| 1. OUTLINE AND DEVICE CHARACTERISTICS ..... | MCU900 - | 1 |
| 2. PIN ASSIGNMENT AND FUNCTIONS .....       | MCU900 - | 3 |
| 2.1 Pin Assignment .....                    | MCU900 - | 3 |
| 2.2 Pin Names and Functions .....           | MCU900 - | 4 |
| 3. OPERATION .....                          | MCU900 - | 7 |
| 3.1 CPU .....                               | MCU900 - | 7 |

---

|                                                           |          |     |
|-----------------------------------------------------------|----------|-----|
| 3.2 Memory Map .....                                      | MCU900 - | 8   |
| 3.3 Interrupts .....                                      | MCU900 - | 9   |
| 3.4 Stanby Function .....                                 | MCU900 - | 23  |
| 3.5 Functions of Ports .....                              | MCU900 - | 25  |
| 3.6 Chip Select/Wait Control .....                        | MCU900 - | 53  |
| 3.7 8-bit Timers .....                                    | MCU900 - | 59  |
| 3.8 8-bit PWM Timer .....                                 | MCU900 - | 76  |
| 3.9 16-bit Timers .....                                   | MCU900 - | 91  |
| 3.10 Stepping Moter Control/Pattern Generation Port ..... | MCU900 - | 112 |
| 3.11 Serial Channel .....                                 | MCU900 - | 125 |
| 3.12 Analog/Digital Converter .....                       | MCU900 - | 150 |
| 3.13 Watchdog Timer (Runaway Detecting Timer) .....       | MCU900 - | 156 |
| 4. ELECTRICAL CHARACTERISTICS .....                       | MCU900 - | 162 |
| 4.1 Absolute Maximum .....                                | MCU900 - | 162 |
| 4.2 DC Characteristics .....                              | MCU900 - | 162 |
| 4.3 AC Electrical Characteristics .....                   | MCU900 - | 163 |
| 4.4 A/D Conversion Characteristics .....                  | MCU900 - | 166 |
| 4.5 Serial Channel Timing-I/O Interface Mode .....        | MCU900 - | 166 |
| 4.6 Timer/Counter Input Clock .....                       | MCU900 - | 166 |
| 4.7 Interrupt Operation .....                             | MCU900 - | 166 |
| 4.8 Timing Chart for I/O Interface Mode .....             | MCU900 - | 167 |
| 4.9 Timing Chart for Bus Request/Bus Acknowledge .....    | MCU900 - | 168 |
| 4.10 Typical Characteristics .....                        | MCU900 - | 169 |
| 5. TABLE OF SPECIAL FUNCTION REGISTERS .....              | MCU900 - | 170 |
| 6. PORT SECTION EQUIVALENT CIRCUIT DIAGRAM .....          | MCU900 - | 184 |
| 7. Core Points and Restriction .....                      | MCU900 - | 189 |

**TMP96C141AF**

|                                             |          |     |
|---------------------------------------------|----------|-----|
| 1. OUTLINE AND DEVICE CHARACTERISTICS ..... | MCU900 - | 191 |
| 2. PIN ASSIGNMENT AND FUNCTIONS .....       | MCU900 - | 193 |
| 3. OPERATION .....                          | MCU900 - | 197 |
| 3.1 CPU .....                               | MCU900 - | 197 |
| 3.2 Memory Map .....                        | MCU900 - | 197 |
| 4. ELECTRICAL CHARACTERISTICS .....         | MCU900 - | 201 |
| 4.1 Absolute Maximum .....                  | MCU900 - | 201 |

---

|                                                           |              |
|-----------------------------------------------------------|--------------|
| 4.2 DC Characteristics .....                              | MCU900 - 201 |
| 4.3 AC Electrical Characteristics .....                   | MCU900 - 202 |
| 4.4 A/D Conversion Characteristics .....                  | MCU900 - 205 |
| 4.5 Serial Channel Timing -I/O Interface Mode .....       | MCU900 - 205 |
| 4.6 Timer/Counter Input Clock .....                       | MCU900 - 205 |
| 4.7 Interrupt Operation .....                             | MCU900 - 205 |
| 4.8 Timing Chart for I/O Interface Mode .....             | MCU900 - 206 |
| 4.9 Timing Chart Bus Request/Bus Acknowledge .....        | MCU900 - 207 |
| 5. TMP96C141/TMP96C141A/TMP96C041A Different points ..... | MCU900 - 208 |

**TMP96C041AF**

|                                                               |              |
|---------------------------------------------------------------|--------------|
| 1. OUTLINE AND DEVICE CHARACTERISTICS .....                   | MCU900 - 209 |
| 2. PIN ASSIGNMENT AND FUNCTIONS .....                         | MCU900 - 209 |
| 2.1 Pin Assignment .....                                      | MCU900 - 211 |
| 2.2 Pin Names and Functions .....                             | MCU900 - 212 |
| 3. OPERATION .....                                            | MCU900 - 215 |
| 3.1 CPU .....                                                 | MCU900 - 215 |
| 3.2 Memory Map .....                                          | MCU900 - 215 |
| 3.3 Bus Release Function .....                                | MCU900 - 218 |
| 4. ELECTRICAL CHARACTERISTICS .....                           | MCU900 - 220 |
| 4.1 Absolute Maximum (TMP96C041AF) .....                      | MCU900 - 220 |
| 4.2 DC Characteristics (TMP96C041AF) .....                    | MCU900 - 220 |
| 4.3 AC Electrical Characteristics (TMP96C041AF) .....         | MCU900 - 221 |
| 4.4 A/D Conversion Characteristics (TMP96C041AF) .....        | MCU900 - 224 |
| 4.5 Serial Channel Timing-I/O Interface Mode .....            | MCU900 - 224 |
| 4.6 Timer/Counter Input Clock (T10, T14, T15, T16, T17) ..... | MCU900 - 224 |
| 4.7 Interrupt Operation .....                                 | MCU900 - 224 |
| 4.8 Timing Chart for I/O interface Mode .....                 | MCU900 - 225 |
| 4.9 Timing Chart for Bus Request/Bus Acknowledge .....        | MCU900 - 226 |
| 5. TMP96C141/TMP96C141A/TMP96C041A Different point .....      | MCU900 - 227 |

**TMP96CM40F**

|                                             |              |
|---------------------------------------------|--------------|
| 1. OUTLINE AND DEVICE CHARACTERISTICS ..... | MCU900 - 229 |
| 2. PIN ASSIGNMENT AND FUNCTIONS .....       | MCU900 - 231 |
| 2.1 Pin Assignment .....                    | MCU900 - 231 |

---

|                                                               |              |
|---------------------------------------------------------------|--------------|
| 2.2 Pin Names and Functions .....                             | MCU900 - 232 |
| 3. OPERATION .....                                            | MCU900 - 235 |
| 3.1 CPU .....                                                 | MCU900 - 235 |
| 3.2 Memory Map .....                                          | MCU900 - 235 |
| 4. ELECTRICAL CHARACTERISTICS .....                           | MCU900 - 237 |
| 4.1 Absolute Maximum .....                                    | MCU900 - 237 |
| 4.2 DC Characteristics .....                                  | MCU900 - 237 |
| 4.3 AC Electrical Characteristics .....                       | MCU900 - 238 |
| 4.4 A/D Conversion Characteristics .....                      | MCU900 - 241 |
| 4.5 Serial Channel Timing-I/O Interface Mode .....            | MCU900 - 241 |
| 4.6 Timer/Counter Input Clock (TI0, TI4, TI5, TI6, TI7) ..... | MCU900 - 241 |
| 4.7 Interrupt Operation .....                                 | MCU900 - 241 |
| 4.8 Timing Chart for I/O Interface Mode .....                 | MCU900 - 242 |
| 4.9 Timing Chart for Bus Request/Bus Acknowledge .....        | MCU900 - 243 |
| 4.10 Typical Characteristics .....                            | MCU900 - 244 |
| 5. TMP96C141/TMP96CM40/TMP96PM40 Different points .....       | MCU900 - 245 |

**TMP96PM40**

|                                                               |              |
|---------------------------------------------------------------|--------------|
| 1. OUTLINE AND DEVICE CHARACTERISTICS .....                   | MCU900 - 247 |
| 2. PIN ASSIGNMENT AND FUNCTIONS .....                         | MCU900 - 249 |
| 2.1 Pin Assignment .....                                      | MCU900 - 249 |
| 2.2 Pin Names and Functions .....                             | MCU900 - 250 |
| 3. OPERATION .....                                            | MCU900 - 254 |
| 3.1 MCU mode .....                                            | MCU900 - 256 |
| 3.2 PROM mode .....                                           | MCU900 - 256 |
| 4. ELECTRICAL CHARACTERISTICS .....                           | MCU900 - 260 |
| 4.1 Absolute Maximum .....                                    | MCU900 - 260 |
| 4.2 DC Characteristics .....                                  | MCU900 - 260 |
| 4.3 AC Electrical Characteristics .....                       | MCU900 - 261 |
| 4.4 A/D Conversion Characteristics .....                      | MCU900 - 264 |
| 4.5 Serial Channel Timing-I/O Interface Mode .....            | MCU900 - 264 |
| 4.6 Timer/Counter Input Clock (TI0, TI4, TI5, TI6, TI7) ..... | MCU900 - 264 |
| 4.7 Interrupt Operation .....                                 | MCU900 - 264 |
| 4.8 Timing Chart for I/O Interface Mode .....                 | MCU900 - 265 |
| 4.9 Timing Chart for Bus Request/Bus Acknowledge .....        | MCU900 - 266 |

---

|                                                           |              |
|-----------------------------------------------------------|--------------|
| 4.10 Read Operation (PROM Mode) .....                     | MCU900 - 267 |
| 4.11 Programming Operation (PROM Mode) .....              | MCU900 - 267 |
| 4.12 Read Operation Timing Chart (PROM Mode) .....        | MCU900 - 268 |
| 4.13 Programming Operation Timing Chart (PROM Mode) ..... | MCU900 - 269 |
| 4.14 Typical Characteristics .....                        | MCU900 - 270 |
| 5. TMP96C141/TMP96CM40/TMP96PM40 Different points .....   | MCU900 - 271 |
| <br>CHAPTER3 TLCS-900 APPLICATION CIRCUIT .....           | APL900 - 1   |
| <br>CHAPTER4 PACKAGE .....                                | PKG900 - 1   |



## **TLCS-900 SERIES(1)**

**CHAPTER1 TLCS-900,900/L CPU**



**CHAPTER2 TLCS-900 LSI DEVICES**

**TMP96C141**



**TMP96C141A**



**TMP96C041A**



**TMP96CM40**



**TMP96PM40**



**CHAPTER3 TLCS-900 APPLICATION CIRCUIT**



**CHAPTER4 TLCS-900 PACKAGE**





**TOSHIBA**

CHAPTER 1    TLCS-900, 900/L   CPU

TOSHIBA CORPORATION



## 900, 900/L CPU Core Different Points

There are 2 type CPU core : ① 900\_CPU, ② 900/L\_CPU in TLCS-900 series and they are different from following points. But a data book of both CPU core is common and they are explained in this chapter.

In this chapter, only the different points are shown by  .

| CPU<br>Different Point            | ① 900 CPU                                                                                          | ② 900/L CPU                                                                                        |
|-----------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|
| CPU Operating mode                | System/Normal mode                                                                                 | System mode                                                                                        |
| CPU Register mode                 | After reset, the mode is set to MIN (minimum) mode.<br>The MAX mode is set by a 'MAX' instruction. | After reset, the mode is set to MAX (maximum) mode.<br>The MIN mode is set by a 'MIN' instruction. |
| Interrupt vector formula          | Restart formula                                                                                    | Vector formula                                                                                     |
| Normal Stack Pointer XNSP         | exist                                                                                              | not exist                                                                                          |
| Interrupt Nesting Counter INTNEST | not exist                                                                                          | exist                                                                                              |
| Operating Voltage                 | 5V ± 10%                                                                                           | 2.7~5.5V                                                                                           |

Figure 1 900, 900/L CPU Different Points

## 1. OUTLINE

The TLCS-900 series has an original Toshiba high-performance 16-bit CPU. Combining the CPU with various I/O function blocks (such as timers, serial I/Os, ADs) creates broad possibilities in application fields.

The TLCS-900 CPU, being 16-bit CPU, has a 32-bit/16-bit register bank configuration, therefore it is suitable as an embedded controller.

The TLCS-900 CPU features are as follows:

(1)TLCS-90 extended architecture

- Upward compatibility on mnemonic and register set levels

(2)General-purpose registers

- All 8 registers usable as accumulator

(3)Register bank system

- Minimum mode : eight 16-bit register banks
- Maximum mode : four 32-bit register banks

(4)16M-byte linear address space ; 9 types addressing modes

(5)Dynamic bus sizing system

- Can consist 8- / 16-bit external data bus together

(6)High reliability

- Supporting system mode and normal mode (900\_CPU)
- Supporting only system mode (900/L\_CPU)

(7)Orthogonal instruction sets

- 8-/16-/32-bit data transfer/arithmetic instructions
- 16-bit multiplication/division  
 $16 \times 16$  to 32-bits (signed/unsigned =  $3.25\mu s$  @16MHz)  
 $32 \div 16$  to 16 bits (unsigned =  $3.75\mu s$ , signed =  $4.0 @16MHz$ )
- Bit processing including bit arithmetic
- Supporting instruction for C compiler
- Filter calculations : multiplication-addition arithmetic, modulo increment instruction

(8)High-speed processing

- Minimum instruction execution time: 200ns @20MHz
- Pipeline system with 4-byte instruction queue buffer
- 16-bit ALU

## 2. CPU OPERATING MODES

### (1) The case of 900\_CPU

The 900\_CPU has two types of operating modes : system and normal. These modes are switched by instructions or interrupts. In system mode, there are no restrictions on using instructions or registers.

The CPU resources effective in system mode are as follows :

- 1) General-purpose registers
  - Four 16-bit general-purpose registers × 8 banks (minimum mode)  
or  
Four 32-bit general-purpose registers × 4 banks (maximum mode)
  - Four 32-bit general-purpose registers (including system stack pointer : XSP)
- 2) Status register (SR) : including system mode flag
- 3) Program counter (PC): 32 bits for maximum mode, 16 bits for minimum mode
- 4) Control register: parameter register for high-speed micro DMA, etc.
- 5) Normal stack pointer: accessible as control register (XNSP)
- 6) All CPU instructions
- 7) All built-in I/O registers
- 8) All built-in memories

In normal mode, the ineffective CPU resources are as follows :

- 1) Privileged instructions (PUSH SR, POP SR, EI, DI, RETI, HALT, LDC, etc.)
- 2) Controlling status register (SR) flags
  - <SYSM>, <IFF0~2>, <MAX>
- 3) Control register (CR) : parameter registers for high-speed micro DMA, etc.
- 4) Built-in I/O registers (depending on products)

| Product name                                                       | Built-in I/O registers which cannot be accessed in normal mode        |
|--------------------------------------------------------------------|-----------------------------------------------------------------------|
| 96C141, 96C141A<br>96C041A<br>96CM40, 96PM40<br>*96C031<br>*96C081 | Chip select/wait controller<br>(BnCS registers)<br>n : channel number |

Note : \* Under development

5) Built-in memories (depending on products)

| Product name                                                       | Memories which cannot be accessed in normal mode                                                                                                        |
|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 96C141, 96C141A<br>96C041A<br>96CM40, 96PM40<br>*96C031<br>*96C081 | Memory blocks whose built-in chip select/wait controller's B <sub>n</sub> SYS bits are set to 1 (memory space set to system mode)<br>n : channel number |

Note : \* Under development

The stack pointers (SP) are provided in both system mode and normal mode, named SYSTEM STACK POINTER and NORMAL STACK POINTER. These pointers are automatically switched when the CPU mode is changed by the NORMAL instruction or an interrupt. In system mode, the normal stack pointer (XNSP) is handled as a control register, and can be accessed by the LDC instruction.

The CPU enters system mode by system reset, as well as by interrupt. The CPU changes from system to normal mode by the NORMAL instruction. The NORMAL instruction resets the <SYSM> bit of the status register (SR) to "0", and sets the CPU to normal mode. Figure (1)-1 shows the mode transition figure.

This makes it possible for an OS-less system to configure software by using system mode only.



Figure (1)-1 The Mode Transition Figure

(2) The case of 900/L\_CPU

The 900/L CPU has only system mode.

Therefore, it does not have the restriction like the 900\_CPU.

### 3. REGISTERS

#### 3.1 Register Structure

Figure 3.1 (1) and (2) illustrate the format of registers. The TLCS-900 series has two register modes.

- ① Minimum mode……64K-byte program area/16M-byte data area

Four 16-bit general-purpose registers × 8 banks  
+

Four 32-bit general-purpose registers  
+  
16-bit program counter

- ② Maximum mode……16M-byte program area/16M-byte data area

Four 32-bit general-purpose registers × 4 banks  
+

Four 32-bit general-purpose registers  
+  
32-bit program counter



#### Register mode changing

##### (1) The case of 900\_CPU

The <MAX> bit in status register (SR) is initialized to “0” and set to Minimum mode by resetting.

The “MAX” instruction changes to Maximum mode. The 900\_CPU does not have a “MIN” instruction.

##### (2) The case of 900/L\_CPU

The <MAX> bit in status register (SR) is initialized to “1” and set to Maximum mode by resetting. The “MIN” instruction changes to Minimum mode. The 900/L\_CPU does not have a “MAX” instruction.

#### Stack Pointer

##### (1) The case of 900\_CPU

The stack pointer (SP) is provided for each operating mode (System and Normal mode). The system stack pointer (XSP) is set to 100H by resetting.

But the Normal stack pointer (XNSP) is not changed by resetting.

## (2) The case of 900/L\_CPU

The stack pointer (SP) is provided for only System mode (XSP). The System stack pointer (XSP) is set to 100H by resetting.



Figure 3.1 (1) Register Format (minimum mode: 64K-byte program area)

Note : The data memory area is 16M-byte.

The whole 16M-byte area can be accessed by using the registers (XIX, XIY, XIZ, XSP) or absolute addressing mode.



Figure 3.1 (2) Register Format (maximum mode: 16M-byte program area)

To change from maximum to minimum mode or from minimum to maximum mode or from minimum to maximum mode, there is no dedicated instruction; instead, the RETI or POP SR instruction changes the <MAX> bit of the status register.

When the mode changes from minimum to maximum, the 16-bit general-purpose registers (WA, BC, DE, and HL) are extended to 32-bit general-purpose registers (XWA, XBC, XDE, and XHL). The value of the upper 16 bits (that is, bit 16 to bit 31) are undefined. Those registers need to be initialized before use. Changing the mode from minimum to maximum also extends the program counter to 32 bits which automatically writes "0" to the upper 16 bits.

So doing ensures program continuity.

### 3.2 Register Details

#### 3.2.1 General-purpose bank registers

As explained in the previous section, the TLCS-900 series has two register formats. Which of the register formats is used depends on whether the mode is minimum or maximum. In either way, the register sets and registers in each bank are used exactly the same.

##### (1) General-purpose Bank Registers in Minimum Mode

In minimum mode, the following four 16-bit general-purpose registers consisting of 8 banks can be used. The register format in a bank is shown below.

Four 16-bit registers (WA, BC, DE, and HL) are general-purpose registers and can be used as accumulators, index registers, and displacement registers. They can also be used as 8-bit registers (W, A, B, C, D, E, H, and L) to function for example as accumulators.



##### (2) General-purpose Bank Registers in Maximum Mode

In maximum mode, the following four 32-bit general-purpose registers consisting of 4 banks can be used. The register format in a bank is shown below.

Four 32-bit registers (XWA, XBC, XDE, and XHL) are general-purpose registers and can be used as accumulators and index registers. They can also be used as 16-bit registers (WA, XHL BC, DE, and HL), in which case, the lower 16 bits of the 32-bit registers are assigned.



Note: Round brackets ( ) signify 16-bit registers.

16-bit registers can be used as accumulators, index registers in index addressing mode, and displacement registers. They can also be used as two 8-bit general-purpose registers (W, A, B, C, D, E, H, and L) to function for example as accumulators.

### 3.2.2 32-bit General-purpose Registers

The TLCS-900 series has four 32-bit general-purpose registers (XIX, XIY, XIZ, and XSP). They are fixed, independent of maximum or minimum mode. The register format is shown below.

These registers can also be used as accumulators, index registers, and displacement registers. They can be used either as 16-bit, or 8-bit registers. Names when registers are used as 8-bit registers are listed later.



#### Stack Pointer

##### (1) The case of 900\_CPU

The XSP register is utilized for stack pointers. This register is provided for both SYSTEM and NORMAL mode. Stack pointer for SYSTEM mode is called SYSTEM STACK POINTER, and for NORMAL mode is called NORMAL STACK POINTER. NORMAL and SYSTEM stack pointer are independent and switched automatically by change of the CPU operating mode. In both modes, they are referred to as XSP. The system stack pointer (XSP) is not able to be accessed from normal mode. The normal stack pointer (XSP) is able to be accessed from system mode as one of control registers (CR). In this case, it is referred to as XNSP. The XNSP can be accessed using the (privileged) LDC instruction.

When an interrupt occurs in the normal mode, the CPU enters system mode. At the same time, the normal stack pointer changes automatically to the system stack pointer (XSP). Then the previous normal stack pointer can be changed as a control register. After return using the RETI instruction, the mode and the stack pointers become normal.

After reset, the system stack pointer is initialized to 100H; the normal stack pointer remains undefined. Thus, when changing to normal mode it is necessary to initialize XSP.

##### (2) The case of 900/L\_CPU

The XSP register is utilized for stack pointer. It is used when the interrupt is occurred or "CALL", "RET" instruction are executed.

### 3.2.3 Status Register (SR)

The status register contains flags indicating the status (operating mode, register format, etc.) of the CPU and operation results. This register consists of two parts. The upper byte of the status register (bits 8 to 15) indicates the CPU status. The lower byte (bits 0 to 7) are referred to as the flag register (F). This indicates the status of the operation result. The TLCS-900 series has two flag registers (F and F'). They can be switched using the EX instruction.

#### (1) Upper Byte of Status Register

| 15   | 14   | 13   | 12   | 11  | 10   | 9    | 8    |
|------|------|------|------|-----|------|------|------|
| SYSM | IFF2 | IFF1 | IFF0 | MAX | RFP2 | RFP1 | RFP0 |

##### ① SYSM (SYStem Mode)

- The case of 900\_CPU

Indicates the CPU operating mode, system or normal. In system mode, all instructions can be executed. In normal mode, privileged instructions cannot be executed. (If forced, a privilege violation interrupt will occur.)

Initialized to 1 (system mode) by reset. To change to normal mode, use the "NORMAL" instruction. An interrupt automatically causes the mode to change from normal to system.

|   |             |
|---|-------------|
| 0 | Normal mode |
| 1 | System mode |

- The case of 900/L\_CPU

"1" is always set, because 900/L\_CPU has only system mode.

② IFF2 ~ IFF0 (Interrupt mask Flip-Flop2 ~ 0)

Mask registers with interrupt levels from 1 to 7. Level 7 has the highest priority.

Initialized to 111 by reset.



|     |                                                                |
|-----|----------------------------------------------------------------|
| 000 | Enables interrupts with level 1 or higher.                     |
| 001 | Enables interrupts with level 1 or higher.                     |
| 010 | Enables interrupts with level 2 or higher.                     |
| 011 | Enables interrupts with level 3 or higher.                     |
| 100 | Enables interrupts with level 4 or higher.                     |
| 101 | Enables interrupts with level 5 or higher.                     |
| 110 | Enables interrupts with level 6 or higher.                     |
| 111 | Enables interrupts with level 7 only (non-maskable interrupt). |

Any value can be set using the EI instruction.

When an interrupt is received, the mask register sets a value higher by 1 than the interrupt level received. When an interrupt with level 7 is received, 111 is set. Unlike with the TLCS-90 series, the EI instruction becomes effective immediately after execution.

③ MAX(MINimum/MAXimum)

Bit used to specify the register mode which determines the sizes of the register banks and the program counter.

|   |              |
|---|--------------|
| 0 | Minimum mode |
| 1 | Maximum mode |

If the program size exceeds 64K bytes, use the "MAX" instruction to set this register to "1" so that register mode becomes maximum mode.

Initialized to "0" (minimum mode) for 900\_CPU by reset.

Initialized to "1" (maximum mode) for 900/L\_CPU by reset.

④ RFP2~RFP0 (Register File Pointer2~0)

Indicates the number of register file (register bank) currently being used.  
Initialized to 000 by reset.

The values in these registers can be operated on using the following three instructions. RFP2 is fixed to 0 in maximum mode. It remains 0 even if an attempt to change it to 1 using following instructions.

- LDF imm ; RFP $\leftarrow$ imm (0~7) (200ns @20MHz)
- INCF ; RFP $\leftarrow$ RFP + 1 (200ns @20MHz)
- DECF ; RFP $\leftarrow$ RFP - 1 (200ns @20MHz)

(2) Flag Register, F

| 7 | 6 | 5   | 4 | 3   | 2 | 1 | 0 | : R/W |
|---|---|-----|---|-----|---|---|---|-------|
| S | Z | "0" | H | "0" | V | N | C |       |

① S (Sign flag)

“1” is set when the operation result is negative, “0” when positive.

(The value of the most significant bit of the operation result is copied.)

② Z (Zero flag)

“1” is set when the operation result is zero, otherwise “0”.

③ H (Half carry flag)

“1” is set when a carry or borrow from bit 3 to bit 4 occurs as a result of the operation, otherwise “0”. With a 32-bit operation instruction, an undefined value is set.

④ V (Parity/over-flow flag)

Indicates either parity or overflow, depending on the operation type.

Parity (P): “0” is set when the number of bits set to 1 is odd, “1” when even.

An undefined value is set with a 32-bit operation instruction.

Overflow (V): “0” is set if no overflow, if overflow “1”.

⑤ N (Negative)

ADD/SUB flag

“0” is set after an addition instruction such as ADD is executed, “1” after a subtraction instruction such as SUB.

Used when executing the DAA (decimal addition adjust accumulator) instruction.

⑥ C (Carry flag)

“1” is set when a carry or borrow occurs, otherwise “0”.

### Read and write process of status register

|                                 | 900_CPU                                                                                                 | 900/L_CPU                                                        |
|---------------------------------|---------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|
| Read from bits 0 ~ 15           | ① PUSH SR (Privileged instruction)<br>② POP src                                                         | ① PUSH SR<br>② POP src                                           |
| Write to bits 0 ~ 15            | ① POP SR (Privileged instruction)                                                                       | ① POP SR                                                         |
| Only bit 15<br><SYSM>           | ① NORMAL (Privileged instruction)<br>"0" is written.<br>② Interrupt<br>"1" is written.                  | "1" is always set, because<br>900/L_CPU has only system<br>mode. |
| Only bits 14 ~ 12<br><IFF2 : 0> | ① EI num (Privileged instruction)<br>A value of "num" is written.                                       | ① EI num<br>A value of "num" is written.                         |
| Only bit 11<br><MAX>            | ① MAX (Privileged instruction)<br>"1" is written.                                                       | ① MIN<br>"0" is written.                                         |
| Only bits 10 ~ 8<br><RFP2 : 0>  | ① LDF imm<br>② INCF<br>③ DECF                                                                           |                                                                  |
| Only bits 7 ~ 0                 | ① PUSH F/POP F<br>② EX F, F'<br>③ A flag is set indirectly by executing arithmetic instructions<br>etc. |                                                                  |

#### 3.2.4 Program Counter (PC)

The program counter is a pointer indicating the memory address to be executed next. The program counter bit length depends on whether the register format is in minimum or maximum mode.

In minimum mode, the program counter consists of 16 bits, and a maximum program area of 64K bytes (from addresses 000000H to 00FFFFH) can be accessed.

In maximum mode, the program counter consists of 32 bits. The size of the program area depends on the number of the address pins that the product has. With 24 address pins (A0 to A23), a maximum program area of 16M bytes can be accessed as a linear address space. In this case, the upper 8 bits of the program counter (bits 24 to 31) are ignored.

When the register format changes from minimum to maximum mode, the upper word of the program counter (bits 16 to 31) is extended so that the program counter becomes 32 bits long. This automatically writes "0" to the upper word of the program counter. So doing ensures program continuity.

**PC after reset**

- The case of 900\_CPU

The program counter is initialized to 8000H by reset. Then, the 900 CPU reads program after 8000H and executed.

- The case of 900/L\_CPU

The 900/L\_CPU reads a value of a reset vector from a vector base address by reset and sets the value into a program counter. Then, program after the vector specified by the program counter are executed.

The vector base address is depending on products. They are given below.

| Product        | Vector Base Address | PC setting after reset                                                                                               |
|----------------|---------------------|----------------------------------------------------------------------------------------------------------------------|
| 93CM40, 93CM41 | 8000H               | PC (7 : 0) ← value of 8000H address<br>PC (15 : 8) ← value of 8001H address<br>PC (23 : 16) ← value of 8002H address |

※ With the TMP93CM40 and TMP93CM41, set PC (23:16) to "00H" and locate a reset vector into 64KB area.

### 3.2.5 Control registers (CR)

The control registers consist of registers used to control high-speed  $\mu$ DMA operation, a TLCS-900 series feature, and a normal stack pointer, which exists only in 900\_CPU (not in 900/L\_CPU) and can be accessed in system mode and an interrupt nesting counter, which exists only in 900/L\_CPU (not in 900\_CPU). Control registers can be accessed by using the LDC instruction (privileged instruction for 900\_CPU), which can only be used in system mode.

Control registers are illustrated below.



For high-speed  $\mu$ DMA, refer to "Part 2 TLCS-900 LSI Devices".

### 3.3 Register Bank Switching

Register banks are classified into the following three types.

- Current bank registers
- Previous bank registers
- Absolute bank registers

The current bank is indicated by the register file pointer, <RFP>, (status register bits 8 to 10). The registers in the current bank are used as general-purpose registers, as described in the previous section. By changing the contents of the <RFP>, another register bank becomes the current register bank.

The previous bank is indicated by the value obtained by subtracting 1 from the <RFP>. For example, if the current bank is bank 3, bank 2 is the previous bank. The names of registers in the previous bank are indicated with a dash (WA', BC', DE', HL'). The EX instruction (EX A,A') is used to switch between current and previous banks.

All bank registers, including the current and previous ones, have a numerical value (absolute bank number) to indicate the bank. With a register name which includes a numerical value such as RW0, RA0, etc., all bank registers can be used. These registers (that is, all registers) are called absolute bank registers.

The TLCS-900 series CPU is designed to perform optimally when the current bank registers are operated as the working registers. In other words, if the CPU uses other bank registers, its performance degrades somewhat. In order to obtain maximum CPU efficiency, the TLCS-900 series has a function which easily switches register banks.

The bank switching function provides the following advantages:

- Optimum CPU operating efficiency
- Reduced programming size (Object codes)
- Higher response speed and reduced programming size when used as a context switch for an interrupt service routine.

Bank switching is performed by the instructions listed below.

LDF imm : Sets the contents of the immediate value in <RFP>. imm: 0 to 7

INCF : Increments <RFP> by 1.

DECF : Decrements <RFP> by 1.

In minimum mode, the immediate values used by the LDF instruction are from 0 to 7, in maximum mode 0 to 3. If a carry or borrow occurs when the INCF or DECF instruction is executed, it is ignored. The value of the <RFP> rotates. For example, if the INCF instruction is executed with bank 7, the result is bank 0. If the DECF instruction is executed with bank 0, the result is bank 7. Note that careless execution of the INCF or DECF instruction may destroy the contents of the register bank.

- Example of Register Bank Usage

The TLCS-900 series registers are formatted in banks. Banks can be used for processing objectives or interrupt levels. Two examples are given below.

<Example 1> When assigning register banks to interrupt processing routines.

Register bank 0 = Used for the main program and interrupt processing other than that shown below.

Register bank 1 = Used for processing INT0 .

Register bank 2 = Used for processing timer 0.

Register bank 3 = Used for processing timer 1.

Register bank 4 = Used for processing A/D converter.

Register bank 5 = Used for processing serial I/O. (Data send)

Register bank 6 = Used for processing serial I/O. (Data receive)

Register bank 7 = Used for processing NMI.

For example, if a timer 1 interrupt occurs during main program execution, processing jumps to a subroutine as follows. PUSH/POP processing for the register is unnecessary.

LDF 3 ; Sets register bank to 3. 0.2  $\mu$ s (@20MHz)

:

:

RETI ; Returns to previous status including <RFP>. 1.2  $\mu$ s (@ 20MHz)

<Example 2> When assigning register banks to their appropriate interrupt level nesting.



Note 1 : In the above example, when interrupt nesting exceeds the number of register banks (8), the <RFP> becomes 000 and the contents of register bank 0 are destroyed. However, interrupt levels are usually from 1 to 7, so in most cases nesting will not exceed 8 levels. Unless, that is, multiple NMIs occur. If there is any chance of multiple NMIs occurring, do not use the INCF instruction in the NMI processing routine.

Note 2 : The INCF instruction is used to execute <RFP> ← <RFP> + 1. 0.2  $\mu$ s (@20 MHz)

### 3.4 Accessing General-purpose Registers

The register access code is formatted in a varied code length on byte basis. The current bank registers can be accessed by the shortest code length. All general-purpose registers can be accessed by an instruction code which is 1 byte longer. General-purpose registers are as follows.

#### ① General-purpose registers in current bank

(Minimum mode)

|  |  |  |  |   |         |   |
|--|--|--|--|---|---------|---|
|  |  |  |  | W | (W   A) | A |
|  |  |  |  | B | (B   C) | C |
|  |  |  |  | D | (D   E) | E |
|  |  |  |  | H | (H   L) | L |

(Maximum mode)

|    |           |    |           |   |          |   |
|----|-----------|----|-----------|---|----------|---|
| QW | (Q   WA ) | QA | <X   WA > | W | (W   A ) | A |
| QB | (Q   BC ) | QC | <X   BC > | B | (B   C ) | C |
| QD | (Q   DE ) | QE | <X   DE > | D | (D   E ) | E |
| QH | (Q   HL ) | QL | <X   HL > | H | (H   L ) | L |

( ) : Word register name (16 bits)

< > : Long word register name (32 bits)

#### ② General-purpose registers in previous bank

(Minimum mode)

|  |  |  |  |    |          |    |
|--|--|--|--|----|----------|----|
|  |  |  |  | W' | (W   A') | A' |
|  |  |  |  | B' | (B   C') | C' |
|  |  |  |  | D' | (D   E') | E' |
|  |  |  |  | H' | (H   L') | L' |

(Maximum mode)

|     |           |     |           |    |          |    |
|-----|-----------|-----|-----------|----|----------|----|
| QW' | (Q   WA') | QA' | <X   WA'> | W' | (W   A') | A' |
| QB' | (Q   BC') | QC' | <X   BC'> | B' | (B   C') | C' |
| QD' | (Q   DE') | QE' | <X   DE'> | D' | (D   E') | E' |
| QH' | (Q   HL') | QL' | <X   HL'> | H' | (H   L') | L' |

#### ③ 32-bit general-purpose registers

(Both minimum and maximum modes)

|      |          |      |          |     |         |     |
|------|----------|------|----------|-----|---------|-----|
| QIXH | (Q   IX) | QIXL | <X   IX> | IXH | (I   X) | IXL |
| QIYH | (Q   IY) | QIYL | <X   IY> | IYH | (I   Y) | IYL |
| QIZH | (Q   IZ) | QIZL | <X   IZ> | IZH | (I   Z) | IYL |
| QSPH | (Q   SP) | QSPL | <X   SP> | SPH | (S   P) | SPL |

④ Absolute bank registers

(Minimum mode)

|  |     |           |     |       |
|--|-----|-----------|-----|-------|
|  | RW0 | (RWA   0) | RA0 | Bank0 |
|  | RB0 | (RBC   0) | RC0 |       |
|  | RD0 | (RDE   0) | RE0 |       |
|  | RH0 | (RHL   0) | RL0 |       |
|  | RW1 | (RWA   1) | RA1 |       |
|  | RB1 | (RBC   1) | RC1 |       |
|  | RD1 | (RDE   1) | RE1 |       |
|  | RH1 | (RHL   1) | RL1 |       |
|  | RW2 | (RWA   2) | RA2 | Bank1 |
|  | RB2 | (RBC   2) | RC2 |       |
|  | RD2 | (RDE   2) | RE2 |       |
|  | RH2 | (RHL   2) | RL2 |       |
|  | RW3 | (RWA   3) | RA3 |       |
|  | RB3 | (RBC   3) | RC3 |       |
|  | RD3 | (RDE   3) | RE3 |       |
|  | RH3 | (RHL   3) | RL3 |       |
|  | RW4 | (RWA   4) | RA4 | Bank2 |
|  | RB4 | (RBC   4) | RC4 |       |
|  | RD4 | (RDE   4) | RE4 |       |
|  | RH4 | (RHL   4) | RL4 |       |
|  | RW5 | (RWA   5) | RA5 |       |
|  | RB5 | (RBC   5) | RC5 |       |
|  | RD5 | (RDE   5) | RE5 |       |
|  | RH5 | (RHL   5) | RL5 |       |
|  | RW6 | (RWA   6) | RA6 | Bank3 |
|  | RB6 | (RBC   6) | RC6 |       |
|  | RD6 | (RDE   6) | RE6 |       |
|  | RH6 | (RHL   6) | RL6 |       |
|  | RW7 | (RWA   7) | RA7 |       |
|  | RB7 | (RBC   7) | RC7 |       |
|  | RD7 | (RDE   7) | RE7 |       |
|  | RH7 | (RHL   7) | RL7 |       |

(Maximum mode)

|     |           |     |           |     |           |     |       |
|-----|-----------|-----|-----------|-----|-----------|-----|-------|
| QW0 | (QWA   0) | QA0 | <XWA   0> | RW0 | (RWA   0) | RA0 | Bank0 |
| QB0 | (QBC   0) | QC0 | <XBC   0> | RB0 | (RBC   0) | RC0 |       |
| QD0 | (QDE   0) | QE0 | <XDE   0> | RD0 | (RDE   0) | RE0 |       |
| QH0 | (QHL   0) | QL0 | <XHL   0> | RH0 | (RHL   0) | RL0 |       |
| QW1 | (QWA   1) | QA1 | <XWA   1> | RW1 | (RWA   1) | RA1 |       |
| QB1 | (QBC   1) | QC1 | <XBC   1> | RB1 | (RBC   1) | RC1 |       |
| QD1 | (QDE   1) | QE1 | <XDE   1> | RD1 | (RDE   1) | RE1 |       |
| QH1 | (QHL   1) | QL1 | <XHL   1> | RH1 | (RHL   1) | RL1 |       |
| QW2 | (QWA   2) | QA2 | <XWA   2> | RW2 | (RWA   2) | RA2 | Bank1 |
| QB2 | (QBC   2) | QC2 | <XBC   2> | RB2 | (RBC   2) | RC2 |       |
| QD2 | (QDE   2) | QE2 | <XDE   2> | RD2 | (RDE   2) | RE2 |       |
| QH2 | (QHL   2) | QL2 | <XHL   2> | RH2 | (RHL   2) | RL2 |       |
| QW3 | (QWA   3) | QA3 | <XWA   3> | RW3 | (RWA   3) | RA3 |       |
| QB3 | (QBC   3) | QC3 | <XBC   3> | RB3 | (RBC   3) | RC3 |       |
| QD3 | (QDE   3) | QE3 | <XDE   3> | RD3 | (RDE   3) | RE3 |       |
| QH3 | (QHL   3) | QL3 | <XHL   3> | RH3 | (RHL   3) | RL3 |       |

( ) : Word register name (16 bits)

< > : Long word register name (32 bits)

## 4. ADDRESSING MODES

The TLCS-900 series has nine addressing modes. These are combined with most instructions to improve CPU processing capabilities.

TLCS-900 series addressing modes are listed below. They cover the entire TLCS-90 addressing modes.

| No. | Addressing mode                  | Description                   |
|-----|----------------------------------|-------------------------------|
| 1.  | Register                         | reg8<br>reg16<br>reg32        |
| 2.  | Immediate                        | n8<br>n16<br>n32              |
| 3.  | Register indirect                | (reg)                         |
| 4.  | Register indirect pre-decrement  | (- reg)                       |
| 5.  | Register indirect post-increment | (reg +)                       |
| 6.  | Index                            | (reg + d8)<br>(reg + d16)     |
| 7.  | Register index                   | (reg + reg8)<br>(reg + reg16) |
| 8.  | Absolute                         | (n8)<br>(n16)<br>(n24)        |
| 9.  | Relative                         | (PC + d8)<br>(PC + d16)       |

reg 8 : All 8-bit registers such as W, A, B, C, D, E, H, L, etc.

reg 16 : All 16-bit registers such as WA, BC, DE, HL, IX, IY, IZ, SP, etc.

reg 32 : All 32-bit registers such as XWA, WBC, XDE, XHL, XIX, XIY, XIZ, XSP, etc.

reg : All 32-bit registers such as XWA, WBC, XDE, XHL, XIX, XIY, XIZ, XSP, etc.  
(Maximum mode)

All 16-bit bank registers such as WA, BC, DE, HL, etc. and XIX, XIY, XIZ, and XSP.  
(Minimum mode)

d8 : 8-bit displacement (-80H~+7FH)

d16 : 16-bit displacement (-8000H~+7FFFH)

n8 : 8-bit constant (00H~FFH)

n16 : 16-bit constant (0000H~FFFFH)

n32 : 32-bit constant (00000000H~FFFFFFFH)

- 
- Note 1 : Relative addressing mode can only be used with the following instructions:  
LDAR, JR, JRL, DJNZ, and CALR
- Note 2 : In minimum mode, register bank blocks (current bank registers and previous bank registers, and bank 0 to 7 registers) consist of 16 bits. When these 16-bit registers are used for addressing, the CPU extends bits 16 to 31 to 0000H for address calculations.

### (1) Register Addressing Mode

In this mode, the operand is the specified register.

Example: LD HL,IX



The IX register contents, 1234H, are loaded to the HL register.

### (2) Immediate Addressing Mode

In this mode, the operand is in the instruction code.

Example: LD HL,5678H



The immediate data, 5678H, is loaded to the HL register.

### (3) Register Indirect Addressing Mode

In this mode, the operand is the memory address specified by the contents of the register.

Example 1: LD, HL, (XIX) ... in both minimum and maximum modes



Memory data, 2233H, at address 345678H is loaded to the HL register.

Example 2: LD, HL, (BC) ... in minimum mode



In minimum mode, if a bank register (WA, BC, DE, or HL) is used for addressing, address bits 16 to 23 are set to 00H.

Example 3: LD HL,(XBC) ... in maximum mode



In maximum mode, if a bank register (XWA, XBC, XDE, or XHL) is used for addressing, the values of bits 0 to 23 are output to the address bus.

#### (4) Register Indirect Pre-decrement Addressing Mode

In this mode, the contents of the register is decremented by the pre-decrement values. In this case, the operand is the memory address specified by the decremented register.

Example 1: LD HL, (-XIX) ... in both minimum and maximum modes



The pre-decrement values are as follows:

When the size of the operand is one byte (8 bits) : -1

When the size of the operand is one word (16 bits) : -2

When the size of the operand is one long word (32 bits) : -4

Example 2: LD A,(-BC) ... in minimum mode



Example 3: LD XIX,(-XBC) ... in maximum mode



### (5) Register Indirect Post-increment Addressing Mode

In this mode, the operand is the memory address specified by the contents of the register. After the operation, the contents of the register are incremented by the size of the operand.

Example 1: LD HL,(XIX + ) ... in both minimum and maximum modes



Example 2: LD XIZ,(BC + ) ... in minimum mode



Example 3: LD A,(XBC + ) ... in maximum mode



## (6) Index Addressing Mode

In this mode, the operand is the memory address obtained by adding the contents of the specified register to the 8- or 16-bit displacement value in the instruction code.

Example 1: LD HL,(XIX + 13H) ... in both minimum and maximum modes



Example 2: LD HL,(BC + 1234H) ... in minimum mode



Example 3: LD HL,(XBC-1000H) ... in maximum mode



The displacement values range from -8000H to +7FFFH.

### (7) Register Index Addressing Mode

In this mode, the operand is the memory address obtained by adding the contents of the register specified as the base to the register specified as the 8- or 16-bit displacement.

Example 1: LD HL,(XIX + A) ... in both minimum and maximum modes



Example 2: LD HL,(BC + DE) ... in minimum mode



Example 3: LD HL,(XBC + DE) ... in maximum mode



## (8) Absolute Addressing Mode

In this mode, the operand is the memory address specified by 1 to 3 bytes in the instruction code. Addresses 000000H to 0000FFH can be specified by 1 byte. Addresses 000000H to 00FFFFH can be specified by 2 bytes. Addresses 000000H to FFFFFFFH can be specified by 3 bytes.

Example 1: LD HL,(80H)



Example 2: LD HL,(1234H)



Example 3: LD HL,(56789AH)



### (9) Relative Addressing Mode

In this mode, the operand is the memory address obtained by adding the 8- or 16-bit displacement value to the address where the instruction code being executed is located.

In this mode, only the following five instructions can be used.

|                  |                                          |
|------------------|------------------------------------------|
| LDAR R, \$+4+d16 |                                          |
| JR cc, \$+2+d8   |                                          |
| JRL cc, \$+3+d16 |                                          |
| CALR \$+3+d16    |                                          |
| DJNZ r, \$+3+d8  | (\$ : start address of instruction code) |

In calculating the displacement object code value, the adjustment value (+2 to +4) depends on the instruction type.

Example 1: JR 2034H



In the above example, the displacement object code value is:

$$2034H - (2000H + 2) = 32H.$$

## 5. INSTRUCTIONS

In addition to its various addressing modes, the TLCS-900 series also has a powerful instruction set. The basic instructions are classified into the following nine groups:

- Load instructions (8/16/32 bits)
- Exchange instructions (8/16 bits)
- Block transfer & Block search instructions (8/16 bits)
- Arithmetic operation instructions (8/16/32 bits)
- Logical operation instructions (8/16/32 bits)
- Bit operation instructions (1 bit)
- Special operations, CPU control instructions
- Rotate and Shift instructions (8/16/32 bits)
- Jump, Call, and Return instructions

Table 5 lists the basic instructions of the TLCS-900 series. For details of instructions, see Appendix A; for the instruction list, Appendix B; for the instruction code map, Appendix C; and for the differences between the TLCS-90 and TLCS-900 series, Appendix D.



Table 5 (1) TLCS-900 Series Basic Instructions

|      |              |                                                                                                                                                                             |
|------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LD   | dst, src     | Load dst $\leftarrow$ src                                                                                                                                                   |
| PUSH | src          | Push src data to stack.<br>SP $\leftarrow$ SP - size : (SP) $\leftarrow$ src                                                                                                |
| POP  | dst          | Pop data from stack to dst.<br>dst $\leftarrow$ (SP) : SP $\leftarrow$ SP + size                                                                                            |
| LDA  | dst, src     | Load address: set src effective address in dst.                                                                                                                             |
| LDAR | dst, PC + dd | Load address relative:<br>set program counter relative address value in dst. dst $\leftarrow$ PC + dd                                                                       |
| EX   | dst1, dst2   | Exchange dst1 and dst2 data.                                                                                                                                                |
| MIRR | dst          | Mirror-invert dst bit pattern.                                                                                                                                              |
| LDI  |              | Load increment                                                                                                                                                              |
| LDIR |              | Load increment repeat                                                                                                                                                       |
| LDD  |              | Load decrement                                                                                                                                                              |
| LDLR |              | Load decrement repeat                                                                                                                                                       |
| CPI  |              | Compare increment                                                                                                                                                           |
| CPIR |              | Compare increment repeat                                                                                                                                                    |
| CPD  |              | Compare decrement                                                                                                                                                           |
| CPDR |              | Compare decrement repeat                                                                                                                                                    |
| ADD  | dst, src     | Add dst $\leftarrow$ dst + src                                                                                                                                              |
| ADC  | dst, src     | Add with carry dst $\leftarrow$ dst + src + CY                                                                                                                              |
| SUB  | dst, src     | Subtract dst $\leftarrow$ dst - src                                                                                                                                         |
| SBC  | dst, src     | Subtract with carry dst $\leftarrow$ dst - src - CY                                                                                                                         |
| CP   | dst, src     | Compare dst - src                                                                                                                                                           |
| AND  | dst, src     | And dst $\leftarrow$ dst AND src                                                                                                                                            |
| OR   | dst, src     | Or dst $\leftarrow$ dst OR src                                                                                                                                              |
| XOR  | dst, src     | Exclusive-or dst $\leftarrow$ dst XOR src                                                                                                                                   |
| INC  | imm, dst     | Increment dst $\leftarrow$ dst + imm                                                                                                                                        |
| DEC  | imm, dst     | Decrement dst $\leftarrow$ dst - imm                                                                                                                                        |
| MUL  | dst, src     | Multiply unsigned dst $\leftarrow$ dst (low) $\times$ src                                                                                                                   |
| MULS | dst, src     | Multiply signed dst $\leftarrow$ dst (low) $\times$ src                                                                                                                     |
| DIV  | dst, src     | Divide unsigned dst (low) $\leftarrow$ dst $\div$ src<br>dst (high) $\leftarrow$ remainder<br>V flag set due to division by 0 or overflow.                                  |
| DIVS | dst, src     | Divide signed dst (low) $\leftarrow$ dst $\div$ src<br>dst (high) $\leftarrow$ remainder: sign is same as that of dividend.<br>V flag set due to division by 0 or overflow. |

|       |          |                                                                                                                                           |
|-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------|
| MULA  | dst      | Multiply and add<br><br>Multiply and add<br>$dst \leftarrow dst + (XDE) \times (XHL -)$<br>32bit 32bit 16bit 16bit                        |
| MINC1 | num, dst | Modulo increment 1                                                                                                                        |
| MINC2 | num, dst | Modulo increment 2                                                                                                                        |
| MINC4 | num, dst | Modulo increment 4                                                                                                                        |
| MDEC1 | num, dst | Modulo decrement 1                                                                                                                        |
| MDEC2 | num, dst | Modulo decrement 2                                                                                                                        |
| MDEC4 | num, dst | Modulo decrement 4                                                                                                                        |
| NEG   | dst      | Negate $dst \leftarrow 0 - dst$ (Twos complement)                                                                                         |
| CPL   | dst      | Complement $dst \leftarrow \text{not } dst$ (Ones complement)                                                                             |
| EXTZ  | dst      | Extend zero: set upper data of dst to 0.                                                                                                  |
| EXTS  | dst      | Extend signed: copy the MSB of the lower data of dst to upper data.                                                                       |
| DAA   | dst      | Decimal adjustment accumulator                                                                                                            |
| PAA   | dst      | Pointer adjustment accumulator:<br>when dst is odd, increment dst by 1 to make it even.<br>if dst (0) = 1 then $dst \leftarrow dst + 1$ . |
| LDCF  | bit, src | Load carry flag: copy src<bit> value to C flag.                                                                                           |
| STCF  | bit, dst | Store carry flag: copy C flag value to dst<bit>.                                                                                          |
| ANDCF | bit, src | And carry flag:<br>and src<bit> value and C flag, then load the result to C flag.                                                         |
| ORCF  | bit, src | Or carry flag: or src<bit> and C flag, then load result to C flag.                                                                        |
| XORCF | bit, src | Exclusive-or carry flag:<br>exclusive-or src<bit> value and C flag, then load result to C flag.                                           |
| RCF   |          | Reset carry flag: reset C flag to 0.                                                                                                      |
| SCF   |          | Set carry flag: set C flag to 1.                                                                                                          |
| CCF   |          | Complement carry flag: invert C flag value.                                                                                               |
| ZCF   |          | Zero flag to carry flag: copy inverted value of Z flag to C flag.                                                                         |
| BIT   | bit, src | Bit test: Z flag $\leftarrow \text{not } src < bit >$                                                                                     |
| RES   | bit, dst | Bit reset                                                                                                                                 |
| SET   | bit, dst | Bit set                                                                                                                                   |
| CHG   | bit, dst | Bit change $dst < bit > \leftarrow \text{not } dst < bit >$                                                                               |
| TSET  | bit, dst | Bit test and set:<br>Z flag $\leftarrow \text{not } dst < bit >$<br>$dst < bit > \leftarrow 1$                                            |



|               |                 |                                                                                                                                |
|---------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------|
| BS1F          | A, dst          | Bit search 1 forward: search dst for the first bit set to 1 starting from the LSB, then set the bit number in the A register.  |
| BS1B          | A,dst           | Bit search 1 backward: search dst for the first bit set to 1 starting from the MSB, then set the bit number in the A register. |
| NOP           |                 | No operation                                                                                                                   |
| <b>NORMAL</b> |                 | <b>Set CPU to normal mode. Not exist in 900/L and 900/H CPU.</b>                                                               |
| <b>MAX</b>    |                 | <b>Set CPU to maximum mode (32-bit bank register and PC).<br/>Not exist in 900/L and 900/H CPU.</b>                            |
| <b>MIN</b>    |                 | <b>Set CPU to minimum mode. Not exist in 900 CPU.</b>                                                                          |
| EI            | imm             | Enable interrupt. IFF←imm                                                                                                      |
| DI            |                 | Disable maskable interrupt. IFF←7                                                                                              |
| PUSH          | SR              | Push status registers.                                                                                                         |
| POP           | SR              | Pop status registers.                                                                                                          |
| SWI           | imm             | Software interrupt<br>PUSH PC&SR : JP 8000H + 10H × imm                                                                        |
| HALT          |                 | Halt CPU.                                                                                                                      |
| LDC           | CTRL – REG, reg | Load control: copy the register contents to control register of CPU.                                                           |
| LDC           | reg, CTRL – REG | Load control: copy the control register contents to register.                                                                  |
| LDX           | dst, src        | Load extract. dst←src                                                                                                          |
| LINK          | reg, dd         | Link: generate stack frame.<br>PUSH reg<br>LD reg, XSP<br>ADD XSP, dd                                                          |
| UNLK          | reg             | Unlink: delete stack frame.<br>LD XSP, reg<br>POP reg                                                                          |
| LDF           | imm             | Load register file pointer:<br>specify register bank. RFP←imm                                                                  |
| INCF          |                 | Increment register file pointer:<br>move to new register bank. RFP←RFP + 1                                                     |
| DECF          |                 | Decrement register file pointer:<br>return to previous register bank. RFP←RFP – 1                                              |
| SCC           | cc, dst         | Set dst with condition codes.<br>if cc then dst ←1<br>else dst ←0.                                                             |

|      |             |                                                                            |                                                                                    |
|------|-------------|----------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| RLC  | num, dst    | Rotate left without carry                                                  |  |
| RRC  | num, dst    | Rotate right without carry                                                 |  |
| RL   | num, dst    | Rotate left                                                                |  |
| RR   | num, dst    | Rotate right                                                               |  |
| SLA  | num, dst    | Shift left arithmetic                                                      |  |
| SRA  | num, dst    | Shift right arithmetic                                                     |  |
| SLL  | num, dst    | Shift left logical                                                         |  |
| SRL  | num, dst    | Shift right logical                                                        |  |
| RLD  | dst         | Rotate left digit                                                          |  |
| RRD  | dst         | Rotate right digit                                                         |  |
| JR   | cc, PC + d  | Jump relative (8-bit displacement)<br>if cc then PC←PC + d.                |                                                                                    |
| JRL  | cc, PC + dd | Jump relative long (16-bit displacement)<br>if cc then PC←PC + dd.         |                                                                                    |
| JP   | cc, dst     | Jump<br>if cc then PC←dst.                                                 |                                                                                    |
| CALR | RC + dd     | Relative call (16-bit displacement)<br>PUSH PC: PC←PC + dd.                |                                                                                    |
| CALL | cc, dst     | Call relative<br>if cc then PUSH PC: PC←dst.                               |                                                                                    |
| DJNZ | dst, PC + d | Decrement and jump if non-zero<br>dst←dst - 1<br>if dst≠ 0 then PC←PC + d. |                                                                                    |
| RET  | cc          | Return<br>if cc then POP PC.                                               |                                                                                    |
| RETD | dd          | Return and deallocate<br>RET<br>XSP←XSP + dd                               |                                                                                    |
| RETI |             | Return from interrupt<br>POP SR&PC                                         |                                                                                    |

Table 5 (2-1) Instruction List (The case of 900\_CPU)

|     |                   |     |                   |     |                    |
|-----|-------------------|-----|-------------------|-----|--------------------|
| BWL | LD reg, reg       | BWL | INC imm3, reg     | --- | NOP                |
| BWL | LD reg, imm       |     | DEC imm3, mem.B/W | --- | *NORMAL            |
| BWL | LD reg, mem       |     |                   | --- | *MAX               |
| BWL | LD mem, reg       |     |                   | --- | ESEN [imm3]        |
| BWL | LD mem, imm       |     |                   | --- | DE                 |
| BW- | LD (nn), mem      | BW- | MUL reg, reg      | -W- | *PUSH SR           |
| BW- | LD mem, (nn)      |     | *MULS reg, imm    | -W- | *POP SR            |
| BW- | LD mem, (nn)      |     | DIV reg, mem      | --- | SWI [imm3]         |
|     |                   |     | *DIVS             | --- | HALT               |
| BWL | PUSH reg/F        | -W- | *MULA reg         | BWL | *LDC CTRL=R, reg   |
| BW- | PUSH imm          |     |                   | BWL | *LDC reg, CTRL=R   |
| BW- | PUSH mem          |     |                   | B-- | *LDX (n), n        |
| BWL | POP reg/F         | -W- | *MINC1 imm, reg   | --L | *LINK reg, dd      |
| BW- | POP mem           | -W- | *MINC2 imm, reg   | --L | *UNLK reg          |
|     |                   | -W- | *MINC4 imm, reg   | --- | *LDF imm3          |
| -WL | LDA reg, mem      | -W- | *MDEC1 imm, reg   | --- | *INCF              |
| -WL | LDAR reg, PC + dd | -W- | *MDEC2 imm, reg   | --- | *DECf              |
|     |                   | -W- | *MDEC4 imm, reg   | --- | *SCC cc, reg       |
| B-- | EX F, F'          | BW- | NEG reg           | BWL | RLC imm, reg       |
| BW- | EX reg, reg       | BW- | CPL reg           |     | RRC A, reg         |
| BW- | EX mem, reg       | -WL | *EXTZ reg         |     | RL mem. B/W        |
|     |                   | B-- | DAA reg           |     | RR                 |
|     |                   | -WL | *PAA reg          |     | SLA                |
|     |                   |     |                   |     | SRA                |
|     |                   |     |                   |     | SLL                |
|     |                   |     |                   |     | SRL                |
| -W- | *MIRR reg         | BW- | *LDCF imm, reg    | B-- | RLD [A,] mem       |
|     |                   |     | *STCF A, reg      | B-- | RRD [A,] mem       |
|     |                   |     | *ANDCF imm, mem.B |     |                    |
|     |                   |     | *ORCF A, mem.B    |     |                    |
|     |                   |     | *XORCF            |     |                    |
| BW- | LDI               | --- | RCF               | --- | JR [cc,] PC + d    |
| BW- | LDIR              | --- | SCF               | --- | JRL [cc,] PC + dd  |
| BW- | LDI               | --- | CCF               | --- | JP [cc,] mem       |
| BW- | LDI               | --- | *ZCF              | --- | CALR PC + dd       |
| BW- | CPI               | BW- | BIT imm, reg      | --- | CALL [cc,] mem     |
| BW- | CPIR              |     | RES imm, mem.B    | BW- | DJNZ [reg], PC + d |
| BW- | CPD               |     | SET               | --- |                    |
| BW- | CPDR              |     | *CHG              | --- | RET [cc]           |
|     |                   |     | TSET              | --- | *RETD dd           |
|     |                   |     |                   | --- | *RETI              |
| BWL | ADD reg, reg      | -W- | *BS1F A, reg      |     |                    |
|     | ADC reg, imm      |     | *BS1B             |     |                    |
|     | SUB reg, mem      |     |                   |     |                    |
|     | SBC mem, reg      |     |                   |     |                    |
|     | CP mem, imm.B/W   |     |                   |     |                    |
|     | AND               |     |                   |     |                    |
|     | OR                |     |                   |     |                    |
|     | XOR               |     |                   |     |                    |

← B = Byte (8bit), W = Word (16bit), L = Long-Word (32bit).

\* : Indicates instruction added to the TLCS-90 series.

: Indicates privileged instruction.

[ ] : Indicates can be omitted.

Table 5 (2-2) Instruction List (The case of 900L\_CPU)

|      |      |              |     |                   |     |                    |
|------|------|--------------|-----|-------------------|-----|--------------------|
| BWL  | LD   | reg, reg     | BWL | INC imm3, reg     | --- | NOP                |
| BWL  | LD   | reg, imm     |     | DEC imm3, mem.B/W | --- | *MIN               |
| BWL  | LD   | reg, mem     |     |                   | --- | EI [imm3]          |
| BWL  | LD   | mem, reg     |     |                   | --- | DI                 |
| BWL- | LD   | mem, imm     | BW- | MUL reg, reg      | -W- | *PUSH SR           |
| BWL- | LD   | (nn), mem    |     | *MULS reg, imm    | -W- | *POP SR            |
| BWL- | LD   | mem, (nn)    |     | DIV reg, mem      | --- | SWI [imm3]         |
|      |      |              |     | *DIVS             | --- | HALT               |
| BWL  | PUSH | reg/F        |     |                   | BWL | *LDC CTRL - R, reg |
| BWL- | PUSH | imm          | -W- | *MULA reg         | BWL | *LDC reg, CTRL - R |
| BWL- | PUSH | mem          |     |                   | B-- | *LDX (n), n        |
| BWL  | POP  | reg/F        |     | *MINC1 imm, reg   | --L | *LINK reg, dd      |
| BWL- | POP  | mem          |     | *MINC2 imm, reg   | --L | *UNLK reg          |
|      |      |              |     | *MINC4 imm, reg   | --- | *LDF imm3          |
| -WL  | LDA  | reg, mem     |     | *MDEC1 imm, reg   | --- | *INCF              |
| -WL  | LDAR | reg, PC + dd |     | *MDEC2 imm, reg   | --- | *DECF              |
|      |      |              |     | *MDEC4 imm, reg   | --- | *SCC cc, reg       |
|      |      |              | BW- | NEG reg           | BWL | RLC imm, reg       |
|      |      |              | BW- | CPL reg           | BWL | RRC A, reg         |
|      |      |              | -WL | *EXTZ reg         | RL  | RR                 |
|      |      |              | -WL | *EXTS reg         | RR  | SLA                |
|      |      |              | B-- | DAA reg           | SRA | SLL                |
|      |      |              | -WL | *PAA reg          | SRL | SRL                |
|      |      |              | BW- | *LDCF imm, reg    | B-- | RLD [A,] mem       |
|      |      |              |     | *STCF A, reg      | B-- | RRD [A,] mem       |
|      |      |              |     | *ANDCF imm, mem.B |     |                    |
|      |      |              |     | *ORCF A, mem.B    |     |                    |
|      |      |              |     | *XORCF            |     |                    |
| BW-  | LDI  |              |     |                   | --- | JR [cc,] PC + d    |
| BW-  | LDIR |              |     |                   | --- | JRL [cc,] PC + dd  |
| BW-  | LDI  |              |     |                   | --- | JP [cc,] mem       |
| BW-  | LDLR |              |     |                   | --- | CALR PC + dd       |
|      |      |              |     |                   | --- | CALL [cc,] mem     |
|      |      |              |     |                   | --- |                    |
| BW-  | CPI  |              | BW- | BIT imm, reg      | BW- | DJNZ [reg], PC + d |
| BW-  | CPIR |              |     | RES imm, mem.B    |     |                    |
| BW-  | CPD  |              |     | SET               |     |                    |
| BW-  | CPDR |              |     |                   | --- | RET [cc]           |
|      |      |              |     |                   | --- | *RETD dd           |
|      |      |              |     |                   | --- | RETI               |
| BWL  | ADD  | reg, reg     | -W- | *BS1F A, reg      |     |                    |
|      | ADC  | reg, imm     |     |                   |     |                    |
|      | SUB  | reg, mem     |     |                   |     |                    |
|      | SBC  | mem, reg     |     |                   |     |                    |
|      | CP   | mem, imm.B/W |     |                   |     |                    |
|      | AND  |              |     |                   |     |                    |
|      | OR   |              |     |                   |     |                    |
|      | XOR  |              |     |                   |     |                    |

← B = Byte (8bit), W = Word (16bit), L = Long-Word (32bit).

\* : Indicates instruction added to the TLCS-90 series.

[] : Indicates can be omitted.

## 6. DATA FORMATS

The TLCS-900 series can handle 1/4/8/16/32-bit data.

### (1) Register Data Format

<Data image>

|           |  |                                     |
|-----------|--|-------------------------------------|
| 1 bit     |  | 10 9 8 7 6 5 4 3 2 1 0              |
| BCD       |  | Upper Lower Upper Lower Upper Lower |
| Byte      |  | MSB LSB MSB LSB MSB LSB             |
| Word      |  | MSB LSB MSB LSB                     |
| Long word |  | MSB LSB                             |

Note 1 : To access the parts indicated by , the instruction code is one byte longer than when accessing the other parts.

### (2) Memory Data Format

<Data image>

|           |                                      |  |                        |
|-----------|--------------------------------------|--|------------------------|
| 1 bit     | Address n                            |  | 10 9 8 7 6 5 4 3 2 1 0 |
| Byte      | Address n                            |  | MSB LSB                |
| Word      | Address n<br>n + 1                   |  | Lower MSB Upper LSB    |
| Long word | Address n<br>n + 1<br>n + 2<br>n + 3 |  | Lower MSB Upper LSB    |

Note 2 : There are no restrictions on the location of word or long word data in memory. They can be located from even or odd numbered address.

Note 3 : When the PUSH instruction is used to save data to the stack area, the stack pointer is decremented, then the data is saved.

Example: PUSH HL; XSP←XSP-2

(XSP) ←L

(XSP+1) ←H

This is the same in register indirect pre-decrement mode. The order is reversed in the TLCS-90 series: data is saved first, then the stack pointer is decremented.

Example: PUSH HL; (XSP-1) ←H

(XSP-2) ←L

XSP←XSP-2

## (3) Dynamic Bus Sizing

The TLCS-900 series can switch between 8- and 16-bit data buses dynamically during each bus cycle. This is called dynamic bus sizing. The function enables external memory extension using both 8- and 16-bit data bus memories. Products with a built-in chip select/wait controller can control external data bus size for each address area.

Table 6 (1) Dynamic Bus Sizing

| Operand data size | Operand start address | Data size at memory side | CPU address | CPU data  |           |
|-------------------|-----------------------|--------------------------|-------------|-----------|-----------|
|                   |                       |                          |             | D15 - D8  | D7 - D0   |
| 8 bits            | 2n + 0<br>(even)      | 8 bits                   | 2n + 0      | xxxxx     | b7 - b0   |
|                   |                       | 16 bits                  | 2n + 0      | xxxxx     | b7 - b0   |
|                   | 2n + 1<br>(odd)       | 8 bits                   | 2n + 1      | xxxxx     | b7 - b0   |
|                   |                       | 16 bits                  | 2n + 1      | b7 - b0   | xxxxx     |
| 16 bits           | 2n + 0<br>(even)      | 8 bits                   | 2n + 0      | xxxxx     | b7 - b0   |
|                   |                       | 8 bits                   | 2n + 1      | xxxxx     | b15 - b8  |
|                   | 2n + 1<br>(odd)       | 16 bits                  | 2n + 0      | b15 - b8  | b7 - b0   |
|                   |                       | 8 bits                   | 2n + 1      | xxxxx     | b7 - b0   |
|                   |                       | 8 bits                   | 2n + 2      | xxxxx     | b15 - b8  |
|                   | 2n + 1<br>(odd)       | 16 bits                  | 2n + 1      | b7 - b0   | xxxxx     |
|                   |                       | 16 bits                  | 2n + 2      | xxxxx     | b15 - b8  |
| 32 bits           | 2n + 0<br>(even)      | 8 bits                   | 2n + 0      | xxxxx     | b7 - b0   |
|                   |                       | 8 bits                   | 2n + 1      | xxxxx     | b15 - b8  |
|                   |                       | 8 bits                   | 2n + 2      | xxxxx     | b23 - b16 |
|                   |                       | 8 bits                   | 2n + 3      | xxxxx     | b31 - b24 |
|                   | 2n + 0<br>(even)      | 16 bits                  | 2n + 0      | b15 - b8  | b7 - b0   |
|                   |                       | 16 bits                  | 2n + 2      | b31 - b24 | b23 - b16 |
|                   | 2n + 1<br>(odd)       | 8 bits                   | 2n + 1      | xxxxx     | b7 - b0   |
|                   |                       | 8 bits                   | 2n + 2      | xxxxx     | b15 - b8  |
|                   |                       | 8 bits                   | 2n + 3      | xxxxx     | b23 - b16 |
|                   |                       | 8 bits                   | 2n + 4      | xxxxx     | b31 - b24 |
|                   | 2n + 1<br>(odd)       | 16 bits                  | 2n + 1      | b7 - b0   | xxxxx     |
|                   |                       | 16 bits                  | 2n + 2      | b23 - b16 | b15 - b8  |
|                   |                       | 16 bits                  | 2n + 4      | xxxxx     | b31 - b24 |

xxxxx : During read, indicates the data input to the bus are ignored. During write, indicates the bus is at high impedance and the write strobe signal is non-active.

#### (4) Internal Data Bus Format

With the TLCS-900 series, the CPU and the internal memory (built-in ROM or RAM) are connected via a 16-bit internal data bus. The internal memory operates with 0 wait. The CPU and the built-in I/Os are connected using an 8-bit internal data bus. This is because the built-in I/O access speed has little influence on the overall system operation speed.

Overall system operation speed depends largely on the speed of program memory access. The built-in I/O operates in sync with the signal phase of the CLK pin. It is synchronized so that the CLK rises () in the middle of the bus cycle. (Figure 7 (1) shows signal phases.) If the CLK is "1" when the ALE signal rises, 1 wait is inserted automatically for synchronization.

## 7. BASIC TIMINGS

The TLCS-900 series runs the following basic timings.

- Read cycle
- Write cycle
- Dummy cycle
- Interrupt receive timing
- Reset

Figures 7 (1) to (8) show the basic timings.



Note : CLK outputs are not always the same as the above phases.

Figure 7 (1) 0 WAIT Read/Write Cycle



Figure 7 (2) 1WAIT Read/Write Cycle



Figure 7 (3) 1WAIT + n Read/Write Cycle (n = 0)



Figure 7 (4) 1WAIT + n Read/Write Cycle (n = 1)



Figure 7 (5) 2WAIT Read/Write Cycle



Figure 7 (6) 1 State Dummy Cycle



Note : This timing chart is a theoretical example. In practice, due to the operation of the bus interface unit in the CPU, external bus and internal interrupt receive timings do not correspond one to one.

Figure 7 (7) Interrupt Receive Timing



Note : - - - - indicates pulled up internally.  
- - - - indicates pulled down internally.

Figure 7 (8) Reset Timings (external ROM operation: TMP96C141)



**TOSHIBA**



## Appendix

Appendix A Details of Instructions (43)

Appendix B Instruction Lists (169)

Appendix C Instruction Code Maps (178)

Appendix D Differences between TLCS-90 and TLCS-900(182)



## Appendix A: Details of Instructions

## ■ Instruction List

## ① Load

LD PUSH POP LDA LDAR

## ② Exchange

EX MIRR

## ③ Load Increment/Decrement &amp; Compare Increment/Decrement

LDI LDIR LDD LDDR CPI CPIR CPD CPDR

## ④ Arithmetic operations

|      |      |      |     |     |      |     |      |
|------|------|------|-----|-----|------|-----|------|
| ADD  | ADC  | SUB  | SBC | CP  | INC  | DEC | NEG  |
| EXTZ | EXTS | DAA  | PAA | MUL | MULS | DIV | DIVS |
| MULA | MINC | MDEC |     |     |      |     |      |

## ⑤ Logical operations

AND OR XOR CPL

## ⑥ Bit operations

|      |      |       |      |       |      |      |     |
|------|------|-------|------|-------|------|------|-----|
| LDCF | STCF | ANDCF | ORCF | XORCF | RCF  | SCF  | CCF |
| ZCF  | BIT  | RES   | SET  | CHG   | TSET | B\$1 |     |

## ⑦ Special operations and CPU control

|      |        |     |     |      |      |         |        |
|------|--------|-----|-----|------|------|---------|--------|
| NOP  | NORMAL | MAX | MIN | EI   | DI   | PUSH.SR | POP.SR |
| SWI  | HALT   | LDC | LDX | LINK | UNLK | LDF     | INCF   |
| DECF | SCC    |     |     |      |      |         |        |

## ⑧ Rotate and shift

|     |     |    |    |     |     |     |     |
|-----|-----|----|----|-----|-----|-----|-----|
| RLC | RRC | RL | RR | SLA | SRA | SLL | SRL |
| RLD | RRD |    |    |     |     |     |     |

## ⑨ Jump, call, and return

|      |    |     |      |      |      |     |      |
|------|----|-----|------|------|------|-----|------|
| JP   | JR | JRL | CALL | CALR | DJNZ | RET | RETD |
|      |    |     |      |      |      |     |      |
| RETI |    |     |      |      |      |     |      |

 : 'NORMAL' and 'MAX' instruction exist only in 900\_CPU, and 'MIN' instruction exists only in 900/L\_CPU.

■ Explanations of symbols used in this document

|           |                                                                                                                                                                                                                                             |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dst       | Destination: destination of data transfer or operation result load.                                                                                                                                                                         |
| src       | Source: source of data transfer or operation data read.                                                                                                                                                                                     |
| num       | Number: numerical value.                                                                                                                                                                                                                    |
| condition | Condition: based on flag status.                                                                                                                                                                                                            |
|           |                                                                                                                                                                                                                                             |
| R         | Eight general-purpose registers including 8/16/32-bit current bank registers.<br>8-bit registers : W, A, B, C, D, E, H, L<br>16-bit registers : WA, BC, DE, HL, IX, IY, IZ, SP<br>32-bit registers : XWA, XBC, XDE, XHL, XIX, XIY, XIZ, XSP |
| r         | 8/16/32-bit general-purpose registers                                                                                                                                                                                                       |
| r16       | 16-bit general-purpose registers                                                                                                                                                                                                            |
| r32       | 32-bit general-purpose registers                                                                                                                                                                                                            |
| cr        | All 8/16/32-bit CPU control registers<br>DMAS0 ~ 3, DMAD0 ~ 3, DMAC0 ~ 3, DMAM0 ~ 3,<br><b>XNSP, INTNEST</b>                                                                                                                                |
| A         | A register (8 bits)                                                                                                                                                                                                                         |
| F         | Flag registers (8 bits)                                                                                                                                                                                                                     |
| F'        | Inverse flag registers (8 bits)                                                                                                                                                                                                             |
| SR        | Status registers (16 bits)                                                                                                                                                                                                                  |
| PC        | Program counter (in minimum mode, 16 bits; in maximum mode, 32 bits)                                                                                                                                                                        |
| (mem)     | 8/16/32-bit memory data                                                                                                                                                                                                                     |
| mem       | Effective address value                                                                                                                                                                                                                     |
| <W>       | When the operand size is a word, W must be specified.                                                                                                                                                                                       |
| [ ]       | Operands enclosed in square brackets can be omitted.                                                                                                                                                                                        |
| #         | 8/16/32-bit immediate data.                                                                                                                                                                                                                 |
| #3        | 3-bit immediate data : 0 to 7 or 1 to 8 ... for abbreviated codes.                                                                                                                                                                          |
| #4        | 4-bit immediate data : 0 to 15 or 1 to 16                                                                                                                                                                                                   |
| d8        | 8-bit displacement : -80H~+7FH                                                                                                                                                                                                              |
| d16       | 16-bit displacement : -8000H~+7FFFH                                                                                                                                                                                                         |
| cc        | Condition code                                                                                                                                                                                                                              |
| CY        | Carry flag                                                                                                                                                                                                                                  |
| Z         | Zero flag                                                                                                                                                                                                                                   |
| (#8)      | Direct addressing: (00H) to (0FFH) ... 256-byte area                                                                                                                                                                                        |
| (#16)     | 64K-byte area addressing: (0000H) to (0FFFFH)                                                                                                                                                                                               |
| (-r32)    | Pre-decrement addressing                                                                                                                                                                                                                    |
| (r32+)    | Post-increment addressing                                                                                                                                                                                                                   |
| \$        | Start address of instruction                                                                                                                                                                                                                |

\*  : XNSP exists only in 900\_CPU, and INTNEST exists only in 900/L\_CPU.

■ Explanations of symbols in object codes

| z<br>zz<br>zzz<br>s                                                                                                                                                                                        | }    | Operand size specify code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------|------|-----------|-----|---|----|-----|-----|----|----|-----|-----|-----|-----|-----|-----|---|----|-----|-----|---|----|-----|-----|---|----|-----|-----|---|----|-----|-----|---|----|-----|
|                                                                                                                                                                                                            |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |           |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
|                                                                                                                                                                                                            |      | <table border="1" style="margin-left: auto; margin-right: auto;"> <thead> <tr> <th></th><th>Byte</th><th>Word</th><th>Long word</th></tr> </thead> <tbody> <tr> <td>z</td><td>0</td><td>1</td><td>—</td></tr> <tr> <td>zz</td><td>00</td><td>01</td><td>10</td></tr> <tr> <td>zzz</td><td>010</td><td>011</td><td>100</td></tr> <tr> <td>s</td><td>—</td><td>0</td><td>1</td></tr> </tbody> </table>                                                                                                                                                                                                                                             |           | Byte | Word | Long word | z   | 0 | 1  | —   | zz  | 00 | 01 | 10  | zzz | 010 | 011 | 100 | s   | — | 0  | 1   |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
|                                                                                                                                                                                                            | Byte | Word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Long word |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| z                                                                                                                                                                                                          | 0    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | —         |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| zz                                                                                                                                                                                                         | 00   | 01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 10        |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| zzz                                                                                                                                                                                                        | 010  | 011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 100       |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| s                                                                                                                                                                                                          | —    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1         |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| R<br>r                                                                                                                                                                                                     | }    | Register specify code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
|                                                                                                                                                                                                            |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |           |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
|                                                                                                                                                                                                            |      | <table border="1" style="margin-left: auto; margin-right: auto;"> <thead> <tr> <th>Code</th><th>Byte</th><th>Word</th><th>Long word</th></tr> </thead> <tbody> <tr> <td>000</td><td>W</td><td>WA</td><td>XWA</td></tr> <tr> <td>001</td><td>A</td><td>BC</td><td>XBC</td></tr> <tr> <td>010</td><td>B</td><td>DE</td><td>XDE</td></tr> <tr> <td>011</td><td>C</td><td>HL</td><td>XHL</td></tr> <tr> <td>100</td><td>D</td><td>IX</td><td>XIX</td></tr> <tr> <td>101</td><td>E</td><td>IY</td><td>XIY</td></tr> <tr> <td>110</td><td>H</td><td>IZ</td><td>XIZ</td></tr> <tr> <td>111</td><td>L</td><td>SP</td><td>XSP</td></tr> </tbody> </table> | Code      | Byte | Word | Long word | 000 | W | WA | XWA | 001 | A  | BC | XBC | 010 | B   | DE  | XDE | 011 | C | HL | XHL | 100 | D | IX | XIX | 101 | E | IY | XIY | 110 | H | IZ | XIZ | 111 | L | SP | XSP |
| Code                                                                                                                                                                                                       | Byte | Word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Long word |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| 000                                                                                                                                                                                                        | W    | WA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | XWA       |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| 001                                                                                                                                                                                                        | A    | BC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | XBC       |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| 010                                                                                                                                                                                                        | B    | DE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | XDE       |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| 011                                                                                                                                                                                                        | C    | HL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | XHL       |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| 100                                                                                                                                                                                                        | D    | IX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | XIX       |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| 101                                                                                                                                                                                                        | E    | IY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | XIY       |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| 110                                                                                                                                                                                                        | H    | IZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | XIZ       |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| 111                                                                                                                                                                                                        | L    | SP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | XSP       |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| <p>Note: In addition to the above, all registers can be specified by "r" using extension codes. (In this case, the number of execution states increases by 1.) The format is shown below.</p>              |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |           |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| First op code<br><br>Second op code                                                                                                                                                                        | }    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
|                                                                                                                                                                                                            |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |           |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |
| <p>The code value in "r" must be:</p> <p>Multiple of 2, if accessed as a word register.</p> <p>Multiple of 4, if accessed as a long word.</p> <p>For registers specified by 8 bits, see Register Maps.</p> |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |           |      |      |           |     |   |    |     |     |    |    |     |     |     |     |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |     |   |    |     |

| mem       | Memory addressing mode specify code |          |        |            |            |            |            |
|-----------|-------------------------------------|----------|--------|------------|------------|------------|------------|
| (XWA)     | =                                   | -0--0000 |        |            |            |            |            |
| (XBC)     | =                                   | -0--0001 |        |            |            |            |            |
| (XDE)     | =                                   | -0--0010 |        |            |            |            |            |
| (XHL)     | =                                   | -0--0011 |        |            |            |            |            |
| (XIX)     | =                                   | -0--0100 |        |            |            |            |            |
| (XIY)     | =                                   | -0--0101 |        |            |            |            |            |
| (XIZ)     | =                                   | -0--0110 |        |            |            |            |            |
| (XSP)     | =                                   | -0--0111 |        |            |            |            |            |
| (XWA+d8)  | =                                   | -0--1000 | d<7:0> | ;+2 states |            |            |            |
| (XBC+d8)  | =                                   | -0--1001 | d<7:0> | ;+2 states |            |            |            |
| (XDE+d8)  | =                                   | -0--1010 | d<7:0> | ;+2 states |            |            |            |
| (XHL+d8)  | =                                   | -0--1011 | d<7:0> | ;+2 states |            |            |            |
| (XIX+d8)  | =                                   | -0--1100 | d<7:0> | ;+2 states |            |            |            |
| (XIY+d8)  | =                                   | -0--1101 | d<7:0> | ;+2 states |            |            |            |
| (XIZ+d8)  | =                                   | -0--1110 | d<7:0> | ;+2 states |            |            |            |
| (XSP+d8)  | =                                   | -0--1111 | d<7:0> | ;+2 states |            |            |            |
| (#8)      | =                                   | -1--0000 | #<7:0> | ;+2 states |            |            |            |
| (#16)     | =                                   | -1--0001 | #<7:0> | #<15:8>    | ;+2 states |            |            |
| (#24)     | =                                   | -1--0010 | #<7:0> | #<15:8>    | #<23:16>   | ;+3 states |            |
| (r32)     | =                                   | -1--0011 | r32'   | 00         | ;+5 states |            |            |
| (r32+d16) | =                                   | -1--0011 | r32'   | 01         | d<7:0>     | d<15:8>    | ;+5 states |
| (r32+r8)  | =                                   | -1--0011 | 000000 | 11         | r32        | r8         | ;+8 states |
| (r32+r16) | =                                   | -1--0011 | 000001 | 11         | r32        | r16        | ;+8 states |
| (-r32)    | =                                   | -1--0100 | r32'   | zz         |            |            | ;+3 states |
| (r32+)    | =                                   | -1--0101 | r32'   | zz         |            |            | ;+3 states |

↑

r32: 32-bit register

r16: Signed 16-bit register

r8: Signed 8-bit register

↑

zz= Code used to specify the value of increments or decrements.

00: ±1  
01: ±2  
10: ±4  
11: (Not defined)

↑

r32' = Upper 6 bits of register code

| cc | Condition codes |         |                                |                                           |
|----|-----------------|---------|--------------------------------|-------------------------------------------|
|    | Code            | Symbol  | Description                    | Conditional expression                    |
|    | 0000            | F       | always False                   | -                                         |
|    | 1000            | (none)  | always True                    | -                                         |
|    | 0110            | Z       | Zero                           | $Z=1$                                     |
|    | 1110            | NZ      | Not Zero                       | $Z=0$                                     |
|    | 0111            | C       | Carry                          | $C=1$                                     |
|    | 1111            | NC      | Not Carry                      | $C=0$                                     |
|    | 1101            | PL or P | Plus                           | $S=0$                                     |
|    | 0101            | MI or M | MINus                          | $S=1$                                     |
|    | 1110            | NE      | Not Equal                      | $Z=0$                                     |
|    | 0110            | EQ      | Equal                          | $Z=1$                                     |
|    | 0100            | OV      | OVerflow                       | $P/V=1$                                   |
|    | 1100            | NOV     | No OVerflow                    | $P/V=0$                                   |
|    | 0100            | PE      | Parity is Even                 | $P/V=1$                                   |
|    | 1100            | PO      | Parity is Odd                  | $P/V=0$                                   |
|    | 1001            | GE      | Greater than or Equal (signed) | $(S \text{ xor } P/V) =0$                 |
|    | 0001            | LT      | Less Than (signed)             | $(S \text{ xor } P/V) =1$                 |
|    | 1010            | GT      | Greater Than (signed)          | $[Z \text{ or } (S \text{ xor } P/V)] =0$ |
|    | 0010            | LE      | Less than or Equal (signed)    | $[Z \text{ or } (S \text{ xor } P/V)] =1$ |
|    | 1111            | UGE     | Unsigned Greater than or Equal | $C=0$                                     |
|    | 0111            | ULT     | Unsigned Less Than             | $C=1$                                     |
|    | 1011            | UGT     | Unsigned Greater Than          | $(C \text{ or } Z) =0$                    |
|    | 0011            | ULE     | Unsigned Less than or Equal    | $(C \text{ or } Z) =1$                    |

### ■ Flag changes

|   |                                                        |
|---|--------------------------------------------------------|
| 0 | Reset to "0".                                          |
| 1 | Set to "1".                                            |
| - | No change.                                             |
| * | "0" or "1" depending on the result of the calculation. |
| X | Indeterminate value.                                   |
| P | Parity result is set.                                  |
| V | Overflow result is set.                                |

## ■ Register map "r" (minimum mode)



( ) : Word register name (16 bits)

&lt; &gt; : Long word register name (32 bits)

## ■ Register map "r" (maximum mode)

|     | + 3           | + 2           | + 1           | + 0 |               |
|-----|---------------|---------------|---------------|-----|---------------|
| 00H | QWO (QWA : 0) | QAO <XWA : 0> | RWO (RWA : 0) | RA0 |               |
| 04H | QBO (QBC : 0) | QCO <XBC : 0> | RBO (RBC : 0) | RC0 |               |
| 08H | QDO (QDE : 0) | QEO <XDE : 0> | RDO (RDE : 0) | RE0 |               |
| 0CH | QHO (QHL : 0) | QLO <XHL : 0> | RHO (RHL : 0) | RL0 |               |
| 10H | QW1 (QWA : 1) | QA1 <XWA : 1> | RW1 (RWA : 1) | RA1 |               |
| 14H | QB1 (QBC : 1) | QC1 <XBC : 1> | RB1 (RBC : 1) | RC1 |               |
| 18H | QD1 (QDE : 1) | QE1 <XDE : 1> | RD1 (RDE : 1) | RE1 |               |
| 1CH | QH1 (QHL : 1) | QL1 <XHL : 1> | RH1 (RHL : 1) | RL1 |               |
| 20H | QW2 (QWA : 2) | QA2 <XWA : 2> | RW2 (RWA : 2) | RA2 |               |
| 24H | QB2 (QBC : 2) | QC2 <XBC : 2> | RB2 (RBC : 2) | RC2 |               |
| 28H | QD2 (QDE : 2) | QE2 <XDE : 2> | RD2 (RDE : 2) | RE2 |               |
| 2CH | QH2 (QHL : 2) | QL2 <XHL : 2> | RH2 (RHL : 2) | RL2 |               |
| 30H | QW3 (QWA : 3) | QA3 <XWA : 3> | RW3 (RWA : 3) | RA3 |               |
| 34H | QB3 (QBC : 3) | QC3 <XBC : 3> | RB3 (RBC : 3) | RC3 |               |
| 38H | QD3 (QDE : 3) | QE3 <XDE : 3> | RD3 (RDE : 3) | RE3 |               |
| 3CH | QH3 (QHL : 3) | QL3 <XHL : 3> | RH3 (RHL : 3) | RL3 |               |
| 40H |               |               |               |     |               |
| 44H |               |               |               |     |               |
| 48H |               |               |               |     |               |
| 4CH |               |               |               |     |               |
| 50H |               |               |               |     |               |
| 54H |               |               |               |     |               |
| 58H |               |               |               |     |               |
| 5CH |               |               |               |     |               |
| 60H |               |               |               |     |               |
| 64H |               |               |               |     |               |
| 68H |               |               |               |     |               |
| 6CH |               |               |               |     |               |
| 70H |               |               |               |     |               |
| 74H |               |               |               |     |               |
| 78H |               |               |               |     |               |
| 7CH |               |               |               |     |               |
| D0H | QW' (Q'WA')   | QA' <X'WA'>   | W' (W'A')     | A'  |               |
| D4H | QB' (Q'BC')   | QC' <X'BC'>   | B' (B'C')     | C'  |               |
| D8H | QD' (Q'DE')   | QE' <X'DE'>   | D' (D'E')     | E'  |               |
| DCH | QH' (Q'HL')   | QL' <X'HL'>   | H' (H'L')     | L'  |               |
| D0H | QW (Q:WA )    | QA <X:WA >    | W (W:A )      | A   | Previous bank |
| D4H | QB (Q:BC )    | QC <X:BC >    | B (B:C )      | C   |               |
| D8H | QD (Q:DE )    | QE <X:DE >    | D (D:E )      | E   |               |
| DCH | QH (Q:HL )    | QL <X:HL >    | H (H:L )      | L   |               |
| E0H | QIXH (Q:IX)   | QIXL <X:IX>   | IXH (I:X)     | IXL | Current bank  |
| E4H | QIYH (Q:IY)   | QIYL <X:IY>   | IYH (I:Y)     | IYL |               |
| E8H | QIZH (Q:IZ)   | QIZL <X:IZ>   | IZH (I:Z)     | IZL |               |
| EC  | QSPH (Q:SP)   | QSPL <X:SP>   | SPH (S:P)     | SPL |               |
| F0H | QIXH (Q:IX)   | QIXL <X:IX>   | IXH (I:X)     | IXL |               |
| F4H | QIYH (Q:IY)   | QIYL <X:IY>   | IYH (I:Y)     | IYL |               |
| F8H | QIZH (Q:IZ)   | QIZL <X:IZ>   | IZH (I:Z)     | IZL |               |
| FC  | QSPH (Q:SP)   | QSPL <X:SP>   | SPH (S:P)     | SPL |               |

( ) : Word register name (16 bits)

&lt; &gt; : Long word register name (32 bits)

■ Control register map "cr"



■ Execution time

The number of states in the table of appendix B are shown in bytes, words, or long words in order of operand size. Execution time is calculated as follows.

At 16 MHz oscillation : number of states x 125 ns

At 20 MHz oscillation : number of states x 100 ns

At 25 MHz oscillation : number of states x 80 ns (Note : only 900/H CPU)

The number of states is the average value when the program and data memory data buses are 16-bit; when buses are 8-bit, the execution time is slower by between 20 to 40%.

If the operand of a read or write instruction is a word or long word, add the number of adjustment states (the number of additional read/write cycles of the operand) below. For the read modify write instruction, add double the number of adjustment states.

| Operand size | Memory size | Start address | Number of adjustment states |
|--------------|-------------|---------------|-----------------------------|
| Word         | Byte        | --            | + 2                         |
| Word         | Word        | Even number   | 0                           |
| Word         | Word        | Odd number    | + 2                         |
| Long word    | Byte        | --            | + 4                         |
| Long word    | Word        | Even number   | 0                           |
| Long word    | Word        | Odd number    | + 2                         |

The number of states of the SWI/CALL/CALR/RET/RETD/RETI instruction is the number in minimum mode. In maximum mode, PUSH /POP for the program counter takes 4 bytes; calculate by adding 2 states.

The TLCS-900 series CPU comes with a built-in 4-byte instruction queue buffer. Execution time is approximately 10 to 20% faster than the time calculated according to the above conditions.

## ADC dst, src

&lt; Add with Carry &gt;

Operation :  $dst \leftarrow dst + src + CY$ 

Description : Adds the contents of dst, src, and carry flag, and transfers the result to dst.

Details :

| Byte     | State<br>Word | Long word | Mnemonic | Code                                                                                                                                                                                                                                                                                                                                                                                            |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|----------|---------------|-----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|---|---|---|---|---|---|---|---|---|---|--------|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|
| 4        | 4             | 7         | ADC      | R, r                                                                                                                                                                                                                                                                                                                                                                                            |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|          |               |           |          | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr> <tr><td>1</td><td>0</td><td>0</td><td>1</td><td>0</td><td></td><td>R</td><td>1</td></tr> </table>                                                                                                                                                                                   | 1 | 1 | z | z | 1 |  | r | 1 | 1 | 0 | 0 | 1 | 0 |   | R | 1 |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | z         | z        | 1                                                                                                                                                                                                                                                                                                                                                                                               |   | r | 1 |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 0             | 0         | 1        | 0                                                                                                                                                                                                                                                                                                                                                                                               |   | R | 1 |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4             | 7         | ADC      | r, #                                                                                                                                                                                                                                                                                                                                                                                            |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|          |               |           |          | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> <tr><td colspan="8">#&lt;23:16&gt;</td></tr> <tr><td colspan="8">#&lt;31:24&gt;</td></tr> </table> | 1 | 1 | z | z | 1 |  | r | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | #<7:0> |  |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |  | #<23:16> |  |  |  |  |  |  |  | #<31:24> |  |  |  |  |  |  |  |
| 1        | 1             | z         | z        | 1                                                                                                                                                                                                                                                                                                                                                                                               |   | r | 1 |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | 0         | 0        | 1                                                                                                                                                                                                                                                                                                                                                                                               | 0 | 0 | 1 |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>   |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>  |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<23:16> |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<31:24> |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4             | 6         | ADC      | R, (mem)                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 6        | 6             | 10        | ADC      | (mem), R                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 7        | 8             | -         | ADC<W>   | (mem), #                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |

Flags: S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | 0 | * |
|---|---|---|---|---|---|

S = MSB value of the result is set.

Z = 1 is set if the result is 0, otherwise 0.

H = 1 is set if a carry from bit 3 to bit 4 occurs as a result of the operation; otherwise, 0. If the operand is 32-bit, an undefined value is set.

V = 1 is set if an overflow occurs as a result of the operation; otherwise, 0.

N = Cleared to zero.

C = 1 is set if a carry occurs from the MSB, otherwise 0.

Execution example: ADC HL,IX

When the HL register = 2000H, the IX register = 3456H, and the carry flag = 1, execution sets the HL register to 5457H.



## ADD dst, src

&lt; Add &gt;

Operation :  $dst \leftarrow dst + src$ 

Description : Adds the contents of dst to those of src and transfers the result to dst.

Details :

| Byte     | State<br>Word | Long word | Mnemonic |          | Code                                                                                                                                                                                                                                                                                                                                                                                           |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|----------|---------------|-----------|----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--------|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|
|          |               |           | ADD      | R, r     |                                                                                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4             | 7         | ADD      | R, r     | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>1</td><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>R</td><td></td></tr> </table>                                                                                                                                                                                    | 1 | 1 | z | z | 1 |   | r |   | 1 | 0 | 0 | 0 | 0 |   | R |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | z         | z        | 1        |                                                                                                                                                                                                                                                                                                                                                                                                | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 0             | 0         | 0        | 0        |                                                                                                                                                                                                                                                                                                                                                                                                | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4             | 7         | ADD      | r, #     | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> <tr><td colspan="8">#&lt;23:16&gt;</td></tr> <tr><td colspan="8">#&lt;31:24&gt;</td></tr> </table> | 1 | 1 | z | z | 1 |   | r |   | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | #<7:0> |  |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |  | #<23:16> |  |  |  |  |  |  |  | #<31:24> |  |  |  |  |  |  |  |
| 1        | 1             | z         | z        | 1        |                                                                                                                                                                                                                                                                                                                                                                                                | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | 0         | 0        | 1        | 0                                                                                                                                                                                                                                                                                                                                                                                              | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>   |               |           |          |          |                                                                                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>  |               |           |          |          |                                                                                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<23:16> |               |           |          |          |                                                                                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<31:24> |               |           |          |          |                                                                                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4             | 6         | ADD      | R, (mem) | <table border="1"> <tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>R</td><td></td></tr> </table>                                                                                                                                                                                  | 1 | m | z | z | m | m | m | m | 1 | 0 | 0 | 0 | 0 |   | R |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m             | z         | z        | m        | m                                                                                                                                                                                                                                                                                                                                                                                              | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 0             | 0         | 0        | 0        |                                                                                                                                                                                                                                                                                                                                                                                                | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 6        | 6             | 10        | ADD      | (mem), R | <table border="1"> <tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>0</td><td>0</td><td>0</td><td>1</td><td></td><td>R</td><td></td></tr> </table>                                                                                                                                                                                  | 1 | m | z | z | m | m | m | m | 1 | 0 | 0 | 0 | 1 |   | R |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m             | z         | z        | m        | m                                                                                                                                                                                                                                                                                                                                                                                              | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 0             | 0         | 0        | 1        |                                                                                                                                                                                                                                                                                                                                                                                                | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 7        | 8             | —         | ADD<W>   | (mem), # | <table border="1"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td><td>0</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> </table>                                                                                         | 1 | m | 0 | z | m | m | m | m | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | #<7:0> |  |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m             | 0         | z        | m        | m                                                                                                                                                                                                                                                                                                                                                                                              | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 0        | 0             | 1         | 1        | 1        | 0                                                                                                                                                                                                                                                                                                                                                                                              | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>   |               |           |          |          |                                                                                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>  |               |           |          |          |                                                                                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | 0 | * |
|---|---|---|---|---|---|

S = MSB value of the result is set.

Z = 1 is set if the result is 0, otherwise 0.

H = 1 is set if a carry from bit 3 to bit 4 occurs as a result of the operation, otherwise 0. If the operand is 32-bit, an undefined value is set.

V = 1 is set if an overflow occurs as a result of the operation, otherwise 0.

N = Cleared to zero.

C = 1 is set if a carry occurs from the MSB, otherwise 0.

Execution example: ADD HL,IX

When the HL register = 2000H and the IX register = 3456H, execution sets the HL register to 5456H.



## AND dst, src

&lt; And &gt;

Operation : dst  $\leftarrow$  dst AND src

Description : Ands the contents of dst and src, then transfers the result to dst.

(Truth table)

| A | B | A and B |
|---|---|---------|
| 0 | 0 | 0       |
| 0 | 1 | 0       |
| 1 | 0 | 0       |
| 1 | 1 | 1       |

Details :

| Byte     | State<br>Word | Long word | Mnemonic |          | Code                                                                                                                                                                                                                                                                                                                                                                                            |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|----------|---------------|-----------|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--------|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|
|          |               |           | AND      | r, #     |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4             | 7         | AND      | R, r     | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>0</td><td>0</td><td></td><td>R</td><td>1</td></tr> </table>                                                                                                                                                                                   | 1 | 1 | z | z | 1 |   | r | 1 | 1 | 1 | 0 | 0 | 0 |   | R | 1 |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | z         | z        | 1        |                                                                                                                                                                                                                                                                                                                                                                                                 | r | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | 0         | 0        | 0        |                                                                                                                                                                                                                                                                                                                                                                                                 | R | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4             | 7         | AND      | r, #     | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> <tr><td colspan="8">#&lt;23:16&gt;</td></tr> <tr><td colspan="8">#&lt;31:24&gt;</td></tr> </table> | 1 | 1 | z | z | 1 |   | r | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | #<7:0> |  |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |  | #<23:16> |  |  |  |  |  |  |  | #<31:24> |  |  |  |  |  |  |  |
| 1        | 1             | z         | z        | 1        |                                                                                                                                                                                                                                                                                                                                                                                                 | r | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | 0         | 0        | 1        | 1                                                                                                                                                                                                                                                                                                                                                                                               | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>   |               |           |          |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>  |               |           |          |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<23:16> |               |           |          |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<31:24> |               |           |          |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4             | 6         | AND      | R, (mem) | <table border="1"> <tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>0</td><td>0</td><td></td><td>R</td><td>1</td></tr> </table>                                                                                                                                                                                  | 1 | m | z | z | m | m | m | m | 1 | 1 | 0 | 0 | 0 |   | R | 1 |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m             | z         | z        | m        | m                                                                                                                                                                                                                                                                                                                                                                                               | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | 0         | 0        | 0        |                                                                                                                                                                                                                                                                                                                                                                                                 | R | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 6        | 6             | 10        | AND      | (mem), R | <table border="1"> <tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td><td></td><td>R</td><td>1</td></tr> </table>                                                                                                                                                                                  | 1 | m | z | z | m | m | m | m | 1 | 1 | 0 | 0 | 1 |   | R | 1 |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m             | z         | z        | m        | m                                                                                                                                                                                                                                                                                                                                                                                               | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | 0         | 0        | 1        |                                                                                                                                                                                                                                                                                                                                                                                                 | R | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 7        | 8             | -         | AND<W>   | (mem), # | <table border="1"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> </table>                                                                                          | 1 | m | 0 | z | m | m | m | m | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | #<7:0> |  |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m             | 0         | z        | m        | m                                                                                                                                                                                                                                                                                                                                                                                               | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 0        | 0             | 1         | 1        | 1        | 1                                                                                                                                                                                                                                                                                                                                                                                               | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>   |               |           |          |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>  |               |           |          |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |

Flags : S Z H V N C

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

S = MSB value of the result is set.

Z = 1 is set if the result is 0, otherwise 0.

H = 1 is set.

V = 1 is set if a parity of the result is even, 0 if odd. If the operand is 32 bits, an undefined value is set.

N = Cleared to zero.

C = Cleared to zero.

Execution example: AND HL,IX

When the HL register = 7350H and the IX register = 3456H,  
execution sets the HL register to 3050H.

|           |      |      |      |                                  |
|-----------|------|------|------|----------------------------------|
| 0111      | 0011 | 0101 | 0000 | ← HL register (before execution) |
| AND) 0011 | 0100 | 0101 | 0110 | ← IX register (before execution) |
| 0011      | 0000 | 0101 | 0000 | ← HL register (after execution)  |

## ANDCF num, src

< And Carry Flag >

Operation : CY  $\leftarrow$  CY and src<num>

Description : Ands the contents of the carry flag and bit num of src, and transfers the result to the carry flag.

Details :

| Byte | State |           | Mnemonic | Code      |
|------|-------|-----------|----------|-----------|
|      | Word  | Long word |          |           |
| 4    | 4     | -         | ANDCF    | #4, r     |
| 4    | 4     | -         | ANDCF    | A, r      |
| 8    | -     | -         | ANDCF    | #3, (mem) |
| 8    | -     | -         | ANDCF    | A, (mem)  |

Notes : When bit num is specified by the A register, the value of the lower 4 bits of the A register is used as bit num. When the operand is a byte and the value of the lower 4 bits of bit num is from 8 to 15, the result is undefined.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | * |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = The value obtained by anding the contents of the carry flag and the bit num of src is set.

Execution example: ANDCF 6,(100H)

When the contents of memory address 100 = 01000000B (binary) and the carry flag = 1, execution sets the carry flag to 1.



## BIT num, src

&lt; Bit test &gt;

Operation : Z flag  $\leftarrow$  inverted value of src<num>

Description : Transfers the inverted value of the bit num of src to the Z flag.

Details :

| Byte | State |           | Mnemonic | #4, r     | Code                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
|------|-------|-----------|----------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|--|---|---|
|      | Word  | Long word |          |           |                                                                                                                                                                                                                                                                           |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 4    | 4     | -         | BIT      | #4, r     | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>#</td><td>4</td></tr> </table> | 1  | 1 | 0 | z | 1 |   | r | 0 | 0 | 1 | 1 | 0 | 0 | 1  | 0 | 0 | 0 | 0 |  | # | 4 |
| 1    | 1     | 0         | z        | 1         |                                                                                                                                                                                                                                                                           | r  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 0    | 0     | 1         | 1        | 0         | 0                                                                                                                                                                                                                                                                         | 1  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 0    | 0     | 0         | 0        |           | #                                                                                                                                                                                                                                                                         | 4  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 8    | -     |           | BIT      | #3, (mem) | <table border="1"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td><td></td><td>#3</td></tr> </table>                                                                               | 1  | m | 1 | 1 | m | m | m | 1 | 1 | 0 | 0 | 1 |   | #3 |   |   |   |   |  |   |   |
| 1    | m     | 1         | 1        | m         | m                                                                                                                                                                                                                                                                         | m  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 1    | 1     | 0         | 0        | 1         |                                                                                                                                                                                                                                                                           | #3 |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| x | * | 1 | x | 0 | - |
|---|---|---|---|---|---|

S = An undefined value is set.

Z = The inverted value of src&lt;num&gt; is set.

H = 1 is set.

V = An undefined value is set.

N = Reset to 0.

C = No change

Execution example: BIT 5,(100H)

When the contents of memory address 100 = 00100000B (binary), execution sets the Z flag to 0.



## BS1B dst, src

&lt; Bit Search 1 Backward &gt;

Operation : dst  $\leftarrow$  src backward searched value

Description : Searches the src bit pattern backward (from MSB to LSB) for the first bit set to 1 and transfers the bit number to dst.



Details :

| Byte | State |           | Mnemonic | Code |
|------|-------|-----------|----------|------|
|      | Word  | Long word |          |      |
| -    | 4     | -         | BS1B     | A, r |

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

Note : dst in the operand must be the A register; src must be the register in words. If no bit set to 1 is found in the searched bit pattern, sets the A register to an undefined value and the V flag to 1.

| Flags : | S | Z | H | V | N | C |
|---------|---|---|---|---|---|---|
|         | - | - | - | * | - | - |

S = No change

Z = No change

H = No change

V = 1 is set if the contents of src are all 0s (no bit is set to 1), otherwise 0.

N = No change

C = No change

Execution example: BS1B A,IX

When the IX register = 1200H, execution sets the A register to 0CH.



**BS1F dst, src**

&lt; Bit Search 1 Forward &gt;

**Operation :** dst  $\leftarrow$  src forward searched result

**Description :** Searches the src bit pattern forward (from LSB to MSB) for the first bit set to 1 and transfers the bit number to dst.

**Details :**

| Byte | State<br>Word | Mnemonic<br>Long word | Code |
|------|---------------|-----------------------|------|
| -    | 4             | BS1F                  | A, r |

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

**Note :** dst in the operand must be the A register; src must be a register in words.

If no bit set to 1 is found in the searched bit pattern, sets the A register to an undefined value and the V flag to 1.

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | * | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = 1 is set if the contents of src are all 0s (no bit is set to 1), otherwise 0.

N = No change

C = No change

**Execution example:** BS1F A,IX

When the IX register = 1200H, execution sets the A register to 09H.



## CALL condition, dst

< Call subroutine >

**Operation :** In minimum mode, if cc is true, then XSP  $\leftarrow$  XSP - 2, (XSP)  $\leftarrow$  16-bit PC, PC  $\leftarrow$  dst.

In maximum mode, if cc is true, then XSP  $\leftarrow$  XSP - 4, (XSP)  $\leftarrow$  32-bit PC, PC  $\leftarrow$  dst.

**Description :** If the operand condition is true, saves the contents of the program counter to the stack area and jumps to the program address specified by dst.

**Details :**

|                                                                                                 | State | Mnemonic       | Code                                                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |        |   |   |   |   |   |   |   |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--------|---|---|---|---|---|---|---|---------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|
| 12 (minimum mode)                                                                               |       | CALL #16       | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> </table>                                              | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | #<7:0> |   |   |   |   |   |   |   | #<15:8> |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 0                                                                                               | 0     | 0              | 1                                                                                                                                                                                                                                                                                                        | 1 | 1 | 0 | 0 |   |   |   |   |        |   |   |   |   |   |   |   |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>                                                                                          |       |                |                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |        |   |   |   |   |   |   |   |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>                                                                                         |       |                |                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |        |   |   |   |   |   |   |   |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 14 (maximum mode)                                                                               |       | CALL #24       | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> <tr><td colspan="8">#&lt;23:16&gt;</td></tr> </table> | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | #<7:0> |   |   |   |   |   |   |   | #<15:8> |  |  |  |  |  |  |  | #<23:16> |  |  |  |  |  |  |  |
| 0                                                                                               | 0     | 0              | 1                                                                                                                                                                                                                                                                                                        | 1 | 1 | 0 | 1 |   |   |   |   |        |   |   |   |   |   |   |   |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>                                                                                          |       |                |                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |        |   |   |   |   |   |   |   |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>                                                                                         |       |                |                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |        |   |   |   |   |   |   |   |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<23:16>                                                                                        |       |                |                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |        |   |   |   |   |   |   |   |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 12 (If cc is true, in minimum mode)<br>14 (If cc is true, in maximum mode.)<br>6 (cc is false.) |       | CALL [cc,] mem | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>1</td><td>1</td><td>0</td><td>c</td><td>c</td><td>c</td><td>1</td></tr> </table>                                           | 1 | m | 1 | 1 | m | m | m | m | 1      | 1 | 1 | 0 | c | c | c | 1 |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1                                                                                               | m     | 1              | 1                                                                                                                                                                                                                                                                                                        | m | m | m | m |   |   |   |   |        |   |   |   |   |   |   |   |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1                                                                                               | 1     | 1              | 0                                                                                                                                                                                                                                                                                                        | c | c | c | 1 |   |   |   |   |        |   |   |   |   |   |   |   |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**Execution example:** CALL 9000H

When the stack pointer XSP is 100H in minimum mode, executing this instruction at memory address 8000H writes the return address 8003H (word data) to memory address 0FEH, sets the stack pointer XSP to 0FEH, and jumps to address 9000H.

**CALR dst**

&lt; Call Relative &gt;

**Operation :** In minimum mode,  $XSP \leftarrow XSP - 2$ ,  $(XSP) \leftarrow 16\text{-bit PC}$ ,  $PC \leftarrow dst$ .  
 In maximum mode,  $XSP \leftarrow XSP - 4$ ,  $(XSP) \leftarrow 32\text{-bit PC}$ ,  $PC \leftarrow dst$ .

**Description :** Saves the contents of the program counter to the stack area and makes a relative jump to the program address specified by dst.

**Details :**

| State             | Mnemonic      | Code                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|-------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--------|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|
| 12 (minimum mode) | CALR \$+3+d16 | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td></tr> <tr><td colspan="8">d&lt;7:0&gt;</td></tr> <tr><td colspan="8">d&lt;15:8&gt;</td></tr> </table> | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | d<7:0> |  |  |  |  |  |  |  | d<15:8> |  |  |  |  |  |  |  |
| 0                 | 0             | 0                                                                                                                                                                                                                                                           | 1 | 1 | 1 | 1 | 0 |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| d<7:0>            |               |                                                                                                                                                                                                                                                             |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| d<15:8>           |               |                                                                                                                                                                                                                                                             |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| 14 (maximum mode) |               |                                                                                                                                                                                                                                                             |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |

**Flags :** S Z H V N C  

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

- S = No change
- Z = No change
- H = No change
- V = No change
- N = No change
- C = No change

# CCF

**< Complement Carry Flag >**

**Operation :** CY  $\leftarrow$  inverted value of CY

**Description :** Inverts the contents of the carry flag.

**Details :**

| State | Mnemonic | Code                                                                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|
| 2     | CCF      | <table border="1" style="margin-left: auto; margin-right: auto;"><tr><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td></tr></table> | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 0 |
| 0     | 1        | 0                                                                                                                                                                                      | 1 | 0 | 1 | 1 | 0 | 1 | 0 |   |   |   |

**Flags :** S Z H V N C  

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | X | - | 0 | * |
|---|---|---|---|---|---|

S = No change

Z = No change

H = An undefined value is set.

V = No change

N = Reset to 0.

C = Inverted value of itself is set.

**Execution example:** When the carry flag = 0, executing CCF sets the carry flag to 1; executing CCF again sets the carry flag to 0.



## CHG num, dst

&lt; Change &gt;

Operation : dst<num>  $\leftarrow$  Inverted value of dst<num>

Description : Inverts the value of bit num of dst.

Details :

| Byte | State | Mnemonic     | Code                                                                                                                                                                                                                                                                                                   |   |    |    |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |    |  |  |
|------|-------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----|----|---|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|---|--|----|--|--|
|      | Word  | Long word    |                                                                                                                                                                                                                                                                                                        |   |    |    |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |    |  |  |
| 4    | 4     | - CHG #4,r   | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td><td>0</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>#4</td><td></td><td></td></tr> </table> | 1 | 1  | 0  | z | 1 |   | r | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1  | 0 | 0 | 0 | 0 | 0 |  | #4 |  |  |
| 1    | 1     | 0            | z                                                                                                                                                                                                                                                                                                      | 1 |    | r  | 1 |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |    |  |  |
| 0    | 0     | 1            | 1                                                                                                                                                                                                                                                                                                      | 0 | 0  | 1  | 0 |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |    |  |  |
| 0    | 0     | 0            | 0                                                                                                                                                                                                                                                                                                      |   | #4 |    |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |    |  |  |
| 8    | -     | CHG #3,(mem) | <table border="1"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>0</td><td>0</td><td></td><td>#3</td><td>1</td></tr> </table>                                                                                        | 1 | m  | 1  | 1 | m | m | m | m | 1 | 1 | 0 | 0 | 0 |   | #3 | 1 |   |   |   |   |  |    |  |  |
| 1    | m     | 1            | 1                                                                                                                                                                                                                                                                                                      | m | m  | m  | m |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |    |  |  |
| 1    | 1     | 0            | 0                                                                                                                                                                                                                                                                                                      | 0 |    | #3 | 1 |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |    |  |  |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: CHG 5,(100H)

When the contents of memory address 100 = 00100111B (binary), execution sets the contents to 00000111B (binary).



## CP src1, src2

&lt; Compare &gt;

Operation : src1 - src2

Description : Compares the contents of src1 with those of src2 and indicates the results in flag register F.



Details :

| Byte      | State<br>Word | Long word | Mnemonic | Code                                                                                                                                                                                                                                                                                                                                                                            |   |    |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
|-----------|---------------|-----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----|---|---|---|---|---|---|---|---|---|---|---|----|---------|--|--|--|--|--|--|----------|--|--|--|--|--|--|-----------|--|--|--|--|--|--|-----------|--|--|--|--|--|--|
| 4         | 4             | 7         | CP       | R, r                                                                                                                                                                                                                                                                                                                                                                            |   |    |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
|           |               |           |          | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td></tr> <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td></td><td>R</td></tr> </table>                                                                                                                                                                                       | 1 | 1  | z | z | 1 |   | r | 1 | 1 | 1 | 1 | 0 |   | R  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 1         | 1             | z         | z        | 1                                                                                                                                                                                                                                                                                                                                                                               |   | r  |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 1         | 1             | 1         | 1        | 0                                                                                                                                                                                                                                                                                                                                                                               |   | R  |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 4         | 4             | -         | CP       | r, #3                                                                                                                                                                                                                                                                                                                                                                           |   |    |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
|           |               |           |          | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td></td><td>#3</td></tr> </table>                                                                                                                                                                                      | 1 | 1  | 0 | z | 1 |   | r | 1 | 1 | 0 | 1 | 1 |   | #3 |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 1         | 1             | 0         | z        | 1                                                                                                                                                                                                                                                                                                                                                                               |   | r  |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 1         | 1             | 0         | 1        | 1                                                                                                                                                                                                                                                                                                                                                                               |   | #3 |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 4         | 4             | 7         | CP       | r, #                                                                                                                                                                                                                                                                                                                                                                            |   |    |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
|           |               |           |          | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td></tr> <tr><td colspan="7"># &lt;7:0&gt;</td></tr> <tr><td colspan="7"># &lt;15:8&gt;</td></tr> <tr><td colspan="7"># &lt;23:16&gt;</td></tr> <tr><td colspan="7"># &lt;31:24&gt;</td></tr> </table> | 1 | 1  | z | z | 1 |   | r | 1 | 1 | 0 | 0 | 1 | 1 | 1  | # <7:0> |  |  |  |  |  |  | # <15:8> |  |  |  |  |  |  | # <23:16> |  |  |  |  |  |  | # <31:24> |  |  |  |  |  |  |
| 1         | 1             | z         | z        | 1                                                                                                                                                                                                                                                                                                                                                                               |   | r  |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 1         | 1             | 0         | 0        | 1                                                                                                                                                                                                                                                                                                                                                                               | 1 | 1  |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| # <7:0>   |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                 |   |    |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| # <15:8>  |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                 |   |    |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| # <23:16> |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                 |   |    |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| # <31:24> |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                 |   |    |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 4         | 4             | 6         | CP       | R, (mem)                                                                                                                                                                                                                                                                                                                                                                        |   |    |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
|           |               |           |          | <table border="1"> <tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td></td><td>R</td></tr> </table>                                                                                                                                                                                      | 1 | m  | z | z | m | m | m | 1 | 1 | 1 | 1 | 0 |   | R  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 1         | m             | z         | z        | m                                                                                                                                                                                                                                                                                                                                                                               | m | m  |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 1         | 1             | 1         | 1        | 0                                                                                                                                                                                                                                                                                                                                                                               |   | R  |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 6         | 6             | 6         | CP       | (mem), R                                                                                                                                                                                                                                                                                                                                                                        |   |    |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
|           |               |           |          | <table border="1"> <tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td></td><td>R</td></tr> </table>                                                                                                                                                                                      | 1 | m  | z | z | m | m | m | 1 | 1 | 1 | 1 | 1 |   | R  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 1         | m             | z         | z        | m                                                                                                                                                                                                                                                                                                                                                                               | m | m  |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 1         | 1             | 1         | 1        | 1                                                                                                                                                                                                                                                                                                                                                                               |   | R  |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 6         | 6             | -         | CP<W>    | (mem), #                                                                                                                                                                                                                                                                                                                                                                        |   |    |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
|           |               |           |          | <table border="1"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td></tr> <tr><td colspan="7"># &lt;7:0&gt;</td></tr> <tr><td colspan="7"># &lt;15:8&gt;</td></tr> </table>                                                                                            | 1 | m  | 0 | z | m | m | m | 0 | 0 | 1 | 1 | 1 | 1 | 1  | # <7:0> |  |  |  |  |  |  | # <15:8> |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 1         | m             | 0         | z        | m                                                                                                                                                                                                                                                                                                                                                                               | m | m  |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| 0         | 0             | 1         | 1        | 1                                                                                                                                                                                                                                                                                                                                                                               | 1 | 1  |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| # <7:0>   |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                 |   |    |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |
| # <15:8>  |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                 |   |    |   |   |   |   |   |   |   |   |   |   |   |    |         |  |  |  |  |  |  |          |  |  |  |  |  |  |           |  |  |  |  |  |  |           |  |  |  |  |  |  |

Note : #3 in operands indicates from 0 to 7.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | 1 | * |
|---|---|---|---|---|---|

S = MSB value of the result is set.

Z = 1 is set if the result is 0, otherwise 0.

H = 1 is set if a borrow from bit 3 to bit 4 occurs as a result of the operation, otherwise 0. If the operand is 32 bits, an undefined value is set.

V = 1 is set if an overflow occurs as a result of the operation, otherwise 0.

N = 1 is set.

C = 1 is set if a borrow occurs from the MSB bit as a result of the operation, otherwise 0.

Execution example: CP HL,IX

When the HL register = 1234H and the IX register = 1234H, execution sets the Z and N flags to 1 and clears the S, H, V, and C flags to zero.



**CPD src1, src2**

&lt; Compare Decrement &gt;

Operation :  $\text{src1} - \text{src2}, \text{BC} \leftarrow \text{BC} - 1$ 

Description : Compares the contents of src1 with those of src2, then decrements the contents of the BC register by 1. src1 must be the A or WA register. src2 must be in post-decrement register indirect addressing mode.



Details :

| Byte | State |           | Mnemonic | Code                                          |
|------|-------|-----------|----------|-----------------------------------------------|
|      | Word  | Long word |          |                                               |
| 8    | 8     | -         | CPD      | [A/WA,(R-)]<br>1 0 0 z 0 R<br>0 0 0 1 0 1 1 0 |

Note : Omitting operands in square brackets [] specifies A,(XHL-).

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | 1 | - |
|---|---|---|---|---|---|

S = MSB value of the result of src1-src2 is set.

Z = 1 is set if the result of src1-src2 is 0, otherwise 0.

H = 1 is set if a borrow from bit 3 to bit 4 occurs as a result of src1-src2, otherwise 0.

V = 0 is set if the BC register value is 0 after execution, otherwise 1.

N = 1 is set.

C = No change

Execution example: CPI A,(XIX-)

When the XIX register = 00123456H and the BC register = 0200H, execution compares the contents of the A register with those of memory address 123456H, then sets the XIX register to 00123455H, the BC register to 01FFH.

**CPDR src1, src2**

&lt; Compare Decrement Repeat &gt;

Operation : src1 - src2, BC  $\leftarrow$  BC - 1, Repeat until src1 = src2 or BC = 0

Description : Compares the contents of src1 with those of src2. Then decrements the contents of the BC register by 1. Repeats until src1 = src2 or BC = 0. src1 must be the A or WA register. src2 must be in post-decrement register indirect addressing mode.

Details :

| Byte | State           |           | Mnemonic | Code                                                                                                                                                                                                                                                                 |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |
|------|-----------------|-----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|---|--|---|---|---|---|---|---|---|---|
|      | Word            | Long word |          |                                                                                                                                                                                                                                                                      |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |
| 10   | 10              | -         | CPDR     | [A/WA, (R-)]                                                                                                                                                                                                                                                         |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |
|      | (At non-repeat) |           |          | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>0</td><td>0</td><td>z</td><td>0</td><td></td><td>R</td><td></td></tr> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td><td>1</td></tr> </table> | 1 | 0 | 0 | z | 0 |  | R |  | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 |
| 1    | 0               | 0         | z        | 0                                                                                                                                                                                                                                                                    |   | R |   |   |   |  |   |  |   |   |   |   |   |   |   |   |
| 0    | 0               | 0         | 1        | 0                                                                                                                                                                                                                                                                    | 1 | 1 | 1 |   |   |  |   |  |   |   |   |   |   |   |   |   |

14      14      -  
 (At repeat)

Note : Omitting operands in square brackets [] specifies A,(XHL-).

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | 1 | - |
|---|---|---|---|---|---|

S = MSB value of the result of src1 - src2 is set.

Z = 1 is set if the result of src1 - src2 is 0, otherwise 0.

H = 1 is set if a borrow from bit 3 to bit 4 occurs as a result of src1 - src2, otherwise 0.

V = 0 is set if the BC register value is 0 after execution, otherwise 1.

N = 1 is set.

C = No change

Execution example: CPIR A,(XIX-)

Under the following conditions, execution reads the contents of memory addresses 123456H, 123455H, and 123454H. The instruction ends with condition BC = 0 and sets the XIX register to 00123453H and the BC register to 0000H.

Conditions: A register = 55H

XIX register = 00123456H

BC register = 0003H

Memory address 123456H = 11H

Memory address 123455H = 22H

Memory address 123454H = 33H

## CPI src1, src2

< Compare Increment >

Operation : src1-src2, BC  $\leftarrow$  BC - 1

Description : Compares the contents of src1 with those of src2, then decrements the contents of the BC register by 1. src1 must be the A or WA register. src2 must be in post-increment register indirect addressing mode.

Details :

| Byte | State |           | Mnemonic | [A/WA, (R+)] | Code        |                 |
|------|-------|-----------|----------|--------------|-------------|-----------------|
|      | Word  | Long word |          |              |             |                 |
| 8    | 8     | -         | CPI      | [A/WA, (R+)] | 1 0 0 z 0 R | 0 0 0 1 0 1 0 0 |

Note : Omitting operands enclosed in square brackets [] specifies A,(XHL+).

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | 1 | - |
|---|---|---|---|---|---|

S = MSB value of the result of src1-src2 is set.

Z = 1 is set if the result of src1-src2 is 0, otherwise 0.

H = 1 is set if a borrow from bit 3 to bit 4 occurs as a result of src1-src2, otherwise 0.

V = 0 is set if the BC register value is 0 after execution, otherwise 1.

N = 1 is set.

C = No change

Execution example: CPI A,(XIX+)

When the XIX register = 00123456H and the BC register = 0200H, execution compares the contents of the A register with those of memory address 123456H, and sets the XIX register to 00123457H and the BC register to 01FFH.

**CPIR src1, src2**

&lt; Compare Increment Repeat &gt;

**Operation :** src1-src2, BC  $\leftarrow$  BC - 1, repeat until src1 = src2 or BC = 0

**Description :** Compares the contents of src1 with those of src2. Then decrements the contents of the BC register by 1. Repeats until src1 = src2 or BC = 0. src1 must be the A or WA register. src2 must be in post-increment register indirect addressing mode.

**Details :**

| Byte                  | State |           | Mnemonic | Code                                                                                                                                                                                                                   |   |   |   |   |   |   |  |   |   |   |   |   |   |   |
|-----------------------|-------|-----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|--|---|---|---|---|---|---|---|
|                       | Word  | Long word |          |                                                                                                                                                                                                                        |   |   |   |   |   |   |  |   |   |   |   |   |   |   |
| 10<br>(At non-repeat) | 10    | -         | CPIR     | [A/WA, (R+)]                                                                                                                                                                                                           |   |   |   |   |   |   |  |   |   |   |   |   |   |   |
| 14<br>(At repeat)     | 14    | -         |          | <table border="1" style="display: inline-table;"><tr><td>1</td><td>0</td><td>0</td><td>z</td><td>0</td><td>R</td><td></td></tr><tr><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td></tr></table> | 1 | 0 | 0 | z | 0 | R |  | 0 | 0 | 0 | 1 | 0 | 1 | 0 |
| 1                     | 0     | 0         | z        | 0                                                                                                                                                                                                                      | R |   |   |   |   |   |  |   |   |   |   |   |   |   |
| 0                     | 0     | 0         | 1        | 0                                                                                                                                                                                                                      | 1 | 0 |   |   |   |   |  |   |   |   |   |   |   |   |

**Note :** Omitting operands in square brackets [ ] specifies A,(XHL+).

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | 1 | - |
|---|---|---|---|---|---|

S = MSB value of the result of src1-src2 is set.

Z = 1 is set if the result of src1-src2 is 0, otherwise 0.

H = 1 is set if a borrow from bit 3 to bit 4 occurs as a result of src1-src2, otherwise 0.

V = 0 is set if the BC register value is 0 after execution, otherwise 1.

N = 1 is set.

C = No change

**Execution example:** CPIR A,(XIX+)

Under the following conditions, execution reads memory addresses 123456H, 123457H, and 123458H. The instruction ends with condition src1 = src2, sets the XIX register to 00123459H and the BC register to 01FDH.

Conditions: A register = 33H

XIX register = 00123456

HBC register = 0200H

Memory address 123456H = 11H

Memory address 123457H = 22H

Memory address 123458H = 33H

**CPL dst**

&lt; Complement &gt;

Operation : dst  $\leftarrow$  Ones complement of dst

Description : Transfers the value of ones complement (inverted bit of 0/1) of dst to dst.

Details :

| Byte | State |           | Mnemonic | Code |
|------|-------|-----------|----------|------|
|      | Word  | Long word |          |      |
| 4    | 4     | -         | CPL      | r    |

1 1 0 z 1   r    
0 0 0 0 0 1 1 0

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | 1 | - | 1 | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = 1 is set.

V = No change

N = 1 is set.

C = No change

Execution example: CPL WA

When the WA register = 1234H, execution sets the WA register to EDCBH.



**DAA dst**

&lt; Decimal Adjust Accumulator &gt;

**Operation :** dst  $\leftarrow$  decimal adjustment of dst

**Description :** Decimal adjusts the contents of dst depending on the states of the C, H, and N flags. Used to adjust the execution result of the add or subtract instruction as binary-coded decimal (BCD).

**Details :**

| Byte | State |           | Mnemonic | Code                                                                                                                                                                                                                                                       |   |   |   |   |   |  |   |   |   |   |   |   |   |   |
|------|-------|-----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|---|---|---|---|---|---|---|---|
|      | Word  | Long word |          |                                                                                                                                                                                                                                                            |   |   |   |   |   |  |   |   |   |   |   |   |   |   |
| 6    | -     | -         | DAA      | r<br><table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>1</td><td>1</td><td>0</td><td>0</td><td>1</td><td></td><td>r</td> </tr> <tr> <td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td> </tr> </table> | 1 | 1 | 0 | 0 | 1 |  | r | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 1    | 1     | 0         | 0        | 1                                                                                                                                                                                                                                                          |   | r |   |   |   |  |   |   |   |   |   |   |   |   |
| 0    | 0     | 0         | 1        | 0                                                                                                                                                                                                                                                          | 0 | 0 |   |   |   |  |   |   |   |   |   |   |   |   |

| Operation | N flag before DAA instruction execution | C flag before DAA instruction execution | Upper 4 bits of dst | H flag before DAA instruction execution | Lower 4 bits of dst | Added value | C flag after DAA instruction execution |
|-----------|-----------------------------------------|-----------------------------------------|---------------------|-----------------------------------------|---------------------|-------------|----------------------------------------|
| ADD       | 0                                       | 0                                       | 0~9                 | 0                                       | 0~9                 | 00          | 0                                      |
|           | 0                                       | 0                                       | 0~8                 | 0                                       | A~F                 | 06          | 0                                      |
|           | 0                                       | 0                                       | 0~9                 | 1                                       | 0~3                 | 06          | 0                                      |
|           | 0                                       | 0                                       | A~F                 | 0                                       | 0~9                 | 60          | 1                                      |
| ADC       | 0                                       | 0                                       | 9~F                 | 0                                       | A~F                 | 66          | 1                                      |
|           | 0                                       | 0                                       | A~F                 | 1                                       | 0~3                 | 66          | 1                                      |
|           | 0                                       | 1                                       | 0~2                 | 0                                       | 0~9                 | 60          | 1                                      |
|           | 0                                       | 1                                       | 0~2                 | 0                                       | A~F                 | 66          | 1                                      |
| SUB       | 0                                       | 1                                       | 0~3                 | 1                                       | 0~3                 | 66          | 1                                      |
|           | 1                                       | 0                                       | 0~9                 | 0                                       | 0~9                 | 00          | 0                                      |
|           | 1                                       | 0                                       | 0~8                 | 1                                       | 6~F                 | FA          | 0                                      |
|           | 1                                       | 1                                       | 7~F                 | 0                                       | 0~9                 | A0          | 1                                      |
| SBC       | 1                                       | 1                                       | 6~F                 | 1                                       | 6~F                 | 9A          | 1                                      |
|           | 1                                       | 1                                       | 6~F                 | 0                                       |                     |             |                                        |
| NEG       |                                         |                                         |                     |                                         |                     |             |                                        |

**Note :** Decimal adjustment cannot be performed for the INC or DEC instruction. This is because the C flag does not change.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | - | * |
|---|---|---|---|---|---|

S = MSB value of the result is set.

Z = 1 is set if the result is 0, otherwise 0.

H = 1 is set if a carry from bit 3 to bit 4 occurs as a result of the operation, otherwise 0.

V = 1 is set if the parity (number of 1s) of the result is even, otherwise 0.

N = No change

C = 1 is set if a carry occurs from the MSB as a result of the operation or a carry was 1 before operation, otherwise 0.

Execution example: ADD A,B

DAA A

When the A register = 59H and the B register = 13 H,  
execution sets the A register to 72H.



## DEC num, dst

&lt; Decrement &gt;

Operation :  $dst \leftarrow dst - num$ 

Description : Decrements dst by the contents of num and transfers the result to dst.

Details :

| Byte | State |           | Mnemonic | #3, r     | Code                                                                                                                                                                                        |    |   |   |   |   |   |   |   |   |   |   |    |  |    |
|------|-------|-----------|----------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|----|--|----|
|      | Word  | Long word |          |           |                                                                                                                                                                                             |    |   |   |   |   |   |   |   |   |   |   |    |  |    |
| 4    | 4     | 5         | DEC      | #3, r     | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td>r</td></tr> <tr><td>0</td><td>1</td><td>1</td><td>0</td><td>1</td><td>#3</td></tr> </table>                    | 1  | 1 | z | z | 1 | r | 0 | 1 | 1 | 0 | 1 | #3 |  |    |
| 1    | 1     | z         | z        | 1         | r                                                                                                                                                                                           |    |   |   |   |   |   |   |   |   |   |   |    |  |    |
| 0    | 1     | 1         | 0        | 1         | #3                                                                                                                                                                                          |    |   |   |   |   |   |   |   |   |   |   |    |  |    |
| 6    | 6     | -         | DEC<W>   | #3, (mem) | <table border="1"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>1</td><td>1</td><td>0</td><td>1</td><td></td><td>#3</td></tr> </table> | 1  | m | 0 | z | m | m | m | 0 | 1 | 1 | 0 | 1  |  | #3 |
| 1    | m     | 0         | z        | m         | m                                                                                                                                                                                           | m  |   |   |   |   |   |   |   |   |   |   |    |  |    |
| 0    | 1     | 1         | 0        | 1         |                                                                                                                                                                                             | #3 |   |   |   |   |   |   |   |   |   |   |    |  |    |

Note : #3 in operands indicates from 1 to 8; object codes correspond from 1 to 7,0.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | 1 | - |
|---|---|---|---|---|---|

S = MSB value of the result is set.

Z = 1 is set if the result is 0, otherwise 0.

H = 1 is set if a borrow from bit 3 to bit 4 occurs as a result of the operation, otherwise 0.

V = 1 is set if an overflow occurs as a result of the operation, otherwise 0.

N = 1 is set.

C = No change

Note : With the DEC #3, r instruction, if the operand is a word or a long word, no flags change.

Execution example: DEC 4, HL

When the HL register = 5678H, execution sets the HL register to 5674H.

## DEC<sub>F</sub>

*< Decrement Register File Pointer >*

**Operation** : RFP<2:0>  $\leftarrow$  RFP<2:0> - 1

**Description** : Decrements the contents of register file pointer RFP <2:0> in the status register by 1. In maximum mode, RFP2 is fixed to 0.

**Details** :

| State | Mnemonic         | Code                                                                                                                                                                                                                                                                                                                                                                             |   |   |   |   |   |   |   |   |
|-------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|
| 2     | DEC <sub>F</sub> | <table border="1" style="margin-left: auto; margin-right: auto; border-collapse: collapse;"> <tr> <td style="padding: 2px;">0</td><td style="padding: 2px;">0</td><td style="padding: 2px;">0</td><td style="padding: 2px;">1</td><td style="padding: 2px;">1</td><td style="padding: 2px;">1</td><td style="padding: 2px;">0</td><td style="padding: 2px;">1</td></tr> </table> | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 |
| 0     | 0                | 0                                                                                                                                                                                                                                                                                                                                                                                | 1 | 1 | 1 | 0 | 1 |   |   |   |

**Flags** : S Z H V N C  

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**Execution example:** DEC<sub>F</sub>

When the contents of RFP<2:0> = 2, execution sets the contents of RFP<2:0> to 1.

## DI

<Disable Interrupt>

This is privileged instruction in 900 CPU.

Operation : IFF<2:0> ← 7

Description : Sets the contents of the interrupt enable flag (IFF) <2:0> in status register to 7. After execution, only non-maskable interrupts (interrupt level 7) can be received.

Details :

| State | Mnemonic | Code                                                                                                                                                                                                         |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 5     | DI       | <table border="1"><tr><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td></tr><tr><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td></tr></table> | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
| 0     | 0        | 0                                                                                                                                                                                                            | 0 | 0 | 1 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |
| 0     | 0        | 0                                                                                                                                                                                                            | 0 | 0 | 1 | 1 | 1 |   |   |   |   |   |   |   |   |   |   |   |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| — | — | — | — | — | — |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**DIV dst, src**

&lt; Divide &gt;

**Operation :** dst<lower half>  $\leftarrow$  dst  $\div$  src, dst<upper half>  $\leftarrow$  remainder (unsigned)

**Description :** Divides unsigned the contents of dst by those of src and transfers the quotient to the lower half of dst, the remainder to the upper half of dst.

**Details :**

| Byte    | State<br>Word | Long word | Mnemonic | Code                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|---------|---------------|-----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--------|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|
| 22      | 30            | -         | DIV      | RR, r                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|         |               |           |          | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td><td></td><td>R</td><td></td></tr> </table>                                                                                          | 1 | 1 | 0 | z | 1 |   | r |   | 0 | 1 | 0 | 1 | 0 |   | R |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| 1       | 1             | 0         | z        | 1                                                                                                                                                                                                                                                                                                    |   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| 0       | 1             | 0         | 1        | 0                                                                                                                                                                                                                                                                                                    |   | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| 22      | 30            | -         | DIV      | rr, #                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|         |               |           |          | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> </table> | 1 | 1 | 0 | z | 1 |   | r |   | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | #<7:0> |  |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |  |
| 1       | 1             | 0         | z        | 1                                                                                                                                                                                                                                                                                                    |   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| 0       | 0             | 0         | 0        | 1                                                                                                                                                                                                                                                                                                    | 0 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| #<7:0>  |               |           |          |                                                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| #<15:8> |               |           |          |                                                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| 22      | 30            | -         | DIV      | RR, (mem)                                                                                                                                                                                                                                                                                            |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|         |               |           |          | <table border="1"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td><td></td><td>R</td><td></td></tr> </table>                                                                                        | 1 | m | 0 | z | m | m | m | m | 0 | 1 | 0 | 1 | 0 |   | R |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| 1       | m             | 0         | z        | m                                                                                                                                                                                                                                                                                                    | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| 0       | 1             | 0         | 1        | 0                                                                                                                                                                                                                                                                                                    |   | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |

\*For RR, see the following page.

**Notes :** When the operation is in bytes, dst (lower byte)  $\leftarrow$  dst (word)  $\div$  src (byte),  
dst (upper byte)  $\leftarrow$  remainder.

When the operation is in words, dst (lower word)  $\leftarrow$  dst (long word)  $\div$  src (word),  
dst (upper word)  $\leftarrow$  remainder. Match coding of the operand dst with the size of the  
dividend.

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | V | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = 1 is set when divided by 0 or the quotient exceeds the numerals which can be  
expressed in bits of dst for load; otherwise, 0 is set.

N = No change

C = No change

Execution example: DIV XIX,IY

When the XIX register = 12345678H and the IY register = 89ABH, execution results in a quotient of 21DAH and a remainder of 0FDAH, and sets the XIX register to 0FDA21DAH.

Note : : "RR" of the DIV RR,r and DIV RR,(mem) instruction is as listed below.

Operation size in bytes  
(8 bits ← 16 bits ÷ 8 bits)

| RR | Code "R" |
|----|----------|
| WA | 001      |
| BC | 011      |
| DE | 101      |
| HL | 111      |
| IX |          |
| IY |          |
| IZ |          |
| SP |          |

Specification not possible!

Operation size in words  
(16 bits ← 32 bits ÷ 16 bits)

| RR  | Code "R" |
|-----|----------|
| XWA | 000      |
| XBC | 001      |
| XDE | 010      |
| XHL | 011      |
| XIX | 100      |
| XIY | 101      |
| XIZ | 110      |
| XSP | 111      |

\*1 When the CPU is in minimum mode, XWA, XBC, XDE, and XHL cannot be used.

"rr" of the DIV rr,# instruction is as listed below.

Operation size in bytes  
(8 bits ← 16 bits ÷ 8 bits)

| rr | Code "r"  |
|----|-----------|
| WA | 001       |
| BC | 011       |
| DE | 101       |
| HL | 111       |
| IX | C7H : F0H |
| IY | C7H : F4H |
| IZ | C7H : F8H |
| SP | C7H : FCH |

1st byte    2nd byte

\*2 Any other word registers can be specified in the same extension coding as IX to SP.

Operation size in words  
(16 bits ← 32 bits ÷ 16 bits)

| rr  | Code "r" |
|-----|----------|
| XWA | 000      |
| XBC | 001      |
| XDE | 010      |
| XHL | 011      |
| XIX | 100      |
| XIY | 101      |
| XIZ | 110      |
| XSP | 111      |

\*3 When the CPU is in minimum mode, XWA, XBC, XDE, and XHL cannot be used.

\*4 Any other long word registers can be specified in the extension coding.

**DIVS dst, src**

&lt; Divide Signed &gt;

Operation : dst<lower half>  $\leftarrow$  dst  $\div$  src, dst<upper half>  $\leftarrow$  remainder (signed)

Description : Divides signed the contents of dst by those of src and transfers the quotient to the lower half of dst, the remainder to the upper half of dst.

Details :

| Byte    | State<br>Word | Long word | Mnemonic |           | Code                                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |          |  |  |  |
|---------|---------------|-----------|----------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---------|--|--|--|----------|--|--|--|
|         |               |           | RR, r    | rr, #     |                                                                                                                                                                                                                                                                                           |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |          |  |  |  |
| 24      | 32            | -         | DIVS     | RR, r     | <table border="1"><tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr><tr><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td><td></td><td>R</td><td>1</td></tr></table>                                                                                | 1 | 1 | 0 | z | 1 |   | r | 1 | 0 | 1 | 0 | 1 | 1 |   | R | 1 |         |  |  |  |          |  |  |  |
| 1       | 1             | 0         | z        | 1         |                                                                                                                                                                                                                                                                                           | r | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |          |  |  |  |
| 0       | 1             | 0         | 1        | 1         |                                                                                                                                                                                                                                                                                           | R | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |          |  |  |  |
| 24      | 32            | -         | DIVS     | rr, #     | <table border="1"><tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr><tr><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td></tr><tr><td colspan="4"># &lt;7:0&gt;</td><td colspan="4"># &lt;15:8&gt;</td></tr></table> | 1 | 1 | 0 | z | 1 |   | r | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | # <7:0> |  |  |  | # <15:8> |  |  |  |
| 1       | 1             | 0         | z        | 1         |                                                                                                                                                                                                                                                                                           | r | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |          |  |  |  |
| 0       | 0             | 0         | 0        | 1         | 0                                                                                                                                                                                                                                                                                         | 1 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |          |  |  |  |
| # <7:0> |               |           |          | # <15:8>  |                                                                                                                                                                                                                                                                                           |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |          |  |  |  |
| 24      | 32            | -         | DIVS     | RR, (mem) | <table border="1"><tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr><tr><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td><td></td><td>R</td><td>1</td></tr></table>                                                                               | 1 | m | 0 | z | m | m | m | m | 0 | 1 | 0 | 1 | 1 |   | R | 1 |         |  |  |  |          |  |  |  |
| 1       | m             | 0         | z        | m         | m                                                                                                                                                                                                                                                                                         | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |          |  |  |  |
| 0       | 1             | 0         | 1        | 1         |                                                                                                                                                                                                                                                                                           | R | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |          |  |  |  |

\* For RR, see the following page.

Notes : When the operation is in bytes, dst (lower byte)  $\leftarrow$  dst (word)  $\div$  src (byte), dst (upper byte)  $\leftarrow$  remainder.When the operation is in words, dst (lower word)  $\leftarrow$  dst (long word)  $\div$  src (word), dst (upper word)  $\leftarrow$  remainder.Match coding of the operand dst with the size of the dividend. The sign of the remainder is the same as that of the dividend.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | * | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = 1 is set when divided by 0, or the quotient exceeds the value which can be expressed in bits of the dst used for loading, otherwise 0.

N = No change

C = No change

Execution example: DIVS XIX,IY

When the XIX register = 12345678H and the IY register = 89ABH, execution results in the quotient as 16EEH and the remainder as D89EH, and sets the XIX register to 16EED89EH.

Note : "RR" of the DIVS RR,r and DIVS RR,(mem) instruction is as listed below.

Operation size in bytes  
(8 bits ← 16 bits ÷ 8 bits)

| RR | Code "R" |
|----|----------|
| WA | 001      |
| BC | 011      |
| DE | 101      |
| HL | 111      |
| IX |          |
| IY |          |
| IZ |          |
| SP |          |

} Specification not possible!

Operation size in words  
(16 bits ← 32 bits ÷ 16 bits)

| RR  | Code "R" |
|-----|----------|
| XWA | 000      |
| XBC | 001      |
| XDE | 010      |
| XHL | 011      |
| XIX | 100      |
| XIY | 101      |
| XIZ | 110      |
| XSP | 111      |

\*1 When the CPU is in minimum mode, XWA, XBC, XDE, or XHL cannot be used.

"rr" of the DIVS rr,# instruction is as listed below.

Operation size in bytes  
(8 bits ← 16 bits ÷ 8 bits)

| rr | Code "r"  |
|----|-----------|
| WA | 001       |
| BC | 011       |
| DE | 101       |
| HL | 111       |
| IX | C7H : F0H |
| IY | C7H : F4H |
| IZ | C7H : F8H |
| SP | C7H : FCH |

1st byte    2nd byte

Operation size in words  
(16 bits ← 32 bits ÷ 16 bits)

| rr  | Code "r" |
|-----|----------|
| XWA | 000      |
| XBC | 001      |
| XDE | 010      |
| XHL | 011      |
| XIX | 100      |
| XIY | 101      |
| XIZ | 110      |
| XSP | 111      |

\*3 When the CPU is in minimum mode, XWA, XBC, XDE, or XHL cannot be used.

\*2 Any other word registers can be specified in the same extension coding as those for IX to SP.

\*4 Any other long word registers can be specified in the extension coding.

**DJNZ dst1, dst2**

&lt; Decrement and Jump if Non Zero &gt;

Operation :  $dst1 \leftarrow dst1 - 1$ . if  $dst1 \neq 0$ , then  $PC \leftarrow dst2$ .

Description : Decrements the contents of dst1 by 1. Makes a relative jump to the program address specified by dst2 if the result is other than 0.



Details :

| Byte                    | State |           | Mnemonic | Code                                                                                                                                                                                                                                                                                                                                       |   |   |   |   |   |  |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |
|-------------------------|-------|-----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|---|---|---|---|---|---|---|---|--------|--|--|--|--|--|--|
|                         | Word  | Long word |          |                                                                                                                                                                                                                                                                                                                                            |   |   |   |   |   |  |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |
| 11<br>( $dst1 \neq 0$ ) | 11    | -         | DJNZ     | [r,] \$ + 3 + d8<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td> </tr> <tr> <td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>0</td> </tr> <tr> <td colspan="7" style="text-align: center;">d&lt;7:0&gt;</td> </tr> </table> | 1 | 1 | 0 | z | 1 |  | r | 0 | 0 | 0 | 1 | 1 | 1 | 0 | d<7:0> |  |  |  |  |  |  |
| 1                       | 1     | 0         | z        | 1                                                                                                                                                                                                                                                                                                                                          |   | r |   |   |   |  |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |
| 0                       | 0     | 0         | 1        | 1                                                                                                                                                                                                                                                                                                                                          | 1 | 0 |   |   |   |  |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |
| d<7:0>                  |       |           |          |                                                                                                                                                                                                                                                                                                                                            |   |   |   |   |   |  |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |
| 7<br>( $dst1 = 0$ )     |       |           |          |                                                                                                                                                                                                                                                                                                                                            |   |   |   |   |   |  |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |

Note : Omitting "r" of the operand in square brackets [ ] is regarded as specifying the B register.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: LOOP: ADD A, A  
DJNZ W, LOOP

When the A register = 12H and the W register = 03H, execution loops three times and sets the A register to 24H → 48 → 90H and the W register to 02H → 01H → 00H.

**EI num**

&lt;Enable Interrupt&gt;

This is privileged instruction in 900 CPU.

Operation : IFF &lt;2:0&gt; ← num

Description : Sets the contents of the IFF&lt;2:0&gt; in the status register to num. After execution, the CPU interrupt receive level becomes num.

Details :

| State | Mnemonic | Code                                    |
|-------|----------|-----------------------------------------|
| 5     | EI       | [#3]<br>0 0 0 0 0 1 1 0<br>0 0 0 0 0 #3 |

Note : A value from 0 to 7 can be specified as the operand value. If the operand is omitted, the default value is "0" (EI 0).

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**EX dst, src**

&lt; Exchange &gt;

Operation : dst ↔ src

Description : Exchanges the contents of dst and src.



Details :

| Byte | State<br>Word | Long word | Mnemonic | Code     |
|------|---------------|-----------|----------|----------|
| 2    | —             | —         | EX       | F, F'    |
| 5    | 5             | —         | EX       | R, r     |
| 6    | 6             | —         | EX       | (mem), r |

Flags : S Z H V N C



S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

\* Executing EX F,F' changes all flags.

Execution example: EX A,B

When the A register = 12H and the B register = 34H, execution sets the A register to 34H and the B register to 12H.



EXTS dst

< Extend Sign >

Operation :  $\text{dst} <\text{upper half}> \leftarrow \text{signed bit of } \text{dst} <\text{lower half}>$

Description : Transfers (copies) the signed bit (bit 7 when the operand size is a word, bit 15 when a long word) of the lower half of dst to all bits of the upper half of dst.

### Details :

| Byte | State Word | Mnemonic  | Code                                                                                                                                                                                                                |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |
|------|------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|---|--|---|---|---|---|---|---|---|---|
|      | Word       | Long word |                                                                                                                                                                                                                     |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |
| —    | 5          | 5         | EXTS r                                                                                                                                                                                                              |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |
|      |            |           | <table border="1"> <tr> <td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td> </td><td>r</td><td> </td> </tr> <tr> <td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td><td>1</td> </tr> </table> | 1 | 1 | z | z | 1 |  | r |  | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
| 1    | 1          | z         | z                                                                                                                                                                                                                   | 1 |   | r |   |   |  |   |  |   |   |   |   |   |   |   |   |
| 0    | 0          | 0         | 1                                                                                                                                                                                                                   | 0 | 0 | 1 | 1 |   |  |   |  |   |   |   |   |   |   |   |   |

フラグ : S Z H V N C

— — — — — —

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: EXTS HL

When the HL register = 6789H, execution sets the HL register to FF89H.

HL register (before execution)

|    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 15 | 8 | 7 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |
| 0  | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 |

↓

HL register (after execution)

|    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 15 | 8 | 7 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |
| 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 |

↑↑↑↑↑↑↑↑

**EXTZ dst**

&lt; Extend Zero &gt;

Operation : dst<upper half>  $\leftarrow$  0

Description : Clears the upper half of dst to zero. Used for making the operand sizes the same when they are different.



Details :

| Byte | State |           | Mnemonic | Code                                                                                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |  |   |   |   |   |   |   |   |  |  |  |  |  |  |   |
|------|-------|-----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|--|---|---|---|---|---|---|---|--|--|--|--|--|--|---|
|      | Word  | Long word |          |                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |  |   |   |   |   |   |   |   |  |  |  |  |  |  |   |
| -    | 4     | 4         | EXTZ     | r<br><table border="1" style="display: inline-table; vertical-align: middle;"> <tr> <td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td>r</td><td></td> </tr> <tr> <td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td> </tr> <tr> <td></td><td></td><td></td><td></td><td></td><td></td><td>0</td> </tr> </table> | 1 | 1 | z | z | 1 | r |  | 0 | 0 | 0 | 1 | 0 | 0 | 1 |  |  |  |  |  |  | 0 |
| 1    | 1     | z         | z        | 1                                                                                                                                                                                                                                                                                                                                      | r |   |   |   |   |   |  |   |   |   |   |   |   |   |  |  |  |  |  |  |   |
| 0    | 0     | 0         | 1        | 0                                                                                                                                                                                                                                                                                                                                      | 0 | 1 |   |   |   |   |  |   |   |   |   |   |   |   |  |  |  |  |  |  |   |
|      |       |           |          |                                                                                                                                                                                                                                                                                                                                        |   | 0 |   |   |   |   |  |   |   |   |   |   |   |   |  |  |  |  |  |  |   |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: EXTZ HL

When the HL register = 6789H, execution sets the HL register to 0089H.

EXTZ XIX

When the XIX register = 12345678H, execution sets the XIX register to 00005678H.

## HALT

< Halt CPU >

This is privileged instruction in 900 CPU

Operation : CPU halt

Description : Halts the instruction execution. To resume, an interrupt must be received

Details :

State

Mnemonic

Code

---

8

HALT

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

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

# INC num, dst

< Increment >

Operation :  $dst \leftarrow dst + num$

Description : Adds the contents of dst and num and transfers the result to dst.

Details :

| Byte | State |           | Mnemonic        | Code                                                                                                                                                                                                                                                                  |   |    |   |   |   |   |   |   |   |   |   |   |   |  |    |   |
|------|-------|-----------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----|---|---|---|---|---|---|---|---|---|---|---|--|----|---|
|      | Word  | Long word |                 |                                                                                                                                                                                                                                                                       |   |    |   |   |   |   |   |   |   |   |   |   |   |  |    |   |
| 4    | 4     | 4         | INC #3,r        | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td><td></td><td>#3</td><td>1</td></tr> </table>  | 1 | 1  | z | z | 1 |   | r |   | 0 | 1 | 1 | 0 | 0 |  | #3 | 1 |
| 1    | 1     | z         | z               | 1                                                                                                                                                                                                                                                                     |   | r  |   |   |   |   |   |   |   |   |   |   |   |  |    |   |
| 0    | 1     | 1         | 0               | 0                                                                                                                                                                                                                                                                     |   | #3 | 1 |   |   |   |   |   |   |   |   |   |   |  |    |   |
| 6    | 6     | -         | INC<W> #3,(mem) | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td><td></td><td>#3</td><td></td></tr> </table> | 1 | m  | 0 | z | m | m | m | m | 0 | 1 | 1 | 0 | 0 |  | #3 |   |
| 1    | m     | 0         | z               | m                                                                                                                                                                                                                                                                     | m | m  | m |   |   |   |   |   |   |   |   |   |   |  |    |   |
| 0    | 1     | 1         | 0               | 0                                                                                                                                                                                                                                                                     |   | #3 |   |   |   |   |   |   |   |   |   |   |   |  |    |   |

Note : #3 in operands indicates from 1 to 8 and object codes correspond from 1 to 7,0.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | 0 | - |
|---|---|---|---|---|---|

S = MSB value of the result is set.

Z = 1 is set if the result is 0, otherwise 0.

H = 1 is set if a carry occurs from bit 3 to bit 4 as a result of the operation, otherwise 0.

V = 1 is set if an overflow occurs as a result of the operation, otherwise 0.

N = Cleared to zero.

C = No change

Note: With the INC #3,r instruction, if the operand is a word or a long word, no flags change.

Execution example : INC 5,WA

When the WA register = 1234H, execution sets the WA register to 1239H.

## INCF

< Increment Register File Pointer >

Operation : RFP<2:0>  $\leftarrow$  RFP<2:0> + 1

Description : Increments the contents of RFP<2:0> in the status register by 1. In maximum mode, RFP2 is fixed to 0.

Details :

| State | Mnemonic | Code |
|-------|----------|------|
|-------|----------|------|

2

INCF

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

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: INCF

When the contents of RFP<2:0> = 2, execution sets the contents of RFP<2:0> to 3.

## JP condition, dst

*< Jump >*

**Operation :** If cc is true, then PC  $\leftarrow$  dst.

**Description :** If the operand condition is true, jumps to the program address specified by dst.

**Details :**

| State                             | Mnemonic     | Code                                                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |        |   |   |   |   |   |   |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|-----------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--------|---|---|---|---|---|---|--|---------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|
| 7                                 | JP #16       | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> </table>                                              | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | #<7:0> |   |   |   |   |   |   |  | #<15:8> |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 0                                 | 0            | 0                                                                                                                                                                                                                                                                                                        | 1 | 1 | 0 | 1 | 0 |   |   |   |        |   |   |   |   |   |   |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>                            |              |                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |        |   |   |   |   |   |   |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>                           |              |                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |        |   |   |   |   |   |   |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| ~                                 | JP #24       | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> <tr><td colspan="8">#&lt;23:16&gt;</td></tr> </table> | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | #<7:0> |   |   |   |   |   |   |  | #<15:8> |  |  |  |  |  |  |  | #<23:16> |  |  |  |  |  |  |  |
| 0                                 | 0            | 0                                                                                                                                                                                                                                                                                                        | 1 | 1 | 0 | 1 | 1 |   |   |   |        |   |   |   |   |   |   |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>                            |              |                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |        |   |   |   |   |   |   |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>                           |              |                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |        |   |   |   |   |   |   |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<23:16>                          |              |                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |        |   |   |   |   |   |   |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 9 (cc is true)<br>6 (cc is false) | JP [cc,] mem | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>1</td><td>c</td><td>c</td><td>c</td><td></td></tr> </table>                                            | 1 | m | 1 | 1 | m | m | m | m | 1      | 1 | 0 | 1 | c | c | c |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1                                 | m            | 1                                                                                                                                                                                                                                                                                                        | 1 | m | m | m | m |   |   |   |        |   |   |   |   |   |   |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1                                 | 1            | 0                                                                                                                                                                                                                                                                                                        | 1 | c | c | c |   |   |   |   |        |   |   |   |   |   |   |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**Execution example:** JP 2000H

Execution jumps unconditionally to address 2000H.

## JR condition, dst

< Jump Relative >

**Operation :** If cc is true, then PC  $\leftarrow$  dst.

**Description :** If the operand condition is true, makes a relative jump to the program address specified by dst.

**Details :**

| State           | Mnemonic | Code                                                            |
|-----------------|----------|-----------------------------------------------------------------|
| 8 (cc is true)  | JR       | [cc,] \$ + 2 + d8<br>0 1 1 0   c c  <br>d < 7:0>                |
| 4 (cc is false) |          |                                                                 |
| 8 (cc is true)  | JRL      | [cc,] \$ + 3 + d16<br>0 1 1 1   c c  <br># < 7:0><br># < 15:8 > |
| 4 (cc is false) |          |                                                                 |

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**Execution example:** JR 2078H

When this instruction is executed at memory address 2000H, execution relative jumps unconditionally to address 2078H. The object code of the instruction is 68H : 76H.



## LD dst, src

&lt; Load &gt;

Operation : dst  $\leftarrow$  src

Description : Loads the contents of src to dst.

Details :

| Byte     | State Word | Long word | Mnemonic | Code                                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
|----------|------------|-----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|--------|---|----|---|---|----|---------|--|--|---|--------|---|----------|--|--|--|--|--|----------|--|--|--|--|--|----------|--|--|--|--|--|
| 4        | 4          | 4         | LD       | R, r<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td>r</td></tr> <tr><td>1</td><td>0</td><td>0</td><td>0</td><td>1</td><td>R</td></tr> </table>                                                                                                                                                                                                                       | 1  | 1 | z | z | 1 | r | 1      | 0 | 0  | 0 | 1 | R  |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 1        | 1          | z         | z        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                    | r  |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 1        | 0          | 0         | 0        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R  |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 4        | 4          | 4         | LD       | r, R<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td>r</td></tr> <tr><td>1</td><td>0</td><td>0</td><td>1</td><td>1</td><td>R</td></tr> </table>                                                                                                                                                                                                                       | 1  | 1 | z | z | 1 | r | 1      | 0 | 0  | 1 | 1 | R  |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 1        | 1          | z         | z        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                    | r  |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 1        | 0          | 0         | 1        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R  |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 4        | 4          | 4         | LD       | r, #3<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td>r</td></tr> <tr><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td><td>#3</td></tr> </table>                                                                                                                                                                                                                     | 1  | 1 | z | z | 1 | r | 1      | 0 | 1  | 0 | 1 | #3 |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 1        | 1          | z         | z        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                    | r  |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 1        | 0          | 1         | 0        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                    | #3 |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 2        | 3          | 5         | LD       | R, #<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>0</td><td>z</td><td>z</td><td>z</td><td>0</td><td>R</td></tr> <tr><td colspan="5">#&lt;7:0&gt;</td><td></td></tr> <tr><td colspan="5">#&lt;15:8&gt;</td><td></td></tr> <tr><td colspan="5">#&lt;23:16&gt;</td><td></td></tr> <tr><td colspan="5">#&lt;31:24&gt;</td><td></td></tr> </table>                                                                        | 0  | z | z | z | 0 | R | #<7:0> |   |    |   |   |    | #<15:8> |  |  |   |        |   | #<23:16> |  |  |  |  |  | #<31:24> |  |  |  |  |  |          |  |  |  |  |  |
| 0        | z          | z         | z        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R  |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| #<7:0>   |            |           |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| #<15:8>  |            |           |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| #<23:16> |            |           |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| #<31:24> |            |           |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 4        | 4          | 6         | LD       | r, #<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td>r</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td></tr> <tr><td colspan="5">#&lt;7:0&gt;</td><td>1</td></tr> <tr><td colspan="5">#&lt;15:8&gt;</td><td></td></tr> <tr><td colspan="5">#&lt;23:16&gt;</td><td></td></tr> <tr><td colspan="5">#&lt;31:24&gt;</td><td></td></tr> </table> | 1  | 1 | z | z | 1 | r | 0      | 0 | 0  | 0 | 0 | 0  | #<7:0>  |  |  |   |        | 1 | #<15:8>  |  |  |  |  |  | #<23:16> |  |  |  |  |  | #<31:24> |  |  |  |  |  |
| 1        | 1          | z         | z        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                    | r  |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 0        | 0          | 0         | 0        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0  |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| #<7:0>   |            |           |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1  |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| #<15:8>  |            |           |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| #<23:16> |            |           |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| #<31:24> |            |           |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 4        | 4          | 6         | LD       | R, (mem)<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td></td><td></td><td>R</td></tr> </table>                                                                                                                                                                             | 1  | m | z | z | m | m | m      | m | 0  | 0 | 1 | 0  | 0       |  |  | R |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 1        | m          | z         | z        | m                                                                                                                                                                                                                                                                                                                                                                                                                                                    | m  | m | m |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 0        | 0          | 1         | 0        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |   | R |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 4        | 4          | 6         | LD       | (mem), R<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>1</td><td>z</td><td>z</td><td>0</td><td></td><td></td><td>R</td></tr> </table>                                                                                                                                                                             | 1  | m | 1 | 1 | m | m | m      | m | 0  | 1 | z | z  | 0       |  |  | R |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 1        | m          | 1         | 1        | m                                                                                                                                                                                                                                                                                                                                                                                                                                                    | m  | m | m |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 0        | 1          | z         | z        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |   | R |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| 5        | 6          |           | LD<W>    | (#8), #<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>z</td><td>0</td></tr> <tr><td colspan="5">#8</td><td></td><td></td><td></td></tr> <tr><td colspan="5">#&lt;7:0&gt;</td><td></td><td></td><td></td></tr> <tr><td colspan="5">#&lt;15:8&gt;</td><td></td><td></td><td></td></tr> </table>                                                             | 0  | 0 | 0 | 0 | 1 | 0 | z      | 0 | #8 |   |   |    |         |  |  |   | #<7:0> |   |          |  |  |  |  |  | #<15:8>  |  |  |  |  |  |          |  |  |  |  |  |
| 0        | 0          | 0         | 0        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0  | z | 0 |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| #8       |            |           |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| #<7:0>   |            |           |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |
| #<15:8>  |            |           |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |        |   |    |   |   |    |         |  |  |   |        |   |          |  |  |  |  |  |          |  |  |  |  |  |          |  |  |  |  |  |

| Byte      | State<br>Word | Long word | Mnemonic           | Code                                                                                                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |
|-----------|---------------|-----------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|-----------|--|--|--|--|--|--|--|
| 5         | 6             | -         | LD<W> (mem), #     | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>z</td><td>0</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> </table>     | 1 | m | 1 | 1 | m | m | m | m | 0 | 0 | 0 | 0 | 0 | 0 | z | 0 | #<7:0>   |  |  |  |  |  |  |  | #<15:8>   |  |  |  |  |  |  |  |
| 1         | m             | 1         | 1                  | m                                                                                                                                                                                                                                                                                                                                                         | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |
| 0         | 0             | 0         | 0                  | 0                                                                                                                                                                                                                                                                                                                                                         | 0 | z | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |
| #<7:0>    |               |           |                    |                                                                                                                                                                                                                                                                                                                                                           |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |
| #<15:8>   |               |           |                    |                                                                                                                                                                                                                                                                                                                                                           |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |
| 8         | 8             |           | LD<W> (#16), (mem) | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td></tr> <tr><td colspan="8">#16&lt;7:0&gt;</td></tr> <tr><td colspan="8">#16&lt;15:8&gt;</td></tr> </table> | 1 | m | 0 | z | m | m | m | m | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | #16<7:0> |  |  |  |  |  |  |  | #16<15:8> |  |  |  |  |  |  |  |
| 1         | m             | 0         | z                  | m                                                                                                                                                                                                                                                                                                                                                         | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |
| 0         | 0             | 0         | 1                  | 1                                                                                                                                                                                                                                                                                                                                                         | 0 | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |
| #16<7:0>  |               |           |                    |                                                                                                                                                                                                                                                                                                                                                           |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |
| #16<15:8> |               |           |                    |                                                                                                                                                                                                                                                                                                                                                           |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |
| 8         | 8             | -         | LD<W> (mem), (#16) | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>z</td><td>0</td></tr> <tr><td colspan="8">#16&lt;7:0&gt;</td></tr> <tr><td colspan="8">#16&lt;15:8&gt;</td></tr> </table> | 1 | m | 1 | 1 | m | m | m | m | 0 | 0 | 0 | 1 | 0 | 1 | z | 0 | #16<7:0> |  |  |  |  |  |  |  | #16<15:8> |  |  |  |  |  |  |  |
| 1         | m             | 1         | 1                  | m                                                                                                                                                                                                                                                                                                                                                         | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |
| 0         | 0             | 0         | 1                  | 0                                                                                                                                                                                                                                                                                                                                                         | 1 | z | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |
| #16<7:0>  |               |           |                    |                                                                                                                                                                                                                                                                                                                                                           |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |
| #16<15:8> |               |           |                    |                                                                                                                                                                                                                                                                                                                                                           |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |

Flags : S Z H V N C  

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

- S = No change
- Z = No change
- H = No change
- V = No change
- N = No change
- C = No change

Execution example: LD IX, DE  
When the DE register=4567H, execution sets the IX register to 4567H.



**LDA dst, src**

&lt; Load Address &gt;

Operation :  $dst \leftarrow src$  effective address value

Description : Loads the src effective address value to dst.

Details :

| Byte | State |           | Mnemonic | Code   |
|------|-------|-----------|----------|--------|
|      | Word  | Long word |          |        |
| -    | 4     | 4         | LDA      | R, mem |

1 | m | 1 | 1 | m | m | m | m  
 0 | 0 | 1 | s | 0 | R |

Note : This instruction operates much like the ADD instruction; the difference is that dst is specified independently from src. Mainly used for handling the pointer with the C compiler.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: LDA XIX, XIY+33H

When the XIY register = 00123456H, execution sets the XIX register to 00123489H.



**LDAR dst, src**

&lt; Load Address Relative &gt;

Operation :  $dst \leftarrow src$  relative address value

Description : Loads the relative address value specified in src to dst.

Details :

| Byte | State |           | Mnemonic | Code       |
|------|-------|-----------|----------|------------|
|      | Word  | Long word |          |            |
| -    | 11    | 11        | LDAR     | R,\$+4+d16 |

d<7:0>  
d<15:8>

|         |   |   |   |   |   |   |   |
|---------|---|---|---|---|---|---|---|
| 1       | 1 | 1 | 1 | 0 | 0 | 1 | 1 |
| 0       | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
| d<7:0>  |   |   |   |   |   |   |   |
| d<15:8> |   |   |   |   |   |   |   |
| 0       | 0 | 1 | s | 0 |   | R | 1 |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: LDAR XIX,\$+1345H

When this instruction is executed at memory address 1000H, execution sets the XIX register to 00002345H. \$ indicates the start address of the instruction. The instruction's object codes are: F3H:13H:41H:13H:34H.



**LDC dst, src**

&lt; Load Control Register &gt;

This is privileged instruction in 900 CPU.

Operation : dst  $\leftarrow$  src

Description : Loads the contents of src to dst.

Details :

| Byte | State |           | Mnemonic | Code                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |
|------|-------|-----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|---|---|---|---|---|---|---|---|---|---|----|--|--|--|--|--|--|--|
|      | Word  | Long word |          |                                                                                                                                                                                                                                                                                                                                     |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |
| 8    | 8     | 8         | LDC      | cr, r<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td><td>1</td><td>0</td></tr> <tr><td colspan="8" style="text-align: center;">cr</td></tr> </table> | 1 | 1 | z | z | 1 |  | r | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | cr |  |  |  |  |  |  |  |
| 1    | 1     | z         | z        | 1                                                                                                                                                                                                                                                                                                                                   |   | r | 1 |   |   |  |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |
| 0    | 0     | 1         | 0        | 1                                                                                                                                                                                                                                                                                                                                   | 1 | 1 | 0 |   |   |  |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |
| cr   |       |           |          |                                                                                                                                                                                                                                                                                                                                     |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |
| 8    | 8     | 8         | LDC      | r, cr<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td></tr> <tr><td colspan="8" style="text-align: center;">cr</td></tr> </table> | 1 | 1 | z | z | 1 |  | r | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | cr |  |  |  |  |  |  |  |
| 1    | 1     | z         | z        | 1                                                                                                                                                                                                                                                                                                                                   |   | r | 1 |   |   |  |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |
| 0    | 0     | 1         | 0        | 1                                                                                                                                                                                                                                                                                                                                   | 1 | 1 | 1 |   |   |  |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |
| cr   |       |           |          |                                                                                                                                                                                                                                                                                                                                     |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: LDC DMAC0, WA

When the WA register = 1234H, execution sets control register DMAC0 to 1234H.

## LDCF num, src

&lt; Load Carry Flag &gt;

Operation : CY  $\leftarrow$  src<num>

Description : Loads the contents of bit num of src to the carry flag.

Details :

| Byte | State |           | Mnemonic | #4, r     | Code                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
|------|-------|-----------|----------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|--|---|---|
|      | Word  | Long word |          |           |                                                                                                                                                                                                                                                                           |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 4    | 4     | -         | LDCF     | #4, r     | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>#</td><td>4</td></tr> </table> | 1  | 1 | 0 | z | 1 |   | r | 0 | 0 | 1 | 0 | 0 | 0 | 1  | 0 | 0 | 0 | 0 |  | # | 4 |
| 1    | 1     | 0         | z        | 1         |                                                                                                                                                                                                                                                                           | r  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 0    | 0     | 1         | 0        | 0         | 0                                                                                                                                                                                                                                                                         | 1  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 0    | 0     | 0         | 0        |           | #                                                                                                                                                                                                                                                                         | 4  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 4    | 4     |           | LDCF     | A, r      | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td></tr> </table>                                                                                | 1  | 1 | 0 | z | 1 |   | r | 0 | 0 | 1 | 0 | 1 | 0 | 1  |   |   |   |   |  |   |   |
| 1    | 1     | 0         | z        | 1         |                                                                                                                                                                                                                                                                           | r  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 0    | 0     | 1         | 0        | 1         | 0                                                                                                                                                                                                                                                                         | 1  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 8    | -     | -         | LDCF     | #3, (mem) | <table border="1"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>0</td><td>0</td><td>1</td><td>1</td><td></td><td>#3</td></tr> </table>                                                                               | 1  | m | 1 | 1 | m | m | m | 1 | 0 | 0 | 1 | 1 |   | #3 |   |   |   |   |  |   |   |
| 1    | m     | 1         | 1        | m         | m                                                                                                                                                                                                                                                                         | m  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 1    | 0     | 0         | 1        | 1         |                                                                                                                                                                                                                                                                           | #3 |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 8    | -     | -         | LDCF     | A, (mem)  | <table border="1"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td></tr> </table>                                                                               | 1  | m | 1 | 1 | m | m | m | 0 | 0 | 1 | 0 | 1 | 0 | 1  |   |   |   |   |  |   |   |
| 1    | m     | 1         | 1        | m         | m                                                                                                                                                                                                                                                                         | m  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |
| 0    | 0     | 1         | 0        | 1         | 0                                                                                                                                                                                                                                                                         | 1  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |   |   |

Notes : When bit num is specified by the A register, the value of the lower 4 bits of the A register is used as bit num. When the operand is a byte and the value of the lower 4 bits of bit num is from 8 to 15, the value of the carry flag is undefined.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | * |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = Contents of bit num of src is set

Execution example: LDCF 6,(100H)

When the contents of memoryad address 100 = 01000000B (binary), execution sets the carry flag to 1.



**LDD dst, src**

&lt; Load Decrement &gt;

Operation :  $dst \leftarrow src, BC \leftarrow BC - 1$ 

Description : Loads the contents of src to dst, then decrements the contents of the BC register by 1. src and dst must be in post-decrement register indirect addressing mode.

Details :

| Byte | State |           | Mnemonic                | Code                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|------|-------|-----------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|      | Word  | Long word |                         |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 10   | 10    | -         | LDD<W> [(XDE-), (XHL-)] | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>0</td><td>0</td><td>z</td><td>0</td><td>0</td><td>1</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td><td>0</td></tr> </table> | 1 | 0 | 0 | z | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 |
| 1    | 0     | 0         | z                       | 0                                                                                                                                                                                                                                                                      | 0 | 1 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0    | 0     | 0         | 1                       | 0                                                                                                                                                                                                                                                                      | 0 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |
|      |       |           | LDD<W> (XIX-), (XIY-)   | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>0</td><td>0</td><td>z</td><td>0</td><td>1</td><td>0</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td><td>0</td></tr> </table> | 1 | 0 | 0 | z | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 |
| 1    | 0     | 0         | z                       | 0                                                                                                                                                                                                                                                                      | 1 | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0    | 0     | 0         | 1                       | 0                                                                                                                                                                                                                                                                      | 0 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |

\* Coding in square brackets [] can be omitted.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | 0 | * | 0 | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = Cleared to 0.

V = 0 is set if the BC register value is 0 after execution, otherwise 1.

N = Cleared to zero.

C = No change

Execution example: LDD (XIX-), (XIY-)

When the XIX register = 00123456H, the XIY register = 00335577H, and the BC register = 0700H, execution loads the contents at address 335577 to address 123456H and sets the XIX register to 123455H, the XIY register to 00335576H, and the BC register to 06FFH.

**LDDR dst, src**

&lt; Load Decrement Repeat &gt;

**Operation :** dst  $\leftarrow$  src, BC  $\leftarrow$  BC - 1, Repeat until BC = 0

**Description :** Loads the contents of src to dst, then decrements the contents of the BC register by 1. If the result is other than 0, the operation is repeated. src and dst must be in post-decrement register indirect addressing mode.

**Details :**

| Byte | State              |           | Mnemonic                | Code                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|------|--------------------|-----------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|      | Word               | Long word |                         |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 10   | 10<br>(Non-repeat) | -         | LDDR<W>[(XDE-), (XHL-)] | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>0</td><td>0</td><td>z</td><td>0</td><td>0</td><td>1</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td><td>1</td></tr> </table> | 1 | 0 | 0 | z | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
| 1    | 0                  | 0         | z                       | 0                                                                                                                                                                                                                                                                      | 0 | 1 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0    | 0                  | 0         | 1                       | 0                                                                                                                                                                                                                                                                      | 0 | 1 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 14   | 14<br>(Repeat)     | -         | LDDR<W> (XIX-), (XIY-)  | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>0</td><td>0</td><td>z</td><td>0</td><td>1</td><td>0</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td><td>1</td></tr> </table> | 1 | 0 | 0 | z | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
| 1    | 0                  | 0         | z                       | 0                                                                                                                                                                                                                                                                      | 1 | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0    | 0                  | 0         | 1                       | 0                                                                                                                                                                                                                                                                      | 0 | 1 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |

\* Coding in square brackets [ ] can be omitted.

**Note :** Interrupt requests are sampled every time 1 item of data is loaded.

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | 0 | 0 | 0 | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = Cleared to zero.

V = Cleared to zero.

N = Cleared to zero.

C = No change

**Execution example:** LDDR (XIX-), (XIY-)

When the XIX register = 00123456H, the XIY register = 00335577H, and the BC register = 0003H, the results of the execution are as follows:

Loads the contents of address 335577H to 123456H.

Loads the contents of address 335576H to 123455H.

Loads the contents of address 335575H to 123454H.

Sets the XIX register to 00123453H.

Sets the XIY register to 00335574H.

Sets the BC register to 0000H.

**LDF num**

&lt; Load Register File Pointer &gt;

Operation : RFP<2:0> $\leftarrow$  num

Description : Loads the num value to the register file pointer RFP<2:0> in status register. Since RFP2 is fixed to 0 in maximum mode, when the num value is from 4 to 7, RFP is set to from 0 to 3.

Details :

State

Mnemonic

Code

|   |     |    |                                                                                                                                                                                                          |   |    |   |   |   |   |   |   |   |   |   |   |   |    |  |  |
|---|-----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----|---|---|---|---|---|---|---|---|---|---|---|----|--|--|
| 2 | LDF | #3 | <table border="1"> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td colspan="3">#3</td></tr> </table> | 0 | 0  | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | #3 |  |  |
| 0 | 0   | 0  | 1                                                                                                                                                                                                        | 0 | 1  | 1 | 1 |   |   |   |   |   |   |   |   |   |    |  |  |
| 0 | 0   | 0  | 0                                                                                                                                                                                                        | 0 | #3 |   |   |   |   |   |   |   |   |   |   |   |    |  |  |

Note : In minimum mode, the operand value can be specified from 0 to 7; in maximum mode, from 0 to 3.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**LDI dst, src**

&lt; Load Increment &gt;

Operation :  $dst \leftarrow src, BC \leftarrow BC - 1$ 

Description : Loads the contents of src to dst, then decrements the contents of the BC register by 1. src and dst must be in post-increment register indirect addressing mode.

Details :

| Byte | State |           | Mnemonic              | Code                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|------|-------|-----------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|      | Word  | Long word |                       |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 10   | 10    | -         | LDI<W>[(XDE+),(XHL+)] | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>0</td><td>0</td><td>z</td><td>0</td><td>0</td><td>1</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td><td>0</td></tr> </table> | 1 | 0 | 0 | z | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| 1    | 0     | 0         | z                     | 0                                                                                                                                                                                                                                                                      | 0 | 1 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0    | 0     | 0         | 1                     | 0                                                                                                                                                                                                                                                                      | 0 | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |
|      |       |           | LDI<W>(XIX+),(XIY+)   | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>0</td><td>0</td><td>z</td><td>0</td><td>1</td><td>0</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td><td>0</td></tr> </table> | 1 | 0 | 0 | z | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| 1    | 0     | 0         | z                     | 0                                                                                                                                                                                                                                                                      | 1 | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0    | 0     | 0         | 1                     | 0                                                                                                                                                                                                                                                                      | 0 | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |

\* Coding in square brackets [ ] can be omitted.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | 0 | * | 0 | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = Cleared to zero.

V = 0 is set when the BC register value is 0 after execution, otherwise 1.

N = Cleared to zero.

C = No change

Execution example: LDI (XIX+),(XIY+)

When the XIX register = 00123456H, the XIY register = 00335577H, and the BC register = 0700H, execution loads the contents of address 335577H to 123456H and sets the XIX register to 00123457H, the XIY register to 00335578H, and the BC register to 06FFH.

**LDIR dst, src**

&lt; Load Increment Repeat &gt;

Operation :  $dst \leftarrow src$ ,  $BC \leftarrow BC - 1$ , Repeat until  $BC = 0$ 

Description : Loads the contents of src to dst, then decrements the contents of the BC register by 1. If the result is other than 0, the operation is repeated. src and dst must be in post-increment register indirect addressing mode.

Details :

| Byte               | State |           | Mnemonic                 | Code                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------------------|-------|-----------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|                    | Word  | Long word |                          |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 10<br>(Non-repeat) | 10    | -         | LDIR<W>[(XDE +),(XHL +)] | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>0</td><td>0</td><td>z</td><td>0</td><td>0</td><td>1</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td><td>1</td></tr> </table> | 1 | 0 | 0 | z | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
| 1                  | 0     | 0         | z                        | 0                                                                                                                                                                                                                                                                      | 0 | 1 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0                  | 0     | 0         | 1                        | 0                                                                                                                                                                                                                                                                      | 0 | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 14<br>(Repeat)     | 14    | -         | LDIR<W>(XIX +),(XIY +)   | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>0</td><td>0</td><td>z</td><td>0</td><td>1</td><td>0</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td><td>1</td></tr> </table> | 1 | 0 | 0 | z | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
| 1                  | 0     | 0         | z                        | 0                                                                                                                                                                                                                                                                      | 1 | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0                  | 0     | 0         | 1                        | 0                                                                                                                                                                                                                                                                      | 0 | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |

\* Coding in square brackets [ ] can be omitted.

Note : Interrupt requests are sampled every time 1 item of data is loaded.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | 0 | 0 | 0 | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = Cleared to zero.

V = Cleared to zero.

N = Cleared to zero.

C = No change

Execution example: LDIR (XIX +),(XIY +)

When the XIX register = 00123456H, the XIY register = 00335577H, and the BC register = 0003H, execution results as follows:

Loads the contents of address 335577H to 123456H.

Loads the contents of address 335578H to 123457H.

Loads the contents of address 335579H to 123458H.

Sets the XIX register to 00123459H.

Sets the XIY register to 0033557AH.

Sets the BC register to 0000H.

**LDX dst, src**

&lt; Load eXtract &gt;

Operation :  $dst \leftarrow src$ 

Description : Loads the contents of src to dst. The effective code is assigned to this instruction every other byte. Used to fetch the code from 8-bit data bus memory in 16-bit data bus mode.

Details :

| Byte | State |           | Mnemonic    | Code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |
|------|-------|-----------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|--|--|--|--|--|--|--|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|---|---|---|---|---|---|---|---|
|      | Word  | Long word |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |
| 9    | -     | -         | LDX (#8), # | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td></tr> <tr><td colspan="8">#8</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td></tr> <tr><td colspan="8">#</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td></tr> </table> | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #8 |  |  |  |  |  |  |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # |  |  |  |  |  |  |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1    | 1     | 1         | 1           | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1 | 1 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |
| 0    | 0     | 0         | 0           | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0 | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |
| #8   |       |           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |
| 0    | 0     | 0         | 0           | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0 | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |
| #    |       |           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |
| 0    | 0     | 0         | 0           | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0 | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |    |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |

Note : Even if the second, fourth, or sixth instruction code value is not 00H, the instruction operates correctly.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: LDX (6AH), 9CH

Using the TMP96C141, the example executes the program using an EPROM which has an 8-bit data bus. After reset, starts fetching the program code in 16-bit data bus mode. When the program starts with an external memory with an 8-bit data bus, loads the above instruction to the start address, 8000H. Execution writes the 9CH data to the control register at address 6AH of the built-in programmable chip select/wait controller. As a result, memory addresses 8000H to 3FFFFFFH enters 8-bit data bus 0WAIT mode.



**LINK dst, num**

&lt; Link &gt;

Operation :  $(-\text{XSP}) \leftarrow \text{dst}$ ,  $\text{dst} \leftarrow \text{XSP}$ ,  $\text{XSP} \leftarrow \text{XSP} + \text{num}$

Description : Saves the contents of dst to the stack area. Loads the contents of stack pointer XSP to dst. Adds the contents of XSP to those of num (signed) and loads the result to XSP. Used for obtaining a local variable area in the stack area for -num bytes.

Details :

| Byte | State |           | Mnemonic | Code   |
|------|-------|-----------|----------|--------|
|      | Word  | Long word |          |        |
| -    | -     | 10        | LINK     | r, d16 |

  

|         |   |   |   |   |   |   |   |
|---------|---|---|---|---|---|---|---|
| 1       | 1 | 1 | 0 | 1 |   | r |   |
| 0       | 0 | 0 | 0 | 1 | 1 | 0 | 0 |
| d<7:0>  |   |   |   |   |   |   |   |
| d<15:8> |   |   |   |   |   |   |   |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: LINK XIZ, -40H

When stack pointer XSP = 280H and the XIZ register = 290H, execution writes 00000290H (long data) at memory address 27CH and sets the XIZ register to 27CH and the stack pointer to XSP 23CH.





Operation : Max bit  $\leftarrow 1$

Description : Sets the MAX bit in status register to 1. Changes the CPU operation mode to maximum.

Details :

| State | Mnemonic | Code            |
|-------|----------|-----------------|
| 4     | MAX      | 0 0 0 0 0 1 0 0 |

Flags : S Z H V N C  

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| — | — | — | — | — | — |
|---|---|---|---|---|---|

- S = No change
- Z = No change
- H = No change
- V = No change
- N = No change
- C = No change

Note : Basically, there is no instruction for changing from maximum to minimum mode. However, if it is absolutely necessary, execute either of the following ways but it is in system mode only.

- (1) PUSH SR  
 RES 3,(XSP+1)  
 POP SR

**MDEC1 num, dst**

&lt; Modulo Decrement 1 &gt;

**Operation :** if (dst mod num) = 0 then dst  $\leftarrow$  dst + (num - 1) else dst  $\leftarrow$  dst - 1.

**Description :** When the modulo num of dst is 0, increments dst by num -1 .  
 Otherwise, decrements dst by 1. Used to operate pointers for cyclic memory table.

**Details :**

| Byte     | State<br>Word | Long word | Mnemonic   | Code                                                                                                                                                                                                                                                                                                                                                  |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
|----------|---------------|-----------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|---|--|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|---------|--|--|--|--|--|--|
| -        | 7             | -         | MDEC1 #, r | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td></tr> <tr><td colspan="7">#&lt;7:0&gt;-1</td></tr> <tr><td colspan="7">#&lt;15:8&gt;</td></tr> </table> | 1 | 1 | 0 | 1 | 1 |  | r |  | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | #<7:0>-1 |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |
| 1        | 1             | 0         | 1          | 1                                                                                                                                                                                                                                                                                                                                                     |   | r |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
| 0        | 0             | 1         | 1          | 1                                                                                                                                                                                                                                                                                                                                                     | 1 | 0 | 0 |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
| #<7:0>-1 |               |           |            |                                                                                                                                                                                                                                                                                                                                                       |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
| #<15:8>  |               |           |            |                                                                                                                                                                                                                                                                                                                                                       |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |

**Note :** The operand # must be 2 to the nth power. (n = 1 to 15)

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**Execution example:** Decrement the IX register by cycling from 1230H to 1237H.

MDEC1 8, IX

When the IX register = 1231H, execution sets the IX register to 1230H. Further execution increments the IX register by 8-1 and sets the IX register to 1237H, since the IX register modulo 8 = 0.



**MDEC2 num, dst**

&lt; Modulo Decrement 2 &gt;

**Operation :** if (dst mod num) = 0 then dst  $\leftarrow$  dst + (num - 2) else dst  $\leftarrow$  dst - 2.

**Description :** When the modulo num of dst is 0, increments dst by num - 2.  
 Otherwise, decrements dst by 2. Used to operate pointers for cyclic memory table.

**Details :**

| Byte     | State |           | Mnemonic   | Code                                                                                                                                                                                                                                                                                                                                         |   |   |   |   |   |   |  |   |   |   |   |   |   |   |          |  |  |  |  |  |   |         |  |  |  |  |  |  |
|----------|-------|-----------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|--|---|---|---|---|---|---|---|----------|--|--|--|--|--|---|---------|--|--|--|--|--|--|
|          | Word  | Long word |            |                                                                                                                                                                                                                                                                                                                                              |   |   |   |   |   |   |  |   |   |   |   |   |   |   |          |  |  |  |  |  |   |         |  |  |  |  |  |  |
| -        | 7     | -         | MDEC2 #, r | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td>r</td><td></td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td></tr> <tr><td colspan="6">#&lt;7:0&gt;-2</td><td>1</td></tr> <tr><td colspan="7">#&lt;15:8&gt;</td></tr> </table> | 1 | 1 | 0 | 1 | 1 | r |  | 0 | 0 | 1 | 1 | 1 | 1 | 0 | #<7:0>-2 |  |  |  |  |  | 1 | #<15:8> |  |  |  |  |  |  |
| 1        | 1     | 0         | 1          | 1                                                                                                                                                                                                                                                                                                                                            | r |   |   |   |   |   |  |   |   |   |   |   |   |   |          |  |  |  |  |  |   |         |  |  |  |  |  |  |
| 0        | 0     | 1         | 1          | 1                                                                                                                                                                                                                                                                                                                                            | 1 | 0 |   |   |   |   |  |   |   |   |   |   |   |   |          |  |  |  |  |  |   |         |  |  |  |  |  |  |
| #<7:0>-2 |       |           |            |                                                                                                                                                                                                                                                                                                                                              |   | 1 |   |   |   |   |  |   |   |   |   |   |   |   |          |  |  |  |  |  |   |         |  |  |  |  |  |  |
| #<15:8>  |       |           |            |                                                                                                                                                                                                                                                                                                                                              |   |   |   |   |   |   |  |   |   |   |   |   |   |   |          |  |  |  |  |  |   |         |  |  |  |  |  |  |

**Note :** The operand # must be 2 to the nth power. (n = 2 to 15)

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**Execution example:** Decrements the IX register by cycling from 1238H to 123FH.

MDEC2 8,IX

When the IX register = 123AH, execution sets the IX register to 1238H. Further execution increments the IX register by 8-2 and sets the IX register to 123EH, since the IX register modulo 8 = 0.



**MDEC4 num, dst**

&lt; Modulo Decrement 4 &gt;

Operation : if (dst mod num)=0 then dst←dst+(num-4) else dst←dst-4.

Description : When the modulo num of dst is 0, increments dst by num-4. Otherwise, decrements dst by 4. Used to operate pointers for cyclic memory table.

Details :

| Byte     | State |           | Mnemonic   | Code                                                                                                                                                                                                                                                                                                                                                                    |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|----------|-------|-----------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|---|--|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|
|          | Word  | Long word |            |                                                                                                                                                                                                                                                                                                                                                                         |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| -        | 7     | -         | MDEC4 #, r | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td></tr> <tr><td colspan="7">#&lt;7:0&gt;-4</td><td></td></tr> <tr><td colspan="7">#&lt;15:8&gt;</td><td></td></tr> </table> | 1 | 1 | 0 | 1 | 1 |  | r |  | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | #<7:0>-4 |  |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |  |
| 1        | 1     | 0         | 1          | 1                                                                                                                                                                                                                                                                                                                                                                       |   | r |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| 0        | 0     | 1         | 1          | 1                                                                                                                                                                                                                                                                                                                                                                       | 1 | 1 | 0 |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| #<7:0>-4 |       |           |            |                                                                                                                                                                                                                                                                                                                                                                         |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| #<15:8>  |       |           |            |                                                                                                                                                                                                                                                                                                                                                                         |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |

Note : The operand # must be 2 to the nth power. (n = 3 to 15)

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: Decrements the IX register by cycling from 1280H to 12FFH.

MDEC4 80H,IX

When the IX register = 1284H, execution sets the IX register to 1280H. Further execution increments the IX register by 80H-4 and sets the IX register to 12FCH, since the IX register modulo 80H = 0.





Operation : Max bit  $\leftarrow$  0

Description : Sets the MAX bit in status register to 0. Changes the CPU operation mode to minimum.

Details :

| State | Mnemonic | Code            |
|-------|----------|-----------------|
| 4     | MIN      | 0 0 0 0 0 1 0 0 |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

- S = No change
- Z = No change
- H = No change
- V = No change
- N = No change
- C = No change

Note : Basically, there is no instruction for changing from minimum to maximum mode. However, if it is absolutely necessary, execute either of the following two ways.

- (1) PUSH SR  
SET 3,(XSP+1)  
POP SR
- (2) SWI n      SET 3,(XSP+1) } At address 8000H + n × 4H  
                  RETI      } (n=0 to 7)

**MINC1 num, dst**

&lt; Modulo Increment 1 &gt;

**Operation :** if (dst mod num) = (num - 1) then dst  $\leftarrow$  dst - (num - 1) else dst  $\leftarrow$  dst + 1.

**Description :** When the modulo num of dst is num - 1, decrements dst by num - 1.  
Otherwise, increments dst by 1. Used to operate pointers for cyclic memory table.

**Details :**

| Byte     | State |           | Mnemonic   | Code                                                                                                                                                                                                                                                                                                                                                  |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
|----------|-------|-----------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|---|--|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|---------|--|--|--|--|--|--|
|          | Word  | Long word |            |                                                                                                                                                                                                                                                                                                                                                       |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
| -        | 8     | -         | MINC1 #, r | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td><td>0</td></tr> <tr><td colspan="7">#&lt;7:0&gt;-1</td></tr> <tr><td colspan="7">#&lt;15:8&gt;</td></tr> </table> | 1 | 1 | 0 | 1 | 1 |  | r |  | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | #<7:0>-1 |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |
| 1        | 1     | 0         | 1          | 1                                                                                                                                                                                                                                                                                                                                                     |   | r |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
| 0        | 0     | 1         | 1          | 1                                                                                                                                                                                                                                                                                                                                                     | 0 | 0 | 0 |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
| #<7:0>-1 |       |           |            |                                                                                                                                                                                                                                                                                                                                                       |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
| #<15:8>  |       |           |            |                                                                                                                                                                                                                                                                                                                                                       |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |

**Note :** The operand # must be 2 to the nth power. (n = 1 to 15)

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**Execution example:** Increments the IX register by cycling from 1200H to 1207H.

MINC1 8, IX

When the IX register = 1206H, execution sets the IX register to 1207H. Further execution decrements the IX register by 8 - 1 and sets the IX register to 1200H, since the IX register modulo 8 = 8 - 1.



**MINC2 num, dst**

&lt; Modulo Increment 2 &gt;

**Operation :** if ( $dst \bmod num$ ) = ( $num - 2$ ) then  $dst \leftarrow dst - (num - 2)$  else  $dst \leftarrow dst + 2$ .

**Description :** When the modulo num of dst is  $num - 2$ , decrements dst by  $num - 2$ .  
 Otherwise, increments dst by 2. Used to operate pointers for cyclic memory table.



**Details :**

| Byte     | State |           | Mnemonic   | Code                                                                                                                                                                                                                                                                                                                                                   |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
|----------|-------|-----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|---|---|---|---|---|---|---|---|---|---|----------|--|--|--|--|--|--|---------|--|--|--|--|--|--|
|          | Word  | Long word |            |                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
| -        | 8     | -         | MINC2 #, r | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td></td><td>r</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td></tr> <tr><td colspan="7">#&lt;7:0&gt;-2</td></tr> <tr><td colspan="7">#&lt;15:8&gt;</td></tr> </table> | 1 | 1 | 0 | 1 | 1 |  | r | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | #<7:0>-2 |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |
| 1        | 1     | 0         | 1          | 1                                                                                                                                                                                                                                                                                                                                                      |   | r | 1 |   |   |  |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
| 0        | 0     | 1         | 1          | 1                                                                                                                                                                                                                                                                                                                                                      | 0 | 0 | 1 |   |   |  |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
| #<7:0>-2 |       |           |            |                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |
| #<15:8>  |       |           |            |                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |  |   |   |   |   |   |   |   |   |   |   |          |  |  |  |  |  |  |         |  |  |  |  |  |  |

**Note :** The operand # must be 2 to the nth power. (n = 2 to 15)

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**Execution example:** Increments the IX register by cycling from 1230H to 1237H.

MINC2 8,IX

When the IX register = 1234H, execution sets the IX register to 1236H. Further execution decrements the IX register by 8-2 and sets the IX Register to 1230H, since the IX register modulo 8 = 8-2.



**MINC4 num, dst**

&lt; Modulo Increment 4 &gt;

**Operation :** if ( $dst \bmod num$ ) = ( $num - 4$ ) then  $dst \leftarrow dst - (num - 4)$  else  $dst \leftarrow dst + 4$ .

**Description :** When the modulo num of dst is  $num - 4$ , decrements dst by  $num - 4$ .  
 Otherwise, increments dst by 4. Used to operate pointers for cyclic memory table.

**Details :**

| Byte | State |           | Mnemonic | Code |
|------|-------|-----------|----------|------|
|      | Word  | Long word |          |      |
| -    | 8     | -         | MINC4    | #, r |

|          |   |   |   |   |   |   |   |
|----------|---|---|---|---|---|---|---|
| 1        | 1 | 0 | 1 | 1 |   | r |   |
| 0        | 0 | 1 | 1 | 1 | 0 | 1 | 0 |
| #<7:0>-4 |   |   |   |   |   |   |   |
| #<15:8>  |   |   |   |   |   |   |   |

**Note :** The operand # must be 2 to the nth power. ( $n = 3$  to  $15$ )

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**Execution example:** Increments the IX register by cycling from 1240H to 127FH.

MINC4 40H,IX

When the IX register = 1278H, execution sets the IX register to 127CH. Further execution decrements the IX register by 40H-4 and sets the IX register to 1240H, since the IX register modulo 40H = 40H-4.



**MIRR dst**

&lt; Mirror &gt;

Operation : dst<MSB:LSB> $\leftarrow$  dst<LSB:MSB>

Description : Mirror-exchanges the contents of dst using the bit pattern image.



Details :

| Byte | State |           | Mnemonic | Code |
|------|-------|-----------|----------|------|
|      | Word  | Long word |          |      |
| -    | 4     | -         | MIRR     | r    |

1 | 1 | 0 | 1 | 1 | r |  
 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: MIRR HL

When the HL register = 0001 0010 0011 0100B (binary), execution sets the HL register to 0010 1100 0100 1000B (binary).



**MUL dst, src**

&lt; Multiply &gt;

Operation :  $dst \leftarrow dst <lower\ half> \times src\ (unsigned)$

Description : Multiplies unsigned the contents of lower half of dst by those of src and loads the result to dst.

Details :

| Byte     | State<br>Word | Long word | Mnemonic      | Code                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
|----------|---------------|-----------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---------|--|--|--|--|--|--|----------|--|--|--|--|--|--|
| 18       | 26            | -         | MUL RR, r     | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td>r</td><td></td></tr> <tr><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td><td>R</td><td></td></tr> </table>                                                                                           | 1 | 1 | 0 | z | 1 | r |   | 0 | 1 | 0 | 0 | 0 | R |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 1        | 1             | 0         | z             | 1                                                                                                                                                                                                                                                                                   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 0        | 1             | 0         | 0             | 0                                                                                                                                                                                                                                                                                   | R |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 18       | 26            |           | MUL rr, #     | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td>r</td><td></td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td></tr> <tr><td colspan="7"># &lt;7:0&gt;</td></tr> <tr><td colspan="7"># &lt;15:8&gt;</td></tr> </table> | 1 | 1 | 0 | z | 1 | r |   | 0 | 0 | 0 | 0 | 1 | 0 | 0 | # <7:0> |  |  |  |  |  |  | # <15:8> |  |  |  |  |  |  |
| 1        | 1             | 0         | z             | 1                                                                                                                                                                                                                                                                                   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 0        | 0             | 0         | 0             | 1                                                                                                                                                                                                                                                                                   | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| # <7:0>  |               |           |               |                                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| # <15:8> |               |           |               |                                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 18       | 26            |           | MUL RR, (mem) | <table border="1"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td><td></td><td>R</td><td></td></tr> </table>                                                                       | 1 | m | 0 | z | m | m | m | m | 0 | 1 | 0 | 0 | 0 |   | R       |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 1        | m             | 0         | z             | m                                                                                                                                                                                                                                                                                   | m | m | m |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 0        | 1             | 0         | 0             | 0                                                                                                                                                                                                                                                                                   |   | R |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |

Note : When the operation is in bytes,  $dst\ (word) \leftarrow dst\ (byte) \times src\ (byte)$ .

When the operation is in words,  $dst\ (long\ word) \leftarrow dst\ (word) \times src\ (word)$

Match coding of the operand dst with the size of the result.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: MUL XIX,IY

When the IX register = 1234H and the IY register = 89ABH,  
 execution multiplies unsigned the contents of the IX register by those of  
 the IY register and sets the XIX register to 09C9FCBCH.

Note : "RR" for the MUL RR,r and MUL RR,(mem) instructions is as listed below:

Operation size in bytes  
(16bits ← 8bits × 8bits)

| RR | Code R |
|----|--------|
| WA | 001    |
| BC | 011    |
| DE | 101    |
| HL | 111    |
| IX |        |
| IY |        |
| IZ |        |
| SP |        |

} Specification not possible!

Operation size in words  
(32bits ← 16bits × 16bits)

| RR  | Code R |
|-----|--------|
| XWA | 000    |
| XBC | 001    |
| XDE | 010    |
| XHL | 011    |
| XIX | 100    |
| XIY | 101    |
| XIZ | 110    |
| XSP | 111    |

\*1 When the CPU is in minimum mode, XWA, XBC, XDE, or XHL cannot be used.

"rr" for the MUL rr,# instruction is as listed below.

Operation size in bytes  
(16bits ← 8bits × 8bits)

| rr | Code r    |
|----|-----------|
| WA | 001       |
| BC | 011       |
| DE | 101       |
| HL | 111       |
| IX | C7H : F0H |
| IY | C7H : F4H |
| IZ | C7H : F8H |
| SP | C7H : FCH |

1st byte      2nd byte

\*2 Any other word registers can be specified in the same extension coding as those for IX to SP.

Operation size in words  
(32bits ← 16bits × 16bits)

| rr  | Code r |
|-----|--------|
| XWA | 000    |
| XBC | 001    |
| XDE | 010    |
| XHL | 011    |
| XIX | 100    |
| XIY | 101    |
| XIZ | 110    |
| XSP | 111    |

\*3 When the CPU is in minimum mode, XWA, XBC, XDE, or XHL cannot be used.

\*4 Any other long word registers can be specified in the extension coding.

**MULA dst**

&lt; Multiply and Add &gt;

Operation :  $dst \leftarrow dst + (XDE) \times (XHL)$ ,  $XHL \leftarrow XHL - 2$

Description : Multiplies signed memory data (16 bits) specified by the XDE register by the memory data (16 bits) specified by the XHL register. Adds the result (32 bits) to the contents of dst (32 bits) and loads the sum to dst (32 bits). Then, decrements the contents of the XHL register by 2.

Details :

| Byte | State<br>Word | Mnemonic | Code | Word | Long word                                                                                                                                                                                                                                         |   |   |   |   |   |  |   |   |   |   |   |   |   |   |
|------|---------------|----------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|---|---|---|---|---|---|---|---|
|      |               |          |      | rr   | rr                                                                                                                                                                                                                                                |   |   |   |   |   |  |   |   |   |   |   |   |   |   |
| -    | 31            | MULA     |      |      | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td></td><td>r</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td></tr> </table> | 1 | 1 | 0 | 1 | 1 |  | r | 0 | 0 | 0 | 1 | 1 | 0 | 0 |
| 1    | 1             | 0        | 1    | 1    |                                                                                                                                                                                                                                                   | r |   |   |   |   |  |   |   |   |   |   |   |   |   |
| 0    | 0             | 0        | 1    | 1    | 0                                                                                                                                                                                                                                                 | 0 |   |   |   |   |  |   |   |   |   |   |   |   |   |

Note : Match coding of the operand dst with the operation size (long word).

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | - | * | - | - |
|---|---|---|---|---|---|

S = MSB value of the result is set.

Z = 1 is set when the result is 0, otherwise 0.

H = No change.

V = 1 is set when an overflow occurs as a result, otherwise 0.

N = No change.

C = No change.

Execution example: MULA XIX

Under the following conditions, execution sets the XIX register to 4795FCBCH and the XHL register to 1FEH.

Conditions: XIX register = 50000000H

XDE register = 100H

XHL register = 200H

Memory data (word) at address 100H = 1234H

Memory data (word) at address 200H = 89ABH



**MULS dst, src**

&lt; Multiply Signed &gt;

Operation :  $dst \leftarrow dst <lower\ half> \times src$  (signed)

Description : Multiplies signed the contents of the lower half of dst by those of src and loads the result to dst.

Details :

| Byte     | State<br>Word | Long word | Mnemonic            | Code                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
|----------|---------------|-----------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---------|--|--|--|--|--|--|----------|--|--|--|--|--|--|
| 18       | 26            | -         | MULS      RR, r     | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td>r</td><td></td></tr> <tr><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td><td>R</td><td></td></tr> </table>                                                                                           | 1 | 1 | 0 | z | 1 | r |   | 0 | 1 | 0 | 0 | 1 | R |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 1        | 1             | 0         | z                   | 1                                                                                                                                                                                                                                                                                   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 0        | 1             | 0         | 0                   | 1                                                                                                                                                                                                                                                                                   | R |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 18       | 26            | -         | MULS      rr, #     | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td>r</td><td></td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td></tr> <tr><td colspan="7"># &lt;7:0&gt;</td></tr> <tr><td colspan="7"># &lt;15:8&gt;</td></tr> </table> | 1 | 1 | 0 | z | 1 | r |   | 0 | 0 | 0 | 0 | 1 | 0 | 0 | # <7:0> |  |  |  |  |  |  | # <15:8> |  |  |  |  |  |  |
| 1        | 1             | 0         | z                   | 1                                                                                                                                                                                                                                                                                   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 0        | 0             | 0         | 0                   | 1                                                                                                                                                                                                                                                                                   | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| # <7:0>  |               |           |                     |                                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| # <15:8> |               |           |                     |                                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 18       | 26            |           | MULS      RR, (mem) | <table border="1"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td><td></td><td>R</td><td></td></tr> </table>                                                                       | 1 | m | 0 | z | m | m | m | m | 0 | 1 | 0 | 0 | 1 |   | R       |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 1        | m             | 0         | z                   | m                                                                                                                                                                                                                                                                                   | m | m | m |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 0        | 1             | 0         | 0                   | 1                                                                                                                                                                                                                                                                                   |   | R |   |   |   |   |   |   |   |   |   |   |   |   |         |  |  |  |  |  |  |          |  |  |  |  |  |  |

Note : When the operation is in bytes,  $dst(\text{word}) \leftarrow dst(\text{byte}) \times src(\text{byte})$ .

When the operation is in words,  $dst(\text{long word}) \leftarrow dst(\text{word}) \times src(\text{word})$ .

Match coding of the operand dst with the size of the result.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: MULS XIX,IY

When the IX register = 1234H and the IY register = 89ABH, execution multiplies signed the contents of the IX register by those of the IY register and sets the XIX register to F795FCBCH.

Note : "RR" for the MULS RR,r and MULS RR,(mem) instructions is as listed below:

Operation size in bytes  
(16bits←8bits × 8bits)

| RR | Code R |
|----|--------|
| WA | 001    |
| BC | 011    |
| DE | 101    |
| HL | 111    |
| IX |        |
| IY |        |
| IZ |        |
| SP |        |

} Specification not possible!

Operation size in words  
(32bits←16bits × 16bits)

| RR  | Code R |
|-----|--------|
| XWA | 000    |
| XBC | 001    |
| XDE | 010    |
| XHL | 011    |
| XIX | 100    |
| XIY | 101    |
| XIZ | 110    |
| XSP | 111    |

\*1 When the CPU is in minimum mode, XWA, XBC, XDE, or XHL cannot be used.

"rr" for the MULS rr,# instruction is as listed below.

Operation size in bytes  
(16bits←8bits × 8bits)

| rr | Code r                  |
|----|-------------------------|
| WA | 001                     |
| BC | 011                     |
| DE | 101                     |
| HL | 111                     |
| IX | C7H : F0H               |
| IY | C7H : F4H               |
| IZ | C7H : F8H               |
| SP | <u>C7H</u> : <u>FCH</u> |

1st byte 2nd byte

\*2 Any other word registers can be specified in the same extension coding as those for IX to SP.

Operation size in words  
(32bits←16bits × 16bits)

| rr  | Code r |
|-----|--------|
| XWA | 000    |
| XBC | 001    |
| XDE | 010    |
| XHL | 011    |
| XIX | 100    |
| XIY | 101    |
| XIZ | 110    |
| XSP | 111    |

\*3 When the CPU is in minimum mode, XWA, XBC, XDE, or XHL cannot be used.

\*4 Any other long word registers can be specified in the extension coding.

**NEG dst**

&lt; Negate &gt;

Operation :  $dst \leftarrow 0 - dst$ Description : Decrements 0 by the contents of dst and loads the result to dst.  
(Twos complement)

Details :

| Byte | State |           | Mnemonic | Code                                |
|------|-------|-----------|----------|-------------------------------------|
|      | Word  | Long word |          |                                     |
| 5    | 5     | -         | NEG      | r<br>1 1 0 z 1 r<br>0 0 0 0 0 1 1 1 |

Flags : S Z H V N C



S = MSB value of the result is set.

Z = 1 is set when the result is 0, otherwise 0.

H = 1 is set when a borrow from bit 3 to bit 4 occurs as a result, otherwise 0.

V = 1 is set when an overflow occurs as a result, otherwise 0.

N = 1 is set.

C = 1 is set when a borrow from the MSB occurs as a result, otherwise 0.

Execution example: NEG IX

When the IX register = 0002H, execution sets the IX register to FFFEH.



# NOP

<No Operation>

Operation : None.

Description : Does nothing but moves execution to the next instruction. The object code of this instruction is 00H.

Details :

| State | Mnemonic | Code                                                                                                                |   |   |   |   |   |   |   |   |
|-------|----------|---------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|
| 2     | NOP      | <table border="1"><tr><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td></tr></table> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0     | 0        | 0                                                                                                                   | 0 | 0 | 0 | 0 | 0 |   |   |   |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**NORMAL**

&lt; Normal &gt;

This instruction doesn't exist in 900/L and 900/H CPU.  
 This is privileged instruction in 900 CPU.

**Operation** : SYSM bit  $\leftarrow 0$

**Description** : Resets the SYSM bit in status register to 0 and changes the CPU to normal mode.

**Details** :

| State | Mnemonic | Code            |
|-------|----------|-----------------|
| 4     | NORMAL   | 0 0 0 0 0 0 0 1 |

**Flags** : S Z H V N C  
 \_\_\_\_\_  
 | - | - | - | - | - | - |

- S = No change
- Z = No change
- H = No change
- V = No change
- N = No change
- C = No change

**Note** : Basically, only the software interrupt (SWI) instruction changes the mode from normal to system by software. The following change the mode :

- (1) SWI
- (2) Privilege violation interrupt
- (3) Illegal instruction interrupt
- (4) Hardware interrupt
- (5) Reset

The SWI instruction is used to change the mode to system in the middle of program execution, as shown below.



## OR dst, src

&lt; Logical OR &gt;

Operation : dst $\leftarrow$  dst OR src

Description : Ors the contents of dst with those of src and loads the result to dst.

(Truth table)

| A | B | A OR B |
|---|---|--------|
| 0 | 0 | 0      |
| 0 | 1 | 1      |
| 1 | 0 | 1      |
| 1 | 1 | 1      |

Details :

| Byte     | State<br>Word | Long word | Mnemonic | Code                                                                                                                                                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|----------|---------------|-----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--------|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|
| 4        | 4             | 7         | OR       | R, r                                                                                                                                                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|          |               |           |          | <table border="1"><tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr><tr><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td><td></td><td>R</td><td></td></tr></table>                                                                                                                                                                                | 1 | 1 | z | z | 1 |   | r |   | 1 | 1 | 1 | 0 | 0 |   | R |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | z         | z        | 1                                                                                                                                                                                                                                                                                                                                                                                       |   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | 1         | 0        | 0                                                                                                                                                                                                                                                                                                                                                                                       |   | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4             | 7         | OR       | r, #                                                                                                                                                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|          |               |           |          | <table border="1"><tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr><tr><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>0</td></tr><tr><td colspan="8">#&lt;7:0&gt;</td></tr><tr><td colspan="8">#&lt;15:8&gt;</td></tr><tr><td colspan="8">#&lt;23:16&gt;</td></tr><tr><td colspan="8">#&lt;31:24&gt;</td></tr></table> | 1 | 1 | z | z | 1 |   | r |   | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | #<7:0> |  |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |  | #<23:16> |  |  |  |  |  |  |  | #<31:24> |  |  |  |  |  |  |  |
| 1        | 1             | z         | z        | 1                                                                                                                                                                                                                                                                                                                                                                                       |   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | 0         | 0        | 1                                                                                                                                                                                                                                                                                                                                                                                       | 1 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>   |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                         |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>  |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                         |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<23:16> |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                         |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<31:24> |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                         |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4             | 6         | OR       | R, (mem)                                                                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|          |               |           |          | <table border="1"><tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr><tr><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td><td></td><td>R</td><td></td></tr></table>                                                                                                                                                                              | 1 | m | z | z | m | m | m | m | 1 | 1 | 1 | 0 | 0 |   | R |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m             | z         | z        | m                                                                                                                                                                                                                                                                                                                                                                                       | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | 1         | 0        | 0                                                                                                                                                                                                                                                                                                                                                                                       |   | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 6        | 6             | 10        | OR       | (mem), R                                                                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|          |               |           |          | <table border="1"><tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr><tr><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td></td><td>R</td><td></td></tr></table>                                                                                                                                                                              | 1 | m | z | z | m | m | m | m | 1 | 1 | 1 | 0 | 1 |   | R |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m             | z         | z        | m                                                                                                                                                                                                                                                                                                                                                                                       | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1             | 1         | 0        | 1                                                                                                                                                                                                                                                                                                                                                                                       |   | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 7        | 8             | -         | OR<W>    | (mem), #                                                                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|          |               |           |          | <table border="1"><tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr><tr><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td></tr><tr><td colspan="8">#&lt;7:0&gt;</td></tr><tr><td colspan="8">#&lt;15:8&gt;</td></tr></table>                                                                                       | 1 | m | 0 | z | m | m | m | m | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | #<7:0> |  |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m             | 0         | z        | m                                                                                                                                                                                                                                                                                                                                                                                       | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 0        | 0             | 1         | 1        | 1                                                                                                                                                                                                                                                                                                                                                                                       | 1 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>   |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                         |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>  |               |           |          |                                                                                                                                                                                                                                                                                                                                                                                         |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |

Flags : S Z H V N C  

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | 0 | * | 0 | 0 |
|---|---|---|---|---|---|

S = MSB value of the result is set.

Z = 1 is set when the result is 0, otherwise 0.

H = 0 is set.

V = 1 is set when the parity (number of 1s) of the result is even, 0 when odd.  
When the operand is 32-bit, an undefined value is set.

N = Cleared to 0.

C = Cleared to 0.



Execution example: OR HL, IX

When the HL register = 7350H and the IX register is 3456H, execution sets the HL register to 7756H.

|      |      |      |      |                                       |
|------|------|------|------|---------------------------------------|
| 0111 | 0011 | 0101 | 0000 | ← HL register (before execution)      |
| OR ) | 0011 | 0100 | 0101 | 0110 ← IX register (before execution) |
|      | 0111 | 0111 | 0101 | 0110 ← HL register (after execution)  |

## ORCF num, src

*< OR Carry Flag >*

**Operation :** CY  $\leftarrow$  CY OR src<num>

**Description :** Ors the contents of the carry flag with those of bit num of src and loads the result to the carry flag.

**Details :**

| Byte | State |           | Mnemonic | Code                                                                                                                                                                                                                                                                                                                                                 |   |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
|------|-------|-----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|---|--|---|---|--|
|      | Word  | Long word |          |                                                                                                                                                                                                                                                                                                                                                      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
| 4    | 4     | -         | ORCF     | #4, r                                                                                                                                                                                                                                                                                                                                                |   |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
|      |       |           |          | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>#</td><td>4</td><td></td></tr> </table> | 1 | 1  | 0 | z | 1 |   | r |   | 0 | 0 | 1 | 0 | 0 | 0 | 0  | 1 | 0 | 0 | 0 | 0 |  | # | 4 |  |
| 1    | 1     | 0         | z        | 1                                                                                                                                                                                                                                                                                                                                                    |   | r  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
| 0    | 0     | 1         | 0        | 0                                                                                                                                                                                                                                                                                                                                                    | 0 | 0  | 1 |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
| 0    | 0     | 0         | 0        |                                                                                                                                                                                                                                                                                                                                                      | # | 4  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
| 4    | 4     | -         | ORCF     | A, r                                                                                                                                                                                                                                                                                                                                                 |   |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
|      |       |           |          | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td></tr> </table>                                                                                         | 1 | 1  | 0 | z | 1 |   | r |   | 0 | 0 | 1 | 0 | 1 | 0 | 0  | 1 |   |   |   |   |  |   |   |  |
| 1    | 1     | 0         | z        | 1                                                                                                                                                                                                                                                                                                                                                    |   | r  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
| 0    | 0     | 1         | 0        | 1                                                                                                                                                                                                                                                                                                                                                    | 0 | 0  | 1 |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
| 8    |       | -         | ORCF     | #3, (mem)                                                                                                                                                                                                                                                                                                                                            |   |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
|      |       |           |          | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>0</td><td>0</td><td>0</td><td>1</td><td></td><td>#3</td><td></td></tr> </table>                                                                                        | 1 | m  | 1 | 1 | m | m | m | m | 1 | 0 | 0 | 0 | 1 |   | #3 |   |   |   |   |   |  |   |   |  |
| 1    | m     | 1         | 1        | m                                                                                                                                                                                                                                                                                                                                                    | m | m  | m |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
| 1    | 0     | 0         | 0        | 1                                                                                                                                                                                                                                                                                                                                                    |   | #3 |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
| 8    | -     | -         | ORCF     | A, (mem)                                                                                                                                                                                                                                                                                                                                             |   |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
|      |       |           |          | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td></tr> </table>                                                                                       | 1 | m  | 1 | 1 | m | m | m | m | 0 | 0 | 1 | 0 | 1 | 0 | 0  | 1 |   |   |   |   |  |   |   |  |
| 1    | m     | 1         | 1        | m                                                                                                                                                                                                                                                                                                                                                    | m | m  | m |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |
| 0    | 0     | 1         | 0        | 1                                                                                                                                                                                                                                                                                                                                                    | 0 | 0  | 1 |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |   |  |   |   |  |

**Note :** When bit num is specified by the A register, the value of the lower 4 bits of the A register is used as bit num. When the operand is a byte and the value of the lower bits of bit num is from 8 to 15, the result is undefined.

**flag :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | * |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = The result of or-ing the contents of the carry flag with those of bit num of src is set.

**Execution example:** ORCF 6,(100H)

When the contents of memory at address 100H = 01000000B (binary) and the carry flag = 0, execution sets the carry flag to 1.



## PAA dst

< Pointer Adjust Accumulator >

Operation : if dst <LSB> = 1 then dst  $\leftarrow$  dst + 1

Description : Increments dst by 1 when the LSB of dst is 1. Does nothing when the LSB of dst is 0.

Used to make the contents of dst even. With the TLCS-900 series, when accessing 16- or 32-bit data in memory, if the data are loaded from an address starting with an even number, the number of bus cycles is 1 less than that of the data loaded from an address starting with an odd number.

Details :

| Byte | State |           | Mnemonic | Code                                                          |
|------|-------|-----------|----------|---------------------------------------------------------------|
|      | Word  | Long word |          |                                                               |
| -    | 4     | 4         | PAA      | r<br>1   1   z   z   1   r  <br>0   0   0   1   0   1   0   0 |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: PAA XIZ

When the XIZ register = 00234567H, execution increments the XIZ register by 1 so that it becomes 00234568H.

## POP dst

&lt; Pop &gt;

Operation :  $dst \leftarrow (XSP +)$  [In bytes :  $dst \leftarrow (XSP)$ ,  $XSP \leftarrow XSP + 1$   
                   In words :  $dst \leftarrow (XSP)$ ,  $XSP \leftarrow XSP + 2$   
                   In long words :  $dst \leftarrow (XSP)$ ,  $XSP \leftarrow XSP + 4$ ]

Description : First loads the contents of memory address specified by the stack pointer XSP to dst. Then increments the stack pointer XSP by the number of bytes in the operand.

Details :

| Byte | State |           | Mnemonic |       | Code                                                                                                                                                                                                         |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|------|-------|-----------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|      | Word  | Long word |          |       |                                                                                                                                                                                                              |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 4    | -     | -         | POP      | F     | <table border="1"><tr><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td></tr></table>                                                                                          | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 |   |   |   |   |   |   |   |   |
| 0    | 0     | 0         | 1        | 1     | 0                                                                                                                                                                                                            | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 4    | -     | -         | POP      | A     | <table border="1"><tr><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td></tr></table>                                                                                          | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 |   |   |   |   |   |   |   |   |
| 0    | 0     | 0         | 1        | 0     | 1                                                                                                                                                                                                            | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| -    | 4     | 6         | POP      | R     | <table border="1"><tr><td>0</td><td>1</td><td>0</td><td>s</td><td>1</td><td></td><td>R</td><td>1</td></tr></table>                                                                                           | 0 | 1 | 0 | s | 1 |   | R | 1 |   |   |   |   |   |   |   |   |
| 0    | 1     | 0         | s        | 1     |                                                                                                                                                                                                              | R | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 6    | 6     | 8         | POP      | r     | <table border="1"><tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr><tr><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td></tr></table>  | 1 | 1 | z | z | 1 |   | r | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 |
| 1    | 1     | z         | z        | 1     |                                                                                                                                                                                                              | r | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0    | 0     | 0         | 0        | 0     | 1                                                                                                                                                                                                            | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 6    | 6     |           | POP<W>   | (mem) | <table border="1"><tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td><td>m</td></tr><tr><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>z</td><td>0</td></tr></table> | 1 | m | 1 | 1 | m | m | m | m | 0 | 0 | 0 | 0 | 0 | 1 | z | 0 |
| 1    | m     | 1         | 1        | m     | m                                                                                                                                                                                                            | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0    | 0     | 0         | 0        | 0     | 1                                                                                                                                                                                                            | z | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

(Note) Executing POP F changes all flags.

Execution example: POP IX

When the stack pointer XSP = 0100H, the contents of address 100H = 56H, and the contents of address 101H = 78H, execution sets the IX register to 7856H and the stack pointer XSP to 0102H.



**POP SR**

&lt; Pop SR &gt;

This is privileged instruction in 900 CPU.

Operation :  $SR \leftarrow (XSP +)$ 

Description : Loads the contents of the address specified by the stack pointer XSP to status register. Then increments the contents of the stack pointer XSP by 2.

Details :

| Byte | State |           | Mnemonic    | Code                                                                                                                |   |   |   |   |   |   |   |   |
|------|-------|-----------|-------------|---------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|
|      | Word  | Long word |             |                                                                                                                     |   |   |   |   |   |   |   |   |
| -    | 6     | -         | POP      SR | <table border="1"><tr><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td></tr></table> | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
| 0    | 0     | 0         | 0           | 0                                                                                                                   | 0 | 1 | 1 |   |   |   |   |   |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | * | * |
|---|---|---|---|---|---|

S =  
 Z =  
 H =  
 V =  
 N =  
 C =

} Contents of the memory address specified by the stack pointer XSP are set.

Note : The timing for executing this instruction is delayed by several states than that for fetching the instruction. This is because an instruction queue (4 bytes) and pipeline processing method is used.

Note, when changing from the system area to the normal area using this instruction, that the access area of the instruction code immediately after this instruction is used as the access area before execution of this instruction. The figure below is an example.



## PUSH SR

<Push SR>

This is privileged instruction in 900 CPU.

Operation :  $(-\text{XSP}) \leftarrow \text{SR}$

Description : Decrements the contents of the stack pointer XSP by 2. Then loads the contents of status register to the memory address specified by the stack pointer XSP.

Details :

| Byte | State |           | Mnemonic     | Code                                                                                                                          |   |   |   |   |   |   |   |   |   |
|------|-------|-----------|--------------|-------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|
|      | Word  | Long word |              |                                                                                                                               |   |   |   |   |   |   |   |   |   |
| -    | 4     | -         | PUSH      SR | <table border="1"><tr><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td></tr></table> | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 |
| 0    | 1     | 0         | 0            | 0                                                                                                                             | 1 | 0 | 1 | 0 |   |   |   |   |   |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**PUSH src**

&lt; Push &gt;

Operation :  $(-\text{XSP}) \leftarrow \text{src}$

|                |                                                                            |
|----------------|----------------------------------------------------------------------------|
| [In bytes      | : $\text{XSP} \leftarrow \text{XSP}-1, (\text{XSP}) \leftarrow \text{src}$ |
| [In words      | : $\text{XSP} \leftarrow \text{XSP}-2, (\text{XSP}) \leftarrow \text{src}$ |
| [In long words | : $\text{XSP} \leftarrow \text{XSP}-4, (\text{XSP}) \leftarrow \text{src}$ |

Description : Decrements the stack pointer XSP by the byte length of the operand.  
 Then loads the contents of src to the memory address specified by the stack pointer XSP.

Details :

| Byte | State |           | Mnemonic      |   | Code                                 |
|------|-------|-----------|---------------|---|--------------------------------------|
|      | Word  | Long word |               |   |                                      |
| 3    | -     | -         | PUSH          | F | 0 0 0 1 1 0 0 0                      |
| 3    | -     | -         | PUSH          | A | 0 0 0 1 0 1 0 0                      |
| -    | 3     | 5         | PUSH          | R | 0 0 1 s 1 R                          |
| 5    | 5     | 7         | PUSH          | r | 1 1 z z 1 r<br>0 0 0 0 0 1 0 0       |
| 4    | 5     |           | PUSH<W> #     |   | 0 0 0 0 1 0 z 1<br>#<7:0><br>#<15:8> |
| 7    | 7     |           | PUSH<W> (mem) |   | 1 m 0 z m m m m<br>0 0 0 0 0 1 0 0   |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: PUSH HL

When the stack pointer XSP = 0100H and the HL register = 1234H, execution changes address 00FEH to 34H, address 00FFH to 12H, and sets the stack pointer XSP to 00FEH.



## RCF

< Reset Carry Flag >

Operation : CY  $\leftarrow$  0

Description : Resets the carry flag to 0.

Details :

| State | Mnemonic | Code              |
|-------|----------|-------------------|
| 2     | RCF      | 0 1 0 0 1 0 0 0 0 |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | 0 | - | 0 | 0 |
|---|---|---|---|---|---|

S = No change

Z = No change

H = Reset to 0.

V = Reset to 0.

N = No change

C = Reset to 0.

## RES num, dst

&lt; Reset &gt;

Operation : dst <num>  $\leftarrow$  0

Description : Resets bit num of dst to 0.

Details :

| Byte | State |           | Mnemonic | #4, r     | Code                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |  |   |   |
|------|-------|-----------|----------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|---|--|---|---|
|      | Word  | Long word |          |           |                                                                                                                                                                                                                                                                           |    |   |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |  |   |   |
| 4    | 4     | -         | RES      | #4, r     | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td><td>0</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>#</td><td>4</td></tr> </table> | 1  | 1 | 0 | z | 1 |   | r | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0  | 0 | 0 | 0 |  | # | 4 |
| 1    | 1     | 0         | z        | 1         |                                                                                                                                                                                                                                                                           | r  |   |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |  |   |   |
| 0    | 0     | 1         | 1        | 0         | 0                                                                                                                                                                                                                                                                         | 0  |   |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |  |   |   |
| 0    | 0     | 0         | 0        |           | #                                                                                                                                                                                                                                                                         | 4  |   |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |  |   |   |
| 8    |       | -         | RES      | #3, (mem) | <table border="1"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>0</td><td>1</td><td>1</td><td>0</td><td></td><td>#3</td><td></td></tr> </table>                                                            | 1  | m | 1 | 1 | m | m | m | m | 1 | 0 | 1 | 1 | 0 |   | #3 |   |   |   |  |   |   |
| 1    | m     | 1         | 1        | m         | m                                                                                                                                                                                                                                                                         | m  | m |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |  |   |   |
| 1    | 0     | 1         | 1        | 0         |                                                                                                                                                                                                                                                                           | #3 |   |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |  |   |   |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

- S = No change
- Z = No change
- H = No change
- V = No change
- N = No change
- C = No change

Execution example: RES 5,(100H)

When the contents of memory at address 100H = 00100111B (binary), execution sets the contents to 00000111B (binary).



## RET condition

*< Return >*

**Operation :** In minimum mode : If cc is true, then the 16-bit PC  $\leftarrow$  (XSP),  
                   XSP  $\leftarrow$  XSP + 2.

In maximum mode : If cc is true, then the 32-bit PC  $\leftarrow$  (XSP),  
                   XSP  $\leftarrow$  XSP + 4.

**Description :** Pops the return address from the stack area to the program counter when the operand condition is true.

**Details :**

| State                            | Mnemonic | Code                          |
|----------------------------------|----------|-------------------------------|
| 9 (minimum mode)                 | RET      | 0   0   0   0   1   1   1   0 |
| 11 (maximum mode)                |          |                               |
| 12 (cc is true, in minimum mode) | RET cc   | 1   0   1   1   0   0   0   0 |
| 14 (cc is true, in maximum mode) |          |                               |
| 6 (cc is false)                  |          |                               |

**Flags :** S Z H V N C

|  |  |  |  |  |  |
|--|--|--|--|--|--|
|  |  |  |  |  |  |
|--|--|--|--|--|--|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**Execution example:** RET

When the stack pointer XSP = 0FEH and the contents of memory at address 0FEH = 9000H (word data) in minimum mode, execution sets the stack pointer XSP to 100H and jumps (returns) to address 9000H.

## RETD num

*< Return and Deallocate >*

**Operation :** In minimum mode : 16-bit PC  $\leftarrow$  (XSP), XSP  $\leftarrow$  XSP + 2, XSP  $\leftarrow$  XSP + num  
                   In maximum mode : 32-bit PC  $\leftarrow$  (XSP), XSP  $\leftarrow$  XSP + 4, XSP  $\leftarrow$  XSP + num

**Description :** Pops the return address from the stack area to the program counter. Then increments the stack pointer XSP by signed num.

**Details :**

| State             | Mnemonic | Code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
|-------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--------|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|
| 9 (minimum mode)  | RETD     | d16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| 11 (maximum mode) |          | <table border="1" style="margin-left: auto; margin-right: auto; border-collapse: collapse;"> <tr> <td style="padding: 2px;">0</td><td style="padding: 2px;">0</td><td style="padding: 2px;">0</td><td style="padding: 2px;">0</td><td style="padding: 2px;">1</td><td style="padding: 2px;">1</td><td style="padding: 2px;">1</td><td style="padding: 2px;">1</td></tr> <tr> <td colspan="8" style="text-align: center; padding: 2px;">d&lt;7:0&gt;</td></tr> <tr> <td colspan="8" style="text-align: center; padding: 2px;">d&lt;15:8&gt;</td></tr> </table> | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | d<7:0> |  |  |  |  |  |  |  | d<15:8> |  |  |  |  |  |  |  |
| 0                 | 0        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0 | 1 | 1 | 1 | 1 |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| d<7:0>            |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |
| d<15:8>           |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |

**Flags :** S Z H V N C

|  |  |  |  |  |  |  |
|--|--|--|--|--|--|--|
|  |  |  |  |  |  |  |
|--|--|--|--|--|--|--|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

**Execution example:** RETD 8

When the stack pointer XSP = 0FEH and the contents of memory at address 0FEH = 9000H (word data) in minimum mode, execution sets the stack pointer XSP to 0FEH + 2 + 8  $\rightarrow$  108H and jumps (returns) to address 9000H.

Usage of the RETD instruction is shown below. In this example, the 8-bit parameter is pushed to the stack before the subroutine call. After the subroutine processing complete, the used parameter area is deleted by the RETD instruction.



## RETI

*< Return from Interrupt >*

**This is privileged instruction in 900 CPU.**

**Operation :** In minimum mode : 2-byte Temp  $\leftarrow$  (XSP), 16-bit PC  $\leftarrow$  (XSP + 2),  
                                   SR  $\leftarrow$  Temp, XSP  $\leftarrow$  XSP + 4  
       In maximum mode : 2-byte Temp  $\leftarrow$  (XSP), 32-bit PC  $\leftarrow$  (XSP + 2),  
                                   SR  $\leftarrow$  Temp, XSP  $\leftarrow$  XSP + 6

**[After the above operation is executed, the 900/L and 900/H CPU decrement a value of interrupt nesting counter INTNEST by 1.]**

**Description :** Pops data from the stack area to the 2-byte Temp register and program counter. Next, loads the contents of the Temp register to status register.

**[After the above operation is executed, the 900/L and 900/H CPU decrement a value of interrupt nesting counter INTNEST by 1.]**

**Note :** The reason that data is not popped to status register directly from the stack area is to avoid changing the mode from normal to system while reading the stack area where the RETI instruction is being executed.

| Details : | State             | Mnemonic | Code            |
|-----------|-------------------|----------|-----------------|
|           | 12 (minimum mode) | RETI     | 0 0 0 0 0 1 1 1 |
|           | 14 (maximum mode) |          |                 |

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | * | * |
|---|---|---|---|---|---|

- S = The value popped from the stack area is set.
- Z = The value popped from the stack area is set.
- H = The value popped from the stack area is set.
- V = The value popped from the stack area is set.
- N = The value popped from the stack area is set.
- C = The value popped from the stack area is set.

## RL num, dst

&lt; Rotate Left &gt;

Operation : {CY & dst  $\leftarrow$  left rotates the value of CY & dst} Repeat num

Description : Rotates left the contents of the linked carry flag and dst.  
Repeats the number of times specified in num.

Description figure:



Details :

| Byte | State |           | Mnemonic |       | Code                                                                                                                                                                                                                                                                                              |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
|------|-------|-----------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|---|---|--|
|      | Word  | Long word |          |       |                                                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 6    | 6     | 8         | RL       | #4, r | <table border="1"><tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr><tr><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td></tr><tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>#</td><td>4</td><td></td></tr></table> | 1 | 1 | z | z | 1 |   | r |   | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |  | # | 4 |  |
| 1    | 1     | z         | z        | 1     |                                                                                                                                                                                                                                                                                                   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 1    | 1     | 1         | 0        | 1     | 0                                                                                                                                                                                                                                                                                                 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 0    | 0     | 0         | 0        |       | #                                                                                                                                                                                                                                                                                                 | 4 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| +2n  | +2n   | +2n       |          |       | <table border="1"><tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr><tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td></tr><tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr></table>       | 1 | 1 | z | z | 1 |   | r |   | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 |   |   |   |   |  |   |   |  |
| 1    | 1     | z         | z        | 1     |                                                                                                                                                                                                                                                                                                   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 1    | 1     | 1         | 1        | 1     | 0                                                                                                                                                                                                                                                                                                 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
|      |       |           |          |       |                                                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 6    | 6     | 8         | RL       | A, r  | <table border="1"><tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr><tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td></tr><tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr></table>       | 1 | 1 | z | z | 1 |   | r |   | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 |   |   |   |   |  |   |   |  |
| 1    | 1     | z         | z        | 1     |                                                                                                                                                                                                                                                                                                   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 1    | 1     | 1         | 1        | 1     | 0                                                                                                                                                                                                                                                                                                 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
|      |       |           |          |       |                                                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| +2n  | +2n   | +2n       |          |       | <table border="1"><tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr><tr><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td></tr><tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr></table>     | 1 | m | 0 | z | m | m | m | m | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 0 |   |   |   |   |  |   |   |  |
| 1    | m     | 0         | z        | m     | m                                                                                                                                                                                                                                                                                                 | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 0    | 1     | 1         | 1        | 1     | 0                                                                                                                                                                                                                                                                                                 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
|      |       |           |          |       |                                                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 8    | 8     | -         | RL <W>   | (mem) | <table border="1"><tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr><tr><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td></tr><tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr></table>     | 1 | m | 0 | z | m | m | m | m | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 0 |   |   |   |   |  |   |   |  |
| 1    | m     | 0         | z        | m     | m                                                                                                                                                                                                                                                                                                 | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 0    | 1     | 1         | 1        | 1     | 0                                                                                                                                                                                                                                                                                                 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
|      |       |           |          |       |                                                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |

Note : When the number of rotates is specified by the A register, the value of the lower 4 bits of the A register is used. Specifying 0 rotates 16 times.  
When dst is memory, rotating is performed only once.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | 0 | * | 0 | * |
|---|---|---|---|---|---|

S = MSB value of dst after rotate is set.

Z = 1 is set when the contents of dst after rotate is 0, otherwise 0.

H = Reset to 0.

V = 1 is set when the parity (number of 1s) of dst is even after rotate, otherwise 0. If the operand is 32 bits, an undefined value is set.

N = Reset to 0.

C = The value after rotate is set.

Execution example: RL 4, HL

When the HL register = 6230H and the carry flag = 1, execution sets the HL register to 230BH and the carry flag to 0.

## RLC num, dst

*< Rotate Left without Carry >*

**Operation :** {CY $\leftarrow$  dst <MSB>, dst $\leftarrow$  left rotate value of dst} Repeat num

**Description :** Loads the contents of the MSB of dst to the carry flag and rotates left the contents of dst. Repeats the number of times specified in num.

**Description figure :**



**Details :**

| Byte     | State    |           | Mnemonic | Code                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
|----------|----------|-----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|---|---|--|
|          | Word     | Long word |          |                                                                                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | RLC      | #4, r                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
|          |          |           |          | <table border="1" style="display: inline-table;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>#</td><td>4</td><td></td></tr> </table> | 1 | 1 | z | z | 1 |   | r |   | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | # | 4 |  |
| 1        | 1        | z         | z        | 1                                                                                                                                                                                                                                                                                                                                    |   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 1        | 1        | 1         | 0        | 1                                                                                                                                                                                                                                                                                                                                    | 0 | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 0        | 0        | 0         | 0        |                                                                                                                                                                                                                                                                                                                                      | # | 4 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | RLC      | A, r                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
|          |          |           |          | <table border="1" style="display: inline-table;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td><td>0</td></tr> </table>                                                                                         | 1 | 1 | z | z | 1 |   | r |   | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 |   |   |   |   |  |   |   |  |
| 1        | 1        | z         | z        | 1                                                                                                                                                                                                                                                                                                                                    |   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 1        | 1        | 1         | 1        | 1                                                                                                                                                                                                                                                                                                                                    | 0 | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 8        | 8        | -         | RLC <W>  | (mem)                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
|          |          |           |          | <table border="1" style="display: inline-table;"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td><td>0</td></tr> </table>                                                                                       | 1 | m | 0 | z | m | m | m | m | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 |   |   |   |   |  |   |   |  |
| 1        | m        | 0         | z        | m                                                                                                                                                                                                                                                                                                                                    | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 0        | 1        | 1         | 1        | 1                                                                                                                                                                                                                                                                                                                                    | 0 | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |

**Note :** When the number of rotates is specified by the A register, the value of the lower 4 bits of the A register is used. Specifying 0 rotates 16 times.  
When dst is memory, rotating is performed only once.

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | 0 | * | 0 | * |
|---|---|---|---|---|---|

S = MSB value of dst after rotate is set.

Z = 1 is set when the contents of dst after rotate is 0, otherwise, 0.

H = Reset to 0.

V = 1 is set when the parity (number of 1s) of dst is even after rotate. If the operand is 32 bits, an undefined value is set.

N = Reset to 0.

C = MSB value of dst before the last rotate is set.

**Execution example:** RLC 4, HL

When the HL register = 1230H, execution sets the HL register to 2301H and the carry flag to 1.

**RLD dst1, dst2**

&lt; Rotate Left Digit &gt;

Operation :  $dst1<3:0>\leftarrow dst2<7:4>, dst2<7:4>\leftarrow dst2<3:0>, dst2<3:0>\leftarrow dst1<3:0>$ ,

Description : Rotates left the lower 4 bits of dst1 and the contents of dst2 in units of 4 bits.



Details :

| Byte | State |           | Mnemonic | Code       |
|------|-------|-----------|----------|------------|
|      | Word  | Long word |          |            |
| 12   | -     | -         | RLD      | [A,] (mem) |

1 | m | 0 | 0 | m | m | m | m  
 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0

Flags : S Z H V N C



S = MSB value of the A register after rotate is set.

Z = 1 is set when the contents of the A register after the rotate are 0, otherwise 0.

H = Reset to 0.

V = 1 is set when the parity (number of 1s) of the A register is even after the rotate, otherwise 0.

N = Reset to 0.

C = No change

Execution example: RLD A,(100H)

When the A register = 12H and the contents of memory at address 100H = 34H, execution sets the A register to 13H and the contents of memory at address 100H to 42H.

## RR num, dst

&lt; Rotate Right &gt;

Operation : {CY & dst  $\leftarrow$  right rotates the value of CY & dst} Repeat num

Description : Rotates right the linked contents of the carry flag and dst.  
Repeats the number of times specified in num.

Description figure:



Details :

| Byte     | State    |           | Mnemonic | Code                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |
|----------|----------|-----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|---|---|
|          | Word     | Long word |          |                                                                                                                                                                                                                                                                           |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | RR       | #4, r                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |
|          |          |           |          | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td></tr> <tr><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>#</td><td>4</td></tr> </table> | 1 | 1 | z | z | 1 |   | r | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 |  | # | 4 |
| 1        | 1        | z         | z        | 1                                                                                                                                                                                                                                                                         |   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |
| 1        | 1        | 1         | 0        | 1                                                                                                                                                                                                                                                                         | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |
| 0        | 0        | 0         | 0        |                                                                                                                                                                                                                                                                           | # | 4 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | RR       | A, r                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |
|          |          |           |          | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td></tr> <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td></tr> </table>                                                                                | 1 | 1 | z | z | 1 |   | r | 1 | 1 | 1 | 1 | 1 | 0 | 1 |   |   |   |   |  |   |   |
| 1        | 1        | z         | z        | 1                                                                                                                                                                                                                                                                         |   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |
| 1        | 1        | 1         | 1        | 1                                                                                                                                                                                                                                                                         | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |
| 8        | 8        | -         | RR <W>   | (mem)                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |
|          |          |           |          | <table border="1"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td></tr> </table>                                                                               | 1 | m | 0 | z | m | m | m | 0 | 1 | 1 | 1 | 1 | 0 | 1 |   |   |   |   |  |   |   |
| 1        | m        | 0         | z        | m                                                                                                                                                                                                                                                                         | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |
| 0        | 1        | 1         | 1        | 1                                                                                                                                                                                                                                                                         | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |

Note : When the number of rotates is specified by the A register, the value of the lower 4 bits of the A register is used. Specifying 0 rotates 16 times.  
When dst is memory, rotating is performed only once.

Flags :

| S | Z | H | V | N | C |
|---|---|---|---|---|---|
| * | * | 0 | * | 0 | * |

S = MSB value of dst after rotate is set.

Z = 1 is set when the contents of dst after rotate is 0, otherwise 0.

H = Reset to 0.

V = 1 is set when the parity (number of 1s) of dst is even after the rotate, otherwise 0. If the operand is 32 bits, an undefined value is set.

N = Reset to 0.

C = The value after rotate is set.

Execution example: RR 4, HL

When the HL register = 6230H and the carry flag = 1, execution sets the HL register to 1623H and the carry flag to 0.

## RRC num, dst

< Rotate Right without Carry >

Operation : {CY←dst <LSB>, dst←right rotate value of dst} Repeat num

Description : Loads the contents of the LSB of dst to the carry flag and rotates the contents of dst to the right. Repeats the number of times specified in num.

Description figure:



Details :

| Byte     | State    |           | Mnemonic |       | Code                                                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
|----------|----------|-----------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|---|---|--|
|          | Word     | Long word |          |       |                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | RRC      | #4, r | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr> <tr><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>#</td><td>4</td><td></td></tr> </table> | 1 | 1 | z | z | 1 |   | r | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |  | # | 4 |  |
| 1        | 1        | z         | z        | 1     |                                                                                                                                                                                                                                                                                                        | r | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 1        | 1        | 1         | 0        | 1     | 0                                                                                                                                                                                                                                                                                                      | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 0        | 0        | 0         | 0        |       | #                                                                                                                                                                                                                                                                                                      | 4 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | RRC      | A, r  | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr> <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td></tr> </table>                                                                                         | 1 | 1 | z | z | 1 |   | r | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |   |   |   |   |  |   |   |  |
| 1        | 1        | z         | z        | 1     |                                                                                                                                                                                                                                                                                                        | r | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 1        | 1        | 1         | 1        | 1     | 0                                                                                                                                                                                                                                                                                                      | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 8        | 8        | -         | RRC <W>  | (mem) | <table border="1"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td></tr> </table>                                                                                        | 1 | m | 0 | z | m | m | m | m | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |   |   |   |   |  |   |   |  |
| 1        | m        | 0         | z        | m     | m                                                                                                                                                                                                                                                                                                      | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 0        | 1        | 1         | 1        | 1     | 0                                                                                                                                                                                                                                                                                                      | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |

Note : When the number of rotates num is specified by the A register, the value of the lower 4 bits of the A register is used as the number of rotates.  
Specifying 0 rotates 16 times. When dst is memory, rotating is only once.

Flags :

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | 0 | * | 0 | * |
|---|---|---|---|---|---|

S = MSB value of dst after rotate is set.

Z = 1 is set when the contents of dst after rotate is 0, otherwise 0.

H = Reset to 0.

V = 1 is set when the parity (number of 1s) of dst is even after rotate, otherwise 0. If the operand is 32 bits, an undefined value is set.

N = Reset to 0.

C = MSB value of dst before the last rotate is set.

Execution example: RLC 4, HL

When the HL register = 1230H, execution sets the HL register to 0123H and the carry flag to 0.

**RRD dst1, dst2**

&lt; Rotate Right Digit &gt;

Operation :  $\text{dst1} < 3:0 > \leftarrow \text{dst2} < 3:0 >, \text{dst2} < 7:4 > \leftarrow \text{dst1} < 3:0 >, \text{dst2} < 3:0 > \leftarrow \text{dst2} < 7:4 >$

Description : Rotates right the lower 4 bits of dst1 and the contents of dst2 in units of 4 bits.

Description figure :



Details :

| Byte | State |           | Mnemonic | Code                    |
|------|-------|-----------|----------|-------------------------|
|      | Word  | Long word |          |                         |
| 12   | -     | -         | RRD      | [A, <sub>1</sub> ](mem) |

Flags : S Z H V N C



S = MSB value of the A register after rotate is set.

Z = 1 is set when the contents of the A register after rotate is 0, otherwise 0.

H = Reset to 0.

V = 1 is set when the parity (number of 1s) of the A register is even after rotate, otherwise 0.

N = Reset to 0.

C = No change

Execution example: RRD A,(100H)

When the A register = 12H and the contents of memory at address 100H = 34H, execution sets the A register to 14H and the contents of memory at address 100H to 23H.

**SBC dst, src**

&lt; Subtract with Carry &gt;

Operation :  $dst \leftarrow dst - src - CY$ 

Description : Subtracts the contents of src and the carry flag from those of dst, and loads the result to dst.



Details :

| Byte     | State<br>Word | Long word | Mnemonic        | Code                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
|----------|---------------|-----------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--------|--|--|--|--|--|--|---------|--|--|--|--|--|--|----------|--|--|--|--|--|--|----------|--|--|--|--|--|--|
| 4        | 4             | 7         | SBC R, r        | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td>r</td><td></td></tr> <tr><td>1</td><td>0</td><td>1</td><td>1</td><td>0</td><td>R</td><td></td></tr> </table>                                                                                                                                                                                   | 1 | 1 | z | z | 1 | r |   | 1 | 0 | 1 | 1 | 0 | R |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 1        | 1             | z         | z               | 1                                                                                                                                                                                                                                                                                                                                                                           | r |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 1        | 0             | 1         | 1               | 0                                                                                                                                                                                                                                                                                                                                                                           | R |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 4        | 4             | 7         | SBC r, #        | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td>r</td><td></td></tr> <tr><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td></tr> <tr><td colspan="7">#&lt;7:0&gt;</td></tr> <tr><td colspan="7">#&lt;15:8&gt;</td></tr> <tr><td colspan="7">#&lt;23:16&gt;</td></tr> <tr><td colspan="7">#&lt;31:24&gt;</td></tr> </table> | 1 | 1 | z | z | 1 | r |   | 1 | 1 | 0 | 0 | 1 | 0 | 1 | #<7:0> |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  | #<23:16> |  |  |  |  |  |  | #<31:24> |  |  |  |  |  |  |
| 1        | 1             | z         | z               | 1                                                                                                                                                                                                                                                                                                                                                                           | r |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 1        | 1             | 0         | 0               | 1                                                                                                                                                                                                                                                                                                                                                                           | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| #<7:0>   |               |           |                 |                                                                                                                                                                                                                                                                                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| #<15:8>  |               |           |                 |                                                                                                                                                                                                                                                                                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| #<23:16> |               |           |                 |                                                                                                                                                                                                                                                                                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| #<31:24> |               |           |                 |                                                                                                                                                                                                                                                                                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 4        | 4             | 6         | SBC R, (mem)    | <table border="1"> <tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>0</td><td>1</td><td>1</td><td>0</td><td>R</td><td></td></tr> </table>                                                                                                                                                                                  | 1 | m | z | z | m | m | m | 1 | 0 | 1 | 1 | 0 | R |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 1        | m             | z         | z               | m                                                                                                                                                                                                                                                                                                                                                                           | m | m |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 1        | 0             | 1         | 1               | 0                                                                                                                                                                                                                                                                                                                                                                           | R |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 6        | 6             | 10        | SBC (mem), R    | <table border="1"> <tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>0</td><td>1</td><td>1</td><td>1</td><td>R</td><td></td></tr> </table>                                                                                                                                                                                  | 1 | m | z | z | m | m | m | 1 | 0 | 1 | 1 | 1 | R |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 1        | m             | z         | z               | m                                                                                                                                                                                                                                                                                                                                                                           | m | m |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 1        | 0             | 1         | 1               | 1                                                                                                                                                                                                                                                                                                                                                                           | R |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 7        | 8             | -         | SBC<W> (mem), # | <table border="1"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td></tr> <tr><td colspan="7">#&lt;7:0&gt;</td></tr> <tr><td colspan="7">#&lt;15:8&gt;</td></tr> </table>                                                                                          | 1 | m | 0 | z | m | m | m | 0 | 0 | 1 | 1 | 1 | 0 | 1 | #<7:0> |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 1        | m             | 0         | z               | m                                                                                                                                                                                                                                                                                                                                                                           | m | m |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| 0        | 0             | 1         | 1               | 1                                                                                                                                                                                                                                                                                                                                                                           | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| #<7:0>   |               |           |                 |                                                                                                                                                                                                                                                                                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |
| #<15:8>  |               |           |                 |                                                                                                                                                                                                                                                                                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |         |  |  |  |  |  |  |          |  |  |  |  |  |  |          |  |  |  |  |  |  |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | 1 | * |
|---|---|---|---|---|---|

S = MSB value of the result is set.

Z = 1 is set when the result is 0, otherwise 0.

H = 1 is set when a borrow from bit 3 to bit 4 occurs as a result, otherwise 0.  
When the operand is 32 bits, an undefined value is set.

V = 1 is set when an overflow occurs as a result, otherwise 0.

N = 1 is set.

C = 1 is set when a borrow from the MSB occurs as a result, otherwise 0.

Execution example: SBC HL, IX

When the HL register is 7654H, the IX register = 5000H, and the carry flag = 1, execution sets the HL register to 2653H.



## SCC condition, dst

< Set Condition Code >

Operation : If cc is true, then dst  $\leftarrow$  1 else dst  $\leftarrow$  0.

Description : Loads 1 to dst when the operand condition is true; when false, 0 is loaded to dst.

Details :

| Byte | State |           | Mnemonic | cc, r | Code                                                                                                                                                                                                                                                           |   |   |   |   |   |  |   |   |   |   |   |   |  |   |   |   |
|------|-------|-----------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|---|---|---|---|---|---|--|---|---|---|
|      | Word  | Long word |          |       |                                                                                                                                                                                                                                                                |   |   |   |   |   |  |   |   |   |   |   |   |  |   |   |   |
| 6    | 6     | -         | SCC      |       | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr> <tr> <td>0</td><td>1</td><td>1</td><td>1</td><td></td><td>c</td><td>c</td><td>1</td></tr> </table> | 1 | 1 | 0 | z | 1 |  | r | 1 | 0 | 1 | 1 | 1 |  | c | c | 1 |
| 1    | 1     | 0         | z        | 1     |                                                                                                                                                                                                                                                                | r | 1 |   |   |   |  |   |   |   |   |   |   |  |   |   |   |
| 0    | 1     | 1         | 1        |       | c                                                                                                                                                                                                                                                              | c | 1 |   |   |   |  |   |   |   |   |   |   |  |   |   |   |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: SCC OV, HL

When the contents of the V flag = 1, execution sets the HL register to 0001H.

**SCF**

&lt; Set Carry Flag &gt;

Operation : CY ← 1

Description : Sets the carry flag to 1.

| Details : | State | Mnemonic | Code                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |
|-----------|-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|
|           | 2     | SCF      | <table border="1"><tr><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td></tr></table> | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 |
| 0         | 1     | 0        | 1                                                                                                                                                           | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 |   |   |   |   |

Flags : S Z H V N C

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

S = No change

Z = No change

H = Reset to 0.

V = No change

N = Reset to 0.

C = Set to 1.

## SET num, dst

&lt; Set &gt;

Operation : dst <num>  $\leftarrow$  1

Description : Sets bit num of dst to 1.

Details :

| Byte | State |           | Mnemonic | #4, r     | Code                          |                               |
|------|-------|-----------|----------|-----------|-------------------------------|-------------------------------|
|      | Word  | Long word |          |           | 1   1   0   z   1   r         | 0   0   1   1   0   0   0   1 |
| 4    | 4     | -         | SET      | #4, r     | 0   0   0   0   #   4         |                               |
| 8    |       | -         | SET      | #3, (mem) | 1   m   1   1   m   m   m   m | 1   0   1   1   1   #3        |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: SET 5,(100H)

When the contents of memory at address 100H = 00000000B (binary), execution sets the contents of memory at address 100H to 00100000B (binary).



## SLA num, dst

&lt; Shift Left Arithmetic &gt;

Operation : {CY  $\leftarrow$  dst<MSB>, dst  $\leftarrow$  left shift value of dst,  
dst<LSB>  $\leftarrow$  0} Repeat num

Description : Loads the contents of the MSB of dst to the carry flag, shifts left the contents of dst, and loads 0 to the LSB of dst. Repeats the number of times specified in num.



Details :

| Byte     | State    |           | Mnemonic | #4, r | Code                                                                                                                                                                                                                                                                                                  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
|----------|----------|-----------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|---|---|--|
|          | Word     | Long word |          |       |                                                                                                                                                                                                                                                                                                       |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | SLA      | A, r  | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>#</td><td>4</td><td></td></tr> </table> | 1 | 1 | z | z | 1 |   | r |   | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |  | # | 4 |  |
| 1        | 1        | z         | z        | 1     |                                                                                                                                                                                                                                                                                                       | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 1        | 1        | 1         | 0        | 1     | 1                                                                                                                                                                                                                                                                                                     | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 0        | 0        | 0         | 0        |       | #                                                                                                                                                                                                                                                                                                     | 4 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | SLA      | #4, r | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td></tr> </table>                                                                                         | 1 | 1 | z | z | 1 |   | r |   | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 |   |   |   |   |  |   |   |  |
| 1        | 1        | z         | z        | 1     |                                                                                                                                                                                                                                                                                                       | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 1        | 1        | 1         | 1        | 1     | 1                                                                                                                                                                                                                                                                                                     | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 8        | 8        | -         | SLA <W>  | (mem) | <table border="1"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>0</td></tr> </table>                                                                                       | 1 | m | 0 | z | m | m | m | m | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 |   |   |   |   |  |   |   |  |
| 1        | m        | 0         | z        | m     | m                                                                                                                                                                                                                                                                                                     | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 0        | 1        | 1         | 1        | 1     | 1                                                                                                                                                                                                                                                                                                     | 0 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |

Note : When the number of shifts, num, is specified by the A register, the value of the lower 4 bits of the A register is used. Specifying 0 shifts 16 times. When dst is memory, shifting is performed only once.

Flags :

| S | Z | H | V | N | C |
|---|---|---|---|---|---|
| * | * | 0 | * | 0 | * |

S = MSB value of dst after shift is set.

Z = 1 is set when the contents of dst after shift is 0, otherwise 0.

H = Reset to 0.

V = 1 is set when the parity (number of 1s) of dst is even after shifting, otherwise 0. If the operand is 32 bits, an undefined value is set.

N = Reset to 0.

C = MSB value of dst before the last shift is set.

Execution example: SLA 4, HL

When the HL register = 1234H, execution sets the HL register to 2340H and the carry flag to 1.

## SLL num, dst

< Shift Left Logical >

Operation : { $CY \leftarrow dst < MSB >$ ,  $dst \leftarrow left shift value of dst$ ,  $dst < LSB > \leftarrow 0$ } Repeat num

Description : Loads the contents of the MSB of dst to the carry flag, shifts left the contents of dst, and loads 0 to the MSB of dst. Repeats the number of times specified in num.



Details :

| Byte     | Word     | Long word | State   | Mnemonic | Code                                                                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----------|----------|-----------|---------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | SLL     | #4, r    | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td></tr> <tr><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>#</td><td>4</td></tr> </table>  | 1 | 1 | z | z | 1 |   | r | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |   | # | 4 |
| 1        | 1        | z         | z       | 1        |                                                                                                                                                                                                                                                                                                                           | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 1        | 1        | 1         | 0       | 1        | 1                                                                                                                                                                                                                                                                                                                         | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0        | 0        | 0         | 0       |          | #                                                                                                                                                                                                                                                                                                                         | 4 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | SLL     | A, r     | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td></tr> <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td></tr> <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td></tr> </table> | 1 | 1 | z | z | 1 |   | r | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |
| 1        | 1        | z         | z       | 1        |                                                                                                                                                                                                                                                                                                                           | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 1        | 1        | 1         | 1       | 1        | 1                                                                                                                                                                                                                                                                                                                         | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 1        | 1        | 1         | 1       | 1        | 1                                                                                                                                                                                                                                                                                                                         | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 8        | 8        | -         | SLL <W> | (mem)    | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td></tr> </table>                                                            | 1 | m | 0 | z | m | m | m | m | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |   |   |   |   |   |
| 1        | m        | 0         | z       | m        | m                                                                                                                                                                                                                                                                                                                         | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0        | 1        | 1         | 1       | 1        | 1                                                                                                                                                                                                                                                                                                                         | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

Note : When the number of shifts, num, is specified by the A register, the value of the lower 4 bits of the A register is used. Specifying 0 shifts 16 times. When dst is memory, shifting is performed only once.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | 0 | * | 0 | * |
|---|---|---|---|---|---|

S = MSB value of dst after shift is set.

Z = 1 is set when the contents of dst after shift is 0, otherwise 0.

H = Reset to 0.

V = 1 is set when the parity (number of 1s) of dst is even after shifting, otherwise 0. If the operand is 32 bits, an undefined value is set.

N = Reset to 0.

C = MSB value of dst before the last shift is set.

Execution example: SLL 4, HL

When the HL register = 1234H, execution sets the HL register to 2340H and the carry flag to 1.

**SRA num, dst**

&lt; Shift Right Arithmetic &gt;

**Operation :** { $CY \leftarrow dst < MSB >$ ,  $dst \leftarrow$  right shift value of  $dst$ ,  $dst < MSB >$  is fixed}  
 Repeat num

**Description :** Loads the contents of the LSB of  $dst$  to the carry flag and shifts right the contents of  $dst$  (MSB is fixed). Repeats the number of times specified in num.

**Description chart:**



**Details :**

| Byte     | State    |           | Mnemonic |       | Code                                                                                                                                                                                                                                                                                                  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
|----------|----------|-----------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|---|---|--|
|          | Word     | Long word |          |       |                                                                                                                                                                                                                                                                                                       |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | SRA      | #4, r | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td>0</td><td>1</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>#</td><td>4</td><td></td></tr> </table> | 1 | 1 | z | z | 1 |   | r |   | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 |  | # | 4 |  |
| 1        | 1        | z         | z        | 1     |                                                                                                                                                                                                                                                                                                       | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 1        | 1        | 1         | 0        | 1     | 1                                                                                                                                                                                                                                                                                                     | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 0        | 0        | 0         | 0        |       | #                                                                                                                                                                                                                                                                                                     | 4 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | SRA      | A, r  | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td></tr> </table>                                                                                         | 1 | 1 | z | z | 1 |   | r |   | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 |   |   |   |   |  |   |   |  |
| 1        | 1        | z         | z        | 1     |                                                                                                                                                                                                                                                                                                       | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 1        | 1        | 1         | 1        | 1     | 1                                                                                                                                                                                                                                                                                                     | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 8        | 8        | -         | SRA <W>  | (mem) | <table border="1"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td></tr> </table>                                                                                       | 1 | m | 0 | z | m | m | m | m | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 |   |   |   |   |  |   |   |  |
| 1        | m        | 0         | z        | m     | m                                                                                                                                                                                                                                                                                                     | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |
| 0        | 1        | 1         | 1        | 1     | 1                                                                                                                                                                                                                                                                                                     | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |   |   |  |

**Note :** When the number of shifts, num, is specified by the A register, the value of the lower 4 bits of the A register is used. Specifying 0 shifts 16 times. When dst is memory, shifting is performed only once.

**Flags :** S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | 0 | * | 0 | * |
|---|---|---|---|---|---|

S = MSB value of  $dst$  after shift is set.

Z = 1 is set when the contents of  $dst$  after shift is 0, otherwise 0.

H = Reset to 0.

V = 1 is set when the parity (number of 1s) of  $dst$  is even after shift, otherwise 0.  
 If the operand is 32 bits, an undefined value is set.

N = Reset to 0.

C = LSB value of  $dst$  before the last shift is set.

**Execution example:** SRA 4, HL

When the HL register = 8230H, execution sets the HL register to F823H and the carry flag to 0.

## SRL num, dst

< Shift Right Logical >

Operation : { $CY \leftarrow dst < LSB >$ ,  $dst \leftarrow right\ shift\ value\ of\ dst$ ,  $dst < MSB > \leftarrow 0$ } Repeat num

Description : Loads the contents of the LSB of dst to the carry flag, shifts right the contents of dst, and loads 0 to the MSB of dst. Repeats the number of times specified in num.

Description chart : "0" →  dst

Details :

| Byte     | State    |           | Mnemonic |       | Code                                                                                                                                                                                                                                                                  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |    |  |
|----------|----------|-----------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|----|--|
|          | Word     | Long word |          |       |                                                                                                                                                                                                                                                                       |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |    |  |
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | SRL      | #4, r | <table border="1"><tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td></tr><tr><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td>1</td></tr><tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td>#4</td><td></td></tr></table> | 1 | 1 | z | z | 1 |   | r | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |  | #4 |  |
| 1        | 1        | z         | z        | 1     |                                                                                                                                                                                                                                                                       | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |    |  |
| 1        | 1        | 1         | 0        | 1     | 1                                                                                                                                                                                                                                                                     | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |    |  |
| 0        | 0        | 0         | 0        |       | #4                                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |    |  |
| 6<br>+2n | 6<br>+2n | 8<br>+2n  | SRL      | A, r  | <table border="1"><tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td></tr><tr><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td></tr></table>                                                                               | 1 | 1 | z | z | 1 |   | r | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |   |   |  |    |  |
| 1        | 1        | z         | z        | 1     |                                                                                                                                                                                                                                                                       | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |    |  |
| 1        | 1        | 1         | 1        | 1     | 1                                                                                                                                                                                                                                                                     | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |    |  |
| 8        | 8        | -         | SRL<W>   | (mem) | <table border="1"><tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr><tr><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td><td>1</td></tr></table>                                                          | 1 | m | 0 | z | m | m | m | m | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |  |    |  |
| 1        | m        | 0         | z        | m     | m                                                                                                                                                                                                                                                                     | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |    |  |
| 0        | 1        | 1         | 1        | 1     | 1                                                                                                                                                                                                                                                                     | 1 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |    |  |

Note : When the number of shifts, num, is specified by the A register, the value of the lower 4 bits of the A register is used. Specifying 0 shifts 16 times. When dst is memory, shifting is performed only once.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | 0 | * | 0 | * |
|---|---|---|---|---|---|

S = MSB value of dst after shift is set.

Z = 1 is set when the contents of dst after shift is 0, otherwise 0.

H = Reset to 0.

V = 1 is set when the parity (number of 1s) of dst is even after shift, otherwise 0.  
If the operand is 32 bits, an undefined value is set.

N = Reset to 0.

C = LSB value of dst before the last shift is set.

Execution example: SRL 4, HL

When the HL register = 1238H, execution sets the HL register to 0123H and the carry flag to 1.

## STCF num, dst

&lt; Store Carry Flag &gt;

Operation : dst<num> $\leftarrow$ CY

Description : Loads the contents of the carry flag to bit num of dst.

Details :

| Byte | State |           | Mnemonic | Code                                                                                                                                                                                                                                                                                                  |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
|------|-------|-----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|--|--|---|---|
|      | Word  | Long word |          |                                                                                                                                                                                                                                                                                                       |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
| 4    | 4     | -         | STCF     | #4, r                                                                                                                                                                                                                                                                                                 |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
|      |       |           |          | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td></td><td>#</td><td>4</td></tr> </table> | 1 | 1 | 0  | z | 1 |   | r |   | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0  | 0 | 0 | 0 | 0 |  |  | # | 4 |
| 1    | 1     | 0         | z        | 1                                                                                                                                                                                                                                                                                                     |   | r |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
| 0    | 0     | 1         | 0        | 0                                                                                                                                                                                                                                                                                                     | 1 | 0 | 0  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
| 0    | 0     | 0         | 0        |                                                                                                                                                                                                                                                                                                       |   | # | 4  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
| 4    | 4     | -         | STCF     | A, r                                                                                                                                                                                                                                                                                                  |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
|      |       |           |          | <table border="1"> <tr><td>1</td><td>1</td><td>0</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td></tr> </table>                                                                                         | 1 | 1 | 0  | z | 1 |   | r |   | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0  |   |   |   |   |  |  |   |   |
| 1    | 1     | 0         | z        | 1                                                                                                                                                                                                                                                                                                     |   | r |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
| 0    | 0     | 1         | 0        | 1                                                                                                                                                                                                                                                                                                     | 1 | 0 | 0  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
| 8    | -     | -         | STCF     | #3, (mem)                                                                                                                                                                                                                                                                                             |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
|      |       |           |          | <table border="1"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>0</td><td>1</td><td>0</td><td>0</td><td></td><td></td><td>#3</td></tr> </table>                                                                                        | 1 | m | 1  | 1 | m | m | m | m | 1 | 0 | 1 | 0 | 0 |   |   | #3 |   |   |   |   |  |  |   |   |
| 1    | m     | 1         | 1        | m                                                                                                                                                                                                                                                                                                     | m | m | m  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
| 1    | 0     | 1         | 0        | 0                                                                                                                                                                                                                                                                                                     |   |   | #3 |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
| 8    | -     | -         | STCF     | A, (mem)                                                                                                                                                                                                                                                                                              |   |   |    |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
|      |       |           |          | <table border="1"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td><td>0</td><td>0</td></tr> </table>                                                                                       | 1 | m | 1  | 1 | m | m | m | m | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0  |   |   |   |   |  |  |   |   |
| 1    | m     | 1         | 1        | m                                                                                                                                                                                                                                                                                                     | m | m | m  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |
| 0    | 0     | 1         | 0        | 1                                                                                                                                                                                                                                                                                                     | 1 | 0 | 0  |   |   |   |   |   |   |   |   |   |   |   |   |    |   |   |   |   |  |  |   |   |

Note : When bit num is specified by the A register, the value of the lower 4 bits of the A register is used. When the operand is a byte and the value of the lower 4 bits of bit num is from 8 to 15, the operand value does not change.

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: STCF 5,(100H)

When the contents of memory at address 100H = 00H and the carry flag = 1, execution sets the contents of memory at address 100H to 00100000B(binary).



**SUB dst, src**

&lt; Subtract &gt;

Operation :  $dst \leftarrow dst - src$ 

Description : Subtracts the contents of src from those of dst and loads the result to dst.

Details :

| Byte     | State Word | Long word | Mnemonic        | Code                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|----------|------------|-----------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--------|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|
| 4        | 4          | 7         | SUB R, r        | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>1</td><td>0</td><td>1</td><td>0</td><td>0</td><td></td><td>R</td><td></td></tr> </table>                                                                                                                                                                                    | 1 | 1 | z | z | 1 |   | r |   | 1 | 0 | 1 | 0 | 0 |   | R |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1          | z         | z               | 1                                                                                                                                                                                                                                                                                                                                                                                                                                             |   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 0          | 1         | 0               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                             |   | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4          | 7         | SUB r, #        | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> <tr><td colspan="8">#&lt;23:16&gt;</td></tr> <tr><td colspan="8">#&lt;31:24&gt;</td></tr> </table> | 1 | 1 | z | z | 1 |   | r |   | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | #<7:0> |  |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |  | #<23:16> |  |  |  |  |  |  |  | #<31:24> |  |  |  |  |  |  |  |
| 1        | 1          | z         | z               | 1                                                                                                                                                                                                                                                                                                                                                                                                                                             |   | r |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1          | 0         | 0               | 1                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>   |            |           |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>  |            |           |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<23:16> |            |           |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<31:24> |            |           |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4          | 6         | SUB R, (mem)    | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>0</td><td>1</td><td>0</td><td>0</td><td></td><td>R</td><td></td></tr> </table>                                                                                                                                                                                  | 1 | m | z | z | m | m | m | m | 1 | 0 | 1 | 0 | 0 |   | R |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m          | z         | z               | m                                                                                                                                                                                                                                                                                                                                                                                                                                             | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 0          | 1         | 0               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                             |   | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 6        | 6          | 10        | SUB (mem), R    | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td><td></td><td>R</td><td></td></tr> </table>                                                                                                                                                                                  | 1 | m | z | z | m | m | m | m | 1 | 0 | 1 | 0 | 1 |   | R |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m          | z         | z               | m                                                                                                                                                                                                                                                                                                                                                                                                                                             | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 0          | 1         | 0               | 1                                                                                                                                                                                                                                                                                                                                                                                                                                             |   | R |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 7        | 8          | -         | SUB<W> (mem), # | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> </table>                                                                                         | 1 | m | 0 | z | m | m | m | m | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | #<7:0> |  |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m          | 0         | z               | m                                                                                                                                                                                                                                                                                                                                                                                                                                             | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 0        | 0          | 1         | 1               | 1                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>   |            |           |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>  |            |           |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | * | * | 1 | * |
|---|---|---|---|---|---|

S = MSB value of the result is set.

Z = 1 is set when the result is 0, otherwise 0.

H = 1 is set when a borrow from bit 3 to bit 4 occurs as a result, otherwise 0.  
When the operand is 32 bits, an undefined value is set.

V = 1 is set when an overflow occurs as a result, otherwise 0.

N = 1 is set.

C = 1 is set when a borrow from MSB occurs as a result, otherwise 0.

Execution example: SUB HL, IX

When the HL register = 7654H and the IX register = 5000H,  
execution sets the HL register to 2654H.



SWI num

### < Software Interrupt >

Operation : [The case of 900\_CPU]

- 1) Temp ← SR
  - 2) SYSM bit ← 1
  - 3) XSP ← XSP - 4    ... in minimum mode  
or  
XSP ← XSP - 6    ... in maximum mode
  - 4) (XSP) ← Temp
  - 5) (XSP + 2) ← 16 bit PC    ... in minimum mode  
or  
(XSP + 2) ← 32 bit PC    ... in maximum mode
  - 6) PC ← 8000H + num × 10H

### [The case of 900L CPU]

- 1)  $XSP \leftarrow XSP - 4$  ... in minimum mode  
or  
 $XSP \leftarrow XSP - 6$  ... in maximum mode
  - 2)  $(XSP) \leftarrow SR$
  - 3)  $(XSP + 2) \leftarrow 16\text{ bit PC}$  ... in minimum mode  
or  
 $(XSP + 2) \leftarrow 32\text{ bit PC}$  ... in maximum mode
  - 4)  $PC_1$  (Address refers to vector 1, num  $\times 4$ )

Note: Address refer to vector is defined for each product

This is defined to 8000H in the first product of TMP93CM40.

Description : [The case of 900 CPU]

After the mode is changed to system mode, the 900\_CPU saves to the stack area the contents of the status register before execution of the SWI instruction and contents of the program counter which indicate the address next to the SWI instruction. Finally, jumps to address  $8000H + num \times 10H$ .

### [The case of 900L CPU]

Saves to the stack area the contents of the status register and contents of the program counter which indicate the address next to the SWI instruction. Finally, jumps to vector is indicated address refer to vector.

## Details

| State             | Mnemonic | Code                |
|-------------------|----------|---------------------|
| 16 (Minimum mode) | SWI      | [#3]                |
| 18 (Maximum mode) |          | [1, 1, 1, 1, 1, #3] |

Note 1 : A value from 0 to 7 can be specified as the operand value. When the operand coding is omitted, SWI 7 is assumed.

Note 2 : The status register structure is as shown below.

|      |      |      |      |     |      |      |      |   |   |     |   |     |   |   |   |
|------|------|------|------|-----|------|------|------|---|---|-----|---|-----|---|---|---|
| 15   | 14   | 13   | 12   | 11  | 10   | 9    | 8    | 7 | 6 | 5   | 4 | 3   | 2 | 1 | 0 |
| SYSM | IFF2 | IFF1 | IFF0 | MAX | RFP2 | RFP1 | RFP0 | S | Z | "0" | H | "0" | V | N | C |

Flags : S Z H V N C  

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: SWI 5

(The case of 900 CPU)

In minimum mode, when the stack pointer XSP = 100H, the status register = 0000H, executing the above instruction at memory address 8400H sets the status register to 8000H, writes the contents of the previous status register 0000H in memory address 00FCH, and the contents of the program counter 8401H in memory address 00FEH, then jumps to address 8050H.



## TSET num, dst

< Test and Set >

Operation : Z flag  $\leftarrow$  inverted value of dst <num>  
dst <num>  $\leftarrow$  1

Description : Loads the inverted value of the bit num of dst to the Z flag.  
Then the bit num of dst is set to "1".

Details :

| byte | State |           | Mnemonic | Code                                                                                                                                                                                                                                                            |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|------|-------|-----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|      | word  | long word |          |                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 6    | 6     | -         | TSET     | #4, r<br><table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td>r</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>0</td><td>0</td><td>0</td></tr> </table>                         | 1 | 1 | z | z | 1 | r | 1 | 1 | 0 | 0 | 0 | 0 |   |   |
| 1    | 1     | z         | z        | 1                                                                                                                                                                                                                                                               | r |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 1    | 1     | 0         | 0        | 0                                                                                                                                                                                                                                                               | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 10   | -     | -         | TSET     | #3, (mem)<br><table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>m</td><td>1</td><td>1</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>0</td><td>1</td><td>0</td><td>1</td><td>1</td><td>0</td></tr> </table> | 1 | m | 1 | 1 | m | m | m | 1 | 0 | 1 | 0 | 1 | 1 | 0 |
| 1    | m     | 1         | 1        | m                                                                                                                                                                                                                                                               | m | m |   |   |   |   |   |   |   |   |   |   |   |   |
| 1    | 0     | 1         | 0        | 1                                                                                                                                                                                                                                                               | 1 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |

Flags : S Z H V N C  

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| X | * | 1 | X | 0 | - |
|---|---|---|---|---|---|

S = An undefined value is set.

Z = The inverted value of the src <num> is set.

H = Set to 1

V = An undefined value is set.

N = Set to 0

C = No change

Execution example: When the contents of memory at address 100H=00100000B (binary), TSET 3,(100H) execution sets the Z flag to 1, the contents of memory at address 100H=00101000B (binary).

|                                                                                                                                                                                                                                                                           |        |   |   |   |   |   |   |   |                                |   |   |   |   |   |   |   |                                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---|---|---|---|---|---|---|--------------------------------|---|---|---|---|---|---|---|---------------------------------|
| <table border="1" style="display: inline-table; border-collapse: collapse;"> <tr><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td></tr> </table> | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 0                              | 0 | 1 | 0 | 0 | 0 | 0 | 0 | address 100H (before execution) |
| 7                                                                                                                                                                                                                                                                         | 6      | 5 | 4 | 3 | 2 | 1 | 0 |   |                                |   |   |   |   |   |   |   |                                 |
| 0                                                                                                                                                                                                                                                                         | 0      | 1 | 0 | 0 | 0 | 0 | 0 |   |                                |   |   |   |   |   |   |   |                                 |
| Inverted                                                                                                                                                                                                                                                                  | Z flag |   |   |   |   |   |   |   |                                |   |   |   |   |   |   |   |                                 |
| <table border="1" style="display: inline-table; border-collapse: collapse;"> <tr><td>0</td><td>0</td><td>1</td><td>0</td><td>1</td><td>0</td><td>0</td><td>0</td></tr> </table>                                                                                           | 0      | 0 | 1 | 0 | 1 | 0 | 0 | 0 | address 100H (after execution) |   |   |   |   |   |   |   |                                 |
| 0                                                                                                                                                                                                                                                                         | 0      | 1 | 0 | 1 | 0 | 0 | 0 |   |                                |   |   |   |   |   |   |   |                                 |

**UNLK dst**

&lt; Unlink &gt;

Operation : XSP  $\leftarrow$  dst, dst  $\leftarrow$  (XSP +)

Description : Loads the contents of dst to the stack pointer XSP, then pops long word data from the stack area to dst. Used paired with the Link instruction.

Details :

| Byte | State |           | Mnemonic |   | Code                                                                                                                                                                                                                                                                 |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |
|------|-------|-----------|----------|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|---|--|---|---|---|---|---|---|---|---|
|      | Word  | Long word |          |   |                                                                                                                                                                                                                                                                      |   |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |
| -    | -     | 8         | UNLK     | r | <table border="1" style="display: inline-table; vertical-align: middle;"> <tr><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td><td></td><td>r</td><td></td></tr> <tr><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>1</td></tr> </table> | 1 | 1 | 1 | 0 | 1 |  | r |  | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 |
| 1    | 1     | 1         | 0        | 1 |                                                                                                                                                                                                                                                                      | r |   |   |   |   |  |   |  |   |   |   |   |   |   |   |   |
| 0    | 0     | 0         | 0        | 1 | 1                                                                                                                                                                                                                                                                    | 0 | 1 |   |   |   |  |   |  |   |   |   |   |   |   |   |   |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | - |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = No change

Execution example: UNLK XIZ

As a result of executing this instruction after executing the Link instruction, the stack pointer XSP and the XIZ register revert to the same values they had before the Link instruction was executed. (For details of the Link instruction, see page 104)

**XOR dst, src**

&lt; Exclusive OR &gt;

Operation : dst $\leftarrow$ dst XOR src

Description : Exclusive ors the contents of dst with those of src and loads the result to dst.

(Truth table)

| A | B | A XOR B |
|---|---|---------|
| 0 | 0 | 0       |
| 0 | 1 | 1       |
| 1 | 0 | 1       |
| 1 | 1 | 0       |

Details :

| Byte     | State |           | Mnemonic | Code                                                                                                                                                                                                                                                                                                                                                                                            |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|----------|-------|-----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--------|--|--|--|--|--|--|--|---------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|
|          | Word  | Long word |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4     | 7         | XOR      | R, r                                                                                                                                                                                                                                                                                                                                                                                            |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|          |       |           |          | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td><td></td><td>R</td><td>1</td></tr> </table>                                                                                                                                                                                   | 1 | 1 | z | z | 1 |   | r | 1 | 1 | 1 | 0 | 1 | 0 |   | R | 1 |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1     | z         | z        | 1                                                                                                                                                                                                                                                                                                                                                                                               |   | r | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1     | 0         | 1        | 0                                                                                                                                                                                                                                                                                                                                                                                               |   | R | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4     | 7         | XOR      | r, #                                                                                                                                                                                                                                                                                                                                                                                            |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|          |       |           |          | <table border="1"> <tr><td>1</td><td>1</td><td>z</td><td>z</td><td>1</td><td></td><td>r</td><td>1</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>0</td><td>1</td><td>1</td><td>0</td><td>1</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> <tr><td colspan="8">#&lt;23:16&gt;</td></tr> <tr><td colspan="8">#&lt;31:24&gt;</td></tr> </table> | 1 | 1 | z | z | 1 |   | r | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | #<7:0> |  |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |  | #<23:16> |  |  |  |  |  |  |  | #<31:24> |  |  |  |  |  |  |  |
| 1        | 1     | z         | z        | 1                                                                                                                                                                                                                                                                                                                                                                                               |   | r | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1     | 0         | 0        | 1                                                                                                                                                                                                                                                                                                                                                                                               | 1 | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>   |       |           |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>  |       |           |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<23:16> |       |           |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<31:24> |       |           |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 4        | 4     | 6         | XOR      | R, (mem)                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|          |       |           |          | <table border="1"> <tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>1</td><td>0</td><td></td><td>R</td><td>1</td></tr> </table>                                                                                                                                                                                  | 1 | m | z | z | m | m | m | m | 1 | 1 | 0 | 1 | 0 |   | R | 1 |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m     | z         | z        | m                                                                                                                                                                                                                                                                                                                                                                                               | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1     | 0         | 1        | 0                                                                                                                                                                                                                                                                                                                                                                                               |   | R | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 6        | 6     | 10        | XOR      | (mem), R                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|          |       |           |          | <table border="1"> <tr><td>1</td><td>m</td><td>z</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>1</td><td>1</td><td></td><td>R</td><td>1</td></tr> </table>                                                                                                                                                                                  | 1 | m | z | z | m | m | m | m | 1 | 1 | 0 | 1 | 1 |   | R | 1 |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m     | z         | z        | m                                                                                                                                                                                                                                                                                                                                                                                               | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | 1     | 0         | 1        | 1                                                                                                                                                                                                                                                                                                                                                                                               |   | R | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 7        | 8     | -         | XOR<W>   | (mem), #                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
|          |       |           |          | <table border="1"> <tr><td>1</td><td>m</td><td>0</td><td>z</td><td>m</td><td>m</td><td>m</td><td>m</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>0</td><td>1</td></tr> <tr><td colspan="8">#&lt;7:0&gt;</td></tr> <tr><td colspan="8">#&lt;15:8&gt;</td></tr> </table>                                                                                          | 1 | m | 0 | z | m | m | m | m | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | #<7:0> |  |  |  |  |  |  |  | #<15:8> |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 1        | m     | 0         | z        | m                                                                                                                                                                                                                                                                                                                                                                                               | m | m | m |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| 0        | 0     | 1         | 1        | 1                                                                                                                                                                                                                                                                                                                                                                                               | 1 | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<7:0>   |       |           |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |
| #<15:8>  |       |           |          |                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |        |  |  |  |  |  |  |  |         |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |

Flags : S Z H V N C

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| * | * | 0 | * | 0 | 0 |
|---|---|---|---|---|---|

S = MSB value of the result is set.

Z = 1 is set when the result is 0, otherwise 0.

H = Reset to 0.

V = 1 is set when the parity (number of 1s) of dst is even as a result, otherwise 0.  
If the operand is 32 bits, an undefined value is set.

N = Cleared to 0.

C = Cleared to 0.

Execution example: XOR HL,IX

When the HL register = 7350H and the IX register = 3456H,  
execution sets the HL register to 4706H.

|      |      |      |      |      |                                  |
|------|------|------|------|------|----------------------------------|
| 0111 | 0011 | 0101 | 0000 | ←    | HL register (before execution)   |
| XOR) | 0011 | 0100 | 0101 | 0110 | ← IX register (before execution) |
|      | 0100 | 0111 | 0000 | 0110 | ← HL register (after execution)  |

## XORCF num, src

< Exclusive OR Carry Flag >

Operation : CY  $\leftarrow$  CY XOR src<num>

Description : Exclusive ors the contents of the carry flag and bit num of src, and loads the result to the carry flag.

Details :

| Byte | State |           | Mnemonic | Code      |
|------|-------|-----------|----------|-----------|
|      | Word  | Long word |          |           |
| 4    | 4     | -         | XORCF    | #4, r     |
| 4    | 4     | -         | XORCF    | A, r      |
| 8    |       | -         | XORCF    | #3, (mem) |
| 8    | -     | -         | XORCF    | A, (mem)  |

Note : When bit num is specified by the A register, the value of the lower 4 bits of the A register is used. When the operand is a byte and the value of the lower 4 bits of bit num is from 8 to 15, the result is undefined.

Flags : S Z H V N C  

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | - | - | - | * |
|---|---|---|---|---|---|

S = No change

Z = No change

H = No change

V = No change

N = No change

C = The value obtained by exclusive or-ing the contents of the carry flag with those of bit num of src is set.

Execution example: XORCF 6,(100H)

When the contents of memory at address 100H = 0100000B (binary) and the carry flag = 1, execution sets the carry flag to 0.



**ZCF**

&lt; Zero flag to Carry Flag &gt;

Operation : CY  $\leftarrow$  inverted value of Z flag

Description : Loads the inverted value of the Z flag to the carry flag.

Details :

| State | Mnemonic | Code            |
|-------|----------|-----------------|
| 2     | ZCF      | 0 0 0 1 0 0 1 1 |

Flags : S Z H V N C  

|   |   |   |   |   |   |
|---|---|---|---|---|---|
| - | - | X | - | 0 | * |
|---|---|---|---|---|---|

S = No change

Z = No change

H = An undefined value is set.

V = No change

N = Reset to 0.

C = The inverted value of the Z flag is set.

Execution example: ZCF

When the Z flag = 0, execution sets the carry flag to 1.



## Appendix B Instruction Lists (1/11)

## ■ Explanation of symbols used in this document

## 1. Size

|   |                                            |
|---|--------------------------------------------|
| B | The operand size is in bytes (8 bits)      |
| W | The operand size is in word (16 bits)      |
| L | The operand size is in long word (32 bits) |

## 2. Mnemonic

|       |                                                                                                                                                                                                                                                                                |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R     | Eight general-purpose registers including 8/16/32-bit current bank registers.<br>8 bit register: W, A, B, C, D, E, H, L<br>16 bit register: WA, BC, DE, HL, IX, IY, IZ, SP<br>32 bit register: XWA, XBC, XDE, XHL, XIX, XIY, XIZ, XSP<br>8/16/32-bit general-purpose registers |
| cr    | All 8/16/32-bit CPU control registers<br>DMAS0~3, DMAD0~3, DMAC0~3, DMAM0~3, XNSP, INTNEST                                                                                                                                                                                     |
| A     | A register (8 bits)                                                                                                                                                                                                                                                            |
| F     | Flag registers (8 bits)                                                                                                                                                                                                                                                        |
| F'    | Inverse flag registers (8 bits)                                                                                                                                                                                                                                                |
| SR    | Status registers (16 bits)                                                                                                                                                                                                                                                     |
| PC    | Program Counter (in minimum mode, 16 bits; in maximum mode, 32 bits)                                                                                                                                                                                                           |
| (mem) | 8/16/32-bit memory data                                                                                                                                                                                                                                                        |
| mem   | Effective address value                                                                                                                                                                                                                                                        |
| <W>   | When the operand size is a word, "W" must be specified.                                                                                                                                                                                                                        |
| [ ]   | Operands enclosed in square brackets can be omitted.                                                                                                                                                                                                                           |
| #     | 8/16/32-bit immediate data.                                                                                                                                                                                                                                                    |
| #3    | 3-bit immediate data: 0 to 7 or 1 to 8 ..... for abbreviated codes.                                                                                                                                                                                                            |
| #4    | 4-bit immediate data: 0 to 15 or 1 to 16                                                                                                                                                                                                                                       |
| d8    | 8-bit displacement: -80H~+7FH                                                                                                                                                                                                                                                  |
| d16   | 16-bit displacement: -8000H~+7FFFH                                                                                                                                                                                                                                             |
| cc    | Condition code                                                                                                                                                                                                                                                                 |
| (#8)  | Direct addressing : (00H) to (0FFH) ... 256-byte area                                                                                                                                                                                                                          |
| (#16) | 64K-byte area addressing : (0000H) to (0FFFFH)                                                                                                                                                                                                                                 |
| \$    | A start address of the instruction is located                                                                                                                                                                                                                                  |

※  XNSP exists only in 900 CPU, and INTNEST exists only in 900/L\_CPU.

## Appendix B Instruction Lists (2/11)

### 3. Cord

|    |                                                                                                                |
|----|----------------------------------------------------------------------------------------------------------------|
| Z  | The code represent the operand sizes.<br>byte (8 bit) = 0<br>word (16 bit) = 2<br>long word (32 bit) = 4       |
| ZZ | The code represent the operand sizes.<br>byte (8 bit) = 00H<br>word (16 bit) = 10H<br>long word (32 bit) = 20H |

### 4. Flag (SZHVN C)

|   |                                                                    |
|---|--------------------------------------------------------------------|
| - | Flag doesn't change.                                               |
| * | Flag changes by executing instruction.                             |
| 0 | Flag is cleared to "0".                                            |
| 1 | Flag is set to "1".                                                |
| P | Flag changes by executing instruction (It works as parity flag).   |
| V | Flag changes by executing instruction (It works as overflow flag). |
| X | An undefined value is set in flag.                                 |

### 5. Instruction length

Instruction length is represented in byte unit.

|     |                                                        |
|-----|--------------------------------------------------------|
| +#  | adds immediate data length.                            |
| +M  | adds addressing code length.                           |
| +#M | adds immediate data length and addressing code length. |

### 6. State

Execution processing time of instruction are shown in order of 8 bit, 16 bit, 32 bit processing in status unit.

1 state = 100ns @20MHz oscillation

## Appendix B Instruction Lists (3/11)

## (1) Load

| Group | Size | Mnemonic          | Codes (hex.)      | Function       | SZHVNC | Length<br>(byte) | State   |
|-------|------|-------------------|-------------------|----------------|--------|------------------|---------|
| LD    | BWL  | LD R, r           | C8+zz+r :88+R     | R ← r          | -----  | 2                | 4. 4. 4 |
|       | BWL  | LD r, R           | C8+zz+r :98+R     | r ← R          | -----  | 2                | 4. 4. 4 |
|       | BWL  | LD r, #3          | C8+zz+r :A8+#3    | r ← #3         | -----  | 2                | 4. 4. 4 |
|       | BWL  | LD R, #           | 20+zz+R :#        | R ← #          | -----  | 1+#              | 2. 3. 5 |
|       | BWL  | LD r, #           | C8+zz+r :03:#     | r ← #          | -----  | 2+#              | 4. 4. 6 |
|       | BWL  | LD R, (mem)       | 80+zz+mem:20+R    | R ← (mem)      | -----  | 2+M              | 4. 4. 6 |
|       | BWL  | LD (mem), R       | B0+mem :40+zz+R   | (mem) ← R      | -----  | 2+M              | 4. 4. 6 |
|       | BW-  | LD<W> (#8) ,#     | 08+z :#8:#        | (#8) ← #       | -----  | 2+#              | 5. 6. - |
| PUSH  | BW-  | LD<W> (mem),#     | B0+mem :00+z:#    | (mem) ← #      | -----  | 2+M#             | 5. 6. - |
|       | BW-  | LD<W> (#16),(mem) | 80+zz+mem:19:#16  | (#16) ← (mem)  | -----  | 4+M              | 8. 8. - |
|       | BW-  | LD<W> (mem),(#16) | B0+mem :14+z:#16  | (mem) ← (#16)  | -----  | 4+M              | 8. 8. - |
|       | B--  | PUSH F            | 18                | (-XSP) ← F     | -----  | 1                | 3. -. - |
| POP   | B--  | PUSH A            | 14                | (-XSP) ← A     | -----  | 1                | 3. -. - |
|       | -WL  | PUSH R            | 18+zz+R           | (-XSP) ← R     | -----  | 1                | -. 3. 5 |
|       | BWL  | PUSH r            | C8+zz+r :04       | (-XSP) ← r     | -----  | 2                | 5. 5. 7 |
|       | BW-  | PUSH<W> #         | 09+z :#           | (-XSP) ← #     | -----  | 1+#              | 4. 5. - |
|       | BW-  | PUSH<W> (mem)     | 80+zz+mem:04      | (-XSP) ← (mem) | -----  | 2+M              | 7. 7. - |
|       | B--  | POP F             | 19                | F ← (XSP+)     | *****  | 1                | 4. -. - |
| LDA   | B--  | POP A             | 15                | A ← (XSP+)     | -----  | 1                | 4. -. - |
|       | -WL  | POP R             | 38+zz+R           | R ← (XSP+)     | -----  | 1                | -. 4. 6 |
|       | BWL  | POP r             | C8+zz+r :05       | r ← (XSP+)     | -----  | 2                | 6. 6. 8 |
|       | BW-  | POP<W> (mem)      | B0+mem :04+z      | (mem) ← (XSP+) | -----  | 2+M              | 6. 6. - |
|       | LDA  | -WL LDA R, mem    | B0+mem :10+zz+R   | R ← mem        | -----  | 2+M              | -. 4. 4 |
| LDAR  | -WL  | LDAR R,\$+4+d16   | F3:13:d16:10+zz+R | R ← PC+d16     | -----  | 5                | -.11.11 |

## (2) Exchange

| Group | Size | Mnemonic   | Codes (hex.)   | Function          | SZHVNC | Length<br>(byte) | State   |
|-------|------|------------|----------------|-------------------|--------|------------------|---------|
| EX    | B--  | EX F, F'   | 16             | F ↔ F'            | *****  | 1                | 2. -. - |
|       | BW-  | EX R, r    | C8+zz+r :B8+R  | R ↔ r             | -----  | 2                | 5. 5. - |
|       | BW-  | EX (mem),R | 80+zz+mem:30+R | (mem) ↔ R         | -----  | 2+M              | 6. 6. - |
| MIRR  | -W-  | MIRR r     | D8+r :16       | r<0:MSB>↔r<MSB:0> | -----  | 2                | -. 4. - |

## Appendix B Instruction Lists (4/11)

## (3) Load Increment/Decrement &amp; Compare Increment/Decrement Size

| Group | Size | Mnemonic                   | Codes (hex.) | Function                                                                   | SZHVNC | Length<br>(byte) | State                                     |
|-------|------|----------------------------|--------------|----------------------------------------------------------------------------|--------|------------------|-------------------------------------------|
| LDxx  | BW-  | LDI<W><br>[(XDE+),(XHL+)]  | 83+zz :10    | (XDE+) $\leftarrow$ (XHL+)<br>BC $\leftarrow$ BC-1                         | --0M0- | 2                | 10.10. -                                  |
|       | BW-  | LDI<W><br>(XIX+),(XIY+)    | 85+zz :10    | (XIX+) $\leftarrow$ (XIY+)<br>BC $\leftarrow$ BC-1                         | --0M0- | 2                | 10.10. -                                  |
|       | BW-  | LDIR<W><br>[(XDE+),(XHL+)] | 83+zz :11    | repeat<br>(XDE+) $\leftarrow$ (XHL+)<br>BC $\leftarrow$ BC-1<br>until BC=0 | --000- | 2                | 10.10. -<br>(end)<br>14.14. -<br>(repeat) |
|       | BW-  | LDIR<W><br>(XIX+),(XIY+)   | 85+zz :11    | repeat<br>(XIX+) $\leftarrow$ (XIY+)<br>BC $\leftarrow$ BC-1<br>until BC=0 | --000- | 2                | 10.10. -<br>(end)<br>14.14. -<br>(repeat) |
|       | BW-  | LDD<W><br>[(XDE-),(XHL-)]  | 83+zz :12    | (XDE-) $\leftarrow$ (XHL-)<br>BC $\leftarrow$ BC-1                         | --0M0- | 2                | 10.10. -                                  |
|       | BW-  | LDD<W><br>(XIX-),(XIY-)    | 85+zz :12    | (XIX-) $\leftarrow$ (XIY-)<br>BC $\leftarrow$ BC-1                         | --0M0- | 2                | 10.10. -                                  |
|       | BW-  | LDDR<W><br>[(XDE-),(XHL-)] | 83+zz :13    | repeat<br>(XDE-) $\leftarrow$ (XHL-)<br>BC $\leftarrow$ BC-1<br>until BC=0 | --000- | 2                | 10.10. -<br>(end)<br>14.14. -<br>(repeat) |
|       | BW-  | LDDR<W><br>(XIX-),(XIY-)   | 85+zz :13    | repeat<br>(XIX-) $\leftarrow$ (XIY-)<br>BC $\leftarrow$ BC-1<br>until BC=0 | --000- | 2                | 10.10. -<br>(end)<br>14.14. -<br>(repeat) |
| CPxx  | BW-  | CPI [A/WA,(R+)]            | 80+zz+R :14  | A/WA - (R+)<br>BC $\leftarrow$ BC-1                                        | *N*M1- | 2                | 8. 8. -                                   |
|       | BW-  | CPIR [A/WA,(R+)]           | 80+zz+R :15  | repeat<br>A/WA - (R+)<br>BC $\leftarrow$ BC-1<br>until A/WA=(R)<br>or BC=0 | *N*M1- | 2                | 10.10. -<br>(end)<br>14.14. -<br>(repeat) |
|       | BW-  | CPD [A/WA,(R-)]            | 80+zz+R :16  | A/WA - (R-)<br>BC $\leftarrow$ BC-1                                        | *N*M1- | 2                | 8. 8. -                                   |
|       | BW-  | CPDR [A/WA,(R-)]           | 80+zz+R :17  | repeat<br>A/WA - (R-)<br>BC $\leftarrow$ BC-1<br>until A/WA=(R)<br>or BC=0 | *N*M1- | 2                | 10.10. -<br>(end)<br>14.14. -<br>(repeat) |

Note 1: Flag M; If BC = 0 after execution, the P/V flag is set to 0, otherwise 1.

Flag N; If A/WA = (R), the Z flag is set to 1, otherwise, 0 is set.

Note 2: When the operand is omitted in the CPI, CPIR, CPD, or CPDR instruction, A,(XHL +/-) is used as the default value.

## Appendix B Instruction Lists (5/11)

## (4) Arithmetic Operations

| Group | Size | Mnemonic         | Codes (hex.)    | Function                                             | SZHVNC | Length<br>(byte) | State    |
|-------|------|------------------|-----------------|------------------------------------------------------|--------|------------------|----------|
| ADD   | BWL  | ADD R, r         | C8+zz+r :80+R   | R ← R + r                                            | ***V0* | 2                | 4. 4. 7  |
|       | BWL  | ADD r,#          | C8+zz+r :C8:#   | r ← r + #                                            | ***V0* | 2+#              | 4. 4. 7  |
|       | BWL  | ADD R, (mem)     | 80+zz+mem:80+R  | R ← R + (mem)                                        | ***V0* | 2+M              | 4. 4. 6  |
|       | BWL  | ADD (mem), R     | 80+zz+mem:88+R  | (mem) ← (mem) + R                                    | ***V0* | 2+M              | 6. 6. 10 |
|       | BW-  | ADD<W> (mem), #  | 80+zz+mem:38:#  | (mem) ← (mem) + #                                    | ***V0* | 2+M#             | 7. 8. -  |
| ADC   | BWL  | ADC R, r         | C8+zz+r :90+R   | R ← R + r + CY                                       | ***V0* | 2                | 4. 4. 7  |
|       | BWL  | ADC r,#          | C8+zz+r :C9:#   | r ← r + # + CY                                       | ***V0* | 2+#              | 4. 4. 7  |
|       | BWL  | ADC R, (mem)     | 80+zz+mem:90+R  | R ← R+(mem)+CY                                       | ***V0* | 2+M              | 4. 4. 6  |
|       | BWL  | ADC (mem), R     | 80+zz+mem:98+R  | (mem) ← (mem)+R+CY                                   | ***V0* | 2+M              | 6. 6. 10 |
|       | BW-  | ADC<W> (mem), #  | 80+zz+mem:39:#  | (mem) ← (mem)+#+CY                                   | ***V0* | 2+M#             | 7. 8. -  |
| SUB   | BWL  | SUB R, r         | C8+zz+r :A0+R   | R ← R - r                                            | ***V1* | 2                | 4. 4. 7  |
|       | BWL  | SUB r,#          | C8+zz+r :CA:#   | r ← r - #                                            | ***V1* | 2+#              | 4. 4. 7  |
|       | BWL  | SUB R, (mem)     | 80+zz+mem:A0+R  | R ← R - (mem)                                        | ***V1* | 2+M              | 4. 4. 6  |
|       | BWL  | SUB (mem), R     | 80+zz+mem:A8+R  | (mem) ← (mem) - R                                    | ***V1* | 2+M              | 6. 6. 10 |
|       | BW-  | SUB<W> (mem), #  | 80+zz+mem:3A:#  | (mem) ← (mem) - #                                    | ***V1* | 2+M#             | 7. 8. -  |
| SBC   | BWL  | SBC R, r         | C8+zz+r :B0+R   | R ← R - r - CY                                       | ***V1* | 2                | 4. 4. 7  |
|       | BWL  | SBC r,#          | C8+zz+r :CB:#   | r ← r - # - CY                                       | ***V1* | 2+#              | 4. 4. 7  |
|       | BWL  | SBC R, (mem)     | 80+zz+mem:B0+R  | R ← R-(mem) - CY                                     | ***V1* | 2+M              | 4. 4. 6  |
|       | BWL  | SBC (mem), R     | 80+zz+mem:BB+R  | (mem) ← (mem) - R - CY                               | ***V1* | 2+M              | 6. 6. 10 |
|       | BW-  | SBC<W> (mem), #  | 80+zz+mem:3B:#  | (mem) ← (mem) - #- CY                                | ***V1* | 2+M#             | 7. 8. -  |
| CP    | BWL  | CP R, r          | C8+zz+r :F0+R   | R - r                                                | ***V1* | 2                | 4. 4. 7  |
|       | BW-  | CP r,#3          | C8+zz+r :D8+#3  | r - #3                                               | ***V1* | 2                | 4. 4. -  |
|       | BWL  | CP r,#           | C8+zz+r :CF:#   | r - #                                                | ***V1* | 2+#              | 4. 4. 7  |
|       | BWL  | CP R, (mem)      | 80+zz+mem:F0+R  | R - (mem)                                            | ***V1* | 2+M              | 4. 4. 6  |
|       | BWL  | CP (mem), R      | 80+zz+mem:F8+R  | (mem) - R                                            | ***V1* | 2+M              | 6. 6. 6  |
|       | BW-  | CP<W> (mem), #   | 80+zz+mem:3F:#  | (mem) - #                                            | ***V1* | 2+M#             | 6. 6. -  |
| INC   | B--  | INC #3, r        | C8+r :60+#3     | r ← r + #3                                           | ***V0- | 2                | 4. - -   |
|       | -WL  | INC #3, r        | C8+zz+r :60+#3  | r ← r + #3                                           | -----  | 2                | - . 4. 4 |
|       | BW-  | INC<W> #3, (mem) | 80+zz+mem:60+#3 | (mem) ← (mem) + #3                                   | ***V0- | 2+M              | 6. 6. -  |
| DEC   | B--  | DEC #3, r        | C8+r :68+#3     | r ← r - #3                                           | ***V1- | 2                | 4. - -   |
|       | -WL  | DEC #3, r        | C8+zz+r :68+#3  | r ← r - #3                                           | -----  | 2                | - . 4. 5 |
|       | BW-  | DEC<W> #3, (mem) | 80+zz+mem:68+#3 | (mem) ← (mem) - #3                                   | ***V1- | 2+M              | 6. 6. -  |
| NEG   | BW-  | NEG r            | C8+zz+r :07     | r ← 0 - r                                            | ***V1* | 2                | 5. 5. -  |
| EXTZ  | -WL  | EXTZ r           | C8+zz+r :12     | r<high> ← 0                                          | -----  | 2                | - . 4. 4 |
| EXTS  | -WL  | EXTS r           | C8+zz+r :13     | r<high> ← r<low.<br>MSB>                             | -----  | 2                | - . 5. 5 |
| DAA   | B--  | DAA r            | C8+r :10        | Decimal adjustment after<br>addition or subtraction. | ***P-* | 2                | 6. - -   |
| PAA   | -WL  | PAA r            | C8+zz+r :14     | if r<0>=1 then<br>INC r                              | -----  | 2                | - . 4. 4 |

Note 1: With the INC/DEC instruction, when the code value of #3=0, functions as +8/-8.

Note 2: When the ADD R, r (word type) instruction is used in the TLCS-90, the S, Z, and V flags do not change. In the TLCS-900, these flags change.

## Appendix B Instruction Lists (6/11)

| Group | Size | Mnemonic                            | Codes (hex.)   | Function                                                                                                                | SZHVNC | Length<br>(byte) | State    |
|-------|------|-------------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------|--------|------------------|----------|
| MUL   | BW-  | MUL RR,r                            | C8+zz+r :40+R  | RR $\leftarrow$ R $\times$ r                                                                                            | -----  | 2                | 18.26. - |
|       | BW-  | MUL rr,#                            | C8+zz+r :08:#  | rr $\leftarrow$ r $\times$ #                                                                                            | -----  | 2+#              | 18.26. - |
|       | BW-  | MUL RR,(mem)                        | 80+zz+mem:40+R | RR $\leftarrow$ R $\times$ (mem)                                                                                        | -----  | 2+M              | 18.26. - |
| MULS  | BW-  | MULS RR,r                           | C8+zz+r :48+R  | RR $\leftarrow$ R $\times$ r ;signed                                                                                    | -----  | 2                | 18.26. - |
|       | BW-  | MULS rr,#                           | C8+zz+r :09:#  | rr $\leftarrow$ r $\times$ # ;signed                                                                                    | -----  | 2+#              | 18.26. - |
|       | BW-  | MULS RR,(mem)                       | 80+zz+mem:48+R | RR $\leftarrow$ R $\times$ (mem);signed                                                                                 | -----  | 2+M              | 18.26. - |
| DIV   | BW-  | DIV RR,r                            | C8+zz+r :50+R  | R $\leftarrow$ RR+r                                                                                                     | ---V-- | 2                | 22.30. - |
|       | BW-  | DIV rr,#                            | C8+zz+r :0A:#  | r $\leftarrow$ rr+#                                                                                                     | ---V-- | 2+#              | 22.30. - |
|       | BW-  | DIV RR,(mem)                        | 80+zz+mem:50+R | R $\leftarrow$ RR+(mem)                                                                                                 | ---V-- | 2+M              | 22.30. - |
| DIVS  | BW-  | DIVS RR,r                           | C8+zz+r :58+R  | R $\leftarrow$ RR+r ;signed                                                                                             | ---V-- | 2                | 24.32. - |
|       | BW-  | DIVS rr,#                           | C8+zz+r :0B:#  | r $\leftarrow$ rr+# ;signed                                                                                             | ---V-- | 2+#              | 24.32. - |
|       | BW-  | DIVS RR,(mem)                       | 80+zz+mem:58+R | R $\leftarrow$ RR+(mem);signed                                                                                          | ---V-- | 2+M              | 24.32. - |
| MULA  | -W-  | MULA rr                             | D8+r :19       | Multiply and add signed<br>rr $\leftarrow$ rr+(XDE) $\times$ (XHL)<br>32bit 32bit 16bit 16bit<br>XHL $\leftarrow$ XHL-2 | **-V-- | 2                | -.31. -  |
| MINC  | -W-  | MINC1 #,r<br>(#=2**n)<br>(1<=n<=15) | D8+r :38:#-1   | Modulo increment;+1<br>if (r mod #)=(#-1)<br>then r=r-(#-1)<br>else r=r+1                                               | -----  | 4                | -. 8. -  |
|       | -W-  | MINC2 #,r<br>(#=2**n)<br>(2<=n<=15) | D8+r :39:#-2   | Modulo increment;+2<br>if (r mod #)=(#-2)<br>then r=r-(#-2)<br>else r=r+2                                               | -----  | 4                | -. 8. -  |
|       | -W-  | MINC4 #,r<br>(#=2**n)<br>(3<=n<=15) | D8+r :3A:#-4   | Modulo increment;+4<br>if (r mod #)=(#-4)<br>then r=r-(#-4)<br>else r=r+4                                               | -----  | 4                | -. 8. -  |
| MDEC  | -W-  | MDEC1 #,r<br>(#=2**n)<br>(1<=n<=15) | D8+r :3C:#-1   | Modulo decrement;-1<br>if (r mod #)=0<br>then r=r+(#-1)<br>else r=r-1                                                   | -----  | 4                | -. 7. -  |
|       | -W-  | MDEC2 #,r<br>(#=2**n)<br>(2<=n<=15) | D8+r :3D:#-2   | Modulo decrement;-2<br>if (r mod #)=0<br>then r=r+(#-2)<br>else r=r-2                                                   | -----  | 4                | -. 7. -  |
|       | -W-  | MDEC4 #,r<br>(#=2**n)<br>(3<=n<=15) | D8+r :3E:#-4   | Modulo decrement;-4<br>if (r mod #)=0<br>then r=r+(#-4)<br>else r=r-4                                                   | -----  | 4                | -. 7. -  |

Note: Operand RR of the MUL, MULS, DIV, and DIVS instructions indicates that a register twice the size of the operation is specified. When the operation is in bytes (8 bits x 8 bits, 16/8 bits), word register (16 bits) is specified; when the operation is in words (16 bits x 16 bits, 32/16 bits), long word register (32 bits) is specified.

## Appendix B Instruction Lists (7/11)

## (5) Logical operations

| Group | Size | Mnemonic       | Codes (hex.)   | Function            | SZHVNC | Length<br>(byte) | State    |
|-------|------|----------------|----------------|---------------------|--------|------------------|----------|
| AND   | BWL  | AND R,r        | C8+zz+r :C0+R  | R ← R and r         | **1P00 | 2                | 4. 4. 7  |
|       | BWL  | AND r,#        | C8+zz+r :CC:#  | r ← r and #         | **1P00 | 2+#              | 4. 4. 7  |
|       | BWL  | AND R,(mem)    | 80+zz+mem:C0+R | R ← R and (mem)     | **1P00 | 2+M              | 4. 4. 6  |
|       | BWL  | AND {mem},R    | 80+zz+mem:C8+R | {mem} ← {mem} and R | **1P00 | 2+M              | 6. 6. 10 |
|       | BW-  | AND<W> {mem},# | 80+zz+mem:3C:# | {mem} ← {mem} and # | **1P00 | 2+M#             | 7. 8. -  |
| OR    | BWL  | OR R,r         | C8+zz+r :E0+R  | R ← R or r          | **0P00 | 2                | 4. 4. 7  |
|       | BWL  | OR r,#         | C8+zz+r :CE:#  | r ← r or #          | **0P00 | 2+#              | 4. 4. 7  |
|       | BWL  | OR R,(mem)     | 80+zz+mem:E0+R | R ← R or (mem)      | **0P00 | 2+M              | 4. 4. 6  |
|       | BWL  | OR {mem},R     | 80+zz+mem:E8+R | {mem} ← {mem} or R  | **0P00 | 2+M              | 6. 6. 10 |
|       | BW-  | OR<W> {mem},#  | 80+zz+mem:3E:# | {mem} ← {mem} or #  | **0P00 | 2+M#             | 7. 8. -  |
| XOR   | BWL  | XOR R,r        | C8+zz+r :D0+R  | R ← R xor r         | **0P00 | 2                | 4. 4. 7  |
|       | BWL  | XOR r,#        | C8+zz+r :CD:#  | r ← r xor #         | **0P00 | 2+#              | 4. 4. 7  |
|       | BWL  | XOR R,(mem)    | 80+zz+mem:D0+R | R ← R xor (mem)     | **0P00 | 2+M              | 4. 4. 6  |
|       | BWL  | XOR {mem},R    | 80+zz+mem:D8+R | {mem} ← {mem} xor R | **0P00 | 2+M              | 6. 6. 10 |
|       | BW-  | XOR<W> {mem},# | 80+zz+mem:3D:# | {mem} ← {mem} xor # | **0P00 | 2+M#             | 7. 8. -  |
| CPL   | BW-  | CPL r          | C8+zz+r :06    | r ← not r           | --1-1- | 2                | 4. 4. -  |

## Appendix B Instruction Lists (8/11)

## (6) Bit operations

| Group | Size | Mnemonic       | Codes (hex.)   | Function                | SZHVNC | Length<br>(byte) | State  |
|-------|------|----------------|----------------|-------------------------|--------|------------------|--------|
| LDCF  | BW-  | LDCF #4,r      | C8+zz+r :23:#4 | CY ← r<#4>              | -----* | 3                | 4.4.-  |
|       | BW-  | LDCF A ,r      | C8+zz+r :2B    | CY ← r<A>               | -----* | 2                | 4.4.-  |
|       | B--  | LDCF #3,(mem)  | B0+mem :98+#3  | CY ← (mem)<#3>          | -----* | 2+M              | 8.-.-  |
|       | B--  | LDCF A ,(mem)  | B0+mem :2B     | CY ← (mem)<A>           | -----* | 2+M              | 8.-.-  |
| STCF  | BW-  | STCF #4,r      | C8+zz+r :24:#4 | r<#4> ← CY              | -----  | 3                | 4.4.-  |
|       | BW-  | STCF A ,r      | C8+zz+r :2C    | r<A> ← CY               | -----  | 2                | 4.4.-  |
|       | B--  | STCF #3,(mem)  | B0+mem :A0+#3  | (mem)<#3> ← CY          | -----  | 2+M              | 8.-.-  |
|       | B--  | STCF A ,(mem)  | B0+mem :2C     | (mem)<A> ← CY           | -----  | 2+M              | 8.-.-  |
| ANDCF | BW-  | ANDCF #4,r     | C8+zz+r :20:#4 | CY ← CY and r<#4>       | -----* | 3                | 4.4.-  |
|       | BW-  | ANDCF A ,r     | C8+zz+r :28    | CY ← CY and r<A>        | -----* | 2                | 4.4.-  |
|       | B--  | ANDCF #3,(mem) | B0+mem :80+#3  | CY ← CY and (mem)<#3>   | -----* | 2+M              | 8.-.-  |
|       | B--  | ANDCF A ,(mem) | B0+mem :28     | CY ← CY and (mem)<A>    | -----* | 2+M              | 8.-.-  |
| ORCF  | BW-  | ORCF #4,r      | C8+zz+r :21:#4 | CY ← CY or r<#4>        | -----* | 3                | 4.4.-  |
|       | BW-  | ORCF A ,r      | C8+zz+r :29    | CY ← CY or r<A>         | -----* | 2                | 4.4.-  |
|       | B--  | ORCF #3,(mem)  | B0+mem :88+#3  | CY ← CY or (mem)<#3>    | -----* | 2+M              | 8.-.-  |
|       | B--  | ORCF A ,(mem)  | B0+mem :29     | CY ← CY or (mem)<A>     | -----* | 2+M              | 8.-.-  |
| XORCF | BW-  | XORCF #4,r     | C8+zz+r :22:#4 | CY ← CY xor r<#4>       | -----* | 3                | 4.4.-  |
|       | BW-  | XORCF A ,r     | C8+zz+r :2A    | CY ← CY xor r<A>        | -----* | 2                | 4.4.-  |
|       | B--  | XORCF #3,(mem) | B0+mem :90+#3  | CY ← CY xor (mem)<#3>   | -----* | 2+M              | 8.-.-  |
|       | B--  | XORCF A ,(mem) | B0+mem :2A     | CY ← CY xor (mem)<A>    | -----* | 2+M              | 8.-.-  |
| RCF   | ---  | RCF            | 10             | CY ← 0                  | --0-00 | 1                | 2      |
| SCF   | ---  | SCF            | 11             | CY ← 1                  | --0-01 | 1                | 2      |
| CCF   | ---  | CCF            | 12             | CY ← not CY             | --X-0* | 1                | 2      |
| ZCF   | ---  | ZCF            | 13             | CY ← not Z flag         | --X-0* | 1                | 2      |
| BIT   | BW-  | BIT #4,r       | C8+zz+r :33:#4 | Z ← not r<#4>           | X*1X0- | 3                | 4.4.-  |
|       | B--  | BIT #3,(mem)   | B0+mem :C8+#3  | Z ← not (mem)<#3>       | X*1X0- | 2+M              | 8.-.-  |
| RES   | BW-  | RES #4,r       | C8+zz+r :30:#4 | r<#4> ← 0               | -----  | 3                | 4.4.-  |
|       | B--  | RES #3,(mem)   | B0+mem :B0+#3  | (mem)<#3> ← 0           | -----  | 2+M              | 8.-.-  |
| SET   | BW-  | SET #4,r       | C8+zz+r :31:#4 | r<#4> ← 1               | -----  | 3                | 4.4.-  |
|       | B--  | SET #3,(mem)   | B0+mem :B8+#3  | (mem)<#3> ← 1           | -----  | 2+M              | 8.-.-  |
| CHG   | BW-  | CHG #4,r       | C8+zz+r :32:#4 | r<#4> ← not r<#4>       | -----  | 3                | 4.4.-  |
|       | B--  | CHG #3,(mem)   | B0+mem :C0+#3  | (mem)<#3>←not (mem)<#3> | -----  | 2+M              | 8.-.-  |
| TSET  | BW-  | TSET #4,r      | C8+zz+r :34:#4 | Z←not r<#4> : r<#4>←1   | X*1X0- | 3                | 6.6.-  |
|       | B--  | TSET #3,(mem)  | B0+mem :A8+#3  | Z ← not (mem)<#3>       | X*1X0- | 2+M              | 10.-.- |
|       |      |                |                | (mem)<#3> ← 1           |        |                  |        |
| BS1   | -W-  | BS1F A,r       | D8+r :0E       | A ← 1 search r;Forward  | ---N-- | 2                | -4.-   |
|       | -W-  | BS1B A,r       | D8+r :0F       | A ← 1 search r;Backward | ---N-- | 2                | -4.-   |

Note: Flag N ;0 is set when the bit searched for is found, otherwise 1 is set and an undefined value is set in the A register.

## Appendix B Instruction Lists (9/11)

## (7) Special operations and CPU control

| Group  | Size | Mnemonic   | Codes (hex.)     | Function                                            | SZHVN | Length<br>(byte) | State   |
|--------|------|------------|------------------|-----------------------------------------------------|-------|------------------|---------|
| NOP    | ---  | NOP        | 00               | no operation                                        | ----- | 1                | 2       |
| NORMAL | ---  | NORMAL     | 01               | Changes to normal mode.<br>SYSM=0 [privileged]      | ----- | 1                | 4       |
| MAX    | ---  | MAX        | 04               | Changes to maximum mode.<br>MAX+1 [privileged]      | ----- | 1                | 4       |
| MIN    | ---  | MIN        | 04               | Changes to minimum mode.<br>MAX=0                   | ----- | 1                | 4       |
| EI     | ---  | EI [#3]    | 06 :#3           | Sets interrupt enable flag.<br>IFF<#3 [privileged]  | ----- | 2                | 5       |
| DI     | ---  | DI         | 06 :07           | Disables interrupt.<br>IFF<7 [privileged]           | ----- | 2                | 5       |
| PUSH   | -W-  | PUSH SR    | 02               | (-XSP)←SR [privileged]                              | ----- | 1                | - .4.-  |
| POP    | -W-  | POP SR     | 03               | SR←(XSP+) [privileged]                              | ***** | 1                | - .6.-  |
| SWI    | ---  | SWI [#3]   | F8+#3            | Software interrupt<br>PUSH PC&SR<br>JP 8000H+10H×#3 | ----- | 1                | 16      |
| HALT   | ---  | HALT       | 05               | CPU halt [privileged]                               | ----- | 1                | 8       |
| LDC    | BWL  | LDC cr,r   | C8+zz+r :2E:cr   | cr ← r [privileged]                                 | ----- | 3                | 8.8.8   |
|        | BWL  | LDC r,cr   | C8+zz+r :2F:cr   | r ← cr [privileged]                                 | ----- | 3                | 8.8.8   |
| LDX    | B--  | LDX (#8),# | F7:00:#8:00:#:00 | (#8) ← #                                            | ----- | 6                | 9.-.-   |
| LINK   | --L  | LINK r,d16 | E8+r :0C:d16     | PUSH r<br>LD r,XSP<br>ADD XSP,d16                   | ----- | 4                | - .-.10 |
| UNLK   | --L  | UNLK r     | E8+r :0D         | LD XSP,r<br>POP r                                   | ----- | 2                | - .-.8  |
| LDF    | ---  | LDF #3     | 17 :#3           | Sets register bank.<br>RFP ← #3 (0 at reset)        | ----- | 2                | 2       |
| INCF   | ---  | INCF       | 0C               | Switches register banks.<br>RFP ← RFP + 1           | ----- | 1                | 2       |
| DECF   | ---  | DECF       | 0D               | Switches register banks.<br>RFP ← RFP - 1           | ----- | 1                | 2       |
| SCC    | BW-  | SCC cc,r   | C8+zz+r :70+cc   | if cc then r ← 1<br>else r ← 0                      | ----- | 2                | 6.-6.-  |

Note 1: When operand #3 coding in the EI instruction is omitted, 0 is used as the default value.

Note 2: When operand #3 coding in the SWI instruction is omitted, 7 is used as the default value.

Note 3: The value in the state column for the SWI instruction represents the number of states when the CPU is in minimum mode. In maximum mode, add + 2.

Note 4: NORMAL and MAX instruction exist only in 900 CPU, and MIN instruction exists only in 900L CPU.

The privileged instruction is for the 900 CPU.

## Appendix B Instruction Lists (10/11)

## (8) Rotate and shift

| Group | Size | Mnemonic       | Codes (hex.)   | Function | SZHVNC | Length<br>(byte) | State    |
|-------|------|----------------|----------------|----------|--------|------------------|----------|
| RLC   | BWL  | RLC #4, r      | C8+zz+r :E8:#4 |          | **OP0* | 3                | 6.6.8+2n |
|       | BWL  | RLC A, r       | C8+zz+r :F8    |          | **OP0* | 2                | 6.6.8+2n |
|       | BW-  | RLC<W> (mem)   | 80+zz+mem:78   |          | **OP0* | 2+M              | 8.8.-    |
| RRC   | BWL  | RRC #4, r      | C8+zz+r :E9:#4 |          | **OP0* | 3                | 6.6.8+2n |
|       | BWL  | RRC A, r       | C8+zz+r :F9    |          | **OP0* | 2                | 6.6.8+2n |
|       | BW-  | RRC<W> (mem)   | 80+zz+mem:79   |          | **OP0* | 2+M              | 8.8.-    |
| RL    | BWL  | RL #4, r       | C8+zz+r :EA:#4 |          | **OP0* | 3                | 6.6.8+2n |
|       | BWL  | RL A, r        | C8+zz+r :FA    |          | **OP0* | 2                | 6.6.8+2n |
|       | BW-  | RL<W> (mem)    | 80+zz+mem:7A   |          | **OP0* | 2+M              | 8.8.-    |
| RR    | BWL  | RR #4, r       | C8+zz+r :EB:#4 |          | **OP0* | 3                | 6.6.8+2n |
|       | BWL  | RR A, r        | C8+zz+r :FB    |          | **OP0* | 2                | 6.6.8+2n |
|       | BW-  | RR<W> (mem)    | 80+zz+mem:7B   |          | **OP0* | 2+M              | 8.8.-    |
| SLA   | BWL  | SLA #4, r      | C8+zz+r :EC:#4 |          | **OP0* | 3                | 6.6.8+2n |
|       | BWL  | SLA A, r       | C8+zz+r :FC    |          | **OP0* | 2                | 6.6.8+2n |
|       | BW-  | SLA<W> (mem)   | 80+zz+mem:7C   |          | **OP0* | 2+M              | 8.8.-    |
| SRA   | BWL  | SRA #4, r      | C8+zz+r :ED:#4 |          | **OP0* | 3                | 6.6.8+2n |
|       | BWL  | SRA A, r       | C8+zz+r :FD    |          | **OP0* | 2                | 6.6.8+2n |
|       | BW-  | SRA<W> (mem)   | 80+zz+mem:7D   |          | **OP0* | 2+M              | 8.8.-    |
| SLL   | BWL  | SLL #4, r      | C8+zz+r :EE:#4 |          | **OP0* | 3                | 6.6.8+2n |
|       | BWL  | SLL A, r       | C8+zz+r :FE    |          | **OP0* | 2                | 6.6.8+2n |
|       | BW-  | SLL<W> (mem)   | 80+zz+mem:7E   |          | **OP0* | 2+M              | 8.8.-    |
| SRL   | BWL  | SRL #4, r      | C8+zz+r :EF:#4 |          | **OP0* | 3                | 6.6.8+2n |
|       | BWL  | SRL A, r       | C8+zz+r :FF    |          | **OP0* | 2                | 6.6.8+2n |
|       | BW-  | SRL<W> (mem)   | 80+zz+mem:7F   |          | **OP0* | 2+M              | 8.8.-    |
| RLD   | B--  | RLD [A, ](mem) | 80+mem :06     |          | **OP0- | 2+M              | 12.-.-   |
| RRD   | B--  | RRD [A, ](mem) | 80+mem :07     |          | **OP0- | 2+M              | 12.-.-   |

Note 1: When #4/A is used to specify the number of shifts, modulo 16 (0 to 15) is used. Code 0 means 16 shifts.

Note 2: When the following instructions are used in the TLCS-90, the S, Z and V flags do not change.

RLCA, RRCA, RLA, RRA, SLAA, SRAA, SLLA, and SRLA

In the TLCS-900, these flags change.

## Appendix B Instruction Lists (11/11)

## (9) Jump, call and return

| Group | Size | Mnemonic          | Codes (hex.)   | Function                        | SZHVNC | Length<br>(byte) | State               |
|-------|------|-------------------|----------------|---------------------------------|--------|------------------|---------------------|
| JP    | ---  | JP #16            | 1A :#16        | PC ← #16                        | -----  | 3                | 7                   |
|       | ---  | JP #24            | 1B :#24        | PC ← #24                        | -----  | 4                | 7                   |
|       | ---  | JR [cc,]\$+2+d8   | 60+cc :d8      | if cc then PC ← PC+d8           | -----  | 2                | 8/4 (T/F)           |
|       | ---  | JRL [cc,]\$+3+d16 | 70+cc :d16     | if cc then PC ← PC+d16          | -----  | 3                | 8/4 (T/F)           |
|       | ---  | JP [cc,]mem       | B0+mem :D0+cc  | if cc then PC ← mem             | -----  | 2+M              | 9/6 (T/F)           |
| CALL  | ---  | CALL #16          | 1C :#16        | PUSH PC : JP #16                | -----  | 3                | 12                  |
|       | ---  | CALL #24          | 1D :#24        | PUSH PC : JP #24                | -----  | 4                | 12                  |
|       | ---  | CALR \$+3+d16     | 1E :d16        | PUSH PC : JR \$+3+d16           | -----  | 3                | 12                  |
|       | ---  | CALL [cc,]mem     | B0+mem :E0+cc  | if cc then<br>PUSH PC : JP mem  | -----  | 2+M              | 12/6 (T/F)          |
| DJNZ  | BW-  | DJNZ [r,]\$+3+d8  | C8+zz+r :1C:d8 | r←r-1<br>if r≠0 then JR \$+3+d8 | -----  | 3                | 11 (r≠0)<br>7 (r=0) |
| RET   | ---  | RET               | 0E             | POP PC                          | -----  | 1                | 9                   |
|       | ---  | RET cc            | B0 :F0+cc      | if cc then POP PC               | -----  | 2                | 12/6 (T/F)          |
|       | ---  | RETD d16          | 0F :d16        | RET : ADD XSP,d16               | -----  | 3                | 9                   |
|       | ---  | RETI              | 07             | POP SR&PC [privileged]          | *****  | 1                | 12                  |

Note 1: The value in the state column for the CALL, CALR, RET, RETD, and RETI instructions represents the number of states when the CPU is in minimum mode. In maximum mode, add + 2.

Note 2: (T/F) represents the number of states at true/false.

## Appendix C Instruction Code Maps (1/4)

## 1-byte op code instructions

| H/L | 0     | 1      | 2          | 3         | 4         | 5            | 6        | 7           | 8            | 9            | A              | B            | C            | D               | E            | F            |     |
|-----|-------|--------|------------|-----------|-----------|--------------|----------|-------------|--------------|--------------|----------------|--------------|--------------|-----------------|--------------|--------------|-----|
| 0   | NOP   | NORMAL | PUSH<br>SR | POP<br>SR | MAX       | HALT         | EL<br>n  | RETI        | LD<br>(n), n | PUSH<br>n    | LDW<br>(n), nn | PUSHW<br>nn  | INCF         | DECF            | RET          | RETD<br>dd   |     |
| 1   | RCF   | SCF    | CCF        | ZCF       | PUSH<br>A | POP<br>F, F' | LDF<br>n | PUSH<br>F   | POP<br>F     | JP<br>nn     | JP<br>nnn      | CALL<br>nn   | CALL<br>nnn  | CALR<br>PC + dd |              |              |     |
| 2   |       |        | LD         | R, n      |           |              |          |             |              |              |                | PUSH         | RR           |                 |              |              |     |
| 3   |       |        | LD         | RR, nn    |           |              |          |             |              |              |                | PUSH         | XRR          |                 |              |              |     |
| 4   |       |        | LD         | XRR, nnnn |           |              |          |             |              |              |                | POP          | RR           |                 |              |              |     |
| 5   |       |        |            |           |           |              |          |             |              |              |                | POP          | XRR          |                 |              |              |     |
| 6   |       |        |            |           |           |              | JR       | cc, PC + d  |              |              |                |              |              |                 |              |              |     |
|     | F     | LT     | LE         | ULE       | PE/OV     | M/MI         | Z        | C<br>(T)    | GE           | GT           | UGT            | PO/NOV       | P/PL         | NZ              | NC           |              |     |
| 7   |       |        |            |           |           |              | JRL      | cc, PC + dd |              |              |                |              |              |                 |              |              |     |
|     | F     | LT     | LE         | ULE       | PE/OV     | M/MI         | Z        | C<br>(T)    | GE           | GT           | UGT            | PO/NOV       | P/PL         | NZ              | NC           |              |     |
| 8   |       |        |            | src. B    |           |              |          |             |              |              |                | src. B       |              |                 |              |              |     |
|     | (XWA) | (XBC)  | (XDE)      | (XHL)     | (XIX)     | (XIY)        | (XIZ)    | (XSP)       | (XWA<br>+ d) | (XBC<br>+ d) | (XDE<br>+ d)   | (XHL<br>+ d) | (XIX<br>+ d) | (XIY<br>+ d)    | (XIZ<br>+ d) | (XSP<br>+ d) |     |
| 9   |       |        |            | src. W    |           |              |          |             |              |              |                | src. W       |              |                 |              |              |     |
|     | (XWA) | (XBC)  | (XDE)      | (XHL)     | (XIX)     | (XIY)        | (XIZ)    | (XSP)       | (XWA<br>+ d) | (XBC<br>+ d) | (XDE<br>+ d)   | (XHL<br>+ d) | (XIX<br>+ d) | (XIY<br>+ d)    | (XIZ<br>+ d) | (XSP<br>+ d) |     |
| A   |       |        |            | src. L    |           |              |          |             |              |              |                | src. L       |              |                 |              |              |     |
|     | (XWA) | (XBC)  | (XDE)      | (XHL)     | (XIX)     | (XIY)        | (XIZ)    | (XSP)       | (XWA<br>+ d) | (XBC<br>+ d) | (XDE<br>+ d)   | (XHL<br>+ d) | (XIX<br>+ d) | (XIY<br>+ d)    | (XIZ<br>+ d) | (XSP<br>+ d) |     |
| B   |       |        |            | dst       |           |              |          |             |              |              |                | dst          |              |                 |              |              |     |
|     | (XWA) | (XBC)  | (XDE)      | (XHL)     | (XIX)     | (XIY)        | (XIZ)    | (XSP)       | (XWA<br>+ d) | (XBC<br>+ d) | (XDE<br>+ d)   | (XHL<br>+ d) | (XIX<br>+ d) | (XIY<br>+ d)    | (XIZ<br>+ d) | (XSP<br>+ d) |     |
| C   |       |        |            | src. B    |           |              |          |             | reg. B       |              |                | reg. B       |              |                 |              |              |     |
|     | (n)   | (nn)   | (nnn)      | (mem)     | (- xrr)   | (xrr +)      |          | r           |              | W            | A              | B            | C            | D               | E            | H            |     |
| D   |       |        |            | src. W    |           |              |          |             | reg. W       |              |                | reg. W       |              |                 |              |              |     |
|     | (n)   | (nn)   | (nnn)      | (mem)     | (- xrr)   | (xrr +)      |          | rr          |              | WA           | BC             | DE           | HL           | IX              | IY           | IZ           | SP  |
| E   |       |        |            | src. L    |           |              |          |             | reg. L       |              |                | reg. L       |              |                 |              |              |     |
|     | (n)   | (nn)   | (nnn)      | (mem)     | (- xrr)   | (xrr +)      |          | xrr         |              | XWA          | XBC            | XDE          | XHL          | XIX             | XIY          | XIZ          | XSP |
| F   |       |        |            | dst       |           |              |          |             | LDX          |              |                | SWI          | n            |                 |              |              |     |
|     | (n)   | (nn)   | (nnn)      | (mem)     | (- xrr)   | (xrr +)      |          | (n), n      |              | 0            | 1              | 2            | 3            | 4               | 5            | 6            | 7   |

Note 1: Codes in shaded parts are privileged instructions. (The case of 900\_CPU)

Note 2: Codes in blank parts are undefined instructions (i.e., illegal instructions).

Note 3: NORMAL instruction

This instruction exists only in 900\_CPU and it is privileged instruction. This instruction doesn't exist in 900/L\_CPU and this code (01H) becomes to undefined instruction.

Note 4: MAX/MIN instruction

MAX instruction exists only in 900\_CPU and it is privileged instruction. MIN instruction exists only in 900/L\_CPU.

## Appendix C Instruction Code Maps (2/4)

1st byte: reg

| H/L | 0             | 1            | 2             | 3                      | 4                         | 5                     | 6                     | 7                     | 8                     | 9                      | A             | B                         | C                         | D                 | E             | F                        |           |
|-----|---------------|--------------|---------------|------------------------|---------------------------|-----------------------|-----------------------|-----------------------|-----------------------|------------------------|---------------|---------------------------|---------------------------|-------------------|---------------|--------------------------|-----------|
| 0   |               |              |               | LD<br>r,#              | PUSH<br>r                 | POP<br>r              | CPL<br><u>BW</u><br>r | NEG<br><u>BW</u><br>r | MUL<br>rr,#           | MULS<br>rr,#           | DIV<br>rr,#   | DIVS<br><u>BW</u><br>rr,# | LINK<br>r, dd             | UNLK<br>r         | BS1F<br>A, r  | BS1B<br><u>W</u><br>A, r |           |
| 1   | DAA<br>r      | B            |               | EXTZ<br><u>WL</u><br>r | EXTS<br><u>WL</u><br>r    | PAA<br><u>WL</u><br>r | MIRR<br><u>W</u><br>r |                       | MULA<br><u>W</u><br>r | X                      | X             | X                         | DJNZ<br><u>BW</u><br>r, d |                   |               |                          |           |
| 2   | ANDCF<br>#, r | ORCF<br>#, r | XORCF<br>#, r | LDCF<br>#, r           | STCF<br><u>BW</u><br>#, r |                       |                       |                       | ANDCF<br>A, r         | ORCF<br>A, r           | XORCF<br>A, r | LDCF<br>A, r              | STCF<br><u>BW</u><br>A, r |                   | LDC<br>GCF    | LDC<br>GCF               |           |
| 3   | RES<br>#, r   | SET<br>#, r  | CHG<br>#, r   | BIT<br>#, r            | TSET<br><u>BW</u><br>#, r |                       |                       |                       | MINC1<br>#, r         | MINC2<br><u>W</u>      | MINC4<br>#, r |                           | MDEC1<br>#, r             | MDEC2<br><u>W</u> | MDEC4<br>#, r |                          |           |
| 4   |               |              |               | MUL<br>R, r            |                           |                       | <u>BW</u>             |                       |                       | MULS<br>R, r           |               |                           |                           |                   |               | <u>BW</u>                |           |
| 5   |               |              |               | DIV<br>R, r            |                           |                       | <u>BW</u>             |                       |                       | DIVS<br>R, r           |               |                           |                           |                   |               | <u>BW</u>                |           |
| 6   |               |              |               | INC<br>8 1 2 3 4 5 6 7 | #3, r                     |                       |                       |                       |                       | DEC<br>8 1 2 3 4 5 6 7 | #3, r         |                           |                           |                   |               |                          |           |
| 7   | F             | LT           | LE            | ULE                    | PE/OV                     | M/MI                  | Z                     | SCC<br>C              | cc, r<br>(T)          | GE                     | GT            | UGT                       | PO/NOV                    | P/PL              | NZ            | NC                       | <u>BW</u> |
| 8   |               |              |               | ADD<br>R, r            |                           |                       |                       |                       |                       | LD<br>R, r             |               |                           |                           |                   |               |                          |           |
| 9   |               |              |               | ADC<br>R, r            |                           |                       |                       |                       |                       | LD<br>r, R             |               |                           |                           |                   |               |                          |           |
| A   |               |              |               | SUB<br>R, r            |                           |                       |                       |                       | 0 1 2 3               | LD<br>r, #3            | 4 5 6 7       |                           |                           |                   |               |                          |           |
| B   |               |              |               | SBC<br>R, r            |                           |                       |                       |                       |                       | EX<br>R, r             |               |                           |                           |                   |               | <u>BW</u>                |           |
| C   |               |              |               | AND<br>R, r            |                           |                       |                       | ADD<br>r, #           | ADC<br>r, #           | SUB<br>r, #            | SBC<br>r, #   | AND<br>r, #               | XOR<br>r, #               | OR<br>r, #        | CP<br>r, #    |                          |           |
| D   |               |              |               | XOR<br>R, r            |                           |                       |                       | 0 1 2 3               | CP<br>r, #3           | 4 5 6 7                |               |                           |                           |                   |               | <u>BW</u>                |           |
| E   |               |              |               | OR<br>R, r             |                           |                       |                       | RLC<br>#, r           | RRC<br>#, r           | RL<br>#, r             | RR<br>#, r    | SLA<br>#, r               | SRA<br>#, r               | SLL<br>#, r       | SRL<br>#, r   |                          |           |
| F   |               |              |               | CP<br>R, r             |                           |                       |                       | RLC<br>A, r           | RRC<br>A, r           | RL<br>A, r             | RR<br>A, r    | SLA<br>A, r               | SRA<br>A, r               | SLL<br>A, r       | SRL<br>A, r   |                          |           |

- r** : Register specified by the 1st byte code. (Any CPU registers can be specified.)  
**R** : Register specified by the 2nd byte code. (Only eight current registers can be specified.)  
**B** : Operand size is a byte.  
**W** : Operand size is a word.  
**L** : Operand size is a long word.

Note : Dummy instructions are assigned to codes 1AH, 1BH, 3BH, and 3FH. Do not use them.

## Appendix C Instruction Code Maps (3/4)

1st byte: src (mem)

| H/L | 0   | 1    | 2   | 3                          | 4         | 5    | 6                        | 7                 | 8    | 9                         | A   | B   | C                        | D                  | E         | F |
|-----|-----|------|-----|----------------------------|-----------|------|--------------------------|-------------------|------|---------------------------|-----|-----|--------------------------|--------------------|-----------|---|
| 0   |     |      |     | PUSH<br><u>BW</u><br>(mem) |           | RLD  | RLD <u>B</u><br>A, (mem) |                   |      |                           |     |     |                          |                    |           |   |
| 1   | LDI | LDIR | LDD | LDDR<br><u>BW</u>          | CPI       | CPIR | CPD                      | CPDR<br><u>BW</u> |      | LD <u>BW</u><br>(nn), (m) |     |     |                          |                    |           |   |
| 2   |     |      | LD  | R, (mem)                   |           |      |                          |                   |      |                           |     |     |                          |                    |           |   |
| 3   |     |      | EX  | (mem), R                   | <u>BW</u> | ADD  | ADC                      | SUB               | SBC  | AND                       | XOR | OR  | CP <u>BW</u><br>(mem), # |                    |           |   |
| 4   |     |      | MUL | R, (mem)                   | <u>BW</u> |      |                          |                   | MULS | R, (mem)                  |     |     |                          | <u>BW</u>          |           |   |
| 5   |     |      | DIV | R, (mem)                   | <u>BW</u> |      |                          |                   | DIVS | R, (mem)                  |     |     |                          | <u>BW</u>          |           |   |
| 6   |     |      | INC | #3, (mem)                  | <u>BW</u> | 8    | 1                        | 2                 | 3    | 4                         | 5   | 6   | DEC                      | #3, (mem)          | <u>BW</u> | 7 |
| 7   |     |      |     |                            |           | RLC  | RRC                      | RL                | RR   | SLA                       | SRA | SLL | SRL                      | <u>BW</u><br>(mem) |           |   |
| 8   |     |      | ADD | R, (mem)                   |           |      |                          |                   | ADD  | (mem), R                  |     |     |                          |                    |           |   |
| 9   |     |      | ADC | R, (mem)                   |           |      |                          |                   | ADC  | (mem), R                  |     |     |                          |                    |           |   |
| A   |     |      | SUB | R, (mem)                   |           |      |                          |                   | SUB  | (mem), R                  |     |     |                          |                    |           |   |
| B   |     |      | SBC | R, (mem)                   |           |      |                          |                   | SBC  | (mem), R                  |     |     |                          |                    |           |   |
| C   |     |      | AND | R, (mem)                   |           |      |                          |                   | AND  | (mem), R                  |     |     |                          |                    |           |   |
| D   |     |      | XOR | R, (mem)                   |           |      |                          |                   | XOR  | (mem), R                  |     |     |                          |                    |           |   |
| E   |     |      | OR  | R, (mem)                   |           |      |                          |                   | OR   | (mem), R                  |     |     |                          |                    |           |   |
| F   |     |      | CP  | R, (mem)                   |           |      |                          |                   | CP   | (mem), R                  |     |     |                          |                    |           |   |

B : Operand size is a byte.W : Operand size is a word.

## Appendix C Instruction Code Maps (4/4)

1st byte: dst (mem)

| H/L | 0                     | 1  | 2                     | 3   | 4                     | 5    | 6                     | 7    | 8              | 9                       | A             | B      | C    | D  | E  | F        |
|-----|-----------------------|----|-----------------------|-----|-----------------------|------|-----------------------|------|----------------|-------------------------|---------------|--------|------|----|----|----------|
| 0   | LD <u>B</u><br>(m), # |    | LD <u>W</u><br>(m), # |     | POP <u>B</u><br>(mem) |      | POP <u>W</u><br>(mem) |      |                |                         |               |        |      |    |    |          |
| 1   |                       |    |                       |     | LD B<br>(m), (nn)     |      | LD W<br>(m), (nn)     |      |                |                         |               |        |      |    |    |          |
| 2   |                       |    | LDA R, mem            |     |                       |      | <u>W</u> ANDCF        | ORCF | XORCF          | LDCF                    | STCF <u>B</u> |        |      |    |    |          |
| 3   |                       |    | LDA R, mem            |     |                       |      | <u>L</u>              |      |                |                         |               |        |      |    |    |          |
| 4   |                       |    | LD (mem), R           |     |                       |      | <u>B</u>              |      |                |                         |               |        |      |    |    |          |
| 5   |                       |    | LD (mem), R           |     |                       |      | <u>W</u>              |      |                |                         |               |        |      |    |    |          |
| 6   |                       |    | LD (mem), R           |     |                       |      | <u>L</u>              |      |                |                         |               |        |      |    |    |          |
| 7   |                       |    |                       |     |                       |      |                       |      |                |                         |               |        |      |    |    |          |
| 8   |                       |    | ANDCF #3, (mem)       |     |                       |      | <u>B</u>              |      | ORCF #3, (mem) |                         |               |        |      |    |    | <u>B</u> |
| 9   | 0                     | 1  | 2                     | 3   | 4                     | 5    | 6                     | 7    | 0              | 1                       | 2             | 3      | 4    | 5  | 6  | 7        |
|     |                       |    | XORCF #3, (mem)       |     |                       |      | <u>B</u>              |      | LDGF #3, (mem) |                         |               |        |      |    |    | <u>B</u> |
| A   | 0                     | 1  | 2                     | 3   | 4                     | 5    | 6                     | 7    | 0              | 1                       | 2             | 3      | 4    | 5  | 6  | 7        |
|     |                       |    | STCF #3, (mem)        |     |                       |      | <u>B</u>              |      | TSET #3, (mem) |                         |               |        |      |    |    | <u>B</u> |
| B   | 0                     | 1  | 2                     | 3   | 4                     | 5    | 6                     | 7    | 0              | 1                       | 2             | 3      | 4    | 5  | 6  | 7        |
|     |                       |    | RES #3, (mem)         |     |                       |      | <u>B</u>              |      | SET #3, (mem)  |                         |               |        |      |    |    | <u>B</u> |
| C   | 0                     | 1  | 2                     | 3   | 4                     | 5    | 6                     | 7    | 0              | 1                       | 2             | 3      | 4    | 5  | 6  | 7        |
|     |                       |    | CHG #3, (mem)         |     |                       |      | <u>B</u>              |      | BIT #3, (mem)  |                         |               |        |      |    |    | <u>B</u> |
| D   | F                     | LT | LE                    | ULE | PE/OV                 | M/MI | Z                     |      | JP cc, mem     |                         |               |        |      |    |    |          |
|     |                       |    |                       |     |                       |      | C                     | (T)  | GE             | GT                      | UGT           | PO/NOV | P/PL | NZ | NC |          |
| E   | F                     | LT | LE                    | ULE | PE/OV                 | M/MI | Z                     |      | CALL cc, mem   |                         |               |        |      |    |    |          |
|     |                       |    |                       |     |                       |      | C                     | (T)  | GE             | GT                      | UGT           | PO/NOV | P/PL | NZ | NC |          |
| F   | F                     | LT | LE                    | ULE | PE/OV                 | M/MI | Z                     |      | RET cc         | (1st byte code is B0H.) |               |        |      |    |    |          |
|     |                       |    |                       |     |                       |      | C                     | (T)  | GE             | GT                      | UGT           | PO/NOV | P/PL | NZ | NC |          |

B : Operand size is a byte.W : Operand size is a word.L : Operand size is a long word.

## Appendix D Differences between TLCS-90 and TLCS-900 Series

| Item                                       | Series            | TLCS-90                                                                                                             | TLCS-900                                                                                                                                                                                                                     |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
|--------------------------------------------|-------------------|---------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|-----|---|-----|---|---|---|
| CPU architecture                           |                   | 8-bit CPU                                                                                                           | 16-bit CPU                                                                                                                                                                                                                   |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Built-in ROM/built-in RAM                  |                   | 8-bit data bus                                                                                                      | 16-bit data bus                                                                                                                                                                                                              |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Built-in I/O                               |                   | 8-bit data bus                                                                                                      | 8-bit data bus                                                                                                                                                                                                               |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| External data bus                          |                   | 8-bit data bus                                                                                                      | 8-bit/16-bit data bus<br>(can be mixed)                                                                                                                                                                                      |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Program space<br>(except devices with MMU) |                   | 64KB                                                                                                                | 16MB (linear)                                                                                                                                                                                                                |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Instruction set/instruction mnemonic       | TLCS-90           |                                                                                                                     | TLCS-90 + $\alpha$<br>$\alpha$ = enhancement of 16-bit multiply / divide instructions and bit operation instruction. 32-bit load/operation instructions, C compiler instructions, register bank operation instructions, etc. |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Instruction code<br>(object code)          | Unique to TLCS-90 |                                                                                                                     | Unique to TLCS-900<br>(Different from TLCS-90.)                                                                                                                                                                              |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Addressing mode                            | TLCS-90           |                                                                                                                     | TLCS-90 + $\alpha$<br>$\alpha$ = (- Reg), (Reg +), (Reg + disp16), (Reg + Reg16), (nnn)                                                                                                                                      |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| General-purpose register                   | TLCS-90           |                                                                                                                     | TLCS-90 + $\alpha$<br>$\alpha$ = Uses as 32 bits and register bank, and adds a system stack pointer.                                                                                                                         |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Flag (F)                                   |                   | <table border="1"><tr><td>S</td><td>Z</td><td>I</td><td>H</td><td>X</td><td>V</td><td>N</td><td>C</td></tr></table> | S                                                                                                                                                                                                                            | Z   | I | H | X | V | N | C | <table border="1"><tr><td>S</td><td>Z</td><td>"0"</td><td>H</td><td>"0"</td><td>V</td><td>N</td><td>C</td></tr></table><br>I flag is extended to IFF2 to 0 of status register.X flag is deleted. | S | Z | "0" | H | "0" | V | N | C |
| S                                          | Z                 | I                                                                                                                   | H                                                                                                                                                                                                                            | X   | V | N | C |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| S                                          | Z                 | "0"                                                                                                                 | H                                                                                                                                                                                                                            | "0" | V | N | C |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Reset                                      |                   | PC $\leftarrow$ 0000H<br>(SP does not change.)                                                                      | PC $\leftarrow$ 8000H<br>XSP $\leftarrow$ 100H                                                                                                                                                                               |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Built-in ROM address                       |                   | 0000H~                                                                                                              | 8000H~                                                                                                                                                                                                                       |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Built-in RAM address                       |                   | $\sim$ FFxxH                                                                                                        | 0080H~                                                                                                                                                                                                                       |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Built-in I/O address                       |                   | FFxxH~FFFFH                                                                                                         | 0000H~007FH                                                                                                                                                                                                                  |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Direct addressing area (n)                 |                   | FFF0H~FFFFH                                                                                                         | 0000H~00FFH                                                                                                                                                                                                                  |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Interrupt                                  |                   |                                                                                                                     |                                                                                                                                                                                                                              |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Interrupt start address                    |                   | 0000H + (8 $\times$ V)                                                                                              | Vector base address + 4 $\times$ V [900L_CPU]<br>8000H + (10H $\times$ V) [900_CPU]                                                                                                                                          |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Register to be saved                       |                   | PC & AF                                                                                                             | PC & SR                                                                                                                                                                                                                      |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Mask register                              |                   | IFF                                                                                                                 | IFF2~0                                                                                                                                                                                                                       |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |
| Mask level                                 |                   | 0~1                                                                                                                 | 0~7                                                                                                                                                                                                                          |     |   |   |   |   |   |   |                                                                                                                                                                                                  |   |   |     |   |     |   |   |   |

| Item \ Series                                                      | TLCS-90                                                                                                                                                                                                                                                                                                                                                                                     | TLCS-900                                              |
|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| Instruction<br>① ADD R, r (word type)<br><br>② Shift of A register | <p>S/Z/V flags don't change.</p> <p><input type="checkbox"/> S/Z/V flag changes expect add<br/>16 bit register.</p> <p>[ RLCA<br/>RRCA<br/>RLA<br/>RRA<br/>SLAA<br/>SRAA<br/>SLLA<br/>SRLA ]</p> <p>S/Z/V flags don't change in these instruction.</p> <p>[ RLC A<br/>RRC A<br/>RL A<br/>RR A<br/>SLA A<br/>SRA A<br/>SLL A<br/>SRL A ]</p> <p>S/Z/V flag changes in these instruction.</p> | <p>S/Z/V flag changes.</p> <p>S/Z/V flag changes.</p> |

Note : The TLCS-900 series is essentially the same as the TLCS-90 series but with a 16-bit CPU. Built-in I/Os are completely compatible with those of the TLCS-90.

However, six types of instructions used in the TLCS-90 series do not directly correspond with those used in the TLCS-900 series. Thus, when transferring programs designed for the TLCS-90 to the TLCS-900, replace them with equivalents as follows:

| Instructions in TLCS-90<br>but not in TLCS-900 | Equivalent instructions in<br>TLCS-900 |
|------------------------------------------------|----------------------------------------|
| EXX                                            | EX BC, BC'<br>EX DE, DE'<br>EX HL, HL' |
| EX AF, AF'                                     | EX A, A'<br>EX F, F'                   |
| PUSH AF                                        | PUSH A<br>PUSH F                       |
| POP AF                                         | POP F<br>POP A                         |
| INCX                                           | (32-bit INC instruction)               |
| DECX                                           | (32-bit DEC instruction)               |

Some TLCS-900 series instructions, though basically the same as TLCS-90 instructions, have more functions and more specification items in their operands. They are listed below.

| TLCS-90 | TLCS-900      |
|---------|---------------|
| INC reg | INC imm3, reg |
| INC mem | INC imm3, mem |
| DEC reg | DEC imm3, reg |
| DEC mem | DEC imm3, mem |
| RLC reg | RLC imm, reg  |
| RRC reg | RRC imm, reg  |
| RL reg  | RL imm, reg   |
| RR reg  | RR imm, reg   |
| SLA reg | SLA imm, reg  |
| SRA reg | SRA imm, reg  |
| SLL reg | SLL imm, reg  |
| SRL reg | SRL imm, reg  |

**TOSHIBA**

**CHAPTER 2 TLCS-900 LSI DEVICES**

**TOSHIBA CORPORATION**



## CMOS 16-bit MICROCONTROLLERS

## TMP96C141F

## 1. OUTLINE AND DEVICE CHARACTERISTICS

TMP96C141F is high-speed advanced 16-bit microcontrollers developed for controlling medium to large-scale equipment. The TMP96C141 does not have a ROM, the TMP96CM40F has a built-in ROM, and the TMP96PM40 has a built-in OTP.

TMP96C141F is housed in an 80-pin flat package.

Device characteristics are as follows:

- 
- (1) Original 16-bit CPU
    - TLCS-90 instruction mnemonic upward compatible.
    - 16M-byte linear address space
    - General-purpose registers and register bank system
    - 16-bit multiplication / division and bit transfer/arithmetic instructions
    - High-speed micro DMA : 4 channels (1.6  $\mu$ s/2 bytes @20MHz)
  - (2) Minimum instruction execution time : 200ns @20MHz
  - (3) Internal RAM : 1K byte  
Internal ROM : None
  - (4) External memory expansion
    - Can be expanded up to 16M bytes (for both programs and data).
    - Can mix 8- and 16-bit external data buses.
  - (5) 8-bit timers : 2 channels
  - (6) 8-bit PWM timers : 2 channels
  - (7) 16-bit timers : 2 channels
  - (8) Pattern generators : 4 bits, 2 channels
  - (9) Serial interface : 2 channels
  - (10) 10-bit A/D converter : 4 channels
  - (11) Watchdog timer
  - (12) Chip select/wait controller : 3 blocks
  - (13) Interrupt functions
    - 3 CPU interrupts ..... SWI instruction, privileged violation, and Illegal instruction
    - 14 internal interrupts
    - 6 external interrupts [ ] 7-level priority can be set.
  - (14) I/O ports
  - (15) Standby function : 3 halt modes (RUN, IDLE, STOP)



Figure1 TMP96C141 Block Diagram

## 2. PIN ASSIGNMENT AND FUNCTIONS

The assignment of input / output pins for TMP96C141, their name and outline functions are described below.

### 2.1 Pin Assignment

Figure 2.1 shows pin assignment of TMP96C141F.



Note : Because the TMP96C141 has an external ROM, P00 to P17 pins are fixed to AD0 to AD15; P30 to RD; and P31 to WR.

Figure 2.1 Pin Assignment (80-pin QFP)

## 2.2 Pin Names and Functions

The names of input/output pins and their functions are described below.

Table 2.2 Pin Names and Functions.

| Pin name                         | Number of pins | I/O                        | Functions                                                                                                                                                                                                                                                                               |
|----------------------------------|----------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P00~P07<br>AD0~AD7               | 8              | I/O<br>Tri-state           | Port 0: I/O port that allows I/O to be selected on a bit basis<br>Address/data (lower): 0 - 7 for address/data bus                                                                                                                                                                      |
| P10~P17<br>AD8~AD15<br>A8~A15    | 8              | I/O<br>Tri-state<br>Output | Port 1: I/O port that allows I/O to be selected on a bit basis<br>Address data (upper): 8 - 15 for address/data bus<br>Address: 8 to 15 for address bus                                                                                                                                 |
| P20~P27<br>A0~A7<br>A16~A23      | 8              | I/O<br>Output<br>Output    | Port 2: I/O port that allows selection of I/O on a bit basis<br>(with pull-down resistor)<br>Address: 0 - 7 for address bus<br>Address: 16 - 23 for address bus                                                                                                                         |
| P30<br><u>RD</u>                 | 1              | Output<br>Output           | Port 30: Output port<br>Read: Strobe signal for reading external memory                                                                                                                                                                                                                 |
| P31<br><u>WR</u>                 | 1              | Output<br>Output           | Port 31: Output port<br>Write: Strobe signal for writing data on pins AD0 - 7                                                                                                                                                                                                           |
| P32<br><u>HWR</u>                | 1              | I/O<br>Output              | Port 32: I/O port (with pull-up resistor)<br>High write: Strobe signal for writing data on pins AD8 - 15                                                                                                                                                                                |
| P33<br><u>WAIT</u>               | 1              | I/O<br>Input               | Port 33: I/O port (with pull-up resistor)<br>Wait: Pin used to request CPU bus wait                                                                                                                                                                                                     |
| P34<br><u>BUSRQ</u>              | 1              | I/O<br>Input               | Port 34: I/O port (with pull-up resistor)<br>Bus request: Signal used to request high impedance for AD0 - 15,<br>A0 - 23, <u>RD</u> , <u>WR</u> , <u>HWR</u> , <u>R/W</u> , <u>RAS</u> , <u>CS0</u> , <u>CS1</u> , and <u>CS2</u> pins.<br>(For external DMAC)                          |
| P35<br><u>BUSAK</u>              | 1              | I/O<br>Output              | Port 35: I/O port (with pull-up resistor)<br>Bus acknowledge: Signal indicating that AD0-15, A0-23, <u>RD</u> ,<br><u>WR</u> , <u>HWR</u> , <u>R/W</u> , <u>RAS</u> , <u>CS0</u> , <u>CS1</u> , and <u>CS2</u> pins are at high impedance<br>after receiving BUSRQ. (For external DMAC) |
| P36<br><u>R/W</u>                | 1              | I/O<br>Output              | Port 36: I/O port (with pull-up resistor)<br>Read/write: 1 represents read or dummy cycle; 0, write cycle.                                                                                                                                                                              |
| P37<br><u>RAS</u>                | 1              | I/O<br>Output              | Port 37: I/O port (with pull-up resistor)<br>Row address strobe: Outputs RAS strobe for DRAM.                                                                                                                                                                                           |
| P40<br><u>CS0</u><br><u>CAS0</u> | 1              | I/O<br>Output<br>Output    | Port 40: I/O port (with pull-up resistor)<br>Chip select 0: Outputs 0 when address is within specified address area.<br>Column address strobe 0: Outputs CAS strobe for DRAM when<br>address is within specified address area.                                                          |

Note : With the external DMA controller, this device's built-in memory or built-in I/O cannot be accessed using the BUSRQ and BUSAK pins.

| Pin name           | Number of pins | I/O                     | Functions                                                                                                                                                                                                                              |
|--------------------|----------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P41<br>CS1<br>CAS1 | 1              | I/O<br>Output<br>Output | Port 41: I/O port (with pull-up resistor)<br>Chip select 1: Outputs 0 if address is within specified address area.<br>Column address strobe 1: Outputs CAS strobe for DRAM if address is within specified address area.                |
| P42<br>CS2<br>CAS2 | 1              | I/O<br>Output<br>Output | Port 42: I/O port (with pull-down resistor)<br>Chip select 2: Outputs 0 if address is within specified address area.<br>Column address strobe 2: Outputs C <sub>A</sub> S strobe for DRAM if address is within specified address area. |
| P50~P53<br>AN0~AN3 | 4              | Input<br>Input          | Port 5: Input port<br>Analog input: Input to A/D converter                                                                                                                                                                             |
| VREF               | 1              | Input                   | Pin for reference voltage input to A/D converter                                                                                                                                                                                       |
| AGND               | 1              | Input                   | Ground pin for A/D converter                                                                                                                                                                                                           |
| P60~P63            | 4              | I/O                     | Ports 60 - 63: I/O ports that allow selection of I/O on a bit basis (with pull-up resistor)                                                                                                                                            |
| PG00~PG03          |                | Output                  | Pattern generator ports: 00 - 03                                                                                                                                                                                                       |
| P64~P67            | 4              | I/O                     | Ports 64 - 67: I/O ports that allow selection of I/O on a bit basis (with pull-up resistor)                                                                                                                                            |
| PG10~PG13          |                | Output                  | Pattern generator ports: 10 - 13                                                                                                                                                                                                       |
| P70<br>TI0         | 1              | I/O<br>Input            | Port 70: I/O port (with pull-up resistor)<br>Timer input 0: Timer 0 input                                                                                                                                                              |
| P71<br>TO1         | 1              | I/O<br>Output           | Port 71: I/O port (with pull-up resistor)<br>Timer output 1: Timer 0 or 1 output                                                                                                                                                       |
| P72<br>TO2         | 1              | I/O<br>Output           | Port 72: I/O port (with pull-up resistor)<br>PWM output 2: 8-bit PWM timer 2 output                                                                                                                                                    |
| P73<br>TO3         | 1              | I/O<br>Output           | Port 73: I/O port (with pull-up resistor)<br>PWM output 3: 8-bit PWM timer 3 output                                                                                                                                                    |
| P80<br>TI4<br>INT4 | 1              | I/O<br>Input<br>Input   | Port 80: I/O port (with pull-up resistor)<br>Timer input 4: Timer 4 count/capture trigger signal input<br>Interrupt request pin 4: Interrupt request pin with programmable rising/falling edge                                         |
| P81<br>TI5<br>INT5 | 1              | I/O<br>Input<br>Input   | Port 81: I/O port (with pull-up resistor)<br>Timer input 5: Timer 4 count/capture trigger signal input<br>Interrupt request pin 5: Interrupt request pin with rising edge                                                              |
| P82<br>TO4         | 1              | I/O<br>Output           | Port 82: I/O port (with pull-up resistor)<br>Timer output 4: Timer 4 output pin                                                                                                                                                        |
| P83<br>TO5         | 1              | I/O<br>Output           | Port 83: I/O port (with pull-up resistor)<br>Timer output 5: Timer 4 output pin                                                                                                                                                        |

| Pin name           | Number of pins | I/O                   | Functions                                                                                                                                                                                      |
|--------------------|----------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P84<br>TI6<br>INT6 | 1              | I/O<br>Input<br>Input | Port 84: I/O port (with pull-up resistor)<br>Timer input 6: Timer 5 count/capture trigger signal input<br>Interrupt request pin 6: Interrupt request pin with programmable rising/falling edge |
| P85<br>TI7<br>INT7 | 1              | I/O<br>Input<br>Input | Port 85: I/O port (with pull-up resistor)<br>Timer input 7: Timer 5 count/capture trigger signal input<br>Interrupt request pin 7: Interrupt request pin with rising edge                      |
| P86<br>TO6         | 1              | I/O<br>Output         | Port 86: I/O port (with pull-up resistor)<br>Timer output 6: Timer 5 output pin                                                                                                                |
| P87<br>INT0        | 1              | I/O<br>Input          | Port 87: I/O port (with pull-up resistor)<br>Interrupt request pin 0: Interrupt request pin with programmable level/rising edge                                                                |
| P90<br>TXD0        | 1              | I/O<br>Output         | Port 90: I/O port (with pull-up resistor)<br>Serial send data 0                                                                                                                                |
| P91<br>RXD0        | 1              | I/O<br>Input          | Port 91: I/O port (with pull-up resistor)<br>Serial receive data 0                                                                                                                             |
| P92<br>CTS0        | 1              | I/O<br>Input          | Port 92: I/O port (with pull-up resistor)<br>Serial data send enable 0 (Clear to Send)                                                                                                         |
| P93<br>TXD1        | 1              | I/O<br>Output         | Port 93: I/O port (with pull-up resistor)<br>Serial send data 1                                                                                                                                |
| P94<br>RXD1        | 1              | I/O<br>Input          | Port 94: I/O port (with pull-up resistor)<br>Serial receive data 1                                                                                                                             |
| P95<br>SCLK1       | 1              | I/O<br>I/O            | Port 95: I/O port (with pull-up resistor)<br>Serial clock I/O 1                                                                                                                                |
| WDTOUT             | 1              | Output                | Watchdog timer output pin                                                                                                                                                                      |
| NMI                | 1              | Input                 | Non-maskable interrupt request pin: Interrupt request pin with falling edge. Can also be operated at rising edge by program.                                                                   |
| CLK                | 1              | Output                | Clock output: Outputs $\lceil X1 \div 4 \rceil$ clock. Pulled-up during reset.                                                                                                                 |
| EA                 | 1              | Input                 | External access: 0 should be inputted with TMP96C141 1, with TMP96CM40/TMP96PM40.                                                                                                              |
| ALE                | 1              | Output                | Address latch enable                                                                                                                                                                           |
| RESET              | 1              | Input                 | Reset: Initializes LSI. (With pull-up resistor)                                                                                                                                                |
| X1/X2              | 2              | I/O                   | Oscillator connecting pin                                                                                                                                                                      |
| VCC                | 2              |                       | Power supply pin (+ 5V)                                                                                                                                                                        |
| VSS                | 3              |                       | GND pin (0V)                                                                                                                                                                                   |

Note : Pull-up/pull-down resistor can be released from the pin by software.

### 3. OPERATION

This section describes in blocks the functions and basic operations of TMP96C141 device.

Check the [7. Care Points and Restriction] because of the Care Points etc are described.

#### 3.1 CPU

TMP96C141 device has a built-in high-performance 16-bit CPU (900-CPU). (For CPU operation, see TLCS-900 CPU in the previous section.)

This section describes CPU functions unique to TMP96C141 that are not described in the previous section.

##### 3.1.1 Reset

To reset the TMP96C141, the RESET input must be kept at 0 for at least 10 system clocks (10 states:  $1\mu s$  with a 20 MHz system clock) within an operating voltage range and with a stable oscillation.

When reset is accepted, the CPU sets as follows:

- Program counter (PC) to 8000H.
- Stack pointer (XSP) for system mode to 100H.
- SYSM bit of status register (SR) to 1. (Sets to system mode.)
- IFF2 to 0 bits of status register to 111. (Sets mask register to interrupt level 7.)
- MAX bit of status register to 0. (Sets to minimum mode)
- Bits RFP2 to 0 of status register to 000. (Sets register banks to 0.)

When reset is released, instruction execution starts from address 8000H. CPU internal registers other than the above are not changed.

When reset is accepted, processing for built-in I/Os, ports, and other pins is as follows

- Initializes built-in I/O registers as per specifications.
- Sets port pins (including pins also used as built-in I/Os) to general-purpose input/output port mode (sets I/O ports to input ports).
- Sets the WDtout pin to 0. (Watchdog timer is set to enable after reset.)
- Pulls up the CLK pin to 1.
- Sets the ALE pin to 0.

### 3.2 Memory Map

Figure 3.2 is a memory map of the TMP96C141.



Note : The start address after reset is 8000H. Resetting sets the stack pointer (XSP) on the system mode side to 100H.

Figure3.2 Memory map

### 3.3 Interrupts

TLCS-900 interrupts are controlled by the CPU interrupt mask flip-flop (IFF2 to 0) and the built-in interrupt controller.

TMP96C141 has altogether the following 23 interrupt sources:

- Interrupts from the CPU…3  
(Software interrupts, privileged violations, and Illegal (undefined) instruction execution)
- Interrupts from external pins (NMI, INT0, and INT4 to 7)…6
- Interrupts from built-in I/Os…14

A fixed individual interrupt vector number is assigned to each interrupt source; six levels of priority (variable) can also be assigned to each maskable interrupt. Non-maskable interrupts have a fixed priority of 7.

When an interrupt is generated, the interrupt controller sends the value of the priority of the interrupt source to the CPU. When more than one interrupt is generated simultaneously, the interrupt controller sends the value of the highest priority (7 for non-maskable interrupts is the highest) to the CPU.

The CPU compares the value of the priority sent with the value in the CPU interrupt mask register (IFF2 to 0). If the value is greater than that the CPU interrupt mask register, the interrupt is accepted. The value in the CPU interrupt mask register (IFF2 to 0) can be changed using the EI instruction (contents of the EI num/IFF<2:0> = num). For example, programming EI 3 enables acceptance of maskable interrupts with a priority of 3 or greater, and non-maskable interrupts which are set in the interrupt controller. The DI instruction (IFF<2:0> = 7) operates in the same way as the EI 7 instruction. Since the priority values for maskable interrupts are 0 to 6, the DI instruction is used to disable maskable interrupts to be accepted. The EI instruction becomes effective immediately after execution. (With the TLCS-90, the EI instruction becomes effective after execution of the subsequent instruction.)

In addition to the general-purpose interrupt processing mode described above, there is also a high-speed micro DMA processing mode . High-speed micro DMA is a mode used by the CPU to automatically transfer byte or word data. It enables the CPU to process interrupts such as data saves to built-in I/Os at high speed.

Figure 3.3 (1) is a flowchart showing overall interrupt processing.





Figure3.3 (1) Interrupt Processing Flowchart

### 3.3.1 General-Purpose Interrupt Processing

When accepting an interrupt, the CPU operates as follows:

- (1) The CPU reads the interrupt vector from the interrupt controller. When more than one interrupt with the same level is generated simultaneously, the interrupt controller generates interrupt vectors in accordance with the default priority (which is fixed as follows: the smaller the vector value, the higher the priority), then clears the interrupt request.
- (2) The CPU pushes the program counter and the status register to the system stack area (area indicated by the system mode stack pointer).
- (3) The CPU sets a value in the CPU interrupt mask register <IFF2 to 0> that is higher by 1 than the value of the accepted interrupt level. However, if the value is 7, 7 is set without an increment.
- (4) The CPU sets the <SYSM> flag of the status register to 1 and enter the system mode.
- (5) The CPU jumps to address 8000H + interrupt vector, then starts the interrupt processing routine.

In minimum mode, all the above processing is completed in 15 states (1.5  $\mu$ s @20 MHz). In maximum mode, it is completed in 17 states.

| Bus Width of stack Area | Interrupt processing state number |          |
|-------------------------|-----------------------------------|----------|
|                         | MAX mode                          | MIN mode |
| 8 bit                   | 23                                | 19       |
| 16 bit                  | 17                                | 15       |

To return to the main routine after completion of the interrupt processing, the RETI instruction is usually used. Executing this instruction restores the contents of the program counter and the status registers.

Though acceptance of non-maskable interrupts cannot be disabled by program, acceptance of maskable interrupts can. A priority can be set for each source of maskable interrupts. The CPU accepts an interrupt request with a priority higher than the value in the CPU mask register <IFF2 to 0>. The CPU mask register <IFF2 to 0> is set to a value higher by 1 than the priority of the accepted interrupt. Thus, if an interrupt with a level higher than the interrupt being processed is generated, the CPU accepts the interrupt with the higher level, causing interrupt processing to nest. The interrupt request with a priority higher than the accepted now interrupt during the CPU is processing above (1)~(5) is accepted before the 1'st instruction in the interrupt processing routine, causing interrupt processing to nest. (This is the same case of overlapped each Non-Maskable interrupt (level "7").) The CPU does not accept an interrupt

request of the same level as that of the interrupt being processed. The CPU does not accept an interrupt request of the same level as that of the interrupt being processed.

Resetting initializes the CPU mask registers <IFF2 to 0> to 7; therefore, maskable interrupts are disabled.

The addresses 008000H to 0081FFH (512 bytes) of the TLCS-900 are assigned for interrupt processing entry area.

Table3.3 (1) TMP96C141 Interrupt Table

| Default priority | Type         | Interrupt source                        | Vector value "v" | Start address | High-speed micro DMA start vector |
|------------------|--------------|-----------------------------------------|------------------|---------------|-----------------------------------|
| 1                | Non-maskable | Reset , or SWI0 instruction             | 0 0 0 0 H        | 8 0 0 0 H     | -                                 |
| 2                |              | INTPREV : Privileged violation, or SWI1 | 0 0 1 0 H        | 8 0 1 0 H     | -                                 |
| 3                |              | INTUNDEF: Illegal instruction, or SWI2  | 0 0 2 0 H        | 8 0 2 0 H     | -                                 |
| 4                |              | SWI 3 instruction                       | 0 0 3 0 H        | 8 0 3 0 H     | -                                 |
| 5                |              | SWI 4 instruction                       | 0 0 4 0 H        | 8 0 4 0 H     | -                                 |
| 6                |              | SWI 5 instruction                       | 0 0 5 0 H        | 8 0 5 0 H     | -                                 |
| 7                |              | SWI 6 instruction                       | 0 0 6 0 H        | 8 0 6 0 H     | -                                 |
| 8                |              | SWI 7 instruction                       | 0 0 7 0 H        | 8 0 7 0 H     | -                                 |
| 9                |              | NMI Pin                                 | 0 0 8 0 H        | 8 0 8 0 H     | 08H                               |
| 10               |              | INTWD : Watchdog timer                  | 0 0 9 0 H        | 8 0 9 0 H     | 09H                               |
| 11               | Maskable     | INT0 pin                                | 0 0 A 0 H        | 8 0 A 0 H     | 0AH                               |
| 12               |              | INT4 pin                                | 0 0 B 0 H        | 8 0 B 0 H     | 0BH                               |
| 13               |              | INT5 pin                                | 0 0 C 0 H        | 8 0 C 0 H     | 0CH                               |
| 14               |              | INT6 pin                                | 0 0 D 0 H        | 8 0 D 0 H     | 0DH                               |
| 15               |              | INT7 pin                                | 0 0 E 0 H        | 8 0 E 0 H     | 0EH                               |
| -                |              | (Reserved)                              | 0 0 F 0 H        | 8 0 F 0 H     | 0FH                               |
| 16               |              | INTT0 : 8-bit timer0                    | 0 1 0 0 H        | 8 1 0 0 H     | 10H                               |
| 17               |              | INTT1 : 8-bit timer1                    | 0 1 1 0 H        | 8 1 1 0 H     | 11H                               |
| 18               |              | INTT2 : 8-bit timer2/PWM0               | 0 1 2 0 H        | 8 1 2 0 H     | 12H                               |
| 19               |              | INTT3 : 8-bit timer3/PWM1               | 0 1 3 0 H        | 8 1 3 0 H     | 13H                               |
| 20               |              | INTTR4 : 16-bit timer4 (TREG4)          | 0 1 4 0 H        | 8 1 4 0 H     | 14H                               |
| 21               |              | INTTR5 : 16-bit timer4 (TREG5)          | 0 1 5 0 H        | 8 1 5 0 H     | 15H                               |
| 22               |              | INTTR6 : 16-bit timer5 (TREG6)          | 0 1 6 0 H        | 8 1 6 0 H     | 16H                               |
| 23               |              | INTTR7 : 16-bit timer5 (TREG7)          | 0 1 7 0 H        | 8 1 7 0 H     | 17H                               |
| 24               |              | INTRX0 : Serial receive (Channel.0)     | 0 1 8 0 H        | 8 1 8 0 H     | 18H                               |
| 25               |              | INTTX0 : Serial send (Channel.0)        | 0 1 9 0 H        | 8 1 9 0 H     | 19H                               |
| 26               |              | INTRX1 : Serial receive (Channel.1)     | 0 1 A 0 H        | 8 1 A 0 H     | 1AH                               |
| 27               |              | INTTX1 : Serial send (Channel.1)        | 0 1 B 0 H        | 8 1 B 0 H     | 1BH                               |
| 28               |              | INTAD : A/D conversion completion       | 0 1 C 0 H        | 8 1 C 0 H     | 1CH                               |
| -                |              | (Reserved)                              | 0 1 D 0 H        | 8 1 D 0 H     | 1DH                               |
| -                |              | (Reserved)                              | 0 1 E 0 H        | 8 1 E 0 H     | 1EH                               |
| -                |              | (Reserved)                              | 0 1 F 0 H        | 8 1 F 0 H     | 1FH                               |

### 3.3.2 High-speed Micro DMA

In addition to the conventional interrupt processing, the TLCS-900 also has a high-speed micro DMA function. When an interrupt is accepted, in addition to an interrupt vector, the CPU receives data indicating whether processing is high-speed micro DMA mode or general-purpose interrupt. If high-speed micro DMA mode is requested, the CPU performs high-speed micro DMA processing.

The TLCS-900 can process at very high speed compared with the TLCS-90 micro DMA because it has transfer parameters in dedicated registers in the CPU. Since those dedicated registers are assigned as CPU control registers, they can only be accessed by the LDC (privileged) instruction.

#### (1) High-speed micro DMA operation

High-speed micro DMA operation starts when the accepted interrupt vector value matches the high-speed micro DMA start vector value set in the interrupt controller. The high-speed micro DMA has four channels so that it can be set for up to four types of interrupt source.

When a high-speed micro DMA interrupt is accepted, data is automatically transferred from the transfer source address to the transfer destination address set in the control register, and the transfer counter is decremented. If the value in the counter after decrementing is other than 0, high-speed micro DMA processing is completed; if the value in the counter after decrementing is 0, general-purpose interrupt processing is performed. In read-only mode, which is provided for DRAM refresh, the value in the counter is ignored and dummy read is repeated.

32-bit control registers are used for setting transfer source/destination addresses. However, the TLCS-900 has only 24 address for output. A 16M-byte space is available for the high-speed micro DMA.

There are two data transfer modes: one-byte mode and one-word mode. Incrementing, decrementing, and fixing the transfer source/destination address after transfer can be done in both modes. Therefore data can easily be transferred between I/O and memory and between I/Os. For details of transfer modes, see the description of transfer mode registers.

The transfer counter has 16 bits, so up to 65536 transfers (the maximum when the initial value of the transfer counter is 0000H) can be performed for one interrupt source by high-speed micro DMA processing.

After the data transferred by the  $\mu$ DMA function, the transfer counter was decreased.

When this counter is “0”H, the processor operates general interrupt processing. At this time, if the same channel of interrupt is required next interrupt, the transfer counter starts from 65536.

Interrupt sources processed by high-speed micro DMA processing are those with the high-speed micro DMA start vectors listed in Table 3.3 (1).



(Note1) This is added 2 states the case of the bus width of source address area is 8bit

(Note2) This is added 2 states the case of the bus width of destination address area is 8bit

(Note3) This may be a dummy cycle with instruction queue buffer.

(Note4) This is added 2 states the case of the bus width of stack address area is 8bit

The following timing chart is a high-speed  $\mu$ DMA cycle of the Transfer Address INC  
rement mode (the other mode except the Read -only mode is same as this)

(Condition : MIN mode, 16bit Bus width for 16M Byte, 0 wait)

## (2) Register configuration (CPU control register)



These Control Register can not be set only "LCD cr, r" instruction.

## (3) Transfer mode register details

(DMAM0~3)

| 0 0 0 0                      | Mode                                                                                                                                                                                                                       | Note : When specifying values for this register, set the upper 4 bits to 0. |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
|                              | Z                                                                                                                                                                                                                          | Z: 0 = byte transfer, 1 = word transfer                                     |
| execution time (Min.) @20MHz |                                                                                                                                                                                                                            |                                                                             |
| 0 0 0 Z                      | Transfer destination address INC mode ..... for I/O to memory<br>$(\text{DMA}D_n +) \leftarrow (\text{DMA}S_n)$<br>$\text{DMA}C_n \leftarrow \text{DMA}C_n - 1$<br>if $\text{DMA}C_n = 0$ then INT.                        |                                                                             |
| 0 0 1 Z                      | Transfer destination address DEC mode ..... for I/O to memory<br>$(\text{DMA}D_n -) \leftarrow (\text{DMA}S_n)$<br>$\text{DMA}C_n \leftarrow \text{DMA}C_n - 1$<br>if $\text{DMA}C_n = 0$ then INT.                        |                                                                             |
| 0 1 0 Z                      | Transfer source address INC mode ..... for I/O to memory<br>$(\text{DMA}D_n) \leftarrow (\text{DMA}S_n +)$<br>$\text{DMA}C_n \leftarrow \text{DMA}C_n - 1$<br>if $\text{DMA}C_n = 0$ then INT.                             |                                                                             |
| 0 1 1 Z                      | Transfer source address DEC mode ..... for I/O to memory<br>$(\text{DMA}D_n) \leftarrow (\text{DMA}S_n -)$<br>$\text{DMA}C_n \leftarrow \text{DMA}C_n - 1$<br>if $\text{DMA}C_n = 0$ then INT.                             |                                                                             |
| 1 0 0 Z                      | Fixed address mode ..... I/O to I/O<br>$(\text{DMA}D_n) \leftarrow (\text{DMA}S_n)$<br>$\text{DMA}C_n \leftarrow \text{DMA}C_n - 1$<br>if $\text{DMA}C_n = 0$ then INT.                                                    |                                                                             |
| 1 0 1 0                      | Read-only mode ..... for DRAM refresh<br>Dummy $\leftarrow (\text{DMA}S_n)$ ; Reads 4 bytes.<br>$\text{DMA}S_n \leftarrow \text{DMA}S_n + 4$ ; Increments lower word only.<br>$\text{DMA}C_n \leftarrow \text{DMA}C_n - 1$ |                                                                             |
| 1 0 1 1                      | Counter mode ..... for interrupt counter<br>$\text{DMA}S_n \leftarrow \text{DMA}S_n + 1$<br>$\text{DMA}C_n \leftarrow \text{DMA}C_n - 1$<br>if $\text{DMA}C_n = 0$ then INT.                                               |                                                                             |

(1 state = 100ns)

This condition is 16-bit bus width and 0 wait of source / destination address space.

Note : n : corresponds to high-speed  $\mu$ DMA channels 0-3.  
 $\text{DMA}D_n / \text{DMA}S_n +$  : Post-increment (Increments register value after transfer.)  
 $\text{DMA}D_n / \text{DMA}S_n -$  : Post-decrement (Decrement register value after transfer.)

All address space (the space for system mode) can be accessed by high-speed  $\mu$ DMA.  
 Do not use undefined codes for transfer mode control.

<Usage of read only mode (DRAM refresh)>

When the hardware configuration is as follows:

DRAM mapping size: = 1MB

DRAM data bus size: = 8 bits

DRAM mapping address range: = 100000H to 1FFFFFH

Set the following registers first; refresh is performed automatically.

① Register initial value setting

LD XIX, 100000H

LDC DMAS0, XIX … mapping start address

LD A, 00001010B

LDC DMAM0, A … read only mode (for DRAM refresh)

② Timer setting

Set the timers so that interrupts are generated at intervals of  $62.5\mu s$  or less.

③ Interrupt controller setting

Set the timer interrupt mask higher than the other interrupts mask. Write the above timer interrupt vector value in the High-Speed  $\mu$ DMA start vector register, DMA0V.

(Operation description)

The DRAM data bus is an 8-bit bus and the high-speed micro DMA is in read-only mode (4 bytes), so refresh is performed for four times per interrupt.

When a 512 refresh/8ms DRAM is connected, DRAM refresh is performed sufficiently if the high-speed micro DMA is started every  $15.625\mu s \times 4 = 62.4\mu s$  or less, since the timing is  $15.625\mu s$ /refresh.

(Overhead)

Each processing time by the high-speed micro DMA is  $1.8\mu s$  (18 states) @20 MHz with an 8-bit data bus.

In the above example, the micro DMA is started every  $62.5\mu s$ ,  $1.8\mu s / 62.5\mu s = 0.029$ ; thus, the overhead is 2.9%.

(Note)

When the Bus is released (BUSAK = "0") which must wait to accept the interrupt, DRAM refresh is not performed because of the high-speed  $\mu$ DMA is generated by an interrupt.

### 3.3.3 Interrupt Controller

Figure 3.3.3 (1) is a block diagram of the interrupt circuits. The left half of the diagram shows the interrupt controller; the right half includes the CPU interrupt request signal circuit and the HALT release signal circuit.

Each interrupt channel (total of 20 channels) in the interrupt controller has an interrupt request flip-flop, interrupt priority setting register, and a register for storing the high-speed micro DMA start vector. The interrupt request flip-flop is used to latch interrupt requests from peripheral devices. The flip-flop is cleared to 0 at reset, when the CPU reads the interrupt channel vector after the acceptance of interrupt, or when the CPU executes an instruction that clears the interrupt of that channel (writes 0 in the clear bit of the interrupt priority setting register).

For example, to clear the INT0 interrupt request, set the register after the DI instruction as follows.

INTE0AD  $\leftarrow$  ---- 0 --- Zero-clears the INT0 Flip Flop.

The status of the interrupt request flip-flop is detected by reading the clear bit. Detects whether there is an interrupt request for an interrupt channel.

The interrupt priority can be set by writing the priority in the interrupt priority setting register (eg, INTE0AD, INTE45, etc.) provided for each interrupt source. Interrupt levels to be set are from 1 to 6. Writing 0 or 7 as the interrupt priority disables the corresponding interrupt request. The priority of the non-maskable interrupt (NMI pin, watchdog timer, etc.) is fixed to 7. If interrupt requests with the same interrupt level are generated simultaneously, interrupts are accepted in accordance with the default priority (the smaller the vector value, the higher the priority).

The interrupt controller sends the interrupt request with the highest priority among the simultaneous interrupts and its vector address to the CPU. The CPU compares the priority value <IFF2 to 0> set in the Status Register by the interrupt request signal with the priority value sent; if the latter is higher, the interrupt is accepted. Then the CPU sets a value higher than the priority value by 1 in the CPU SR<IFF2 to 0>. Interrupt requests where the priority value equals or is higher than the set value are accepted simultaneously during the previous interrupt routine. When interrupt processing is completed (after execution of the RETI instruction), the CPU restores the priority value saved in the stack before the interrupt was generated to the CPU SR<IFF2 to 0>.

The interrupt controller also has four registers used to store the high-speed micro DMA start vector. These are I/O registers; unlike other high-speed micro DMA registers (DMAS, DMAD, DMAM, and DMAC), they can be accessed in either normal or system mode. Writing the start vector of the interrupt source for the high-speed micro DMA processing (see Table 3.3.(1)), enables the corresponding interrupt to be processed by high-speed micro DMA processing. The values must be set in the high-speed micro DMA parameter registers (eg, DMAS and DMAD) prior to the high-speed micro DMA processing.



Figure 3.3.3 (1) Block Diagram of Interrupt Controller

## (1) Interrupt priority setting register

(Read-modify-write prohibited.)

| Symbol   | Address | 7                   | 6      | 5      | 4      | 3     | 2                   | 1      | 0      |
|----------|---------|---------------------|--------|--------|--------|-------|---------------------|--------|--------|
| INTE0AD  | 0070H   | INTAD               |        |        |        |       | INT0                |        |        |
|          |         | IADC                | IADM2  | IADM1  | IADM0  | I0C   | I0M2                | I0M1   | I0M0   |
|          |         | R/W                 | W      |        |        | R/W   | W                   |        |        |
|          |         | 0                   | 0      | 0      | 0      | 0     | 0                   | 0      | 0      |
| INTE45   | 0071H   | INT5                |        |        |        |       | INT4                |        |        |
|          |         | ISC                 | I5M2   | I5M1   | I5M0   | I4C   | I4M2                | I4M1   | I4M0   |
|          |         | R/W                 | W      |        |        | R/W   | W                   |        |        |
|          |         | 0                   | 0      | 0      | 0      | 0     | 0                   | 0      | 0      |
| INTE67   | 0072H   | INT7                |        |        |        |       | INT6                |        |        |
|          |         | I7C                 | I7M2   | I7M1   | I7M0   | I6C   | I6M2                | I6M1   | I6M0   |
|          |         | R/W                 | W      |        |        | R/W   | W                   |        |        |
|          |         | 0                   | 0      | 0      | 0      | 0     | 0                   | 0      | 0      |
| INTE10   | 0073H   | INTT1 (Timer1)      |        |        |        |       | INTT0 (Timer0)      |        |        |
|          |         | IT1C                | IT1M2  | IT1M1  | IT1M0  | IT0C  | IT0M2               | IT0M1  | IT0M0  |
|          |         | R/W                 | W      |        |        | R/W   | W                   |        |        |
|          |         | 0                   | 0      | 0      | 0      | 0     | 0                   | 0      | 0      |
| INTEPW10 | 0074H   | INTT3 (Timer3/PWM1) |        |        |        |       | INTT2 (Timer2/PWM0) |        |        |
|          |         | IPW1C               | IPW1M2 | IPW1M1 | IPW1M0 | IPW0C | IPW0M2              | IPW0M1 | IPW0M0 |
|          |         | R/W                 | W      |        |        | R/W   | W                   |        |        |
|          |         | 0                   | 0      | 0      | 0      | 0     | 0                   | 0      | 0      |
| INTEET54 | 0075H   | INTTR5 (TREG5)      |        |        |        |       | INTTR4 (TREG4)      |        |        |
|          |         | IT5C                | IT5M2  | IT5M1  | IT5M0  | IT4C  | IT4M2               | IT4M1  | IT4M0  |
|          |         | R/W                 | W      |        |        | R/W   | W                   |        |        |
|          |         | 0                   | 0      | 0      | 0      | 0     | 0                   | 0      | 0      |
| INTEET76 | 0076H   | INTTR7 (TREG7)      |        |        |        |       | INTTR6 (TREG6)      |        |        |
|          |         | IT7C                | IT7M2  | IT7M1  | IT7M0  | IT6C  | IT6M2               | IT6M1  | IT6M0  |
|          |         | R/W                 | W      |        |        | R/W   | W                   |        |        |
|          |         | 0                   | 0      | 0      | 0      | 0     | 0                   | 0      | 0      |
| INTE50   | 0077H   | INTTX0              |        |        |        |       | INTRX0              |        |        |
|          |         | ITX0C               | ITX0M2 | ITX0M1 | ITX0M0 | IRX0C | IRX0M2              | IRX0M1 | IRX0M0 |
|          |         | R/W                 | W      |        |        | R/W   | W                   |        |        |
|          |         | 0                   | 0      | 0      | 0      | 0     | 0                   | 0      | 0      |
| INTES1   | 0078H   | INTTX1              |        |        |        |       | INTRX1              |        |        |
|          |         | ITX1C               | ITX1M2 | ITX1M1 | ITX1M0 | IRX1C | IRX1M2              | IRX1M1 | IRX1M0 |
|          |         | R/W                 | W      |        |        | R/W   | W                   |        |        |
|          |         | 0                   | 0      | 0      | 0      | 0     | 0                   | 0      | 0      |

←Interrupt source  
←bit Symbol  
←Read/Write  
←After reset

| IxxM2 | -IxxM1 | IxxM0 | Function (Write)                     |
|-------|--------|-------|--------------------------------------|
| 0     | 0      | 0     | Prohibits interrupt request.         |
| 0     | 0      | 1     | Sets interrupt request level to "1". |
| 0     | 1      | 0     | Sets interrupt request level to "2". |
| 0     | 1      | 1     | Sets interrupt request level to "3". |
| 1     | 0      | 0     | Sets interrupt request level to "4". |
| 1     | 0      | 1     | Sets interrupt request level to "5". |
| 1     | 1      | 0     | Sets interrupt request level to "6". |
| 1     | 1      | 1     | Prohibits interrupt request.         |

  

| IxxC | Function (Read)                 | Function (Write)               |
|------|---------------------------------|--------------------------------|
| 0    | Indicates no interrupt request. | Clears interrupt request flag. |
| 1    | Indicates interrupt request.    | ----- Don't care -----         |

## (2) External interrupt control

| Interrupt Input Mode Control Register |   |   |   |   |   |                                                                 |                                        |
|---------------------------------------|---|---|---|---|---|-----------------------------------------------------------------|----------------------------------------|
| IIMC<br>(007BH)                       | 7 | 6 | 5 | 4 | 3 | 2                                                               | 1 0                                    |
| bit Symbol                            |   |   |   |   |   | IOIE                                                            | IOLE NMIREE                            |
| Read/Write                            |   |   |   |   |   | W                                                               | W W                                    |
| After reset                           |   |   |   |   |   | 0                                                               | 0 0                                    |
| Function                              |   |   |   |   |   | 1: INT0 input enable<br>0: INT0 edge mode<br>1: INT0 level mode | 1: Can be operated in NMI rising edge. |

Read-modify-write is prohibited.

INT0 input enable (Note)

|   |                                  |
|---|----------------------------------|
| 0 | INT0 disable (P87 function only) |
| 1 | Input enable                     |

NMI rising edge enable

|   |                                                     |
|---|-----------------------------------------------------|
| 0 | Interrupt request generation at falling edge        |
| 1 | Interrupt request generation at falling/rising edge |

Note . The INT0 pin can also be used for standby release as described later. Even if the pin is not used for standby release, setting this register to "0" maintains the port function during standby mode.

INT0 level enable

|   |                              |
|---|------------------------------|
| 0 | Rising edge detect interrupt |
| 1 | High level interrupt         |

## Setting of External Interrupt Pin Functions

| Interrupt | Pin name | Mode                     | Setting method                       |
|-----------|----------|--------------------------|--------------------------------------|
| NMI       | —        | Falling edge             | IIMC<NMIREE> = 0                     |
|           |          | falling and Rising edges | IIMC<NMIREE> = 1                     |
| INT0      | P87      | Rising edge              | IIMC<IOLE> = 0, <IOIE> = 1           |
|           |          | Level                    | IIMC<IOLE> = 1, <IOIE> = 1           |
| INT4      | P80      | Rising edge              | T4MOC<CAP12M1,0> = 0,0 or 0,1 or 1,1 |
|           |          | Falling edge             | T4MOD<CAP12M1,0> = 1, 0              |
| INT5      | P81      | Rising edge              | —                                    |
| INT6      | P84      | Rising edge              | T5MOC<CAP34M1,0> = 0,0 or 0,1 or 1,1 |
|           |          | Falling edge             | T5MOD<CAP34M1,0> = 1, 0              |
| INT7      | P85      | Rising edge              | —                                    |

### (3) High-speed micro DMA start vector

When the CPU reads the interrupt vector after accepting an interrupt, it simultaneously compares the interrupt vector with each channel's high-speed micro DMA start vector (bits 4 to 8 of the interrupt vector). When both match, the interrupt is processed in high-speed micro DMA mode for the channel whose value matched.

If the interrupt vector matches more than one channel, the channel with the lower channel number has a higher priority.

| Micro DMA0 Start Vector (read-modify-write is not possible.) |   |   |   |        |        |        |        |        |  |
|--------------------------------------------------------------|---|---|---|--------|--------|--------|--------|--------|--|
| DMA0V<br>(007CH)                                             | 7 | 6 | 5 | 4      | 3      | 2      | 1      | 0      |  |
| bit Symbol                                                   |   |   |   | DMA0V8 | DMA0V7 | DMA0V6 | DMA0V5 | DMA0V4 |  |
| Read/Write                                                   |   |   |   |        |        |        | W      |        |  |
| After reset                                                  |   |   |   | 0      | 0      | 0      | 0      | 0      |  |
| Micro DMA1 Start Vector (read-modify-write is not possible.) |   |   |   |        |        |        |        |        |  |
| DMA1V<br>(007DH)                                             | 7 | 6 | 5 | 4      | 3      | 2      | 1      | 0      |  |
| bit Symbol                                                   |   |   |   | DMA1V8 | DMA1V7 | DMA1V6 | DMA1V5 | DMA1V4 |  |
| Read/Write                                                   |   |   |   |        |        |        | W      |        |  |
| After reset                                                  |   |   |   | 0      | 0      | 0      | 0      | 0      |  |
| Micro DMA2 Start Vector (read-modify-write is not possible.) |   |   |   |        |        |        |        |        |  |
| DMA2V<br>(007EH)                                             | 7 | 6 | 5 | 4      | 3      | 2      | 1      | 0      |  |
| bit Symbol                                                   |   |   |   | DMA2V8 | DMA2V7 | DMA2V6 | DMA2V5 | DMA2V4 |  |
| Read/Write                                                   |   |   |   |        |        |        | W      |        |  |
| After reset                                                  |   |   |   | 0      | 0      | 0      | 0      | 0      |  |
| Micro DMA3 Start Vector (read-modify-write is not possible.) |   |   |   |        |        |        |        |        |  |
| DMA3V<br>(007FH)                                             | 7 | 6 | 5 | 4      | 3      | 2      | 1      | 0      |  |
| bit Symbol                                                   |   |   |   | DMA3V8 | DMA3V7 | DMA3V6 | DMA3V5 | DMA3V4 |  |
| Read/Write                                                   |   |   |   |        |        |        | W      |        |  |
| After reset                                                  |   |   |   | 0      | 0      | 0      | 0      | 0      |  |

### (4) Notes

The instruction execution unit and the bus interface unit of this CPU operate independently of each other. Therefore, if the instruction used to clear an interrupt request flag of an interrupt is fetched before the interrupt is generated, it is possible that the CPU might execute the fetched instruction to clear the interrupt request flag while reading the interrupt vector after accepting the interrupt. If so, the CPU would read the default vector 00A0H and start the interrupt processing from the address 80A0H.

To avoid this, make sure that the instruction used to clear the interrupt request flag comes after the DI instruction.

### 3.4 Standby Function

When the HALT instruction is executed, the TMP96C141 enters RUN, IDLE, or STOP mode depending on the contents of the HALT mode setting register.

- (1) RUN : Only the CPU halts; power consumption remains unchanged.
- (2) IDLE : Only the built-in oscillator operates, while all other built-in circuits halt. Power consumption is reduced to 1/10 or less than that during normal operation.
- (3) STOP : All internal circuits including the built-in oscillator halt. This greatly reduces power consumption.

The states of the port pins in STOP mode can be set as listed in Table 3.4 (1) using the I/O register WDMOD<DRVE> bit.

|                  | 7                 | 6                                                                                                            | 5                                                                        | 4                                                                                    | 3                                                                         | 2                                         | 1     | 0    |
|------------------|-------------------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------|-------------------------------------------|-------|------|
| WDMOD<br>(005CH) | WDTE              | WDTP1                                                                                                        | WDTP0                                                                    | WARM                                                                                 | HALTM1                                                                    | HALTM0                                    | RESCR | DRVE |
| Read/Write       | R / W             |                                                                                                              |                                                                          |                                                                                      |                                                                           |                                           |       |      |
| After reset      | 1                 | 0                                                                                                            | 0                                                                        | 0                                                                                    | 0                                                                         | 0                                         | 0     | 0    |
| Function         | 1 : WDT<br>Enable | 00 : 2 <sup>16</sup> /fc<br>01 : 2 <sup>18</sup> /fc<br>10 : 2 <sup>20</sup> /fc<br>11 : 2 <sup>22</sup> /fc | Warming<br>up time<br>0 : 2 <sup>14</sup> /fc<br>1 : 2 <sup>16</sup> /fc | Standby mode<br>00 : RUN mode<br>01 : STOP mode<br>10 : IDLE mode<br>11 : Don't care | 1 : Connects<br>watchdog<br>timer<br>output to<br>RESET pin<br>internally | 1 : Drive<br>pin even<br>in STOP<br>mode. |       |      |

When STOP mode is released by other than a reset, the system clock output starts after allowing some time for warming up set by the warming-up counter for stabilizing the built-in oscillator. To release STOP mode by a reset, it is necessary to allow a reset time long enough to allow the oscillator to stabilize.

To release standby mode, a reset or an interrupt is used. To release IDLE or STOP mode, only an interrupt by the NMI or INT0 pin, or a reset can be used. The details are described below.

Standby Release by Interrupt

| interrupt level<br>Standby mode | Interrupt mask (IFF2 to 0)<br>≤ interrupt request level                                                               | Interrupt mask (IFF2 to 0)<br>> interrupt request level                                           |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| RUN                             | Can be released by any interrupt.<br>After standby mode is released,<br>interrupt processing starts. (Note)           | Can only be released by INT0 pin.<br>Processing resumes from address<br>next to HALT instruction. |
| IDLE                            | Can only be released by NMI or<br>INT0 pin. After standby mode is<br>released, interrupt processing<br>starts. (Note) | ↑                                                                                                 |
| STOP                            | ↑ (Note)                                                                                                              | ↑                                                                                                 |

Table 3.4 (1) Pin states in STOP mode

| Pin name                                     | I/O                                        | 96C141     |               | 96CM40 / 96PM40 |               |
|----------------------------------------------|--------------------------------------------|------------|---------------|-----------------|---------------|
|                                              |                                            | DRVE = 0   | DRVE = 1      | DRVE = 0        | DRVE = 1      |
| P0                                           | Input mode / AD0~7<br>Output mode          | -<br>x     | -<br>x        | -<br>-          | -<br>Output   |
| P1                                           | Input mode / AD8~15<br>Output mode / A8~15 | -<br>x     | -<br>x        | -<br>-          | -<br>Output   |
| P2                                           | Input mode<br>Output mode / A0~7, A16~23   | PD*<br>PD* | PD*<br>Output | PD*<br>PD*      | PD*<br>Output |
| P30 (RD), P31 (WR)                           | Output                                     | -          | "1" Output    | -               | Output        |
| P32~P37                                      | Input mode<br>Output mode                  | PU<br>PU   | PU<br>Output  | ←               |               |
| P40, P41                                     | Input mode<br>Output mode                  | PU*<br>PU* | PU<br>Output  | ←               |               |
| P42 ( $\overline{CS2}$ / $\overline{CAS2}$ ) | Input mode<br>Output mode                  | PD*<br>PD* | PD<br>Output  | ←               |               |
| P5                                           | Input                                      | -          | -             | ←               |               |
| P6                                           | Input mode<br>Output mode                  | PU*<br>PU* | PU<br>Output  | ←               |               |
| P7                                           | Input mode<br>Output mode                  | PU*<br>PU* | PU<br>Output  | ←               |               |
| P80~P86                                      | Input mode<br>Output mode                  | PU*<br>PU* | PU<br>Output  | ←               |               |
| P87 (INT0)                                   | Input mode<br>Output mode                  | PU<br>PU   | PU<br>Output  | ←               |               |
| P9                                           | Input mode<br>Output mode                  | PU*<br>PU* | PU<br>Output  | ←               |               |
| NMI                                          | Input                                      | Input      | Input         | ←               |               |
| WDTOUT                                       | Output                                     | Output     | Output        | ←               |               |
| ALE                                          | Output                                     | "0"        | "0"           | ←               |               |
| CLK                                          | Output                                     | -          | "1"           | ←               |               |
| RESET                                        | Input                                      | Input      | Input         | ←               |               |
| EA                                           | Input                                      | Input      | Input         | ←               |               |
| X1                                           | Input                                      | -          | -             | ←               |               |
| X2                                           | Output                                     | "1"        | "1"           | ←               |               |

- : Input for input mode/input pin is invalid; output mode/output pin is at high impedance.

Input : Input enable state

Input : Input gate in operation. Fix input voltage to 0 or 1 so that input pin stays constant.

Output : Output state

PU : Programmable pull-up pin. Fix the pin to avoid through current since the input gate operates when a pull-up resistor is not set.

PD : Programmable pull-down pin. Fix the pin like a pull-up pin when a pull-down resistor is not set.

\* : Input gate disable state. No through current even if the pin is set to high impedance.

x : Cannot set.

Note : Port registers are used for controlling programmable pull-up/pull-down. If a pin is also used for an output function (eg, TO1) and the output function is specified, whether pull-up or pull-down is selected depends on the output function data. If a pin is also used for an input function, whether pull-up or pull-down is selected depends on the port register setting value only.

### 3.5 Functions of Ports

The TMP96CM40/TMP96PM40 has 65 bits for I/O ports. The TMP96C141 has 47 bits for I/O ports because Port0, Port1, P30, and P31 are dedicated pins for AD0 to 7, AD8 to 15, RD, and WR.

These port pins have I/O functions for the built-in CPU and internal I/Os as well as general-purpose I/O port functions. Table 3.5 lists the function of each port pin.

Table 3.5 Functions of Ports  
(R: ↑ = With programmable pull-up resistor  
↓ = With programmable pull-down)

| Port name | Pin name                                             | Number of pins                       | Direction                                                  | R                                    | Direction setting unit                                       | Pin name for built-in function                                            |
|-----------|------------------------------------------------------|--------------------------------------|------------------------------------------------------------|--------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------------|
| Port0     | P00~P07                                              | 8                                    | I/O                                                        | —                                    | Bit                                                          | AD0~AD7                                                                   |
| Port1     | P10~P17                                              | 8                                    | I/O                                                        | ↑                                    | Bit                                                          | AD8~AD15/A8~A15                                                           |
| Port2     | P20~P27                                              | 8                                    | I/O                                                        | ↓                                    | Bit                                                          | A0~A7/A16~A23                                                             |
| Port3     | P30<br>P31<br>P32<br>P33<br>P34<br>P35<br>P36<br>P37 | 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | Output<br>Output<br>I/O<br>I/O<br>I/O<br>I/O<br>I/O<br>I/O | —<br>—<br>↑<br>↑<br>↑<br>↑<br>↑<br>↑ | (Fixed)<br>(Fixed)<br>Bit<br>Bit<br>Bit<br>Bit<br>Bit<br>Bit | RD<br>WR<br>HWR<br>WAIT<br>BUSRQ<br>BUSAK<br>R/W<br>RAS                   |
| Port4     | P40<br>P41<br>P42                                    | 1<br>1<br>1                          | I/O<br>I/O<br>I/O                                          | ↑<br>—<br>↓                          | Bit<br>Bit<br>Bit                                            | CS0 / CAS0<br>CS1 / CAS1<br>CS2 / CAS2                                    |
| Port5     | P50~P53                                              | 4                                    | Input                                                      | —                                    | (Fixed)                                                      | AN0~AN3                                                                   |
| Port6     | P60~P67                                              | 8                                    | I/O                                                        | ↑                                    | Bit                                                          | PG00~PG03, PG10~PG13                                                      |
| Port7     | P70<br>P71<br>P72<br>P73                             | 1<br>1<br>1<br>1                     | I/O<br>I/O<br>I/O<br>I/O                                   | ↑<br>↑<br>↑<br>↑                     | Bit<br>Bit<br>Bit<br>Bit                                     | T10<br>TO1<br>TO2<br>TO3                                                  |
| Port8     | P80<br>P81<br>P82<br>P83<br>P84<br>P85<br>P86<br>P87 | 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | I/O<br>I/O<br>I/O<br>I/O<br>I/O<br>I/O<br>I/O<br>I/O       | ↑<br>↑<br>↑<br>↑<br>↑<br>↑<br>↑<br>↑ | Bit<br>Bit<br>Bit<br>Bit<br>Bit<br>Bit<br>Bit<br>Bit         | T14/INT4<br>T15/INT5<br>TO4<br>TO5<br>T16/INT6<br>T17/INT7<br>TO6<br>INT0 |
| Port9     | P90<br>P91<br>P92<br>P93<br>P94<br>P95               | 1<br>1<br>1<br>1<br>1<br>1           | I/O<br>I/O<br>I/O<br>I/O<br>I/O<br>I/O                     | ↑<br>↑<br>↑<br>↑<br>↑<br>↑           | Bit<br>Bit<br>Bit<br>Bit<br>Bit<br>Bit                       | TXD0<br>RXD0<br>CTS0 (Note)<br>TXD1<br>RXD1<br>SCLK1                      |

Resetting makes the port pins listed below function as general-purpose I/O ports.

I/O pins programmable for input or output function as input ports.

To set port pins for built-in functions, a program is required.

Since the TMP96C141 has an external ROM, some ports are permanently assigned to the CPU.

- P00~P07 → AD0~AD7
- P10~P17 → AD8~AD15
- P30 → RD
- P31 → WR

Notes on bus release:

When buses are released ( $\overline{\text{BUSAK}} = 0$ ), the TMP96C141/TMP96CM40/TMP96PM40 sets the output buffer for AD0-AD15, A0-A23, and bus control signals (RD, WR, HWR, R/W, RAS, CS0/CAS0-CS2/CAS2) to off to set them to high impedance. The internal programmable pull-up/pull-down resistors continue to operate. Resistors are programmable only for operations in input mode; not in output mode.

Pin states at bus release are shown below:

| Pin name                                      | Pin state at bus release                                                                                  |                                                                                                                                              |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
|                                               | Port mode                                                                                                 | Function mode                                                                                                                                |
| P00-P07<br>(AD0-AD7)<br>P10-P17<br>(AD8-AD15) | No status change (not set to high impedance)<br>Sets to high impedance.                                   | Set to high impedance.                                                                                                                       |
| P30 (RD)<br>P31 (WR)                          | Sets to high impedance.                                                                                   | ←                                                                                                                                            |
| P32 (HWR)<br>P37 (RAS)                        | Sets output buffer to off.<br>Internal pull-up resistor is selected only when output latch is set to 1.   | Sets output buffer to off. Internal pull-up resistor is selected regardless of output latch value.                                           |
| P36 (R/W)<br>P40 (CS0/CAS0)<br>P41 (CS1/CAS1) | Sets output buffer to off.<br>Internal pull-up resistor is selected only when output latch is set to 1.   | Sets output buffer to off. Regardless of output latch value, internal pull-up resistor is selected or not depending on bus release timing.   |
| P20-P27<br>(A16-A23)<br>P42 (CS2/CAS2)        | Sets output buffer to off.<br>Internal pull-down resistor is selected only when output latch is set to 0. | Sets output buffer to off. Regardless of output latch value, internal pull-down resistor is selected or not depending on bus release timing. |

Below shows an example of the external bus interface for the above signals when using the bus release function.

However, when buses are released, internal memory and internal I/Os cannot be accessed; they function as internal I/Os only. Thus, the watchdog timer continues counting, with bus release function, take bus release time into consideration when setting the runaway detect time.



Example of external bus interface using bus release function

When an external pull-up/pull-down resistor is selected to ensure the signal levels at bus release, the above circuit is required.

Reset sets P30 (RD) and P31 (WR) to output mode. P40-P41 (CS0-CS1), P32 (HWR), P36 (R/W), P37 (RAS), and P35 (BUSAK) are set to input mode using a pull-up resistor. P42 (CS2) and P20-P27 (A16-23) are set to input mode using a pull-down resistor. The above circuit is required because if P42 (CS2) is directly pulled up externally, after a reset the internal pull-down conflicts with the external pull-up and, as a result, the level becomes undefined. The pull-up resistor value must be set to several k ohms because the internal pull-down resistor value is set to 50k -150k ohms.

With P20-27 (A16-23), the same circuit as that for P42 (CS2) is required for external pull-up. However, unlike CS2, A16-23 are not active even at low level; thus, directly pull down (as in the above example) for a system where low level is acceptable.

### 3.5.1 Port 0 (P00 - P07)

Port 0 is an 8-bit general-purpose I/O port. I/O can be set on a bit basis using the control register P0CR. Resetting resets all bits of P0CR to 0 and sets Port 0 to input mode.

In addition to functioning as a general-purpose I/O port, Port 0 also functions as an address data bus (AD0 to 7). To access external memory, Port 0 functions as an address data bus (AD0 to 7) and all bits of the control register P0CR are cleared to 0.

With the TMP96C141/TMP96C141A/TMP96C041A, which has an external ROM, Port 0 always functions as an address data bus (AD0 to 7) regardless of the value set in control register P0CR.



Figure 3.5 (1) Port 0

### 3.5.2 Port 1 (P10 - P17)

Port 1 is an 8-bit general-purpose I/O port. I/O can be set on a bit basis using control register P1CR and function register P1FC. Resetting resets all bits of output latch P1, control register P1CR, and function register P1FC to 0 and sets Port 1 to input mode.

In addition to functioning as a general-purpose I/O port, Port 1 also functions as an address data bus (AD8 to 15) or an address bus (A8 to 15).

With the TMP96C141/TMP96C141A/TMP96C041A, which comes with an external ROM, Port 1 always functions as an address data bus (AD8 to 15) regardless of the value set in control register P1CR.



Figure 3.5 (2) Port 1

## Port 0 Register

|             | 7                                                     | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------------|-------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|
| bit Symbol  | P07                                                   | P06 | P05 | P04 | P03 | P02 | P01 | P00 |
| Read/Write  | R/W                                                   |     |     |     |     |     |     |     |
| After reset | Input mode (Output latch register becomes undefined.) |     |     |     |     |     |     |     |

## Port 0 Control Register

|             | 7                                                                                 | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------------|-----------------------------------------------------------------------------------|------|------|------|------|------|------|------|
| bit Symbol  | P07C                                                                              | P06C | P05C | P04C | P03C | P02C | P01C | P00C |
| Read/Write  | W                                                                                 |      |      |      |      |      |      |      |
| After reset | 0                                                                                 | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| Function    | 0:IN 1:OUT (At external access, Port 0 becomes AD7 - 0 and P0CR is cleared to 0.) |      |      |      |      |      |      |      |

→ Port 0 I/O setting

|   |        |
|---|--------|
| 0 | Input  |
| 1 | Output |

## Port 1 Register

|             | 7                                                     | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------------|-------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|
| bit Symbol  | P17                                                   | P16 | P15 | P14 | P13 | P12 | P11 | P10 |
| Read/Write  | R/W                                                   |     |     |     |     |     |     |     |
| After reset | Input mode (Output latch register is cleared to "0".) |     |     |     |     |     |     |     |

## Port 1 Control Register

|             | 7                   | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------------|---------------------|------|------|------|------|------|------|------|
| bit Symbol  | P17C                | P16C | P15C | P14C | P13C | P12C | P11C | P10C |
| Read/Write  | W                   |      |      |      |      |      |      |      |
| After reset | 0                   | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| Function    | <<See P1FC below.>> |      |      |      |      |      |      |      |

## Port 1 Function Register

|             | 7                                                      | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------------|--------------------------------------------------------|------|------|------|------|------|------|------|
| bit Symbol  | P17F                                                   | P16F | P15F | P14F | P13F | P12F | P11F | P10F |
| Read/Write  | W                                                      |      |      |      |      |      |      |      |
| After reset | 0                                                      | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| Function    | P1FC/P1CR = 00 : IN, 01 : OUT, 10 : AD15-8, 11 : A15-8 |      |      |      |      |      |      |      |

Read-modify-write is prohibited for registers P0CR, P1CR, and P1FC.

→ Port 1 function setting

|                      |             |                           |
|----------------------|-------------|---------------------------|
| P1CR<P1XF><br><P1XC> | 0           | 1                         |
| 0                    | Input port  | Address data bus (AD15-8) |
| 1                    | Output port | Address bus (A15-8)       |

Note : <P1XF> is bit X in register P1FC; <P1XC>, in register P1CR.

Figure 3.5 (3) Registers for Ports 0 and 1

### 3.5.3 Port 2 (P20 - P27)

Port 2 is an 8-bit general-purpose I/O port. I/O can be set on bit basis using the control register P2CR and function register P2FC. Resetting resets all bits of output latch P2, control register P2CR and function register P2FC to 0. It also sets Port 2 to input mode and connects a pull-down resistor. To disconnect the pull-down resistor, write 1 in the output latch.

In addition to functioning as a general-purpose I/O port, Port 2 also functions as an address data bus (A0 to 7) and an address bus (A16 to 23).



図 3.5 (4) Port 2

## Port 2 Register

|               | 7                                                     | 6     | 5   | 4   | 3   | 2   | 1   | 0   |     |
|---------------|-------------------------------------------------------|-------|-----|-----|-----|-----|-----|-----|-----|
| P2<br>(0006H) | bit Symbol                                            | P27   | P26 | P25 | P24 | P23 | P22 | P21 | P20 |
| Read/Write    |                                                       | R / W |     |     |     |     |     |     |     |
| After reset   | Input mode (Output latch register is cleared to "0".) |       |     |     |     |     |     |     |     |

## Port 2 Control Register

|                 | 7                   | 6    | 5    | 4    | 3    | 2    | 1    | 0    |      |
|-----------------|---------------------|------|------|------|------|------|------|------|------|
| P2CR<br>(0008H) | bit Symbol          | P27C | P26C | P25C | P24C | P23C | P22C | P21C | P20C |
| Read/Write      |                     | W    |      |      |      |      |      |      |      |
| After reset     | 0                   | 0    | 0    | 0    | 0    | 0    | 0    | 0    |      |
| Function        | <<See P2FC below.>> |      |      |      |      |      |      |      |      |

## Port 2 Function Register

|                 | 7                                                     | 6    | 5    | 4    | 3    | 2    | 1    | 0    |      |
|-----------------|-------------------------------------------------------|------|------|------|------|------|------|------|------|
| P2FC<br>(0009H) | bit Symbol                                            | P27F | P26F | P25F | P24F | P23F | P22F | P21F | P20F |
| Read/Write      |                                                       | W    |      |      |      |      |      |      |      |
| After reset     | 0                                                     | 0    | 0    | 0    | 0    | 0    | 0    | 0    |      |
| Function        | P2FC/P2CR = 00 : IN, 01 : OUT, 10 : A7-0, 11 : A23-16 |      |      |      |      |      |      |      |      |

Read-modify-write is prohibited for registers P2CR and P2FC.

| P2CR<br><P2XF><br><P2XC> | 0      | 1                    |
|--------------------------|--------|----------------------|
| 0                        | Input  | address bus (A7-0)   |
| 1                        | Output | address bus (A23-16) |

Note : <P2XF> is bit X in register P2FC; <P2XC> ; in register P2CR.  
To set as an address bus A23~16, set P2FC after setting P2CR.

Figure 3.5 (5) Registers for Port 2

### 3.5.4 Port 3 (P30 - P37)

Port 3 is an 8-bit general-purpose I/O port.

I/O can be set on a bit basis, but note that P30 and P31 are used for output only. I/O is set using control register P3CR and function register P3FC. Resetting resets all bits of output latch P3, control register P3CR (bits 0 and 1 are unused), and function register P3FC to 0. Resetting also outputs 1 from P30 and P31, sets P32 to P37 to input mode, and connects a pull-up resistor.

In addition to functioning as a general-purpose I/O port, Port 3 also functions as an I/O for the CPU's control/status signal.

With the TMP96C141, when P30 pin is defined as  $\overline{RD}$  signal output mode ( $<P30F> = 1$ ), clearing the output latch register  $<P30>$  to 0 outputs the  $\overline{RD}$  strobe (used for the pseudo static RAM) from the P30 pin even when the internal address area is accessed.

If the output latch register  $<P30>$  remains 1, the  $\overline{RD}$  strobe signal is output only when the external address area is accessed.

With the TMP96C141/TMP96C141A/TMP96C041A, which comes with an external ROM, P30 outputs the  $\overline{RD}$  signal; P31, the  $\overline{WR}$  signal, regardless of the values set in function registers P30F and P31F.





Figure 3.5 (6) Port 3 (P30, P31, P32, P35, P36, P37)



Figure 3.5 (7) Port3 (P33, P34)



Note) When P33/WAIT pin is used as a WAIT pin, set P3CR<P33C> to "0" and Chip Select / WAIT control register <BnW1, 0> to "10".

Figure3.5 (8) Registers for Port 3

### 3.5.5 Port 4 (P40 - P42)

Port 4 is a 3-bit general-purpose I/O port. I/O can be set on a bit basis using control register P4CR and function register P4FC. Resetting does the following:

- Sets the P40 and P42 output latch registers to 1.
- Resets all bits of the P42 output latch register, the control register P4CR, and the function register P4FC to 0.
- Sets P40 and P41 to input mode and connects a pull-up resistor.
- Sets P42 to input mode and connects a pull-down resistor.

In addition to functioning as a general-purpose I/O port, Port 4 also functions as a chip select output signal ( $\overline{CS0}$  to  $\overline{CS2}$  or  $\overline{CAS0}$  to  $\overline{CAS2}$ ).





Figure 3.5 (9) Port 4



Note : To output chip select signal ( $\overline{CS0}/\overline{CAS0}$  to  $\overline{CS2}/\overline{CAS2}$ ), set the corresponding bits of the control register P4CR and the function register P4FC.

The B0CS, B1CS, and B2CS registers of the chip select / wait controller are used to select the CS/CAS function.

290591

Figure 3.5 (10) Registers for Port 4

### 3.5.6 Port 5 (P50 - P53)

Port 5 is a 4-bit input port, also used as an analog input pin.



Figure3.5 (11) Port 5

Port 5 Register

|               | 7           | 6 | 5 | 4 | 3   | 2          | 1   | 0   |
|---------------|-------------|---|---|---|-----|------------|-----|-----|
| P5<br>(000DH) | bit Symbol  |   |   |   | P53 | P52        | P51 | P50 |
|               | Read/Write  |   |   |   |     | R          |     |     |
|               | After reset |   |   |   |     | Input mode |     |     |

Note : The input channel selection of A/D Converter is set by A/D Converter mode register ADMOD2.

Figure 3.5 (12) Registers for Port 5

### 3.5.7 Port 6 (P60 - P67)

Port 6 is an 8-bit general-purpose I/O port. I/O can be set on bit basis. Resetting sets Port 6 as an input port and connects a pull-up resistor. It also sets all bits of the output latch to 1. In addition to functioning as a general-purpose I/O port, Port 6 also functions as a pattern generator PG0/PG1 output. PG0 is assigned to P60 to P63; PG1, to P64 to P67. Writing 1 in the corresponding bit of the port 6 function register (P6FC) enables PG output. Resetting resets the function register P6FC value to 0, and sets all bits to ports.



Figure 3.5 (13) Port 6

| Port 6 Register |             |                      |     |     |     |     |     |     |     |
|-----------------|-------------|----------------------|-----|-----|-----|-----|-----|-----|-----|
| P6<br>(0012H)   | bit Symbol  | 7                    | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|                 | Read/Write  | P67                  | P66 | P65 | P64 | P63 | P62 | P61 | P60 |
|                 |             | R/W                  |     |     |     |     |     |     |     |
|                 | After reset | Input mode (Pull-up) |     |     |     |     |     |     |     |
|                 |             | 1                    | 1   | 1   | 1   | 1   | 1   | 1   | 1   |

  

| Port 6 Control Register |             |        |      |      |      |         |      |      |      |
|-------------------------|-------------|--------|------|------|------|---------|------|------|------|
| P6CR<br>(0014H)         | bit Symbol  | 7      | 6    | 5    | 4    | 3       | 2    | 1    | 0    |
|                         | Read/Write  | P67C   | P66C | P65C | P64C | P63C    | P62C | P61C | P60C |
|                         |             | W      |      |      |      |         |      |      |      |
|                         | After reset | 0      | 0    | 0    | 0    | 0       | 0    | 0    | 0    |
|                         | Function    | 0 : IN |      |      |      | 1 : OUT |      |      |      |

  

|                    |        |
|--------------------|--------|
| Port 6 I/O setting |        |
| 0                  | Input  |
| 1                  | Output |

  

| Port 6 Function Register |             |          |      |             |      |          |      |             |      |
|--------------------------|-------------|----------|------|-------------|------|----------|------|-------------|------|
| P6FC<br>(0016H)          | bit Symbol  | 7        | 6    | 5           | 4    | 3        | 2    | 1           | 0    |
|                          | Read/Write  | P67F     | P66F | P65F        | P64F | P63F     | P62F | P61F        | P60F |
|                          |             | W        |      |             |      |          |      |             |      |
|                          | After reset | 0        | 0    | 0           | 0    | 0        | 0    | 0           | 0    |
|                          | Function    | 0 : PORT |      | 1 : PG1-OUT |      | 0 : PORT |      | 1 : PG0-OUT |      |

  

Read-modify-write is prohibited for registers P6CR and P6FC.

|                         |                                                  |
|-------------------------|--------------------------------------------------|
| Port 6 function setting |                                                  |
| 0                       | General-purpose port                             |
| 1                       | Stepping motor control / Pattern generation port |

Figure3.5 (14) Registers for Port 6

### 3.5.8 Port 7 (P70 - P73)

Port 7 is a 4-bit general-purpose I/O port. I/O can be set on bit basis. Resetting sets Port 7 as an input port and connects a pull-up resistor. In addition to functioning as a general-purpose I/O port, Port 70 also functions as an input clock pin TI0; Port 71 as an 8-bit timer output (TO1), Port 72 as a PWM0 output (TO2), and Port 73 as a PWM1 output (TO3) pin. Writing 1 in the corresponding bit of the Port 7 function register (P7FC) enables output of the timer. Resetting resets the function register P7FC value to 0, and sets all bits to ports.



Figure 3.5 (15) Port 7



Note : P70/TI0 pin does not have a register changing PORT/FUNCTION.

For example, when it is used as an input port (P70), the input signal for P70 is inputted to 8bit Timer 0 as a timer input 0 (TI0).

Figure3.5 (16) Registers for Port 7

### 3.5.9 Port 8 (P80 - P83)

Port 8 is an 8-bit general-purpose I/O port. I/O can be set on a bit basis. Resetting sets Port 8 as an input port and connects a pull-up resistor. It also sets all bits of the output latch register P8 to 1. In addition to functioning as a general-purpose I/O port, Port 8 also functions as an input for 16-bit timer 4 & 5 clocks, an output for 16-bit timer F/F 4, 5, & 6 output, and an input for INT0. Writing 1 in the corresponding bit of the Port 8 function register (P8FC) enables those functions. Resetting resets the function register P8FC value to 0 and sets all bits to ports.

#### (1) P80~P86



Figure 3.5 (17) Port 8 (P80 - P86)

## (2) P87 (INT0)

Port 87 is a general-purpose I/O port, and also used as an INT0 pin for external interrupt request input.



Figure 3.5 (18) Port 87

| Port 8 Register |            |     |     |     |     |     |     |     |
|-----------------|------------|-----|-----|-----|-----|-----|-----|-----|
| P8<br>(0018H)   | 7          | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| bit Symbol      | P87        | P86 | P85 | P84 | P83 | P82 | P81 | P80 |
| Read/Write      | R/W        |     |     |     |     |     |     |     |
| After reset     | Input mode |     |     |     |     |     |     |     |
|                 | 1          | 1   | 1   | 1   | 1   | 1   | 1   | 1   |

  

| Port 8 Control Register |        |      |      |      |         |      |      |      |
|-------------------------|--------|------|------|------|---------|------|------|------|
| P8CR<br>(001AH)         | 7      | 6    | 5    | 4    | 3       | 2    | 1    | 0    |
| bit Symbol              | P87C   | P86C | P85C | P84C | P83C    | P82C | P81C | P80C |
| Read/Write              | W      |      |      |      |         |      |      |      |
| After reset             | 0      | 0    | 0    | 0    | 0       | 0    | 0    | 0    |
| Function                | 0 : IN |      |      |      | 1 : OUT |      |      |      |

  

Port 8 I/O setting

|   |        |
|---|--------|
| 0 | Input  |
| 1 | Output |

  

| Port 8 Function Register |      |          |   |   |          |          |   |   |
|--------------------------|------|----------|---|---|----------|----------|---|---|
| P8FC<br>(001CH)          | 7    | 6        | 5 | 4 | 3        | 2        | 1 | 0 |
| bit Symbol               | P86F |          |   |   | P83F     | P82F     |   |   |
| Read/Write               |      |          |   |   | W        | W        |   |   |
| After reset              |      | 0        |   |   | 0        | 0        |   |   |
| Function                 |      | 0 : PORT |   |   | 0 : PORT | 0 : PORT |   |   |
|                          |      | 1 : TO6  |   |   | 1 : TO5  | 1 : TO4  |   |   |

  

Read-modify-write is prohibited for registers P8CR and P8FC.

Setting P82 as TO4

|             |   |
|-------------|---|
| P8FC <P82F> | 1 |
| P8CR <P82C> | 1 |

Setting P83 as TO5

|             |   |
|-------------|---|
| P8FC <P83F> | 1 |
| P8CR <P83C> | 1 |

Setting P84 as TO6

|             |   |
|-------------|---|
| P8FC <P86F> | 1 |
| P8CR <P86C> | 1 |

Note : P80/TI4, P81/TI5, P84/TI6, P85/TI7 pins do not have a register changing PORT/FUNCTION.

Therefore this is the same as P70/TI0 pin.

When P87/INT0 pin is used as an INT0 pin, set P8CR<P87C> to "0" and IIMC<IOIE> to "1".

Figure3.5 (19) Registers for Port 8

### 3.5.10 Port 9 (P90 - P95)

Port 9 is a 6-bit general-purpose I/O port. I/Os can be set on a bit basis.

Resetting sets Port 9 to an input port and connects a pull-up resistor.

It also sets all bits of the output latch register to 1.

In addition to functioning as a general-purpose I/O port, Port 9 can also function as an I/O for serial channels 0 and 1. Writing 1 in the corresponding bit of the port 9 function register (P9FC) enables this function.

Resetting resets the function register value to 0 and sets all bits to ports.

#### (1) Port 90 & 93 (TXD0/TXD1)

Ports 90 and 93 also function as serial channel TXD output pins in addition to I/O ports.

They have a programmable open drain function.



Figure 3.5 (20) Ports 90 and 93

## (2) Ports 91 and 94 (RXD0, 1)

Ports 91 and 94 are I/O ports, and also used as RXD input pins for serial channels.



Figure3.5 (21) Ports 91 and 94

(3) Port 92 ( $\overline{CTS}$ )

Port 92 is an I/O port, and also used as a  $\overline{CTS}$  input pin for serial channels.



Figure3.5 (22) Port 92



Figure3.5 (23) Ports 92 (TMP96CM40/TMP96PM40/TMP96C141A/TMP96C041A)

## (4) Port 95 (SCLK)

Port 95 is a general-purpose I/O port. It is also used as an SCLK I/O pin for serial channel 1.



Figure3.5 (23) Port 95

**Port 9 Register**

|               |             |            |   |   |   |   |   |   |
|---------------|-------------|------------|---|---|---|---|---|---|
| P9<br>(0019H) | 7           | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|               | bit Symbol  |            |   |   |   |   |   |   |
|               | Read/Write  | R/W        |   |   |   |   |   |   |
|               | After reset | Input mode |   |   |   |   |   |   |

  

**Port 9 Control Register**

|                 |             |                     |   |   |   |   |   |   |
|-----------------|-------------|---------------------|---|---|---|---|---|---|
| P9CR<br>(001BH) | 7           | 6                   | 5 | 4 | 3 | 2 | 1 | 0 |
|                 | bit Symbol  |                     |   |   |   |   |   |   |
|                 | Read/Write  | W                   |   |   |   |   |   |   |
|                 | After reset | 0 : IN      1 : OUT |   |   |   |   |   |   |

  

Port 9 I/O setting  

|   |        |
|---|--------|
| 0 | Input  |
| 1 | Output |

  

**Port 9 Function Register**

|                 |             |                 |   |   |   |   |   |   |
|-----------------|-------------|-----------------|---|---|---|---|---|---|
| P9FC<br>(001DH) | 7           | 6               | 5 | 4 | 3 | 2 | 1 | 0 |
|                 | bit Symbol  |                 |   |   |   |   |   |   |
|                 | Read/Write  | W      W      W |   |   |   |   |   |   |
|                 | After reset | 0      0      0 |   |   |   |   |   |   |

  

Note: Only the  
 TMP96CM40/TMP96PM40/  
 TMP96C141A/TMP96C041A  
 have register P92F. That is,  
 SCLK0 cannot be specified for  
 the TMP96C141.

P90 TxDO output setting (Note)  

|             |   |
|-------------|---|
| P9FC <P90F> | 1 |
| P9CR <P90C> | 1 |

P93 TxD1 output setting (Note)  

|             |   |
|-------------|---|
| P9FC <P93F> | 1 |
| P9CR <P93C> | 1 |

P95 SCLK output setting  

|             |   |
|-------------|---|
| P9FC <P95F> | 1 |
| P9CR <P95C> | 1 |

Note: To set the TxD pin to open drain, write 1 in bit 0 (for TxDO pin) or bit 1 (for TxD1 pin) of the ODE register.  
 P91/RXD0, P94/RXD1 pins do not have a register changing PORT/FUNCTION.  
 Therefore this is the same as P70/TI0 pin.

Figure 3.5 (24) Registers for Port 9

### 3.6 Chip Select / Wait Control

TMP96C141 has a built-in chip select / wait controller used to control chip select ( $\overline{CS0}$  -  $\overline{CS2}$  pins), wait ( $\overline{WAIT}$  pin), and data bus size (8 or 16 bits) for any of the three block address areas.

#### 3.6.1 Control Registers

Table 3.6.(1) shows control registers.

One block address areas are controlled by 1-byte CS/WAIT control registers (B0CS, B1CS, and B2CS). Registers can be written to only when the CPU is in system mode (there are two CPU modes: system and normal). The reason is that the settings of these registers have an important effect on the system.

##### (1) Enable

Control register bit 7 (B0E, B1E, and B2E) is a master bit used to specify enable (1) / disable (0) of the setting.

Resetting sets B0E and B1E to disable (0) and B2E to enable (1).

##### (2) System only specification

Control register bit 6 (B0SYS, B1SYS, and B2SYS) is used to specify enable / disable of the setting depending on the CPU operating mode (system or normal). Setting this bit to 0 enables setting (Address space for  $\overline{CS}$ , Wait state, Bus size, etc.) regardless of the CPU operating mode; setting it to 1 enables setting in system mode but disables setting in normal mode.

Resetting clears bit 6 to 0.

Bit 6 is mainly used when external memory data should not be accessed in normal mode (ie, for system mode only memory data for the operating system).

##### (3) CS/CAS Waveform select

Control register bit 5 (B0CAS, B1CAS, and B2CAS) is used to specify waveform mode output from the chip select pin ( $\overline{CS0}/\overline{CAS0}$  -  $\overline{CS2}/\overline{CAS2}$ ). Setting this bit to 0 specifies  $\overline{CS0}$  to  $\overline{CS2}$  waveforms; setting it to 1 specifies CAS0 to CAS2 waveforms.

Resetting clears bit 5 to 0.



(4) Data bus size select

Bit 4 (B0BUS, B1BUS, and B2BUS) of the control register is used to specify data bus size. Setting this bit to 0 accesses the memory in 16-bit data bus mode; setting it to 1 accesses the memory in 8-bit data bus mode.

Changing data bus size depending on the access address is called dynamic bus sizing. Table 3.6 (2) shows the details of the bus operation.

(5) Wait control

Control register bits 3 and 2 (B0W1,0; B1W1,0; B2W1,0) are used to specify the number of waits. Setting these bits to 00 inserts a 2-state wait regardless of the WAIT pin status. Setting them to 01 inserts a 1-state wait regardless of the WAIT status. Setting them to 10 inserts a 1-state wait and samples the WAIT pin status. If the pin is low, inserting the wait maintains the bus cycle until the pin goes high. Setting them to 11 completes the bus cycle without a wait regardless of the WAIT pin status.

Resetting sets these bits to 00 (2-state wait mode).

(6) Address area specification

Control register bits 1 and 0 (B0C1,0; B1C1,0; B2C1,0) are used to specify the target address area. Setting these bits to 00 enables settings (CS output, Wait state, Bus size, etc.) as follows:

- \* CS0 setting enabled when 7F00H to 7FFFH is accessed.
- \* CS1 setting enabled when 480H to 7FFFH is accessed.  
CS1 setting enable when 80H to 7FFFH is accessed for the TMP96C041A, which does not have a built-in RAM.
- \* CS2 setting enabled when 8000H to 3FFFFFFH is accessed.  
CS2 setting enabled when 10000H to 3FFFFFFH is accessed for the TMP96CM40/TMP96PM40, which has built-in 32K byte ROM/PROM..

Setting bits to 01 enables setting for all CS's blocks and outputs a low strobe signal (CS0/CAS0~CS2/CAS2) from chip select pins when 400000H to 7FFFFFFH is accessed. Setting bits to 10 enables them 800000H to BFFFFFFH is accessed. Setting bits to 11 enables them when C00000H to FFFFFFFH is accessed.

Table 3.6 (1) Chip select / wait control register

| Code | Name                                     | Address | 7                      | 6                    | 5          | 4              | 3            | 2               | 1    | 0    |
|------|------------------------------------------|---------|------------------------|----------------------|------------|----------------|--------------|-----------------|------|------|
| B0CS | Block0<br>CS/WAIT<br>control<br>register | 0068H   | B0E                    | B0SYS                | B0CAS      | B0BUS          | B0W1         | B0W0            | B0C1 | B0C0 |
|      |                                          |         | W                      | W                    | W          | W              | W            | W               | W    | W    |
|      |                                          |         | 0                      | 0                    | 0          | 0              | 0            | 0               | 0    | 0    |
|      |                                          |         | 1:<br>CS/CAS<br>Enable | 1:<br>SYSTEM<br>only | 0:<br>CS0  | 0:16bit<br>Bus | 00: 2WAIT    | 00: 7F00H~7FFFH |      |      |
|      |                                          |         |                        |                      | 1:<br>CAS0 | 1:8bit<br>Bus  | 01: 1WAIT    | 01: 400000H~    |      |      |
|      |                                          |         |                        |                      |            | 10: 1WAIT + n  | 10: 800000H~ |                 |      |      |
|      |                                          |         |                        |                      |            | 11: 0WAIT      | 11: C00000H~ |                 |      |      |
|      |                                          |         | B1E                    | B1SYS                | B1CAS      | B1BUS          | B1W1         | B1W0            | B1C1 | B1C0 |
| B1CS | Block1<br>CS/WAIT<br>control<br>register | 0069H   | W                      | W                    | W          | W              | W            | W               | W    | W    |
|      |                                          |         | 0                      | 0                    | 0          | 0              | 0            | 0               | 0    | 0    |
|      |                                          |         | 1:<br>CS/CAS<br>Enable | 1:<br>SYSTEM<br>only | 0:<br>CS1  | 0:16bit<br>Bus | 00: 2WAIT    | *00: 480H~7FFFH |      |      |
|      |                                          |         |                        |                      | 1:<br>CAS1 | 1:8bit<br>Bus  | 01: 1WAIT    | 01: 400000H~    |      |      |
|      |                                          |         |                        |                      |            | 10: 1WAIT + n  | 10: 800000H~ |                 |      |      |
|      |                                          |         |                        |                      |            | 11: 0WAIT      | 11: C00000H~ |                 |      |      |
|      |                                          |         | B2E                    | B2SYS                | B2CAS      | B2BUS          | B2W1         | B2W0            | B2C1 | B2C0 |
|      |                                          |         | W                      | W                    | W          | W              | W            | W               | W    | W    |
| B2CS | Block2<br>CS/WAIT<br>control<br>register | 006AH   | 1:<br>CS/CAS<br>Enable | 1:<br>SYSTEM<br>only | 0:<br>CS2  | 0:16bit<br>Bus | 00: 2WAIT    | 00: 8000H~      |      |      |
|      |                                          |         |                        |                      | 1:<br>CAS2 | 1:8bit<br>Bus  | 01: 1WAIT    | 01: 400000H~    |      |      |
|      |                                          |         |                        |                      |            | 10: 1WAIT + n  | 10: 800000H~ |                 |      |      |
|      |                                          |         |                        |                      |            | 11: 0WAIT      | 11: C00000H~ |                 |      |      |

Note : With only block 2, enable (16-bit data bus, 2-wait mode) after reset.

Table 3.6 (2) Dynamic bus sizing

| Operand data size | Operand start address   | Memory data size | CPU address | CPU data  |           |
|-------------------|-------------------------|------------------|-------------|-----------|-----------|
|                   |                         |                  |             | D15 – D8  | D7 – D0   |
| 8 bits            | 2n + 0<br>(even number) | 8 bits           | 2n + 0      | xxxxx     | b7 – b0   |
|                   |                         | 16 bits          | 2n + 0      | xxxxx     | b7 – b0   |
|                   | 2n + 1<br>(odd number)  | 8 bits           | 2n + 1      | xxxxx     | b7 – b0   |
|                   |                         | 16 bits          | 2n + 1      | b7 – b0   | xxxxx     |
| 16 bits           | 2n + 0<br>(even number) | 8 bits           | 2n + 0      | xxxxx     | b7 – b0   |
|                   |                         | 8 bits           | 2n + 1      | xxxxx     | b15 – b8  |
|                   |                         | 16 bits          | 2n + 0      | b15 – b8  | b7 – b0   |
|                   |                         | 16 bits          | 2n + 1      | xxxxx     | b7 – b0   |
|                   | 2n + 1<br>(odd number)  | 8 bits           | 2n + 2      | xxxxx     | b15 – b8  |
|                   |                         | 8 bits           | 2n + 1      | xxxxx     | b7 – b0   |
|                   |                         | 16 bits          | 2n + 1      | b7 – b0   | xxxxx     |
|                   |                         | 16 bits          | 2n + 2      | xxxxx     | b15 – b8  |
| 32 bits           | 2n + 0<br>(even number) | 8 bits           | 2n + 0      | xxxxx     | b7 – b0   |
|                   |                         | 8 bits           | 2n + 1      | xxxxx     | b15 – b8  |
|                   |                         | 8 bits           | 2n + 2      | xxxxx     | b23 – b16 |
|                   |                         | 8 bits           | 2n + 3      | xxxxx     | b31 – b24 |
|                   | 2n + 1<br>(odd number)  | 16 bits          | 2n + 0      | b15 – b8  | b7 – b0   |
|                   |                         | 16 bits          | 2n + 2      | b31 – b24 | b23 – b16 |
|                   |                         | 8 bits           | 2n + 1      | xxxxx     | b7 – b0   |
|                   |                         | 8 bits           | 2n + 2      | xxxxx     | b15 – b8  |
|                   |                         | 8 bits           | 2n + 3      | xxxxx     | b23 – b16 |
|                   |                         | 8 bits           | 2n + 4      | xxxxx     | b31 – b24 |
|                   |                         | 16 bits          | 2n + 1      | b7 – b0   | xxxxx     |
|                   |                         | 16 bits          | 2n + 2      | b23 – b16 | b15 – b8  |
|                   |                         | 16 bits          | 2n + 4      | xxxxx     | b31 – b24 |

xxxxx : During a read, data input to the bus is ignored. At write, the bus is at high impedance and the write strobe signal remains non-active.

### 3.6.2 Chip Select Image

An image of the actual chip select is shown below. Out of the whole memory area, address areas that can be specified are divided into four parts. Addresses from 000000H to 3FFFFFH are divided differently: 7F00H to 7FFFH is specified for CS0; 480H to 7FFFH, for CS1; and 8000H to 3FFFFFH, for CS2. The reason is that a device other than ROM (ie, RAM or I/O) might be connected externally.

7F00 to 7FFFH (256 bytes) for CS0 are mapped mainly for possible expansions to external I/O.

480H to 7FFFH (approx. 31K bytes) for CS1 are mapped there mainly for possible extensions to external RAM.

8000H to 3FFFFH (approx. 4M bytes) for CS2 are mapped mainly for possible extensions to external ROM. After reset, CS2 is enabled in 16-bit bus and 2-wait. With the TMP96C141, which does not have a built-in ROM, the program is externally read at address 8000H in this setting (16-bit bus, 2-wait). With the TMP96CM40/TMP96PM40, which has a built-in ROM, addresses from 8000H to FFFFFH are used as the internal ROM area; CS2 is disabled in this area. After reset, the CPU reads the program from the built-in ROM in 16-bit bus, 0-wait mode.



Supplement 1: Access priority is highest for built-in I/O, then built-in memory, and lowest for the chip select/wait controller.

Supplement 2: External areas other than CS0 to CS2 are accessed in 16-bit data bus (0 wait) mode.

When using the chip select/wait controller, do not specify the same address area more than once. (However, when addresses 7F00H - 7FFFH for CS0 and 480H - 7FFFH for CS1 are specified, in other words, specifications overlap, only the CS0 setting/pin is active.)

Note: When the bus is released (BUSAK = "0"), CS0~CS2 pins are also released (the output buffer is OFF). Refer to [Note about the bus release] in 3.5 Functions of Ports about the state of pins.

### 3.6.3 Example of Usage

Figure 3.6 (1) is an example in which an external memory is connected to the TMP96C141. In this example, a ROM is connected using 16 bit Bus; a RAM is connected using 8 bit Bus.



Figure 3.6 (1) Example of External Memory Connection (ROM = 16 bits, RAM & I/O = 8 bits)

Resetting sets pins  $\overline{CS0}$  to  $\overline{CS2}$  to input port mode.  $\overline{CS0}$  and  $\overline{CS1}$  are set high due to an internal pull-up resistor;  $\overline{CS2}$ , low due to an internal pull-down resistor. The program used to set these pins is as follows.

```

P4CR EQU 0EH
P4FC EQU 10H
B0CS EQU 68H
B1CS EQU 69H
B2CS EQU 6AH
LD (B0CS),90H ; CS0 = 8 bits, 2WAIT, 7F00H~7FFFFH
LD (B1CS),9CH ; CS1 = 8 bits, 0WAIT, 480H~7EFFH
LD (B2CS),84H ; CS2 = 16 bits, 1WAIT, 8000H~3FFFFH
LD (P4CR),07H
LD (P4FC),07H
    } CS0, CS1, CS2 output mode setting

```

### 3.6.4 How to Start with an 8-bit Data Bus

Resetting sets the  $\overline{CS2}$  pin low due to an internal pull-down resistor; memory access starts in 16-bit data bus (2-wait) mode. To start in 8-bit data bus mode, a special operation is required. Operation is as described in the example below.

```
B2CS EQU 6AH ; CS2 register address
ORG 8000H ; RESET address
LDX (B2CS), 9CH ; CS2 8bit, 0WAIT, 8000H~
```

After reset, the program reads the LDX(B2CS),9CH instruction in 16-bit data bus mode. LDX is a 6-byte instruction: the 2nd, 4th, and 6th bytes are handled as dummies (ie, only codes in the 1st, 3rd, and 5th bytes are actually used). Even if starting in 8-bit data bus mode, it is possible to program so that the LDX instruction is executed and the CS2 area (8000H - 3FFFFFFH) is accessed in 8-bit data bus mode without any problem.

The above program does not include setting the P42/ $\overline{CS2}$  pin to output; add a program to set the P4CR and P4FC registers as required.



### 3.7 8-bit Timers

TMP96C141 has two 8-bit timers (timers 0 and 1), each of which can be operated independently. The cascade connection allows these timers to be used as 16-bit timer. The following four operating modes are provided for the 8-bit timers.

- 8-bit interval timer mode (2 timers)
- 16-bit interval timer mode (1 timer)
- 8-bit programmable square wave pulse generation (PPG: variable duty with variable cycle) output mode (1 timer)
- 8-bit pulse width modulation (PWM: variable duty with constant cycle) output mode (1 timer)

Figure 3.7 (1) shows the block diagram of 8-bit timer (timer 0 and timer 1).

Each interval timer consists of an 8-bit up-counter, 8-bit comparator, and 8-bit timer register. Besides, one timer flip-flop (TFF1) is provided for pair of timer 0 and timer 1.

Among the input clock sources for the interval timers, the internal clocks of  $\phi T1$ ,  $\phi T4$ ,  $\phi T16$ , and  $\phi T256$  are obtained from the 9-bit prescaler shown in Figure 3.7 (2).

The operation modes and timer flip-flops of the 8-bit timer are controlled by three control registers TMOD, TFFCR, and TRUN.



Figure 3.7 (1) Block Diagram of 8-bit Timers (Timers 0 and 1)



### ① Prescaler

This 9-bit prescaler generates the clock input to the 8-bit timers, 16-bit timer/event counters, and baud rate generators by further dividing the fundamental clock ( $f_c$ ) after it has been divided by 4 ( $f_c/4$ ).

Among them, 8-bit timer uses 4 types of clock:  $\phi T1$ ,  $\phi T4$ ,  $\phi T16$ , and  $\phi T256$ .

This prescaler can be run or stopped by the timer operation control register  $TRUN <PRRUN>$ . Counting starts when  $<PRRUN>$  is set to "1", while the prescaler is cleared to zero and stops operation when  $<PRRUN>$  is set to "0". Resetting clears  $<PRRUN>$  to "0", which clears and stops the prescaler.

| Input clock            | Cycle      |            |
|------------------------|------------|------------|
|                        | $f_c$      | $16MHz$    |
| $\phi T1 (8/f_c)$      | $0.5\mu s$ | $0.4\mu s$ |
| $\phi T4 (32/f_c)$     | $2.0\mu s$ | $1.6\mu s$ |
| $\phi T16 (128/f_c)$   | $8.0\mu s$ | $6.4\mu s$ |
| $\phi T256 (2048/f_c)$ | $128\mu s$ | $102\mu s$ |



Figure 3.7 (2) Prescaler

## ② Up-counter

This is an 8-bit binary counter which counts up by the input clock pulse specified by TMOD.

The input clock of timer 0 is selected from the external clock from TI0 pin and the three internal clocks  $\phi T1$  (8/fc),  $\phi T4$  (32/fc), and  $\phi T16$  (128/fc), according to the set value of TMOD register.

The input clock of timer 1 differs depending on the operation mode. When set to 16-bit timer mode, the overflow output of timer 0 is used as the input clock. When set to any other mode than 16-bit timer mode, the input clock is selected from the internal clocks  $\phi T1$  (8/fc),  $\phi T16$  (128/fc), and  $\phi T256$  (2048/fc) as well as the comparator output (match detection signal) of timer 0 according to the set value of TMOD register.

Example : When  $TMOD < T10M1,0 > = 01$ , the overflow output of timer 0 becomes the input clock of timer 1 (16-bit timer mode).

When  $TMOD < T10M1,0 > = 00$  and  $TMOD < T1CLK1,0 > = 01$ ,  $\phi T1$  (8/fc) becomes the input of timer 1 (8bit timer mode).

Operation mode is also set by TMOD register. When reset, it is initialized to  $TMOD < T01M1, 0 > = 00$  whereby the up-counter is placed in the 8-bit timer mode.

The counting and stop & clear of up-counter can be controlled for each interval timer by the timer operation control register TRUN. When reset, all up-counters will be cleared to stop the timers.

## ③ Timer register

This is an 8-bit register for setting an interval time. When the set value of timer registers TREG0, TREG1, matches the value of up-counter, the comparator match detect signal becomes active. If the set value is 00H, this signal becomes active when the up-counter overflows.

Timer register TREG0 is of double buffer structure, each of which makes a pair with register buffer.

The timer flip-flop controll register TFFCR<DBEN> bit controls whether the double buffer structure in the TREG0 should be enabled or disabled. It is disabled when  $<DBEN> = 0$  and enabled when they are set to 1.

In the condition of double buffer enable state, the data is transferred from the register buffer to the timer register when the  $2^n - 1$  overflow occurs in PWM mode, or at the PPG cycle in PPG mode. Therefore, during timer mode, the double buffer can not be used.

When reset, it will be initialized to  $<DBEN> = 0$  to disable the double buffer. To use the double buffer, write data in the timer register, set  $<DBEN>$  to 1, and

write the following data in the register buffer.



Figure 3.7 (3) Configuration of Timer Register 0

Note : Timer register and the register buffer are allocated to the same memory address. When  $<\text{DBEN}> = 0$ , the same value is written in the register buffer as well as the timer register, while when  $<\text{DBEN}> = 1$  only the register buffer is written.

The memory address of each timer register is as follows.

TREG0: 000022H

TREG1: 000023H

All the registers are write-only and cannot be read.

#### ④ Comparator

A comparator compares the value in the up-counter with the values to which the timer register is set. When they match, the up-counter is cleared to zero and an interrupt signal (INTT0, INTT1) is generated. If the timer flip-flop inversion is enabled, the timer flip-flop is inverted at the same time.

#### ⑤ Timer flip-flop (timer F/F : TFF1)

The status of the timer flip-flop is inverted by the match detect signal (comparator output) of each interval timer and the value can be output to the timer output pins TO1 (also used as P71).

A timer F/F is provided for a pair of timer 0 and timer 1 and is called TFF1. TFF1 is output to TO1 pin.

|       |   |                                      |
|-------|---|--------------------------------------|
| PRRUN | : | Operation of prescaler               |
| T5RUN | : | Operation of 16-bit timer (timer5)   |
| T4RUN | : | Operation of 16-bit timer (timer4)   |
| P1RUN | : | Operation of PWM timer (PWM1/timer3) |
| P0RUN | : | Operation of PWM timer (PWM0/timer2) |
| T1RUN | : | Operation of 8-bit timer (timer1)    |
| T0RUN | : | Operation of 8-bit timer (timer0)    |

Figure 3.7 (4) Timer Operation Control Register (TRUN)



Figure 3.7 (5) Timer Mode control Register (TMOD)



Figure 3.7 (6) Timer Flip-flop Control Register (TFFCR)

The operation of 8-bit timers will be described below:

### (1) 8-bit timer mode

Two interval timers 0, 1, can be used independently as 8-bit interval timer. All interval timers operate in the same manner, and thus only the operation of timer 1 will be explained below.

#### ① Generating interrupts in a fixed cycle

To generate timer 1 interrupt at constant intervals using timer 1 (INTT1), first stop timer 1 then set the operation mode, input clock, and a cycle to TMOD and TREG1 register, respectively. Then, enable interrupt INTT1 and start the counting of timer 1.

Example : To generate timer 1 interrupt every 40 microseconds at  $f_c = 16$  MHz, set each register in the following manner.

|         | MSB                                 | LSB |                                                                                                     |
|---------|-------------------------------------|-----|-----------------------------------------------------------------------------------------------------|
|         | 7 6 5 4 3 2 1 0                     |     |                                                                                                     |
| TRUN    | $\leftarrow - X - - - - 0 -$        |     | Stop timer 1, and clear it to "0".                                                                  |
| TMOD    | $\leftarrow 0\ 0\ X\ X\ 0\ 1\ -\ -$ |     | Set the 8-bit timer mode, and select $\phi T1$ ( $0.5\ \mu s$ @ $f_c = 16$ MHz) as the input clock. |
| TREG1   | $\leftarrow 0\ 1\ 0\ 1\ 0\ 0\ 0\ 0$ |     | Set the timer register at $40\ \mu s$ $\phi T1 = 50H$ .                                             |
| INTET10 | $\leftarrow 1\ 1\ 0\ 1\ -\ -\ -$    |     | Enable INTT1, and set it to "Level 5".                                                              |
| TRUN    | $\leftarrow 1\ X\ -\ -\ -\ 1\ -$    |     | Start timer 1 counting.                                                                             |

Note : X:don't care-; no change

Use the following table for selecting the input clock.

Table 3.7 (1) 8-Bit Timer Interrupt Cycle and Input Clock

| Input clock                | Interrupt cycle<br>(at $f_c = 16$ MHz) | Resolution   | Interrupt cycle<br>(at $f_c = 20$ MHz) | Resolution     |
|----------------------------|----------------------------------------|--------------|----------------------------------------|----------------|
| $\phi T1$ ( $8/f_c$ )      | $0.5\ \mu s \sim 128\ \mu s$           | $0.5\ \mu s$ | $0.4\ \mu s \sim 102.4\ \mu s$         | $0.4\ \mu s$   |
| $\phi T4$ ( $32/f_c$ )     | $2\ \mu s \sim 512\ \mu s$             | $2\ \mu s$   | $1.6\ \mu s \sim 409.6\ \mu s$         | $1.6\ \mu s$   |
| $\phi T16$ ( $128/f_c$ )   | $8\ \mu s \sim 2.048\ ms$              | $8\ \mu s$   | $6.4\ \mu s \sim 1.638\ ms$            | $6.4\ \mu s$   |
| $\phi T256$ ( $2048/f_c$ ) | $128\ \mu s \sim 32.708\ ms$           | $128\ \mu s$ | $102.4\ \mu s \sim 2.621\ ms$          | $102.4\ \mu s$ |

Note : The input clock of timer 0 and timer 1 are different from as follows.

Timer 0 : TI0 input,  $\phi T1$ ,  $\phi T4$ ,  $\phi T16$

Timer 1 : Match Output of Timer 0,  $\phi T1$ ,  $\phi T16$ ,  $\phi T256$

② Generating a 50% duty square wave pulse

The timer flip-flop (TFF1) is inverted at constant intervals, and its status is output to timer output pin (TO1).

Example : To output a  $3.0 \mu\text{s}$  square wave pulse from TO1 pin at  $f_c = 16 \text{ MHz}$ , set each register in the following procedures. Either timer 0 or timer 1 may be used, but this example uses timer 1.

|                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                              |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $\begin{matrix} 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \end{matrix}$<br>TRUN $\leftarrow - X - - - - 0 -$<br>TMOD $\leftarrow 0 \ 0 \ X \ X \ 0 \ 1 \ - -$<br><br>TREG1 $\leftarrow 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 1 \ 1$<br>TFFCR $\leftarrow - - - - 1 \ 0 \ 1 \ 1$<br><br>P7CR $\leftarrow X \ X \ X \ X - - 1 -$<br>P7FC $\leftarrow X \ X \ X \ X - - 1 \ X$<br>TRUN $\leftarrow 1 \ X - - - - 1 -$ | Stop timer 1, and clear it to "0".<br>Set the 8-bit timer mode, and select $\phi T1$ ( $0.5 \mu\text{s} @ f_c = 16 \text{ MHz}$ ) as the input clock.<br>Set the timer register at $3.0 \mu\text{s} \div \phi T1 \div 2 = 3$ .<br>Clear TFF1 to "0", and set to invert by the match detect signal from timer 1.<br><br>Select P71 as TO1 pin.<br><br>Start timer 1 counting. |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Note : X ; don't care    - ; no change



Figure 3.7 (7) Square Wave (50% Duty) Output Timing Chart

③ Making timer 1 count up by match signal from timer 0 comparator

Set the 8-bit timer mode, and set the comparator output of timer 0 as the input clock to timer 1.



Figure 3.7 (8) Timer 1 count up by timer 0

④ Output inversion with software

The value of timer flip-flop (TFF1) can be inverted, independent of timer operation.

Writing “00” into TFFCR<TFF1C1, 0> (memory address : 000025h of bit 3 and bit 2) inverts the value of TFF1.

⑤ Initial setting of timer flip-flop (TFF1)

The value of TFF1 can be initialized to “0” or “1”, independent of timer operation.

For example, write “10” in TFFCR<TFF1C1,0> to clear TFF1 to “0”, while write “01” in TFFCR<TFF1C1,0> to set TFF1 to “1”.

Note: The value of timer register cannot be read.

(2) 16-bit timer mode

A 16-bit interval timer is configured by using the pair of timer 0 and timer 1.

To make a 16-bit interval timer by cascade connecting timer 0 and timer 1, set timer 0/timer 1 mode register TMOD<T10M1,0> to “0, 1”.

When set in 16-bit timer mode, the overflow output of timer 0 will become the input clock of timer 1, regardless of the set value of TMOD<T1CLK1,0>. Table 3.7 (2) shows the relation between the cycle of timer (interrupt) and the selection of input clock.

Table 3.7 (2) 16-Bit Timer (Interrupt) and Input Clock

| Input clock         | Interrupt cycle (fc = 16MHz) | Resolution  | Interrupt cycle (fc = 20MHz) | Resolution  |
|---------------------|------------------------------|-------------|------------------------------|-------------|
| $\phi T1$ (8/fc)    | 0.5 $\mu s$ ~ 32.786ms       | 0.5 $\mu s$ | 0.4 $\mu s$ ~ 26.214ms       | 0.4 $\mu s$ |
| $\phi T4$ (32/fc)   | 2 $\mu s$ ~ 131.072ms        | 2 $\mu s$   | 1.6 $\mu s$ ~ 104.857ms      | 1.6 $\mu s$ |
| $\phi T16$ (128/fc) | 8 $\mu s$ ~ 524.288ms        | 8 $\mu s$   | 6.4 $\mu s$ ~ 419.430ms      | 6.4 $\mu s$ |

The lower 8 bits of the timer (interrupt) cycle are set by the timer register TREG0, and the upper 8 bits are set by TREG1. Note that TREG0 always must be set first. (Writing data into TREG0 disables the comparator temporarily, and the comparator is restarted by writing data into TREG1.)

Setting example: To generate an interrupt INTT1 every 0.5 seconds at  $f_c = 16$  MHz, set the following values for timer registers TREG0 and TREG1.

When counting with input clock of  $\phi_{T16}$  ( $8\mu s$  @ 16 MHz)

$$0.5s \div 8\mu s = 62500 = F424H$$

Therefore, set TREG1=F4H and TREG0=24H, respectively.

The comparator match signal is output from timer 0 each time the up-counter UC0 matches TREG0, where the up-counter UC0 is not be cleared. And the interrupt INT0 is not generated.

With the timer 1 comparator, the match detect signal is output at each comparator timing when up-counter UC1 and TREG1 values match. When the match detect signal is output simultaneously from both comparators of timer 0 and timer 1, the up-counters UC0 and UC1 are cleared to "0", and only the interrupt INTT1 is generated. If inversion is enabled, the value of the timer flip-flop TFF1 is inverted.

Example : When TREG1=04H and TREG0=80H



Figure 3.7 (9) Output timer by 16-bit timer mode

### (3) 8-bit PPG (Programmable Pulse Generation) Output mode

Square wave pulse can be generated at any frequency and duty by timer 0 and timer 1. The output pulse may be either low-active or high-active. In this mode, timer 1 cannot be used.

Timer 0 outputs pulse to TO1 pin (also used as P70).

In this mode, a programmable square wave is generated by inverting timer output each time the 8-bit up-counter (UC0) matches the timer registers TREG0 and TREG1.

However, it is required that the set value of TREG0 is smaller than that of TREG1.

Though the up-counter (UC1) of timer 1 is not used in this mode, UC1 should be set for counting by setting TRUN<T1RUN> to 1.

Figure 3.7 (11) shows the block diagram for this mode.



Figure 3.7 (10) 8bit PPG output waveforms



Figure 3.7 (11) Block Diagram of 8-Bit PPG Output Mode

When the double buffer of TREG0 is enabled in this mode, the value of register buffer will be shifted in TREG0 each time TREG1 matches UC0.

Use of the double buffer makes easy the handling of low duty waves (when duty is varied).



Figure 3.7 (12) Operation of Register buffer

Example : Generating 1/4 duty 50 kHz pulse (@ fc=16 MHz)



- Calculate the value to be set for timer register.

To obtain the frequency 50 kHz, the pulse cycle t should be :  $t = 1/50 \text{ kHz} = 20 \mu\text{s}$ .

Given  $\phi T1 = 0.5 \mu\text{s}$  (@ 16 Hz),

$$20 \mu\text{s} \div 0.5 \mu\text{s} = 40$$

Consequently, to set the timer register 1 (TREG1) to  $TREG1 = 40 = 28H$

and then duty to 1/4,  $t \times 1/4 = 20 \mu\text{s} \times 1/4 = 5 \mu\text{s}$

$$5 \mu\text{s} \div 0.5 \mu\text{s} = 10$$

Therefore, set timer register 0 (TREG0) to  $TREG0 = 10 = 0AH$ .

|       |              |   |   |   |   |   |       |
|-------|--------------|---|---|---|---|---|-------|
| 7     | 6            | 5 | 4 | 3 | 2 | 1 | 0     |
| TRUN  | $\leftarrow$ | - | X | - | - | - | 0 0   |
| TMOD  | $\leftarrow$ | 1 | 0 | X | X | X | 0 1   |
| TREG0 | $\leftarrow$ | 0 | 0 | 0 | 0 | 1 | 0 1 0 |
| TREG1 | $\leftarrow$ | 0 | 0 | 1 | 0 | 1 | 0 0 0 |
| TFFCR | $\leftarrow$ | - | - | X | 0 | 1 | 1 X   |
|       |              |   |   |   |   |   |       |
| P7CR  | $\leftarrow$ | X | X | X | X | - | - 1 - |
| P7FC  | $\leftarrow$ | X | X | X | X | - | - 1 X |
| TRUN  | $\leftarrow$ | 1 | X | - | - | - | 1 1   |

Stop timer 0, and clear it to "0".

Set the 8-bit PPG mode, and select  $\phi T1$  as input clock.

Write "0AH".

Write "28H".

Sets TFF1 and enable the inversion.

Writing "10" provides negative logic pulse.

Set P71 as the TO1 pin.

Start timer 0 and timer 1 counting.

Note : X ; don't care    - ; no change

#### (4) 8-bit PWM Output mode

This mode is valid only for timer 0. In this mode, maximum 8-bit resolution of PWM pulse can be output.

PWM pulse is output to TO1 pin (also used as P71) when using timer 0. Timer 1 can also be used as 8-bit timer.

Timer output is inverted when up-counter (UC0) matches the set value of timer register TREG0 or when  $2n - 1$  ( $n = 6, 7$ , or  $8$ ; specified by T01MOD<PWM01,0>) counter overflow occurs. Up-counter UC0 is cleared when  $2n - 1$  counter overflow occurs. For example, when  $n = 6$ , 6-bit PWM will be outputted, while when  $n = 7$ , 7-bit PWM will be outputted.

To use this PWM mode, the following conditions must be satisfied.

(Set value of timer register) < (Set value of  $2^n - 1$  counter overflow)

(Set value of timer register) ≠ 0



Figure 3.7(13) 8-bit PWM waveforms

Figure 3.7 (14) shows the block diagram of this mode.



Figure 3.7 (14) Block Diagram of 8-Bit PWM Mode

In this mode, the value of register buffer will be shifted in TREG0 if  $2^n - 1$  overflow is detected when the double buffer of TREG0 is enabled.

Use of the double buffer makes easy the handling of small duty waves.



Figure 3.7 (15) Operation of Register buffer

Example : To output the following PWM waves to TO1 pin at fc=16 MHz.



To realize 63.5 μs of PWM cycle by φT1 = 0.5 μs (@fc = 16 MHz),

$$63.5 \mu\text{s} \div 0.5 \mu\text{s} = 127 = 2^7 - 1$$

Consequently, n should be set to 7.

As the period of low level is 36 μs, for φT1 = 0.5 μs,  
set the following value for TREG0.

$$36 \mu\text{s} \div 0.5 \mu\text{s} = 72 = 48\text{H}$$

|                                        | MSB<br>7 6 5 4 3 2 1 0       | LSB |                                                                                 |
|----------------------------------------|------------------------------|-----|---------------------------------------------------------------------------------|
| TRUN                                   | $\leftarrow - X - - - - 0$   |     | Stop timer 0, and clear it to "0".                                              |
| TMOD                                   | $\leftarrow 1 1 1 0 - - 0 1$ |     | Set 8-bit PWM mode (cycle: $2^7 - 1$ ) and select $\phi T1$ as the input clock. |
| TREG0                                  | $\leftarrow 0 1 0 0 1 0 0 0$ |     | Writes "48H".                                                                   |
| TFFCR                                  | $\leftarrow X X X X 1 0 1 X$ |     | Clears TFF1, enable the inversion.                                              |
| P7CR                                   | $\leftarrow X X X X - - 1 -$ | }   | Set P71 as the TO1 pin.                                                         |
| P7FC                                   | $\leftarrow X X X X - - 1 X$ |     | Start timer 0 counting.                                                         |
| TRUN                                   | $\leftarrow 1 X - - - - 1$   |     |                                                                                 |
| Note : X ; don't care    - ; no change |                              |     |                                                                                 |

Table 3.7 (3) PWM Cycle and the Setting of  $2^n - 1$  Counter

|                   | PWM cycle (@ fc = 16MHz) |                      |                  | PWM cycle (@ fc = 20MHz) |                       |                  |
|-------------------|--------------------------|----------------------|------------------|--------------------------|-----------------------|------------------|
|                   | $\phi T1$                | $\phi T4$            | $\phi T16$       | $\phi T1$                | $\phi T4$             | $\phi T16$       |
| 2 <sup>6</sup> -1 | 31.5 $\mu$ s (31.7kHz)   | 126 $\mu$ s (7.9kHz) | 0.50ms (1.9kHz)  | 25.2 $\mu$ s (39.0kHz)   | 100 $\mu$ s (10.0kHz) | 0.40ms (2.4kHz)  |
| 2 <sup>7</sup> -1 | 63.5 $\mu$ s (15.7kHz)   | 254 $\mu$ s (3.9kHz) | 1.01ms (0.98kHz) | 50.8 $\mu$ s (19.7kHz)   | 203 $\mu$ s (4.9kHz)  | 0.81ms (1.2kHz)  |
| 2 <sup>8</sup> -1 | 127 $\mu$ s (7.8kHz)     | 510 $\mu$ s (1.9kHz) | 2.04ms (0.49kHz) | 102 $\mu$ s (9.80kHz)    | 408 $\mu$ s (2.4kHz)  | 1.63ms (0.61kHz) |

(5) Table 3.7 (4) shows the list of 8-bit timer modes.

Table 3.7 (4) Timer Mode Setting Registers

| Register name            | TMOD       |                                                                         |                                                              |                                                                     | TFFCR                                          |
|--------------------------|------------|-------------------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------|------------------------------------------------|
| Name of function in      | T10M       | PWMM                                                                    | T1CLK                                                        | T0CLK                                                               | TFF1IS                                         |
| Function                 | Timer mode | PWM0 cycle                                                              | Upper timer input clock                                      | Lower timer input clock                                             | Timer F/F invert signal select                 |
| 16-bit timer mode        | 01         | -                                                                       | -                                                            | External clock,<br>$\phi T1, \phi T4, \phi T16$<br>(00, 01, 10, 11) | -                                              |
| 8-bit timer x 2 channels | 00         | -                                                                       | Lower timer match:<br>$\phi T1, 16, 256$<br>(00, 01, 10, 11) | External clock,<br>$\phi T1, \phi T4, \phi T16$<br>(00, 01, 10, 11) | 0: Lower timer output<br>1: Upper timer output |
| 8-bit PPG x 1 channel    | 10         | -                                                                       | -                                                            | External clock,<br>$\phi T1, \phi T4, \phi T16$<br>(00, 01, 10, 11) | -                                              |
| 8-bit PWM x 1 channel    | 11         | 2 <sup>6</sup> -1, 2 <sup>7</sup> -1, 2 <sup>8</sup> -1<br>(01, 10, 11) | -                                                            | External clock,<br>$\phi T1, \phi T4, \phi T16$<br>(00, 01, 10, 11) | -                                              |
| 8-bit timer x 1 channel  | 11         | -                                                                       | $\phi T1, \phi T16, \phi T256$<br>(01, 10, 11)               | -                                                                   | Output disabled                                |

Note : - ; Don't care

### 3.8 8-bit PWM Timer

The TMP96C141 has two built-in 8-bit PWM timers (timers 2 & 3).

They have two operating modes.

- 8-bit PWM (pulse width modulation: variable duty at fixed interval) output mode
- 8-bit interval timer mode

Figure 3.8 (1) is a block diagram of 8-bit PWM timer (timers 2 & 3).

PWM timers consist of an 8-bit up-counter, 8-bit comparator, and 8-bit timer register. Two timer flip-flops (TFF2 for timer 2 and TFF3 for timer 3) are provided.

Input clocks  $\phi P1$ ,  $\phi P4$ , and  $\phi P16$  for the PWM timers can be obtained using the built-in prescaler.

PWM timer operating mode and timer flip-flops are controlled by four control registers (P0MOD, P1MOD, PFFCR, and TRUN).



Figure3.8 (1) Block diagram of 8-bit PWM timer 0 (timer 2)

Note: Block diagram for 8-bit PWM timer 1 (timer 3) is the same as the above diagram.

## ① Prescaler

Generates input clocks dedicated to PWM timers by further dividing the fundamental clock ( $f_c$ ) after it has been divided by 2 ( $f_c/2$ ). Since the register used to control the prescaler is the same as the one for other timers, the prescaler cannot be operated independently.

The PWM timer uses three input clocks:  $\phi/P1$ ,  $\phi/P4$ , and  $\phi/P16$ .

Like the 9-bit prescaler described in the 8-bit timer section, this prescaler can be counted/stopped using bit 7 <PRRUN> of the timer operation control register TRUN. Setting <PRRUN> to 1 starts counting; setting it to 0 zero-clears and stops counting. Resetting clears <PRRUN> to 0, which clears and stops the prescaler.



Figure3.8 (2) Prescaler

## ② Up-counter

An 8-bit binary counter which counts up using the input clock specified by PWM mode register (P0MOD or P1MOD).

The input clock for the PWM0/PWM1 is selected from the internal clocks  $\phi/P1$ ,  $\phi/P4$ , and  $\phi/P16$  (PWM dedicated prescaler output) depending on the value set in the P0MOD/P1MOD register.

Operating mode is also set by P0MOD and P1MOD registers. At reset, they are initialized to P0MOD<PWM0M> = 0 and P1MOD<PWM1M> = 0, thus, the up-counter is in PWM mode. In PWM mode, the up-counter is cleared when a  $2^n-1$  overflow occurs; in timer mode, the up-counter is cleared at compare and match.

Count/stop & clear of the up-counter can be controlled for each PWM timer using the timer operation control register TRUN. Resetting clears all up-counters and stops timers.

### ③ Timer registers

Two 8-bit registers used for setting an interval time. When the value set in the timer registers (TREG2 & 3) matches the value in the up-counter, the match detect signal of the comparator becomes active.

Timer registers TREG2 and TREG3 are each paired with register buffer to make a double buffer structure.

TREG2 and TREG3 are controlled double buffer enable/disable by P0MOD <DB2EN> and P1MOD <DB3EN> : disabled when <DB2EN> / <DB3EN> = 0, enabled when <DB2EN> / <DB3EN> = 1.

Data is transferred from register buffer to timer register when a  $2^n-1$  overflow occurs in PWM mode, or when compare and match occurs in 8-bit timer mode. That is, with a PWM timer, the timer mode can be operated in double buffer enable state, unlike timer mode for timers 0 and 1.

At reset, <DB2EN>/<DB3EN> is initialized to 0 to disable double buffer. To use double buffer, write the data in the timer register at first, then set <DB2EN> / <DB3EN> to 1, and write the following data in the register buffer.





Figure 3.8 (3) Structure of Timer Registers 2 & 3

Note : The timer register and register buffer are allocated to the same memory address. When  $<\text{DB2EN}>/<\text{DB3EN}> = 0$ , the same value is written to both register buffer and timer register. When  $<\text{DB2EN}>/<\text{DB3EN}> = 1$ , the value is written to the register buffer only.

Memory addresses of the timer registers are as follows:

TREG2 : 000026H  
TREG3 : 000027H

Both timer registers are write only; however, register buffer values can be read when reading the above addresses.

#### ④ Comparator

Compares the value in the up-counter with the value in the timer register (TREG2/TREG3). When they match, the comparator outputs the match detect signal. A timer interrupt (INTT2/INTT3) is generated at compare and match if the interrupt select bit  $<\text{PWM0INT}>/<\text{PWM1NT}>$  of the mode register (P0MOD/P1MOD) is set to 1. In timer mode, the comparator clears the up-counter to 0 at compare and match. It also inverts the value of the timer flip-flop if timer flip-flop invert is enabled.

#### ⑤ Timer flip-flop

The value of the timer flip-flop is inverted by the match detect signal (comparator output) of each interval timer or  $2^n-1$  overflow. The value can be output to the timer output pin TO2/TO3 (also used as P72/P73).

|             | 7                     | 6                 | 5                                      | 4                            | 3                                                                       | 2                                                  | 1      | 0      |
|-------------|-----------------------|-------------------|----------------------------------------|------------------------------|-------------------------------------------------------------------------|----------------------------------------------------|--------|--------|
| bit Symbol  | FF2RD                 | DB2EN             | PWM0INT                                | PWM0M                        | T2CLK1                                                                  | T2CLK0                                             | PWM0S1 | PWM0S0 |
| Read/Write  | R                     |                   |                                        |                              | W                                                                       |                                                    |        |        |
| After reset | -                     | 0                 | 0                                      | 0                            | 0                                                                       | 0                                                  | 0      | 0      |
| Function    | Flip-flop output data | 1: Double Buffer2 | 0: 2 <sup>n-1</sup> overflow interrupt | 0: PWM mode<br>1: Timer mode | 00: φP1 (fc/4)<br>01: φP4 (fc/16)<br>10: φP16 (fc/64)<br>11: Don't care | 00: 26-1<br>01: 27-1<br>10: 28-1<br>11: Don't care |        |        |

Read-modify-write is prohibited.



Figure3.8 (4) 8-bit PWM0 mode control register



Figure 3.8 (5) 8-bit PWM1 mode control register



Figure 3.8 (6) 8-bit PWM F/F control register



Figure 3.8 (7) Timer operation control register (TRUN)

The following explains PWM timer operations.

### (1) PWM timer mode

Both PWM timers can output 8-bit resolution PWM independently. Since both timers operate in exactly the same way, PWM0 is used for the purposes of explanation.

PWM output changes under the following two conditions.

Condition 1:

- TFF2 is cleared to 0 when the value in the up-counter (UC2) and the value set in the TREG2 match.
- TFF2 is set to 1 when a  $2^n-1$  counter overflow ( $n = 6, 7$ , or  $8$ ) occurs.

Condition 2:

- TFF2 is set to 1 when the value in the up-counter (UC2) and the value set in TREG2 match.
- TFF2 is cleared to 0 when a  $2^n-1$  counter overflow ( $n = 6, 7$ , or  $8$ ) occurs.

The up-counter (UC2) is cleared by a  $2^n-1$  counter overflow.

The PWM timer can output 0%-100% duty pulses because a  $2^n-1$  counter overflow has a higher priority. That is, to obtain 0% output (always low), the mode used to set TFF2 to 0 due to overflow (PFFCR<FF2TRG1,0> = 1,0) must be set and  $2^n-1$  (Value for overflow) must be set in TREG2. To obtain 100% output (always high), the mode must be changed: PFFCR<FF2TRG1,0> = 1,1 then the same operation is required.

### PWM timing



Figure3.8 (8) Output Waves in PWM Timer Mode

Note: The above waves are obtained in a mode where the F/F is set by a match with the timer register (TREG) and reset by an overflow.

Figure 3.8 (9) is a block diagram of this mode.



Figure 3.8 (9) Block diagram of PWM Timer Mode (PWM0)

In this mode, enabling double buffer is very useful. The register buffer value shifts into TREG2 when a  $2^n-1$  overflow is detected, when double buffer is enabled.

Using double buffer makes handling small duty waves easy.



Figure 3.8 (10) Register Buffer Operation

Example: To output the following PWM waves to TO2 pin using PWM0 at  
 $f_c = 16 \text{ MHz}$



To implement  $31.75\mu\text{s}$  PWM cycle by  $\phi P1 = 0.25\mu\text{s}$  (@ $f_c = 16 \text{ MHz}$ )

$$31.75\mu\text{s} \div 0.25\mu\text{s} = 127 = 2^7 - 1.$$

Consequently, set n to 7.

Since the low level cycle =  $15\mu\text{s}$ ; for  $\phi P1 = 0.25\mu\text{s}$

$$15\mu\text{s} \div 0.25\mu\text{s} = 60 = 3\text{CH}$$

set the 3CH in TREG2.

|       |                              |    |                                                                                                            |
|-------|------------------------------|----|------------------------------------------------------------------------------------------------------------|
|       | 7 6 5 4 3 2 1 0              |    |                                                                                                            |
| TRUN  | $\leftarrow$ - X - - - 0 - - |    | Stops PWM0 and clears it to 0.                                                                             |
| P0MOD | $\leftarrow$ - 0 0 0 0 0 0 1 |    | Sets PWM (2 <sup>7</sup> -1) mode, input clock $\phi P1$ , overflow interrupt, and disables double buffer. |
| TREG2 | $\leftarrow$ 0 0 1 1 1 1 0 0 |    | Writes 3CH.                                                                                                |
| P0MOD | $\leftarrow$ 1 0 0 0 0 0 1   |    | Enables double buffer.                                                                                     |
| PFFCR | $\leftarrow$ - - - - 0 1 1 1 |    | Sets TFF2 and a mode where TFF2 is set by compare and match, and cleared by overflow.                      |
| P7CR  | $\leftarrow$ X X X X - 1 - - | {} | Sets P72 as TO2 pin                                                                                        |
| P7FC  | $\leftarrow$ X X X X - 1 - X |    |                                                                                                            |
| TRUN  | $\leftarrow$ 1 X - - - 1 - - |    | Starts PWM0 counting.                                                                                      |

Note: X; don't care      - ; no change

Table 3.8 (1) PWM Cycle and  $2^n - 1$  Counter Setting

|      | Formula               | 16MHz                        |                                |                                | 20MHz                        |                                |                              |
|------|-----------------------|------------------------------|--------------------------------|--------------------------------|------------------------------|--------------------------------|------------------------------|
|      |                       | $\phi P1$                    | $\phi P4$                      | $\phi P16$                     | $\phi P1$                    | $\phi P4$                      | $\phi P16$                   |
| 26-1 | $26-1 \times \phi Pn$ | $15.8\mu\text{s}$<br>(63kHz) | $63.0\mu\text{s}$<br>(16kHz)   | $252\mu\text{s}$<br>(3.9kHz)   | $12.6\mu\text{s}$<br>(79kHz) | $50.4\mu\text{s}$<br>(20kHz)   | $201\mu\text{s}$<br>(4.9kHz) |
| 27-1 | $27-1 \times \phi Pn$ | $31.8\mu\text{s}$<br>(31kHz) | $127.0\mu\text{s}$<br>(7.9kHz) | $508\mu\text{s}$<br>(1.9kHz)   | $25.4\mu\text{s}$<br>(39kHz) | $101.6\mu\text{s}$<br>(9.8kHz) | $406\mu\text{s}$<br>(2.5kHz) |
| 28-1 | $28-1 \times \phi Pn$ | $63.8\mu\text{s}$<br>(16kHz) | $255.0\mu\text{s}$<br>(3.9kHz) | $1020\mu\text{s}$<br>(0.98kHz) | $51.0\mu\text{s}$<br>(20kHz) | $204.0\mu\text{s}$<br>(4.9kHz) | $816\mu\text{s}$<br>(1.2kHz) |

## (2) 8-bit timer mode

Both PWM timers can be used independently as 8-bit interval timers. Since both timers operate in exactly the same way, PWM0 (timer 2) is used for the purposes of explanation.

## ① Generating interrupts at a fixed interval

To generate timer 2 interrupt (INTT2) at a fixed interval using PWM0 timer, first stop PWM0, then set the operating mode, input clock, and interval in the P0MOD and TREG2 registers. Next, enable INTT2 and start counting PWM0.

Example: To generate a timer 2 interrupt every  $40\ \mu s$  at  $f_c = 16\text{MHz}$ , set registers as follows:

|          | 7 6 5 4 3 2 1 0   |                                                                                      |
|----------|-------------------|--------------------------------------------------------------------------------------|
| TRUN     | ← - X - - - 0 - - | Stops PWM0 and clears it to 0.                                                       |
| P0MOD    | ← X 0 1 1 0 0 X X | Sets 8-bit timer mode and selects $\phi P1$ ( $0.25\ \mu s$ ) and compare interrupt. |
| TREG2    | ← 1 0 1 0 0 0 0 0 | Sets $40\ \mu s/0.25\ \mu s = A0H$ in timer register.                                |
| INTEPW10 | ← - - - - 1 1 0 0 | Enables INTT2 and sets interrupt level 4.                                            |
| TRUN     | ← 1 X - - - 1 - - | Starts counting PWM0.                                                                |

Note: X ; don't care      - ; no change

Select an input clock using the table below.

Table 3.8 (2) Interrupt Cycle and Input Clock Selection using 8-bit timer mode

| Input clock         | Interrupt cycle (@ $f_c = 16\text{MHz}$ ) | Resolution    | Interrupt cycle (@ $f_c = 20\text{MHz}$ ) | Resolution   |
|---------------------|-------------------------------------------|---------------|-------------------------------------------|--------------|
| $\phi P1 (4/f_c)$   | $0.25\ \mu s \sim 64\ \mu s$              | $0.25\ \mu s$ | $0.2\ \mu s \sim 51.2\ \mu s$             | $0.2\ \mu s$ |
| $\phi P4 (16/f_c)$  | $1\ \mu s \sim 256\ \mu s$                | $1\ \mu s$    | $0.8\ \mu s \sim 204.8\ \mu s$            | $0.8\ \mu s$ |
| $\phi P16 (64/f_c)$ | $4\ \mu s \sim 1024\ \mu s$               | $4\ \mu s$    | $3.2\ \mu s \sim 819.2\ \mu s$            | $3.2\ \mu s$ |

Note: To generate interrupts in 8-bit timer mode, bit 5 (interrupt control bit <PWM0INT> / <PWM1NT> of P0MOD/P1MOD) must be set to 1.

## ② Generating a 50% square wave

To generate a 50% square wave, invert the timer flip-flop at a fixed interval and output the timer flip-flop value to the timer output pin (TO2).

Example: To output a  $3.0\ \mu s$  square wave at  $f_c = 16\ MHz$  from TO2 pin, set registers as follows.

|                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $\begin{matrix} 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \end{matrix}$<br>$\text{TRUN} \leftarrow -X----0--$<br>$\text{P0MOD} \leftarrow X\ 0\ 1\ 1\ 0\ 0\ X\ X$<br><br>$\text{TREG2} \leftarrow 0\ 0\ 0\ 0\ 1\ 1\ 0$<br>$\text{PFFCR} \leftarrow ---1\ 0\ 0\ 1$<br>$\text{P7CR} \leftarrow X\ X\ X\ X\ -1--$<br>$\text{P7FC} \leftarrow X\ X\ X\ X\ -1-X \quad \}$<br>$\text{TRUN} \leftarrow 1\ X----1--$ | Stops PWM0 and clears it to 0.<br>Sets 8-bit timer mode and selects $\phi P1$ ( $0.25\ \mu s$ ) as the input clock.<br>Sets $3.0\ \mu s / 0.25\ \mu s / 2 = 6$ in the timer register.<br>Clears TFF2 to 0 and inverts using comparator output.<br>Sets P72 as TO2 pin.<br>Starts counting PWM0. |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Note: X; don't care    -; no change



Figure3.8 (11) Square Wave (50% Duty) Output Timing Chart

This mode is as shown in Figure 3.8 (12) below.



Figure 3.8 (12) Block Diagram of 8-bit Timer Mode

### 3.9 16-bit Timer

TMP96C141 has two (timer 4 and timer 5) multifunctional 16-bit timer/event counter with the following operation modes.

- 16-bit interval timer mode
- 16-bit event counter mode
- 16-bit programmable pulse generation (PPG) mode
- Frequency measurement mode
- Pulse width measurement mode
- Time differential measurement mode

Timer/event counter consists of 16-bit up-counter, two 16-bit timer registers, two 16-bit capture registers (One of them applies double-buffer), two comparators, capture input controller, and timer flip-flop and the control circuit.

Timer/event counter is controlled by 4 control registers: T4MOD/T5MOD, T4FFCR / T5FFCR, TRUN and T45CR.

Figure 3.9 (1), (2) shows the block diagram of 16-bit timer/event counter (timer 4 and timer 5).





Figure 3.9 (1) Block Diagram of 16-Bit Timer (Timer 4)



Figure 3.9 (2) Block Diagram of 16-Bit Timer (Timer 5)



Figure 3.9 (3) 16-Bit Timer Mode Controller Register (T4MOD) (1/2)

|                  |                                            | 7      | 6                                        | 5                         | 4       | 3                   | 2                    | 1      | 0      |
|------------------|--------------------------------------------|--------|------------------------------------------|---------------------------|---------|---------------------|----------------------|--------|--------|
| T4MOD<br>(0038H) | bit Symbol                                 | CAP2T5 | EQ5T5                                    | CAP1IN                    | CAP12M1 | CAP12M0             | CLE                  | T4CLK1 | T4CLK0 |
|                  | Read/Write                                 | R/W    |                                          | W                         | R/W     |                     | R/W                  | R/W    |        |
|                  | After reset                                | 0      | 0                                        | 1                         | 0       | 0                   | 0                    | 0      | 0      |
| Function         | TFF5 invert trigger                        |        | 0: Soft-Capture                          | Capture timing            |         | 1: UC4 Clear Enable | Timer 4 source clock |        |        |
|                  | 0: Disable trigger                         |        | 0: Disable                               | INT4 occurs at rise edge. |         | 00: T14             | 00: T14              |        |        |
|                  | 1: Enable trigger                          |        | 1: don't care                            | 01: TI4↑ TIS↑             |         | 01: φT1             | 01: φT1              |        |        |
|                  | Invert when the UC value is loaded to CAP2 |        | Invert when the up-counter matches TREG5 | INT4 occurs at rise edge. |         | 10: TI4↑ TI4↓       | 10: φT4              |        |        |
|                  |                                            |        |                                          | INT4 occurs at fall edge. |         | 11: TFF1↑ TFF1↓     | 11: φT16             |        |        |
|                  |                                            |        |                                          | INT4 occurs at rise edge. |         |                     |                      |        |        |

#### → Capture timing of timer4

|    | Capture control                        | INT4 control                                           |
|----|----------------------------------------|--------------------------------------------------------|
| 00 | Capture disable                        | Interrupt occurs at the rise edge of TI4 (INT1) input. |
| 01 | CAP1 at TI4 rise<br>CAP2 at TI5 rise   | Interrupt occurs at the fall edge of TI4 (INT1) input. |
| 10 | CAP1 at TI4 rise<br>CAP2 at TI4 fall   | Interrupt occurs at the rise edge of TI4 (INT1) input. |
| 11 | CAP1 at TFF1 rise<br>CAP2 at TFF1 fall | Interrupt occurs at the fall edge of TI4 (INT1) input. |

→ Software capture

|   |                                                             |
|---|-------------------------------------------------------------|
| 0 | The up-counter4 value is loaded to CAP1 (software capture). |
| 1 | Always read as "1".                                         |

→ Timer flip-flop 5 (TFF5) invert trigger

|   |                                      |
|---|--------------------------------------|
| 0 | Trigger disable (Invert Prohibition) |
| 1 | Trigger enable (Invert permission)   |

CAP2T5 : Invert when the up-counter value is loaded to CAP2  
EQ5T5 : Invert when the up-counter matches TREG5

Figure 3.9 (4) 16-Bit Timer Controller Register (T4MOD) (2/2)

|             | 7                                                                                               | 6                                                                                                                | 5                                          | 4                                | 3                                | 2                                                                                                | 1      | 0      |
|-------------|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|--------------------------------------------|----------------------------------|----------------------------------|--------------------------------------------------------------------------------------------------|--------|--------|
| bit Symbol  | TFF5C1                                                                                          | TFF5C0                                                                                                           | CAP2T4                                     | CAP1T4                           | EQ5T4                            | EQ4T4                                                                                            | TFF4C1 | TFF4C0 |
| Read/Write  | W                                                                                               | R/W                                                                                                              | R/W                                        | R/W                              | R/W                              | R/W                                                                                              | W      |        |
| After reset | 0                                                                                               | 0                                                                                                                | 0                                          | 0                                | 0                                | 0                                                                                                | 0      | 0      |
| Function    | 00: Invert TFF5<br>01: Set TFF5<br>10: Clear TFF5<br>11: don't care<br><br>Always read as "11". | TFF4 invert trigger<br>0: Disable trigger<br>1: Enable trigger<br><br>Invert when the UC value is loaded to CAP2 | Invert when the UC value is loaded to CAP1 | Invert when the UC matches TREG5 | Invert when the UC matches TREG4 | 00: Invert TFF4<br>01: Set TFF4<br>10: Clear TFF4<br>11: don't care<br><br>※ Always read as "11" |        |        |

→ Timer flip-flop 4 (TFF4) control

|    |                                              |
|----|----------------------------------------------|
| 00 | Inverts the TFF4 value (software inversion). |
| 01 | Sets TFF4 to "1".                            |
| 10 | Clear TFF4 to "0".                           |
| 11 | Don't care (Always read as "11").            |

→ Timer flip-flop 4 (TFF4) invert trigger

|   |                                      |
|---|--------------------------------------|
| 0 | Trigger disable (Invert prohibition) |
| 1 | Trigger enable (Invert permission)   |

CAP2T4 : Invert when the up-counter value is loaded to CAP2  
CAP1T4 : Invert when the up-counter value is loaded to CAP1  
EQ5T4 : Invert when up-counter matches TREG5  
EQ4T4 : Invert when up-counter matches TREG4

→ Timer flip-flop 5 (TFF5) control

|    |                                              |
|----|----------------------------------------------|
| 00 | Inverts the TFF5 value (software inversion). |
| 01 | Set TFF5 to "1".                             |
| 10 | Clear TFF5 to "0".                           |
| 11 | Don't care (Always read as "11".)            |

Figure 3.9 (5) 16-Bit Timer 4 F/F Control (T4FFCR)

|             | 7 | 6 | 5                                | 4                                                                                                                                | 3                   | 2                                                                                   | 1      | 0      |
|-------------|---|---|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------------------------------------------------------------------------------|--------|--------|
| bit Symbol  |   |   | CAP3IN                           | CAP34M1                                                                                                                          | CAP34M0             | CLE                                                                                 | T5CLK1 | T5CLK0 |
| Read/Write  |   |   | W                                | R/W                                                                                                                              | R/W                 | R/W                                                                                 | R/W    | R/W    |
| After reset |   |   | 1                                | 0                                                                                                                                | 0                   | 0                                                                                   | 0      | 0      |
| Function    |   |   | 0: Soft-Capture<br>1: don't care | Capture timing<br>00: Disable<br>01: INT6 occurs at rise edge.<br>10: INT6 occurs at fall edge.<br>11: INT4 occurs at rise edge. | 1: UCS Clear Enable | Timer 5 source clock<br>00: TI6<br>01: $\phi T1$<br>10: $\phi T4$<br>11: $\phi T16$ |        |        |

→ Timer 5 input clock

|    |                      |
|----|----------------------|
| 00 | External clock (TI4) |
| 01 | $\phi T1$ (8/fc)     |
| 10 | $\phi T4$ (32/fc)    |
| 11 | $\phi T16$ (128/fc)  |

→ Clearing the up-counter UC5

|   |                           |
|---|---------------------------|
| 0 | Clear disable             |
| 1 | Clear by match with TREG7 |

Figure 3.9 (6) 16-bit Timer Mode Control Register (T5MOD) (1/2)



|                   | 7          | 6                                                                                                                | 5                                          | 4                                | 3                                | 2                                                                                                | 1      | 0      |
|-------------------|------------|------------------------------------------------------------------------------------------------------------------|--------------------------------------------|----------------------------------|----------------------------------|--------------------------------------------------------------------------------------------------|--------|--------|
| T5FFCR<br>(0049H) | bit Symbol |                                                                                                                  | CAP4T6                                     | CAP3T6                           | EQ7T6                            | EQ6T6                                                                                            | TFF6C1 | TFF6C0 |
| Read/Write        |            | R/W                                                                                                              | R/W                                        | R/W                              | R/W                              |                                                                                                  | W      |        |
| After reset       |            | 0                                                                                                                | 0                                          | 0                                | 0                                | 0                                                                                                | 0      | 0      |
| Function          |            | TFF6 invert trigger<br>0: Disable trigger<br>1: Enable trigger<br><br>Invert when the UC value is loaded to CAP4 | Invert when the UC value is loaded to CAP3 | Invert when the UC matches TREG7 | Invert when the UC matches TREG6 | 00: Invert TFF6<br>01: Set TFF6<br>10: Clear TFF6<br>11: don't care<br><br>※ Always read as "11" |        |        |

→ Timer flip-flop 6 (TFF6) control

|    |                                              |
|----|----------------------------------------------|
| 00 | Inverts the TFF4 value (software inversion). |
| 01 | Sets TFF6 to "1".                            |
| 10 | Clear TFF6 to "0".                           |
| 11 | Don't care (Always read as "11").            |

→ Timer flip-flop 6 (TFF6) invert trigger

|   |                                      |
|---|--------------------------------------|
| 0 | Trigger disable (Invert prohibition) |
| 1 | Trigger enable (Invert permission)   |

CAP4T6 : Invert when the up-counter value is loaded to CAP4  
 CAP3T6 : Invert when the up-counter value is loaded to CAP3  
 EQ7T6 : Invert when up-counter matches TREG7  
 EQ6T6 : Invert when up-counter matches TREG6

Figure 3.9 (8) 16-Bit Timer5 F/F Control (T5FFCR)

|                  | 7          | 6   | 5 | 4 | 3                                                                                                             | 2                                                                                                             | 1                       | 0                            |                              |
|------------------|------------|-----|---|---|---------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|-------------------------|------------------------------|------------------------------|
| T45CR<br>(003AH) | bit Symbol | —   |   |   | PG1T                                                                                                          | PG0T                                                                                                          | DB6EN                   | DB4EN                        |                              |
|                  | Read/Write | R/W |   |   |                                                                                                               | R/W                                                                                                           |                         |                              |                              |
| After reset      | 0          |     |   |   | 0                                                                                                             | 0                                                                                                             | 0                       | 0                            |                              |
|                  | Fix at "0" |     |   |   | PG1 shift<br>Trigger<br>0:8 bit<br>Timer Trigger:<br>(Timer 0, 1)<br>1: 16 bit<br>Timer Trigger:<br>(Timer 5) | PG0 shift<br>Trigger<br>0:8 bit<br>Timer Trigger:<br>(Timer 0, 1)<br>1: 16 bit<br>Timer Trigger:<br>(Timer 4) | 0: Disable<br>1: Enable | Double<br>buffer of<br>TREG6 | Double<br>buffer of<br>TREG4 |

Figure 3.9 (9) 16-Bit Timer (Timer 4, 5) Control Register (T45CR)

Figure 3.9 (10) Timer Operation Control Register (TRUN)

① Up-counter (UC4/UC5)

UC4/UC5 is a 16-bit binary counter which counts up according to the input clock specified by T4MOD<T4CLK1,0> or T5MOD<T5CLK1,0> register.

As the input clock, one of the internal clocks  $\phi T1$  (8/fc),  $\phi T4$  (32/fc), and  $\phi T16$  (128/fc) from 9-bit prescaler (also used for 8-bit timer), and external clock from TI4 pin (also used as P80/INT4 pin) or TI6 (also used as P84/INT6 pin) can be selected. When reset, it will be initialized to <T4CLK1,0> / <T5CLK1,0>=00 to select TI4/TI6 input mode. Counting or stop & clear of the counter is controlled by timer operation control register TRUN<T4RUN, T5RUN>.

When clearing is enabled, up-counter UC4/UC5 will be cleared to zero each time it coincides matches the timer register TREG5, TREG7. The “clear enable/disable” is set by T4MOD<CLE> and T5MOD<CLE>.

If clearing is disabled, the counter operates as a free-running counter.

② Timer Registers

These two 16-bit registers are used to set the interval time. When the value of up-counter UC4/UC5 matches the set value of this timer register, the comparator match detect signal will be active.

Setting data for timer register (TREG4, TREG5, TREG6 and TREG7) is executed using 2 byte date transfer instruction or using 1 byte date transfer instruction twice for lower 8 bits and upper 1 bits in order.

TREG 4

|              |              |
|--------------|--------------|
| Upper 8 bits | Lower 8 bits |
| 000031H      | 000030H      |

TREG 5

|              |              |
|--------------|--------------|
| Upper 8 bits | Lower 8 bits |
| 000033H      | 000032H      |

TREG 6

|              |              |
|--------------|--------------|
| Upper 8 bits | Lower 8 bits |
| 000041H      | 000040H      |

TREG 7

|              |              |
|--------------|--------------|
| Upper 8 bits | Lower 8 bits |
| 000043H      | 000042H      |

TREG4 and TREG6 timer register is of double buffer structure, which is paired with register buffer. The timer control register T45CR<DB4EN, DB6EN> controls whether the double buffer structure should be enabled or disabled. : disabled when <DB4EN, DB6EN>=0, while enabled when <DB4EN, DB6EN>=1.

When the double buffer is enabled, the timing to transfer data from the register buffer to the timer register is at the match between the up-counter (UC4/UC5) and timer register TREG5/TREG7.

When reset, it will be initialized to  $\langle DB4EN, DB6EN \rangle = 0$ , whereby the double buffer is disabled. To use the double buffer, write data in the timer register, set  $\langle DB4EN, DB6EN \rangle = 1$ , and then write the following data in the register buffer.

TREG4, TREG6 and register buffer are allocated to the same memory addresses 000030H/000031H/000040H/000041H. When  $\langle DB4EN, DB6EN \rangle = 0$ , same value will be written in both the timer register and register buffer. When  $\langle DB4EN, DB6EN \rangle = 1$ , the value is written into only the register buffer.

### ③ Capture Register

These 16-bit registers are used to hold the values of the up-counter.

Data in the capture registers should be read by a 2-byte data load instruction or two 1-byte data load instruction, from the lower 8 bits followed by the upper 8 bits.

| CAP 1                   | CAP 2                   |
|-------------------------|-------------------------|
| Upper 8 bits<br>000035H | Lower 8 bits<br>000034H |
| Upper 8 bits<br>000037H | Lower 8 bits<br>000036H |
| CAP 3                   | CAP 4                   |
| Upper 8 bits<br>000045H | Lower 8 bits<br>000044H |
| Upper 8 bits<br>000047H | Lower 8 bits<br>000046H |

### ④ Capture Input Control

This circuit controls the timing to latch the value of up-counter UC4/UC5 into (CAP1, CAP2) / (CAP3, CAP4). The latch timing of capture register is controlled by register T4MOD<CAP12M 1, 0> / T5MOD <CAP34M1, 0>.

- When T4MOD<CAP12M 1, 0> / T5MOD <CAP34M1, 0> = 00

Capture function is disabled. Disable is the default on reset.

- When  $T4MOD <CAP12M1, 0> / T5MOD <CAP34M1, 0> = 01$

Data is loaded to CAP1, CAP3 at the rise edge of TI4 pin (also used as P80/INT4) and TI6 pin (also used as P84/INT6) input, while data is loaded to CAP2, CAP4 at the rise edge of TI5 pin (also used as P81/INT5) and TI7 pin (also used as P85/INT7) input. (Time difference measurement)

- When  $T4MOD <CAP12M1, 0> / T5MOD <CAP34M1, 0> = 10$

Data is loaded to CAP1 at the rise edge of TI4 pin input and to CAP3 at the rise edge of TI6, while to CAP2, CAP4 at the fall edge. Only in this setting, interrupt INT4/INT6 occurs at fall edge. (Pulse width measurement)

- When  $T4MOD <CAP12M1, 0> / T5MOD <CAP34M1, 0> = 11$

Data is loaded to CAP1, CAP3 at the rise edge of timer flip-flop TFF1, while to CAP2, CAP4 at the fall edge.

Besides, the value of up-counter can be loaded to capture registers by software. Whenever "0" is written in  $T4MOD <CAPIN>$ ,  $T5MOD <CAP31N>$  the current value of up-counter will be loaded to capture register CAP1/CAP3. It is necessary to keep the prescaler in RUN mode ( $TRUN <PRRUN>$  to be "1").

#### ⑤ Comparator

These are 16-bit comparators which compare the up-counter UC4/UC5 value with the set value of (TREG4, TREG5) / (TREG6, TREG7) to detect the match. When a match is detected, the comparators generate an interrupt (INTT4, INTT5) / (INTT6, INTT7) respectively. The up-counter UC4/UC5 is cleared only when UC4/UC5 matches TREG5/TREG7. (The clearing of up-counter UC4/UC5 can be disabled by setting  $T4MOD <CLE> / T5MOD <CLE> = 0$ .)

#### ⑥ Timer Flip-flop (TFF4/TFF6)

This flip-flop is inverted by the match detect signal from the comparators and the latch signals to the capture registers. Disable/enable of inversion can be set for each element by  $T4FFCR <CAP2T4, CAP1T4, EQ5T4, EQ4T4> / T6FFCR <CAP4T6, CAP3T6, EQ7T6, EQ6T6>$ . TFF4/TFF6 will be inverted when "00" is written in  $T4FFCR <TFF4C1,0> / T6FFCR <TFF6C1, 0>$ . Also it is set to "1" when "10" is written, and cleared to "0" when "10" is written. The value of TFF4/TFF6 can be output to the timer output pin TO4 (also used as P82) and TO6 (also used as P86).



### ⑦ Timer Flip-flop (TFF5)

This flip-flop is inverted by the match detect signal from the comparator and the latch signal to the capture register CAP2. TFF5 will be inverted when "00" is written in T4FFCR<TF5C1,0>/T6FFCR<TF6C1,0>. Also it is set to "1" when "10" is written, and cleared to "0" when "10" is written. The value of TFF5 can be output to the timer output pin TO5 (also used as P82).

Note : This flip-flop (TFF5) is contained only in the 16-bit timer 4

#### (1) 16-bit Timer Mode

Timers 4 and 5 operate independently.

Since both timers operate in exactly the same way, timer 4 is used for the purposes of explanation.

Generating interrupts at fixed intervals

In this example, the interval time is set in the timer register TREG5 to generate the interrupt INTTR5.

|         | 7 6 5 4 3 2 1 0                  |                                                                                        |
|---------|----------------------------------|----------------------------------------------------------------------------------------|
| TRUN    | $\leftarrow$ - X - 0 - - - -     | Stop timer 4.                                                                          |
| INTET54 | $\leftarrow$ 1 1 0 0 1 0 0 0     | Enable INTTR5 and sets interrupt level 4. Disable INTTR4.                              |
| T4FFCR  | $\leftarrow$ 1 1 0 0 0 0 1 1     | Disable trigger.                                                                       |
| T4MOD   | $\leftarrow$ 0 0 1 0 0 1 * *     | Select internal clock for input and disable the capture function.<br>(** = 01, 10, 11) |
| TREG5   | $\leftarrow$ * * * * * * * * * * | Set the interval time (16 bits).                                                       |
| TRUN    | $\leftarrow$ 1 X - 1 - - - -     | Start timer 4.                                                                         |

Note : X ; don't care      - ; no change

#### (2) 16-bit Event Counter Mode

In 16-bit timer mode as described in above, the timer can be used as an event counter by selecting the external clock (TI4/TI6 pin input) as the input clock. To read the value of the counter, first perform "software capture" once and read the captured value.

The counter counts at the rise edge of TI4/TI6 pin input.

TI4/TI6 pin can also be used as P80/INT4 and P84/INT6.

Since both timers operate in exactly the same way, timer 4 is used for the purposes of explanation.

|         | 7 6 5 4 3 2 1 0              |                                                                     |
|---------|------------------------------|---------------------------------------------------------------------|
| TRUN    | $\leftarrow - X - 0 - - - -$ | Stop timer 4.                                                       |
| P8CR    | $\leftarrow - - - - - - - 0$ | Set P80 to input mode                                               |
| INTET54 | $\leftarrow 1 1 0 0 1 0 0 0$ | Enable INTTR5 and sets interrupt level 4, while<br>disables INTTR4. |
| T4FFCR  | $\leftarrow 1 1 0 0 0 0 1 1$ | Disable trigger.                                                    |
| T4MOD   | $\leftarrow 0 0 1 0 0 1 0 0$ | Select TI4 as the input clock.                                      |
| TREG5   | $\leftarrow * * * * * * * *$ | Set the number of counts (16 bits).                                 |
| TRUN    | $\leftarrow 1 X - 1 - - - -$ | Start timer 4.                                                      |

Note : When used as an event counter, set the prescaler in RUN mode.

### (3) 16-bit Programmable Pulse Generation (PPG) Output Mode

Since both timers operate in exactly the same way, timer 4 is used for the purposes of explanation.

The PPG mode is obtained by inversion of the timer flip-flop TFF4 that is to be enabled by the match of the up-counter UC4 with the timer register TREG4 or 5 and to be output to TO4 (also used as P82). In this mode, the following conditions must be satisfied.

$$(\text{Set value of TREG4}) < (\text{Set value of TREG5})$$

|        | 7 6 5 4 3 2 1 0                                     |                                                                                             |
|--------|-----------------------------------------------------|---------------------------------------------------------------------------------------------|
| TRUN   | $\leftarrow - X - 0 - - - -$                        | Stop timer 4.                                                                               |
| TREG4  | $\leftarrow * * * * * * * *$                        | Set the duty. (16-Bit)                                                                      |
| TREG5  | $\leftarrow * * * * * * * *$                        | Set the cycle. (16-Bit)                                                                     |
| T45CR  | $\leftarrow 0 X X X - - - 1$                        | Double Buffer of TREG4 enable<br>(Change the duty and cycle at the interrupt INTTR5)        |
| T4FFCR | $\leftarrow 1 1 0 0 1 1 0 0$                        | Set the mode to invert TFF4 at the match with<br>TREG4/TREG5, and also set the TFF4 to "0". |
| T4MOD  | $\leftarrow 0 0 1 0 0 1 * *$<br>$(** = 01, 10, 11)$ | Select the internal clock for the input, and disable<br>the capture function.               |
| P8CR   | $\leftarrow - - - - - 1 - -$                        | }                                                                                           |
| P8FC   | $\leftarrow X - X X - 1 X X$                        |                                                                                             |
| TRUN   | $\leftarrow 1 X - 1 - - - -$                        | Assign P82 as TO4.<br>Start timer 4.                                                        |

Note : X ; don't care    - ; no change



Figure 3.9(11) Programmable Pulse Generation (PPG) Output Waveforms

When the double buffer of TREG4 is enabled in this mode, the value of register buffer 4 will be shifted in TREG4 at match with TREG5. This feature makes easy the handling of low duty waves.



Figure 3.9 (12) Operation of Register Buffer

Shows the block diagram of this mode.



Figure 3.9 (13) Block Diagram of 16-Bit PPG Mode

#### (4) Application Examples of Capture Function

The loading of up-counter (UC4) values into the capture registers CAP1 and CAP2, the timer flip-flop TFF4 inversion due to the match detection by comparators CP4 and CP5, and the output of the TFF4 status to TO4 pin can be enabled or disabled. Combined with interrupt function, they can be applied in many ways, for example:

- ① One-shot pulse output from external trigger pulse
- ② Frequency measurement
- ③ Pulse width measurement
- ④ Time difference measurement

##### ① One-shot Pulse Output from External Trigger Pulse

Set the up-counter UC4 in free-running mode with the internal input clock, input the external trigger pulse from TI4 pin, and load the value of up-counter into capture register CAP1 at the rise edge of the TI4 pin. Then set to T4MOD<CAP12M1, 0>=01.

When the interrupt INT4 is generated at the rise edge of TI4 input, set the CAP1 value (c) plus a delay time (d) to TREG4 ( $= c + d$ ), and set the above set value ( $c + d$ ) plus a one-shot pulse width (p) to TREG5 ( $= c + d + p$ ). When the interrupt INT4 occurs the T4FFCR<EQ5T4, EQ4T4>register should be set that the TFF4 inversion is enabled only when the up-counter value matches TREG4 or TREG5. When interrupt INTTR5 occurs, this inversion will be disabled.



Figure 3.9 (14) One-Shot Pulse Output (with Delay)

Setting example : To output 2ms one-shot pulse with 3ms delay to the external trigger pulse to TI4 pin



#### Setting of INT4



#### Setting of INT5



Note: X ; don't care    - ; no change

When delay time is unnecessary, invert timer flip-flop TFF4 when the up-counter value is loaded into capture register 1 (CAP1), and set the CAP1 value (c) plus the one-shot pulse width (p) to TREG5 when the interrupt INT4 occurs. The TFF4 inversion should be enabled when the up-counter (UC4) value matches TREG5, and disabled when generating the interrupt INTTR5.



010289

Figure 3.9 (15) One-Shot Pulse Output (without Delay)

## ② Frequency Measurement

The frequency of the external clock can be measured in this mode. The clock is input through the TI4 pin, and its frequency is measured by the 8-bit timers (Timer 0 and Timer 1) and the 16-bit timer/event counter (Timer 4).

The TI4 pin input should be selected for the input clock of Timer 4. The value of the up-counter is loaded into the capture register CAP1 at the rise edge of the timer flip-flop TFF1 of 8-bit timers (Timer 0 and Timer 1), and into CAP2 at its fall edge.

The frequency is calculated by the difference between the loaded values in CAP1 and CAP2 when the interrupt (INTT0 or INTT1) is generated by either 8-bit timer.



010289

Figure 3.9 (16) Frequency Measurement

For example, if the value for the level “1” width of TFF1 of the 8-bit timer is set to 0.5 s. and the difference between CAP1 and CAP2 is 100, the frequency will be  $100/0.5[\text{s}] = 200[\text{Hz}]$ .

### ③ Pulse Width Measurement

This mode allows to measure the "H" level width of an external pulse. While keeping the 16-bit timer/event counter counting (free-running) with the internal clock input, the external pulse is input through the TI4 pin. Then the capture function is used to load the UC4 values into CAP1 and CAP2 at the rising edge and falling edge of the external trigger pulse respectively. The interrupt INT4 occurs at the falling edge of TI4.

The pulse width is obtained from the difference between the values of CAP1 and CAP2 and the internal clock cycle.

For example, if the internal clock is 0.8 microseconds and the difference between CAP1 and CAP2 is 100, the pulse width will be  $100 \times 0.8 = 80$  microseconds.



Figure 3.9 (17) Pulse Width Measurement

Note: Only in this pulse width measuring mode ( $T4MOD < CAP12M1, 0 > = 10$ ), external interrupt INT4 occurs at the falling edge of TI4 pin input. In other modes, it occurs at the rising edge.

The width of "L" level can be measured from the difference between the first C2 and the second C1 at the second INT4 interrupt.

### ④ Time Difference Measurement

This mode is used to measure the difference in time between the rising edges of external pulses input through TI4 and TI5.

Keep the 16-bit timer/event counter (Timer 4) counting (free-running) with the internal clock, and load the UC4 value into CAP1 at the rising edge of the input pulse to TI4. Then the interrupt INT4 is generated.

Similarly, the UC4 value is loaded into CAP2 at the rising edge of the input pulse to TI5, generating the interrupt INT5.

The time difference between these pulses can be obtained from the difference between the time counts at which loading the up-counter value into CAP1 and CAP2 has been done.



Figure 3.9 (18) Time Difference Measurement

#### (5) Different Phased Pulses Output Mode

In this mode, signals with any different phase can be outputted by free-running up-counter UC4.

When the value in up-counter UC4 and the value in TREG4 (TREG5) match, the value in TFF4 (TFF5) is inverted and output to TO4 (TO5).

This mode can only be used by 16-bit timer 4.



Figure 3.9 (19) Phase Output

Cycles (counter overflow time) of the above output waves are listed below.

|            | 16MHz      | 20MHz      |
|------------|------------|------------|
| $\phi T1$  | 32.768 ms  | 26.214 ms  |
| $\phi T4$  | 131.072 ms | 104.856 ms |
| $\phi T16$ | 524.288 ms | 419.424 ms |

### 3.10 Stepping Motor Control/Pattern Generation Port

TMP96C141 has 2 channels (PG0 and PG1) of 4-bit hardware stepping motor control/pattern generation (herein after called PG) which actuate in synchronization with the (8-bit/16-bit) timers. The PG (PG0 and PG1) are shared in 8-bit I/O ports P6.

Channel 0 (PG0) is synchronous with 8-bit timer 0 or timer 1, 16-bit timer 5, to update the output.

The PG ports are controlled by control registers (PG01CR) and can select either stepping motor control mode or pattern generation mode. Each bit of the P6 can be used as the PG port.

PG0 and PG1 can be used independently.

All PG operate in the same manner except the following points, and thus only the operation of PG0 will be explained below.

Different Points between PG0 and PG1

|               | PG0           | PG1           |
|---------------|---------------|---------------|
| Tigger Signal | from Timmer 4 | from Timmer 5 |



Figure 3.10 (1) PG Block Diagram



Figure 3.10 (2 a) Pattern Generation Control Register (PG01CR)

Figure 3.10 (2 b) Pattern Generation Control Register (PG01CR)

|             | 7                                                                                                                       | 6    | 5    | 4    | 3                                                                    | 2    | 1    | 0    |
|-------------|-------------------------------------------------------------------------------------------------------------------------|------|------|------|----------------------------------------------------------------------|------|------|------|
| bit Symbol  | PG03                                                                                                                    | PG02 | PG01 | PG00 | SA03                                                                 | SA02 | SA01 | SA00 |
| Read/Write  | W                                                                                                                       |      |      |      | R / W                                                                |      |      |      |
| After reset | 0                                                                                                                       | 0    | 0    | 0    | Undefined                                                            |      |      |      |
| Function    | Pattern Generation 0 (PG0) output latch register<br><br>(Reading the P6 that is set to the PG port allows to read-out.) |      |      |      | Shift alternate register 0<br>For the PG mode (4-bit write) register |      |      |      |

Prohibit Read  
modify write

Figure 3.10 (3) Pattern Generation 0 Register (PG0REG)

|             | 7                                                                                                                       | 6    | 5    | 4    | 3                                                                    | 2    | 1    | 0    |
|-------------|-------------------------------------------------------------------------------------------------------------------------|------|------|------|----------------------------------------------------------------------|------|------|------|
| bit Symbol  | PG13                                                                                                                    | PG12 | PG11 | PG10 | SA13                                                                 | SA12 | SA11 | SA10 |
| Read/Write  | W                                                                                                                       |      |      |      | R / W                                                                |      |      |      |
| After reset | 0                                                                                                                       | 0    | 0    | 0    | Undefined                                                            |      |      |      |
| Function    | Pattern Generation 1 (PG1) output latch register<br><br>(Reading the P6 that is set to the PG port allows to read-out.) |      |      |      | Shift alternate register 1<br>For the PG mode (4-bit write) register |      |      |      |

Prohibit Read  
modify write

Figure 3.10 (4) Pattern Generation 1 Register (PG1REG)



Figure 3.10 (5) 16-bit Timer Trigger Control Register (T45CR)



Figure 3.10 (6) Connection of Timer and Pattern Generator



### (1) Pattern Generation Mode

PG functions as a pattern generation according to the setting of PG01CR <PAT1> / <PAT0>. In this mode, writing from CPU is executed only on the shifter alternate register. Writing a new data should be done during the interrupt operation of the timer for shift trigger and a pattern can be output, synchronous with the timer.

In this mode, set PG01CR <PG0M> and <PG1M> to 1, and PG01CR <CCW0> and <CCW1> to 0.

The output of this pattern generator is output to port 6 ; since port and functions can be switched on a bit basis using port function control register P6FC, any port pin can be assigned to pattern generator output.

Figure 3.10 (7) shows the block diagram of this mode.



Example of pattern generation mode



Figure 3.10 (7) Pattern Generation Mode Block Diagram (PG0)

In this pattern generation mode, only writing the output latch is disabled by hardware, but other functions do the same operation as 1-2 excitation in stepping motor control port mode. Accordingly, the data shifted by trigger signal from a timer must be written before the next trigger signal is output.

## (2) Stepping Motor Control Mode

## ① 4-phase 1-Step/2-Step Excitation

Figure 3.10 (8) and Figure 3.10 (9) show the output waveforms of 4-phase 1 excitation and 4-phase 2 excitation, respectively when channel 0 (PG0) is selected.



Note : bn indicates the initial value of  $PG0REG \leftarrow b7\ b6\ b5\ b4\ \times\ \times\ \times$

## ① Normal Rotation



## ② Reverse Rotation

010289

Figure 3.10 (8) Output Waveforms of 4-Phase 1-step Excitation  
(Normal Rotation and Reverse Rotation)



Figure 3.10 (9) Output Waveforms of 4-Phase 2-step Excitation (Normal Rotation)

The operation when channel 0 is selected is explained below.

The output latch of PG0 (also used as P6) is shifted at the rising edge of the trigger signal from the timer to be output to the port.

The direction of shift is specified by PG01CR<CCW0>: Normal rotation (PG00→PG01→PG02→PG03) when <CCW0> is set to "0"; reverse rotation (PG00←PG01←PG02←PG03) when "1". 4-phase 1-step excitation will be selected when only one bit is set to "1" during the initialization of PG, while 4-phase 2-step excitation will be selected when two consecutive bits are set to "1".

The value in the shift alternate registers are ignored when the 4-phase 1-step/2-step excitation mode is selected.

Figure 3.10 (10) shows the block diagram.



Figure 3.10 (10) Block Diagram of 4-Phase 1-step Excitation/2-step Excitation (Normal Rotation)

② 4-Phase 1-2 step Excitation

Figure 3.10 (11) shows the output waveforms of 4-phase 1-2 step excitation when channel 0 is selected.



Note: bn denotes the initial value  $PG0REG \leftarrow b7\ b6\ b5\ b4\ b3\ b2\ b1\ b0$

① Normal Rotation



② Reverse Rotation

Figure 3.10 (11) Output Waveforms of 4-Phase 1-2 step Excitation (Normal Rotation and Reverse Rotation)

The initialization for 4-phase 1-2 step excitation is as follows.

By rearranging the initial value “b7 b6 b5 b4 b3 b2 b1 b0” to “b7 b3 b6 b2 b5 b1 b4 b0”, the consecutive 3 bits are set to “1” and other bits are set to “0” (positive logic).

For example, if b7, b3, and b6 are set to “1”, the initial value becomes “11001000”, obtaining the output waveforms as shown in Figure 3.10 (11).

To get an output waveform of negative logic, set values 1's and 0's of the initial value should be inverted. For example, to change the output waveform shown in Figure 3.10 (11) into negative logic, change the initial value to “00110111”.

The operation will be explained below for channel 0.

The output latch of PG0 (shared by P6) and the shifter alternate register (SA0) for Pattern Generation are shifted at the rising edge of trigger signal from the timer to be output to the port. The direction of shift is set by PG01CR<CCW0>.

Figure 3.10 (12) shows the block diagram.



Figure 3.10 (12) Block Diagram of 4-Phase 1-2 step Excitation (Normal Rotation)

Setting example: To drive channel 0 (PG0) by 4-phase 1-2 step excitation (normal rotation) when timer 0 is selected, set each register as follows.

|        |                   |                                                                           |
|--------|-------------------|---------------------------------------------------------------------------|
|        | 7 6 5 4 3 2 1 0   |                                                                           |
| TRUN   | ← - X - - - - 0   | Stop timer 0, and clear it to zero.                                       |
| TMOD   | ← 0 0 X X - - 0 1 | Set 8-bit timer mode and select $\phi T_1$ as the input clock of timer 0. |
| TFFCR  | ← X X X 0 1 0 1 0 | Clear TFF1 to zero and enable the inversion trigger by timer 0.           |
| TREG0  | ← * * * * * * * * | Set the cycle in timer register.                                          |
| P6CR   | ← - - - 1 1 1 1   | Set P60~P63 bits to the output mode.                                      |
| P6FC   | ← - - - 1 1 1 1   | Set P60~P63 bits to the PG output.                                        |
| PG01CR | ← - - - 0 0 1 1   | Select PG0 4-phase 1-2 step excitation mode and normal rotation .         |
| PG0REG | ← 1 1 0 0 1 0 0 0 | Set an initial value.                                                     |
| TRUN   | ← 1 X - - - - 1   | Start timer 0.                                                            |

Note: X ; don't care - ; no change



### (3) Trigger Signal From Timer

The trigger signal from the timer which is used by PG is not equal to the trigger signal of timer flip-flop (TFF1, TFF4, TFF5, and TFF6) and differs as shown in Table 3.10 (1) depending on the operation mode of the timer.

Table 3.10 (1) Select of Trigger Signal

|                   | TFF1 inversion                                                                                                                 | PG shift                                                  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|
| 8-bit timer mode  | Selected by TFFCR<br><TFF1IS> when the up-counter value matches TREG0 or TREG1 value.                                          | ←—                                                        |
| 16-bit timer mode | When the up-counter value matches with both TREG0 and TREG1 values<br>(The value of up-counter = TREG1*2 <sup>8</sup> + TREG0) | ←—                                                        |
| PPG output mode   | When the up-counter value matches with both TREG0 and TREG1                                                                    | When the up-counter value matches TREG1 value (PPG cycle) |
| PWM output mode   | When the up-counter value matches TREG0 value and PWM cycle.                                                                   | Trigger signal for PG is not generated.                   |

Note : To shift PG, TFFCR<TFF1IE> must be set to "1" to enable TFF1 inversion.

Channel 1 of PG can be synchronized with the 16-bit timer Timer4/Timer5. In this case, the PG shift trigger signal from the 16-bit timer is output only when the up-counter UC4 / UC5 value matches TREG5/TREG7.

When using a trigger signal from Timer4, set either T4FFCR<EQ5T4> or T4MOD <EQ5T5> to "1" and a trigger is generated when the value in UC4 and the value in TREG5 match. When using a trigger signal from Timer5, set T5FFCR<EQ7T6> to 1. Generates a trigger when the value in UC5 and the value in TREG7 match.

#### (4) Application of PG and Timer Output

As explained "Trigger signal from timer", the timing to shift PG and invert TFF differs depending on the mode of timer. An application to operate PG while operating an 8-bit timer in PPG mode will be explained below.

To drive a stepping motor, in addition to the value of each phase (PG output), synchronizing signal is often required at the timing when excitation is changed over. In this application, port 6 is used as a stepping motor control port to output a synchronizing signal to the TO1 pin (shared by P71).



Figure 3.10 (13) Output Waveforms of 4-Phase 1-step Excitation

Setting example:

|                          |                                                                               |
|--------------------------|-------------------------------------------------------------------------------|
| 7 6 5 4 3 2 1 0          |                                                                               |
| TRUN ← - X - - - 0 0     | Stop timer 0, and clear it to zero.                                           |
| TMOD ← 1 0 X X X X 0 1   | Set timer 0 and timer 1 in PPG output mode and select φT1 as the input clock. |
| TFFCR ← X X X 0 0 1 1 X  | Enable TFF1 inversion and set TFF1 to "1".                                    |
| TREG0 ← * * * * * * *    | Set the duty of TO1 to TREG0.                                                 |
| TREG1 ← * * * * * * *    | Set the cycle of TO1 to TREG1.                                                |
| P7CR ← X X X X - - 1 -   |                                                                               |
| P7FC ← X X X X - - 1 X   | } Assign P71 as TO1.                                                          |
| P6CR ← - - - - 1 1 1 1   |                                                                               |
| PGFC ← - - - - 1 1 1 1   | } Assign P60-63 as PG0.                                                       |
| PG01CR ← - - - - 0 0 0 1 | Set PG0 in 4-phase 1-step excitation mode.                                    |
| PG0REG ← * * * * * * *   | Set an initial value.                                                         |
| TRUN ← 1 X - - - 1 1     | Start timer 0 and timer 1.                                                    |

Note: X ; don't care - ; no change

### 3.11 Serial Channel

TMP96C141 contains 2 serial I/O channels for full duplex asynchronous transmission (UART) as well as for I/O extension.

The serial channel has the following operation modes.

- I/O interface mode (channel 1 only) Mode 0: To transmit and receive I/O data as well as the synchronizing signal SCLK for extending I/O.

Note : TMP96C141A / TMP96C041A / TMP96CM40 / TMP96PM40 with channel 0 and 1

  - Asynchronous transmission (UART) mode (channel 0 and 1)
    - Mode 1: 7-bit data
    - Mode 2: 8-bit data
    - Mode 3: 9-bit data



In mode 1 and mode 2, a parity bit can be added. Mode 3 has wake-up function for making the master controller start slave controllers in serial link (multi-controller system).

Figure 3.11 (1) shows the data format (for one frame) in each mode.

- Mode 0 (I/O interface mode)



- Mode 1 (7-bit UART mode)



- Mode 2 (8-bit UART mode)



- Mode 3 (9-bit UART mode)



When bit 8 = 1, address (select code) is denoted.  
When bit 8 = 0, data is denoted.

Figure 3.11 (1) Data Formats

The serial channel has a buffer register for transmitting and receiving operations, in order to temporarily store transmitted or received data, so that transmitting and receiving operations can be done independently (full duplex).

However, in I/O interface mode, SCLK (serial clock) pin is used for both transmission and receiving, the channel becomes half-duplex.

The receiving data register is of a double buffer structure to prevent the occurrence of overrun error and provides one frame of margin before CPU reads the received data. The receiving data register stores the already received data while the buffer register receives the next frame data.

By using CTS and RTS (there is no RTS pin, so any 1 port must be controlled by software), it is possible to halt data send until the CPU finishes reading receive data every time a frame is received. (Handshake function)

In the UART mode, a check function is added not to start the receiving operation by error start bits due to noise. The channel starts receiving data only when the start bit is detected to be normal at least twice in three samplings.

When the transmission buffer becomes empty and requests the CPU to send the next transmission data, or when data is stored in the receiving data register and the CPU is requested to read the data, INTTX or INTRX interrupt occurs. Besides, if an overrun error, parity error, or framing error occurs during receiving operation, flag SC0CR/SC1CR<OERR, PERR, FERR> will be set.

The serial channel 0/1 includes a special baud rate generator, which can set any baud rate by dividing the frequency of 4 clocks ( $\phi T_0$ ,  $\phi T_2$ ,  $\phi T_8$ , and  $\phi T_{32}$ ) from the internal prescaler (shared by 8-bit/16-bit timer) by the value 2 to 16.

In I/O interface mode, it is possible to input synchronous signals as well as to transmit or receive data by external clock.

### 3.11.1 Control Registers

The serial channel is controlled by 3 control registers SC0CR, SC0MOD and BR0CR. Transmitted and received data are stored in register SC0BUF.

|             | 7                              | 6          | 5                                                             | 4                                                                                       | 3                                                                                                                    | 2                                                                                                                         | 1   | 0   |
|-------------|--------------------------------|------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-----|-----|
| bit Symbol  | TB8                            | CTSE       | RXE                                                           | WU                                                                                      | SM1                                                                                                                  | SM0                                                                                                                       | SC1 | SC0 |
| Read/Write  | R/W                            |            |                                                               |                                                                                         |                                                                                                                      |                                                                                                                           |     |     |
| After reset | 0                              | 0          | 0                                                             | 0                                                                                       | 0                                                                                                                    | 0                                                                                                                         | 0   | 0   |
| Function    | Transfer data Bit 8            | Hand shake | Receiving Function<br>0: Receive disable<br>1: Receive enable | Wake up Function<br>0: I/O interface<br>1: 7-bit UART<br>2: 8-bit UART<br>3: 9-bit UART | Serial transmission mode<br>00: I/O interface<br>01: TOO Trigger<br>10: baud rate generator<br>11: Internal clock F1 | Serial transmission clock (UART)<br>00: TOO Trigger<br>01: baud rate generator<br>10: Internal clock F1<br>11: don't care |     |     |
|             | : CTS disable<br>1: CTS enable |            |                                                               |                                                                                         |                                                                                                                      |                                                                                                                           |     |     |



Note : There is SC1MOD (56H) in Channel1

Figure 3.11 (2) Serial Mode Control Register (channel 0, SC0MOD)



Note: Serial control register for channel 1 is SC1CR (55H).

Note: As all error flags are cleared after reading do not test only a single bit with a bit-testing instruction.

Figure 3.11 (3) Serial Control Register (channel, SC0CR)



Note : As all error flags are cleared after reading, do not test only a single bit with a bit-testing instruction.

Figure 3.11 (4) Serial Channel Control (channel 0, BR0CR)

|                 |                |     |     |     |     |     |     |     |
|-----------------|----------------|-----|-----|-----|-----|-----|-----|-----|
| SC0BUF<br>(50H) | 7              | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|                 | TB7            | TB6 | TB5 | TB4 | TB3 | TB2 | TB1 | TB0 |
|                 | (Transmission) |     |     |     |     |     |     |     |
| 7               | 6              | 5   | 4   | 3   | 2   | 1   | 0   |     |
| RB7             | RB6            | RB5 | RB4 | RB3 | RB2 | RB1 | RB0 |     |
| (Receiving)     |                |     |     |     |     |     |     |     |

Figure 3.11 (5) Serial Transmission / Receiving Buffer Registers (channel 0, SC0BUF)



Figure 3.11 (6) Serial Mode Control Register (Channel 1, SC1MOD)



Note : As all error flags are cleared after reading, do not test only a single bit with a bit testing instruction.

Figure 3.11 (7) Serial Control Register (Channel 1, SC1CR)



Note : To use baud rate generator, set TRUN<PRRUN> to "1", putting the prescaler in RUN mode.

Figure 3.11 (8) Baud Rate Generator Control Register (channel 0, BR0CR)



Figure 3.11 (9) Serial Transmission / Receiving Buffer Registers (channel 1, SC1BUF)



Figure 3.11 (10) Port 9 Function Register (P9FC)



Figure 3.11 (11) Port 9 Open Drain Enable Register (ODE)

### 3.11.2 Configuration

Figure 3.11 (12) shows the block diagram of the serial channel 0.



Figure 3.11 (12) Block Diagram of the Serial Channel 0

Figure 3.11 (13) shows the block diagram of the serial channel 1.



Figure 3.11 (13) Block Diagram of the Serial Channel 1

## ① Baud Rate Generator

Baud rate generator comprises a circuit that generates transmission and receiving clocks to determine the transfer rate of the serial channel.

The input clock to the baud rate generator,  $\phi T0$  ( $fc/4$ ),  $\phi T2$  ( $fc/16$ ),  $\phi T8$  ( $fc/64$ ), or  $\phi T32$  ( $fc/256$ ) is generated by the 9-bit prescaler which is shared by the timers. One of these input clocks is selected by the baud rate generator control register BR0CR/BR1CR<BR0CK1, 0/BR1CK1, 0>.

The baud rate generator includes a 4-bit frequency divider, which divides frequency by 2 to 16 values to determine the transfer rate.

How to calculate a transfer rate when the baud rate generator is used is explained below.

- UART mode

$$\text{Transfer rate} = \frac{\text{Input clock of baud rate generator}}{\text{Frequency divisor of baud rate generator}} \div 16$$

- I/O interface mode

$$\text{Transfer rate} = \frac{\text{Input clock of baud rate generator}}{\text{Frequency divisor of baud rate generator}} \div 2$$

The relation between the input clock and the source clock ( $fc$ ) is as follows.

$$\phi T0 = fc/4$$

$$\phi T2 = fc/16$$

$$\phi T8 = fc/64$$

$$\phi T32 = fc/256$$

Accordingly, when source clock  $fc$  is 12.288 MHz, input clock is  $\phi T2$  ( $fc/16$ ), and frequency divisor is 5, the transfer rate in UART mode becomes as follows:

$$\begin{aligned} \text{Transfer rate} &= \frac{fc/16}{5} \div 16 \\ &= 12.288 \times 10^6 / 16 / 5 / 16 = 9600 \text{ (bps)} \end{aligned}$$

Table 3.11 (1) shows an example of the transfer rate in UART mode.

Also with 8-bit timer 0, the serial channel can get a transfer rate. Table 3.9 (2) shows an example of baud rate using timer 0.

Table 3.11 (1) Selection of Transfer Rate (1) (When Baud Rate Generator Is Used)  
Unit (kbps)

| fc [MHz]  | Input clock<br>Frequency divisor | $\phi T_0$<br>(fc/4) | $\phi T_2$<br>(fc/16) | $\phi T_8$<br>(fc/64) | $\phi T_{32}$<br>(fc/256) |
|-----------|----------------------------------|----------------------|-----------------------|-----------------------|---------------------------|
| 9.830400  | 2                                | 76.800               | 19.200                | 4.800                 | 1.200                     |
| ↑         | 4                                | 38.400               | 9.600                 | 2.400                 | 0.600                     |
| ↑         | 8                                | 19.200               | 4.800                 | 1.200                 | 0.300                     |
| ↑         | 0                                | 9.600                | 2.400                 | 0.600                 | 0.150                     |
| 12.288000 | 5                                | 38.400               | 9.600                 | 2.400                 | 0.600                     |
| ↑         | A                                | 19.200               | 4.800                 | 1.200                 | 0.300                     |
| 14.745600 | 3                                | 76.800               | 19.200                | 4.800                 | 1.200                     |
| ↑         | 6                                | 38.400               | 9.600                 | 2.400                 | 0.600                     |
| ↑         | C                                | 19.200               | 4.800                 | 1.200                 | 0.300                     |

Note: Transfer rate in I/O interface mode is 8 times as fast as the values given in the above table.

Table 3.11 (2) Selection of Transfer Rate (1) (When timer 0 (input Clock  $\phi T_1$ ) is used)  
Unit (kbps)

| TREG0 | fc   | 12.288 MHz | 12 MHz | 9.8304 MHz | 8 MHz | 6.144 MHz |
|-------|------|------------|--------|------------|-------|-----------|
| 1H    | 96   |            |        | 76.8       | 62.5  | 48        |
| 2H    | 48   |            |        | 38.4       | 31.25 | 24        |
| 3H    | 32   | 31.25      |        |            |       | 16        |
| 4H    | 24   |            |        | 19.2       |       | 12        |
| 5H    | 19.2 |            |        |            |       | 9.6       |
| 8H    | 12   |            |        | 9.6        |       | 6         |
| AH    | 9.6  |            |        |            |       | 4.8       |
| 10H   | 6    |            |        | 4.8        |       | 3         |
| 14H   | 4.8  |            |        |            |       | 2.4       |

How to calculate the transfer rate (when timer 0 is used):

$$\text{Transfer rate} = \frac{\text{fc}}{\text{TREG0} \times 8 \times 16}$$

↑  
(When Timer 0 (input clock  $\phi T_1$ ) is used)

Input clock of timer 0

$$\begin{aligned}\phi T_1 &= \text{fc}/8 \\ \phi T_4 &= \text{fc}/32 \\ \phi T_{16} &= \text{fc}/128\end{aligned}$$

Note: Timer 0 match detect signal cannot be used as the transfer clock in I/O interface mode.

## ② Serial Clock Generation Circuit

This circuit generates the basic clock for transmitting and receiving data.

### 1) I/O interface mode (channel 1 only)

When in SCLK output mode with the setting of SC1CR<IOC> = "0", the basic clock will be generated by dividing by 2 the output of the baud rate generator described before. When in SCLK input mode with the setting of SC1CR<IOC> = "1", the rising edge or falling edge will be detected according to the setting of SC1CR<SCLKC> register to generate the basic clock.

### 2) Asynchronous Communication (UART) mode

According to the setting of SC0CR and SC1CR <SC1, 0>, the above baud rate generator clock, internal clock  $\phi_1$  (500kbps @  $f_c=16MHz$ ), or the match detect signal from timer 0 will be selected to generate the basic clock SIOCLK.

## ③ Receiving Counter

The receiving counter is a 4-bit binary counter used in asynchronous communication (UART) mode and counts up by SIOCLK clock. 16 pulses of SIOCLK are used for receiving 1 bit of data, and the data bit is sampled three times at 7th, 8th and 9th clock.

With the three samples, the received data is evaluated by the rule of majority.

For example, if the sampled data bit is "1", "0" and "1" at 7th, 8th and 9th clock respectively, the received data is evaluated as "1". The sampled data "0", "0" and "1" is evaluated that the received data is "0".

## ④ Receiving Control

### 1) I/O interface mode (channel 1 only)

When in SCLK1 output mode with the setting of SC1CR<IOC> = "0", RxD1 signal will be sampled at the rising edge of shift clock which is output to SCLK pin.

When in SCLK input mode with the setting SC1CR<IOC> = "1" RxD1 signal will be sampled at the rising edge or falling edge of SCLK input according to the setting of SC1CR<SCLKS> register.

### 2) Asynchronous communication (UART) mode

The receiving control has a circuit for detecting the start bit by the rule of majority. When two or more "0" are detected during 3 samples, it is recognized as start bit and the receiving operation is started.

Data being received are also evaluated by the rule of majority.

## ⑤ Receiving Buffer

To prevent overrun error, the receiving buffer has a double buffer structure.

Received data are stored one bit by one bit in the receiving buffer 1 (shift register type). When 7 bits or 8 bits of data is stored in the receiving buffer 1, the stored data are transferred to another receiving buffer 2 (SC0BUF/SC1BUF), generating an interrupt INTRX0/INTRX1. The CPU reads only receiving buffer 2 (SC0BUF/SC1BUF). Even before the CPU reads the receiving buffer 2 (SC0BUF/SC1BUF), the received data can be stored in the receiving buffer 1. However, unless the receiving buffer 2 (SC0BUF/SC1BUF) is read before all bits of the next data are received by the receiving buffer 1, an overrun error occurs. If an overrun error occurs, the contents of the receiving buffer 1 will be lost, although the contents of the receiving buffer 2 and SC0CR<RB8>/SC1CR<RB8> is still preserved.

The parity bit added in 8-bit UART mode and the most significant bit (MSB) in 9-bit UART mode are stored in SC0CR<RB8>/SC1CR<RB8>.

When in 9-bit UART mode, the wake-up function of the slave controllers is enabled by setting SC0MOD<WU>/SC1MOD<WU> to “1”, and interrupt INTRX0/INTRX1 occurs only when SC0CR<RB8>/SC1CR<RB8> is set to “1”.

#### ⑥ Transmission Counter

Transmission counter is a 4-bit binary counter which is used in asynchronous communication (UART) mode and, like a receiving counter, counts by SIOCLK clock, generating TxDCLK every 16 clock pulses.



Figure 3.11 (14) Generation of Transmission Clock

#### ⑦ Transmission Controller

##### 1) I/O interface mode (TMP96C141 is only channel 1)

In SCLK output mode with the setting of SC1CR<IOC> = “0”, the data in the transmission buffer are output bit by bit to TxD1 pin at the rising edge of shift clock which is output from SCLK1 pin.

In SCLK input mode with the setting of SC1CR<IOC> = “1”, the data in the transmission buffer are output bit by bit to TxD1 pin at the rising edge or falling edge of SCLK input according to the setting of SC1CR<SCLKC> register.

##### 2) Asynchronous communication (UART) mode

When transmission data are written in the transmission buffer sent from the CPU, transmission starts at the rising edge of the next TxDCLK, generating a transmission shift clock TxDSFT.

Handshake function

Serial channel 0 has a  $\overline{CTS_0}$  pin. Using this pin, data can be sent in units of one frame ; thus, overrun errors can be avoided. The handshake function is enabled/ disabled by SC0MOD<CTSE>.

When the  $\overline{CTS_0}$  pin goes high, after completion of the current data send, data send is halted until the  $\overline{CTS_0}$  pin goes low again. The INTTX0 Interrupts are generated, requests the next send data to the CPU.

Though there is no  $\overline{RTS}$  pin, a handshake function can be easily configured by setting any port assigned to the  $\overline{RTS}$  function. The  $\overline{RTS}$  should be output "High" to request data send halt after data receive is completed by a software in the RXD interrupt routine.



Figure 3.11 (15) Handshake Function



Note 1 : If the  $\overline{CTS}$  signal falls during transmission, the next data is not sent after the completion of the current transmission.

Note 2 : Transmission starts at the first TxDCLK clock fall after the  $\overline{CTS}$  signal falls.

Figure 3.11 (16) Timing of  $\overline{CTS}$  (Clear to send)

⑧ Transmission Buffer

Transmission buffer (SC0BUF/SC1BUF) shifts out and sends the transmission data written from the CPU from the least significant bit (LSB) in order, using transmission shift clock TxDSFT which is generated by the transmission control. When all bits are shifted out, the transmission buffer becomes empty and generates INTTX0/INTTX1 interrupt.

⑨ Parity Control Circuit

When serial channel control register SC0CR<PE>/SC1CR<PE> is set to “1”, it is possible to transmit and receive data with parity. However, parity can be added only in 7-bit UART or 8-bit UART mode. With SC0CR <EVEN> / SC1CR <EVEN> register, even (odd) parity can be selected.



For transmission, parity is automatically generated according to the data written in the transmission buffer SCBUF, and data are transmitted after being stored in SC0BUF<TB7>/SC1BUF<TB7> when in 7-bit UART mode while in SCMOD <TB8> / SCMOD <TB8> when in 8-bit UART mode. <PE> and <EVEN> must be set before transmission data are written in the transmission buffer.

For receiving, data are shifted in the receiving buffer 1, and parity is added after the data are transferred in the receiving buffer 2 (SC0BUF/SC1BUF), and then compared with SC0BUF<RB7>/SC1BUF<RB7> when in 7-bit UART mode and with SC0MOD<RB8>/SC1MOD<RB8> when in 8-bit UART mode. If they are not equal, a parity error occurs, and SC0CR<PERR>/SC1CR<PERR> flag is set.

⑩ Error Flag

Three error flags are provided to increase the reliability of receiving data.

1. Overrun error <OERR>

If all bits of the next data are received in receiving buffer 1 while valid data are stored in receiving buffer 2 (SCBUF), an overrun error will occur.

2. Parity error <PERR>

The parity generated for the data shifted in receiving buffer 2 (SCBUF) is compared with the parity bit received from RxD pin. If they are not equal, a parity error occurs.

3. Framing error <FERR>

The stop bit of received data is sampled three times around the center. If the majority is “0”, a framing error occurs.

## ① Generating Timing

### 1) UART mode

#### Receiving

| Mode                 | 9 Bit                         | 8 Bit + parity                     | 8 Bit, 7 Bit + parity, 7 Bit |
|----------------------|-------------------------------|------------------------------------|------------------------------|
| Interrupt timing     | Center of last bit<br>(Bit 8) | Center of last bit<br>(parity bit) | Center of stop bit           |
| Framing error timing | Center of stop bit            | Center of stop bit                 | Center of stop bit           |
| Parity error timing  |                               | Center of last bit<br>(parity bit) | Center of stop bit           |
| Overrun error timing | Center of last bit<br>(Bit 8) | Center of last bit<br>(parity bit) | Center of stop bit           |

Note: Framing error occurs after an interrupt has occurred. Therefore, to check for framing error during interrupt operation, it is necessary to wait for 1 bit period of transfer rate.

#### Transmitting

| Mode             | 9 Bit                                | 8 Bit + parity | 8 Bit, 7 Bit + parity, 7 Bit |
|------------------|--------------------------------------|----------------|------------------------------|
| Interrupt timing | Just before last bit is transmitted. | ←              | ←                            |

### 2) I/O interface mode

|                                     |                  |                                                                                                                                         |
|-------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Transmission<br>Interrupt<br>timing | SCLK output mode | Immediately after rise of last SCLK signal.<br>(See figure 3.11 (19). )                                                                 |
|                                     | SCLK input mode  | Immediately after rise of last SCLK signal (rising mode), or immediately after fall in falling mode. (See figure 3.11 (20).)            |
| Receiving<br>Interrupt<br>timing    | SCLK output mode | Timing used to transfer received data to data receive buffer 2 (SC1BUF) (that is, immediately after last SCLK). (See figure 3.11 (21).) |
|                                     | SCLK input mode  | Timing used to transfer received data to data receive buffer 2 (SC1BUF) (that is, immediately after last SCLK). (See figure 3.11 (22).) |

### 3.11.3 Operational Description

#### (1) Mode 0 (I/O interface mode) (TMP96C141 is only channel 1.)

This mode is used to increase the number of I/O pins of for transmitting or receiving data to or from the external shifter register.

This mode includes SCLK output mode to output synchronous clock SCLK and SCLK input mode to input external synchronous clock SCLK.



Figure 3.11 (17) Example of SCLK Output Mode Connection



Figure 3.11 (18) Example of SCLK Input Mode Connection

### ① Transmission

In SCLK output mode, 8-bit data and synchronous clock are output from TxD pin and SCLK pin, respectively, each time the CPU writes data in the transmission buffer. When all data is output, INTES1<ITX1C> will be set to generate INTTX1 interrupt.



Figure 3.11 (19) Transmitting Operation in I/O Interface Mode (SCLK Output Mode)

In SCLK output mode, 8-bit data are output from TxD1 pin when SCLK input becomes active while data are written in the transmission buffer by CPU.

When all data are output, INTES1<ITX1C> will be set to generate INTTX1 interrupt.



Figure 3.11 (20) Transmitting Operation in I/O Interface Mode (SCLK Input Mode)

## ② Receiving

In SCLK output mode, synchronous clock is outputted from SCLK pin and the data are shifted in the receiving buffer 1 whenever the receive interrupt flag INTES1<IRX1C> is cleared by reading the received data. When 8-bit data are received, the data will be transferred in the receiving buffer 2 (SC1BUF) at the timing shown below, and INTES1<IRX1C> will be set again to generate INTRX1 interrupt.



Figure 3.11 (21) Receiving Operation in I/O Interface Mode (SCLK Output Mode)

In SCLK input mode, the data is shifted in the receiving buffer 1 when SCLK input (SCLKC = 0: Rising edge mode) or SCLK input (SCLKC = 1: Falling edge mode) becomes active while the receive interrupt flag INTES1 <IRX1C> is cleared by reading the received data. When 8-bit data is received, the data will be shifted in the receiving buffer 2 (SC1BUF) at the timing shown below, and INTES1 <IRX1C> will be set again to generate INTRX1 interrupt.



Figure 3.11 (22) Receiving Operation in I/O Interface Mode (SCLK Input Mode)

Note : For data receiving, the system must be placed in the receive enable state  
(SCMOD<RXE> = "1")

## (2) Mode 1 (7-bit UART Mode)

7-bit mode can be set by setting serial channel mode register SC0MOD <SM1,0> / SC1MOD<SM1,0> to "01".

In this mode, a parity bit can be added, and the addition of a parity bit can be enabled or disabled by serial channel control register SC0CR<PE>/SC1CR<PE>, and even parity or odd parity is selected by SC0CR <EVEN>/SC1CR<EVEN> when <PE> is set to "1" (enable).

Setting example: When transmitting data with the following format, the control registers should be set as described below. Channel 0 is explained here.



|        |   |   |   |   |   |   |   |   |
|--------|---|---|---|---|---|---|---|---|
|        | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| P9CR   | ↔ | X | X | - | - | - | - | 1 |
| P9FC   | ↔ | X | X | - | X | - | X | 1 |
| SC0MOD | ↔ | X | 0 | - | X | 0 | 1 | 0 |
| SC0CR  | ↔ | X | 1 | 1 | X | X | X | 0 |
| BROCR  | ↔ | 0 | X | 1 | 0 | 0 | 1 | 0 |
| TRUN   | ↔ | 1 | X | - | - | - | - | - |
| INTES0 | ↔ | 1 | 1 | 0 | 0 | - | - | - |
| SC0BUF | ↔ | * | * | * | * | * | * | * |

} Select P90 as the TxD pin.  
Set 7-bit UART mode.  
Add an even parity.  
Set transfer rate at 2400 bps.  
Start the prescaler for the baud rate generator.  
Enable INTTX0 interrupt and set interrupt level 4.  
Set data for transmission.

Note: X; don't care      - ; no change

## (3) Mode 2 (8-bit UART Mode)

8-bit UART mode can be specified by setting SC0MOD<SM1,0>/SC1MOD<SM1,0> to "10". In this mode, parity bit can be added, the addition of a parity bit is enabled or disabled by SC0CR<PE>/SC1CR<PE>, and even parity or odd parity is selected by SC0CR<EVEN>/SC1CR<EVEN> when <PE> is set to "1" (enable).

Setting example: When receiving data with the following format, the control register should be set as described below.



**Main setting**

|                          |                                                    |
|--------------------------|----------------------------------------------------|
| 7 6 5 4 3 2 1 0          |                                                    |
| P9CR ← X X - - - - 0 -   | Select P91 (RxD) as the input pin.                 |
| SC0MOD ← - 0 1 X 1 0 0 1 | Enable receiving in 8-bit UART mode.               |
| SC0CR ← X 0 1 X X X 0 0  | Add an odd parity.                                 |
| BROCR ← 0 X 0 1 0 1 0 1  | Set transfer rate at 9600 bps.                     |
| TRUN ← 1 X - - - - -     | Start the prescaler for the baud rate generator.   |
| INTES0 ← - - - - 1 1 0 0 | Enable INTTX0 interrupt and set interrupt level 4. |

**Interrupt processing**

```

Acc ← SC0CR AND 00011100      } Check for error.
if Acc ≠ 0 then ERROR
Acc ← SC0BUF                  Read the received data.

Note: X; don't care -; no change
  
```

**(4) Mode 3 (9-bit UART Mode)**

9-bit UART mode can be specified by setting SC0MOD<SM1,0>/SC1MOD<SM 1,0> to “11”. In this mode, parity bit cannot be added.

For transmission, the MSB (9th bit) is written in SCMOD <TB8>, while in receiving it is stored in SCCR<RB8>. For writing and reading the buffer, the MSB is read or written first then SC0BUF/SC1BUF.

**Wake-up function**

In 9-bit UART mode, the wake-up function of slave controllers is enabled by setting SC0MOD<WU>/SC1MOD<WU> to “1”. The interrupt INTRX1/INTRX0 occurs only when <RB8> = 1.



Note: TxD pin of the slave controllers must be in open drain output mode.

Figure 3.11 (23) Serial Link Using Wake-Up Function

**Protocol**

- ① Select the 9-bit UART mode for the master and slave controllers.
- ② Set SC0MOD<WU>/SC1MOD<WU> bit of each slave controller to “1” to enable data receiving.
- ③ The master controller transmits one-frame data including the 8-bit select code for the slave controllers. The MSB (bit 8)<TB8> is set to “1”.



- ④ Each slave controller receives the above frame, and clears WU bit to “0” if the above select code matches its own select code.
- ⑤ The master controller transmits data to the specified slave controller whose SC0MOD<WU>/SC1MOD<WU> bit is cleared to “0”. The MSB (bit 8)<TB8> is cleared to “0”.



- ⑥ The other slave controllers (with the <WU> bit remaining at “1”) ignore the receiving data because their MSBs (bit 8 or <RB8>) are set to “0” to disable the interrupt INTRX0/INTRX1.

The slave controllers ( $WU=0$ ) can transmit data to the master controller, and it is possible to indicate the end of data receiving to the master controller by this transmission.

Setting example: To link two slave controllers serially with the master controller, and use the internal clock  $\phi_1$  ( $f_C/2$ ) as the transfer clock.



Since serial channels 0 and 1 operate in exactly the same way, channel 0 is used for the purposes of explanation.

- Setting the master controller

Main

```
P9CR ← X X - - - 0 1      } Select P90 as TxD pin and P91 as RxD pin.  
P9FC ← X X - X - X X 1  
INTES0 ← 1 1 0 0 1 1 0 1  
  
SCOMOD ← 1 0 1 0 1 1 1 0  Enable INTTX0 and set the interrupt level 4.  
SC0BUF ← 0 0 0 0 0 0 0 1  Enable INTTX0 and set the interrupt level 5.  
Set  $\phi_1$  ( $f_C/2$ ) as the transmission clock in 9-bit UART mode.  
Set the select code for slave controller 1.
```

INTTX0 interrupt

```
SCOMOD ← 0 - - - - - - - Sets TB8 to "0".  
SC0BUF ← * * * * * * * * Set data for transmission.
```

- Setting the slave controller 2

Main

```
P9CR ← X X - - - 0 1      } Select P91 as RxD pin and P90 as TxD pin (open drain  
P9FC ← X X - X - X X 1  
ODE ← X X X X X X - 1  
INTES0 ← 1 1 0 1 1 1 1 0  output).  
SCOMOD ← 0 0 1 1 1 1 1 0  Enable INTRX0 and INTTX0.  
Set <WU> to "1" in the 9-bit UART transmission mode  
with transfer clock  $\phi_1$  ( $f_C/2$ ).
```

INTRX0 interrupt

```
Acc ← SC0BUF  
if Acc = Select code  
Then SCOMOD4 ← - - - 0 - - - - Clear <WU> to "0".
```

### 3.12 Analog/Digital Converter

TMP96C141 has a high-speed analog / digital converter (A/D converter) with 4-channel analog input that features 10-bit successive approximation.

Figure 3.12 (1) shows the block diagram of the A/D converter. 4-channel analog input pins (AN3 to AN0) are shared by input-only port P5 and so can be used as input port.



Figure 3.12 (1) Block Diagram of A/D Converter

Note 1 :This A/D converter does not have a built-in sample and hold circuit.

Therefore, when A/D converting high-frequency signals, connect a sample and hold circuit externally.

|             | 7                                    | 6                                      | 5                                               | 4                                                          | 3                                                               | 2                                           | 1                                                 | 0     |
|-------------|--------------------------------------|----------------------------------------|-------------------------------------------------|------------------------------------------------------------|-----------------------------------------------------------------|---------------------------------------------|---------------------------------------------------|-------|
| bit Symbol  | EOCF                                 | ADBF                                   | REPET                                           | SCAN                                                       | ADCS                                                            | ADS                                         | ADCH1                                             | ADCH0 |
| Read/Write  | R                                    |                                        |                                                 |                                                            |                                                                 | R/W                                         |                                                   |       |
| After reset | 0                                    | 0                                      | 0                                               | 0                                                          | 0                                                               | 0                                           | 0                                                 | 0     |
| Function    | A/D conversion<br>End Flag<br>1: END | A/D conversion<br>BUSY Flag<br>1: BUSY | Repeat mode<br>0: Single mode<br>1: Repeat mode | Scan mode<br>0: Fixed channel mode<br>1: Channel Scan mode | A/D conversion Speed<br>0: High speed mode<br>1: Low speed mode | A/D conversion Start<br>1: conversion Start | Analog Input Channel Select<br>Always read as "0" | ⋮     |



Figure 3.12 (2) A/D Control Register

|             | 7                                              | 6     | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------|------------------------------------------------|-------|---|---|---|---|---|---|
| bit Symbol  | ADR01                                          | ADR00 |   |   |   |   |   |   |
| Read/Write  |                                                |       |   |   | R |   |   |   |
| After reset | Undefined                                      |       | 1 | 1 | 1 | 1 | 1 | 1 |
| Function    | Lower 2 bits of A/D result for AN0 are stored. |       |   |   |   |   |   |   |

|             | 7                                              | 6     | 5     | 4     | 3         | 2     | 1     | 0     |
|-------------|------------------------------------------------|-------|-------|-------|-----------|-------|-------|-------|
| bit Symbol  | ADR09                                          | ADR08 | ADR07 | ADR06 | ADR05     | ADR04 | ADR03 | ADR02 |
| Read/Write  |                                                |       |       |       | R         |       |       |       |
| After reset |                                                |       |       |       | Undefined |       |       |       |
| Function    | Upper 8 bits of A/D result for AN0 are stored. |       |       |       |           |       |       |       |

|             | 7                                              | 6     | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------|------------------------------------------------|-------|---|---|---|---|---|---|
| bit Symbol  | ADR11                                          | ADR10 |   |   |   |   |   |   |
| Read/Write  |                                                |       |   |   | R |   |   |   |
| After reset | Undefined                                      |       | 1 | 1 | 1 | 1 | 1 | 1 |
| Function    | Lower 2 bits of A/D result for AN1 are stored. |       |   |   |   |   |   |   |

|             | 7                                              | 6     | 5     | 4     | 3         | 2     | 1     | 0     |
|-------------|------------------------------------------------|-------|-------|-------|-----------|-------|-------|-------|
| bit Symbol  | ADR19                                          | ADR18 | ADR17 | ADR16 | ADR15     | ADR14 | ADR13 | ADR12 |
| Read/Write  |                                                |       |       |       | R         |       |       |       |
| After reset |                                                |       |       |       | Undefined |       |       |       |
| Function    | Upper 8 bits of A/D result for AN1 are stored. |       |       |       |           |       |       |       |

Figure 3.12 (3-1) A/D Conversion Result Register (ADREG0, 1)

|             | 7                                              | 6     | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------|------------------------------------------------|-------|---|---|---|---|---|---|
| bit Symbol  | ADR21                                          | ADR20 |   |   |   |   |   |   |
| Read/Write  |                                                |       |   | R |   |   |   |   |
| After reset | Undefined                                      |       | 1 | 1 | 1 | 1 | 1 | 1 |
| Function    | Lower 2 bits of A/D result for AN2 are stored. |       |   |   |   |   |   |   |

|             | 7                                              | 6     | 5     | 4         | 3     | 2     | 1     | 0     |
|-------------|------------------------------------------------|-------|-------|-----------|-------|-------|-------|-------|
| bit Symbol  | ADR29                                          | ADR28 | ADR27 | ADR26     | ADR25 | ADR24 | ADR23 | ADR22 |
| Read/Write  |                                                |       |       | R         |       |       |       |       |
| After reset |                                                |       |       | Undefined |       |       |       |       |
| Function    | Upper 8 bits of A/D result for AN2 are stored. |       |       |           |       |       |       |       |

|             | 7                                              | 6     | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------|------------------------------------------------|-------|---|---|---|---|---|---|
| bit Symbol  | ADR31                                          | ADR30 |   |   |   |   |   |   |
| Read/Write  |                                                |       |   | R |   |   |   |   |
| After reset | Undefined                                      |       | 1 | 1 | 1 | 1 | 1 | 1 |
| Function    | Lower 2 bits of A/D result for AN3 are stored. |       |   |   |   |   |   |   |

|             | 7                                              | 6     | 5     | 4         | 3     | 2     | 1     | 0     |
|-------------|------------------------------------------------|-------|-------|-----------|-------|-------|-------|-------|
| bit Symbol  | ADR39                                          | ADR38 | ADR37 | ADR36     | ADR35 | ADR34 | ADR33 | ADR32 |
| Read/Write  |                                                |       |       | R         |       |       |       |       |
| After reset |                                                |       |       | Undefined |       |       |       |       |
| Function    | Upper 8 bits of A/D result for AN3 are stored. |       |       |           |       |       |       |       |

Figure 3.12 (3-2) A/D Conversion Result Register (ADREG2, 3)

### 3.12.1 Operation

#### (1) Analog Reference Voltage

High analog reference voltage is applied to the VREF pin, and the low analog reference voltage is applied to AGND pin.

The reference voltage between VREF and AGND is divided by 1024 using ladder resistance, and compared with the analog input voltage for A/D conversion.

#### (2) Analog Input Channels

Analog input channel to select depends on the operation mode of the A/D converter.

In fixed analog input mode, one channel is selected by ADMOD<ADCH1,0> among four pins: AN0 to AN3.

In analog input channel scan mode, the number of channels to be scanned from AN0 is specified by ADMOD<ADCH1,0>, such as AN0→AN1, AN0→AN1→AN2, and AN0→AN1→AN2→AN3.

When reset, A/D conversion channel register will be initialized to ADMOD<ADCH1,0> = 00, so that AN0 pin will be selected.

The pins which are not used as analog input channel can be used as ordinary input port P5.

#### (3) Starting A/D Conversion

A/D conversion starts when A/D conversion register ADMOD<ADS> is written “1”. When A/D conversion starts, A/D conversion busy flag ADMOD<ADBF> which indicates “A/D conversion is in progress” will be set to “1”.

#### (4) A/D Conversion Mode

Both fixed A/D conversion channel mode and A/D conversion channel scan mode have two conversion modes, i.e., single and repeat conversion modes.

In fixed channel repeat mode, conversion of specified one channel is executed repeatedly.

In scan repeat mode, scanning from AN0, ⋯→AN3 is executed repeatedly.

A/D conversion mode is selected by ADMOD<REPET, SCAN>.

#### (5) A/D Conversion Speed Selection

There are two A/D conversion speed modes: high speed mode and low speed mode. The selection is executed by ADMOD<ADCS> register.

When reset, ADMOD<ADCS> will be initialized to “0”, so that high speed conversion mode will be selected.

#### (6) A/D Conversion End and Interrupt

- A/D conversion single mode

ADMOD<EOCF> for A/D conversion end will be set to "1", ADMOD<ADBF> flag will be reset to "0", and INTAD interrupt will be enabled when A/D conversion of specified channel ends in fixed conversion channel mode or when A/D conversion of the last channel ends in channel scan mode.

- A/D conversion repeat mode

For both fixed conversion channel mode and conversion channel scan mode, INTAD should be disabled when in repeat mode. Always set the INTE0AD at "000", that disables the interrupt request.

Write "0" to ADMOD<REPET> to end the repeat mode. Then, the repeat mode will be exited as soon as the conversion in progress is completed.

#### (7) Storing the A/D Conversion Result

The results of A/D conversion are stored in ADREG0 to ADREG3 registers for each channel. In repeat mode, the registers are updated whenever conversion ends.

ADREG0 to ADREG3 are read-only registers.

#### (8) Reading the A/D Conversion Result

The results of A/D conversion are stored in ADREG0 to ADREG3 registers. When the contents of one of ADREG0 to ADREG3 registers are read, ADMOD<EOCF> will be cleared to "0".

Setting example: ① When the analog input voltage of the AN3 pin is A/D converted and the result is stored in the memory address FF10H by A/D interrupt INTAD routine

##### Main setting

|                         |                                                                                          |
|-------------------------|------------------------------------------------------------------------------------------|
| INTE0AD ← 1 1 0 0 - - - | Enable INTAD and set interrupt level 4.                                                  |
| ADMOD ← X X 0 0 0 1 1 1 | Specify AN3 pin as an analog input channel and starts A/D conversion in high speed mode. |

##### INTAD routine

|               |                                                          |
|---------------|----------------------------------------------------------|
| WA ← ADREG3   | Read ADREG3L and ADREG3H values and write to WA (16 bit) |
| WA >> 6       | Right-shifts WA six times and writes 0 in upper bits.    |
| (00FF10H)← WA | Writes contents of WA in memory at FF10H                 |

When the analog input voltage of AN0~AN2 pins is A/D converted in high speed conversion channel scan repeat mode

|                         |                                                                                               |
|-------------------------|-----------------------------------------------------------------------------------------------|
| INTE0AD ← 1 0 0 0 - - - | Disable INTAD.                                                                                |
| ADMOD ← X X 1 1 0 1 1 0 | Start the A/D conversion of analog input channels AN0~AN2 in the high-speed scan repeat mode. |

Note: X; don't care - ; no change

### 3.13 Watchdog Timer (Runaway Detecting Timer)

TMP96C141 is containing watchdog timer of Runaway detecting.

The watchdog timer (WDT) is used to return the CPU to the normal state when it detects that the CPU has started to malfunction (runaway) due to causes such as noise. When the watchdog timer detects a malfunction, it generates a non-maskable interrupt to notify the CPU of the malfunction, and outputs 0 externally from watchdog timer out pin WDTOUT to notify the peripheral devices of the malfunction.

Connecting the watchdog timer output to the reset pin internally forces a reset.

#### 3.13.1 Configuration

Figure 3.13 (1) shows the block diagram of the watchdog timer (WDT).



Figure 3.13 (1) Block Diagram of Watchdog Timer

The watchdog timer is a 22-stage binary counter which uses  $\phi(f_c/2)$  as the input clock. There are four outputs from the binary counter:  $2^{16}/f_c$ ,  $2^{18}/f_c$ ,  $2^{20}/f_c$ , and  $2^{22}/f_c$ . Selecting one of the outputs with the WDMOD register generates a watchdog interrupt, and outputs watchdog timer out when an overflow occurs.

Since the watchdog timer out pin (WDTOUT) outputs "0" due to a watchdog timer overflow, the peripheral devices can be reset. The watchdog timer out pin is set to 1 by clearing the watchdog timer (by writing a clear code 4EH in the WDCR register). In other words, the WDTOUT keeps outputting "0" until the clear code is written.

The watchdog timer out pin can also be connected to the reset pin internally. In this case, the watchdog timer out pin (WDTOUT) outputs 0 at 32states ( $3.2\mu s @ 20MHz$ ) and resets itself.



Figure 3.13 (2) Normal Mode



Figure 3.13 (3) Reset Mode

### 3.13.2 Control Registers

Watchdog timer WDT is controlled by two control registers WDMOD and WDCR.

#### (1) Watchdog Timer Mode Register (WDMOD)

##### ① Setting the detecting time of watchdog timer <WDTP>

This 2-bit register is used to set the watchdog timer interrupt time for detecting the runaway. This register is initialized to WDMOD<WDTP1, 0>=00 when reset, and therefore  $2^{16}/fc$  is set. (The number of states is approx. 32,768.)

##### ② Watchdog timer enable/disable control register <WDTE>

When reset, WDMOD<WDTE> is initialized to "1" enable the watchdog timer.

To disable, it is necessary to clear this bit to "0" and write the disable code (B1H) in the watchdog timer control register WDCR. This makes it difficult for the watchdog timer to be disabled by runaway.

However, it is possible to return from the disable state to enable state by merely setting <WDTE> to "1".

##### ③ Watchdog timer out reset connection<RESCR>

This register is used to connect the output of the watchdog timer with RESET terminal, internally. Since WDMOD<RESCR> is initialized to 0 at reset, a reset by the watchdog timer will not be performed.

#### (2) Watchdog Timer Control Register (WDCR)

This register is used to disable and clear of binary counter the watchdog timer function.

##### ● Disable control

By writing the disable code (B1H) in this WDCR register after clearing WDMOD<WDTE> to "0", the watchdog timer can be disabled.

|                                                                                                                                        |                               |
|----------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| $\boxed{\begin{array}{l} \text{WDMOD} \leftarrow 0 - - - - X \ X \\ \text{WDCR} \leftarrow 1 \ 0 \ 1 \ 1 \ 0 \ 0 \ 0 \ 1 \end{array}}$ | Clear WDMOD<WDTE> to "0".     |
|                                                                                                                                        | Write the disable code (B1H). |

##### ● Enable control

Set WDMOD<WDTE> to "1".

##### ● Watchdog timer clear control

The binary counter can be cleared and resume counting by writing clear code (4EH) into the WDCR register.

|                                                                |                             |
|----------------------------------------------------------------|-----------------------------|
| $\boxed{\text{WDCR} \leftarrow 0 \ 1 \ 0 \ 0 \ 1 \ 1 \ 1 \ 0}$ | Write the clear code (4EH). |
|----------------------------------------------------------------|-----------------------------|



Figure 3.13 (4) Watchdog Timer Mode Register

| WDCR<br>(005DH)                                                                                                                                | 7            | 6                                              | 5 | 4 | 3 | 2 | 1 | 0 |     |              |     |            |        |   |  |
|------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------------------------------------------|---|---|---|---|---|---|-----|--------------|-----|------------|--------|---|--|
|                                                                                                                                                | bit Symbol   | —                                              |   |   |   |   |   |   |     |              |     |            |        |   |  |
|                                                                                                                                                | Read/Write   | W                                              |   |   |   |   |   |   |     |              |     |            |        |   |  |
|                                                                                                                                                | After reset  | —                                              |   |   |   |   |   |   |     |              |     |            |        |   |  |
| Function                                                                                                                                       |              | B1H : WDT disable code<br>4EH : WDT clear code |   |   |   |   |   |   |     |              |     |            |        |   |  |
| → Disable/clear WDT                                                                                                                            |              |                                                |   |   |   |   |   |   |     |              |     |            |        |   |  |
| <table border="1"><tr><td>B1H</td><td>Disable code</td></tr><tr><td>4EH</td><td>Clear code</td></tr><tr><td>Others</td><td>—</td></tr></table> |              |                                                |   |   |   |   |   |   | B1H | Disable code | 4EH | Clear code | Others | — |  |
| B1H                                                                                                                                            | Disable code |                                                |   |   |   |   |   |   |     |              |     |            |        |   |  |
| 4EH                                                                                                                                            | Clear code   |                                                |   |   |   |   |   |   |     |              |     |            |        |   |  |
| Others                                                                                                                                         | —            |                                                |   |   |   |   |   |   |     |              |     |            |        |   |  |

Figure 3.13 (5) Watchdog Timer Control Register

### 3.13.3 Operation

The watchdog timer generates interrupt INTWD after the detecting time set in the WDMOD<WDTP1, 0>register and outputs a low level signal. The watchdog timer must be zero-cleared by software before an INTWD interrupt is generated. If the CPU malfunctions (runaway) due to causes such as noise, but does not execute the instruction used to clear the binary counter, the binary counter overflows and an INTWD interrupt is generated. The CPU detects malfunction (runaway) due to the INTWD Interrupt and it is possible to return to normal operation by an anti-malfunction program. By connecting the watchdog timer out pin to peripheral devices' resets, a CPU malfunction can also be acknowledged to other devices.

~~The watchdog timer restarts operation immediately after resetting is released.~~

The watchdog timer stops its operation in the IDLE and STOP modes. In the bus releasing, the watchdog timer continues the counting. In the RUN mode, the watchdog timer is enabled.

However, the function can be disabled when entering the RUN mode.

Example : ① Clear the binary counter

WDCR ← 0 1 0 0 1 1 1 0                  Write clear code (4EH).

② Set the watchdog timer detecting time to  $2^{18}/fc$

WDMOD ← 1 0 1 - - - X X

③ Disable the watchdog timer.

WDMOD ← 0 - - - - - X X                  Clear WDTE to "0".  
WDCR ← 1 0 1 1 0 0 0 1                  Write disable code (B1H).

④ Set IDLE mode.

WDMOD ← 0 - - - 1 0 X X                  Disables WDT and sets IDLE mode.

WDCR ← 1 0 1 1 0 0 0 1

Executes HALT command

Set the standby mode

⑤ Set the STOP mode (warming up time:  $2^{16}/fc$ )

WDMOD ← - - - 1 0 1 X X                  Set the STOP mode.

Executes HALT command.

Execute HALT instruction. Set the standby mode.

## 4. ELECTRICAL CHARACTERISTICS

### 4.1 Absolute Maximum (TMP96C141F)

| Symbol              | Parameter                     | Rating                    | Unit |
|---------------------|-------------------------------|---------------------------|------|
| V <sub>cc</sub>     | Power Supply voltage          | -0.5~6.5                  | V    |
| V <sub>IN</sub>     | Input voltage                 | -0.5~V <sub>cc</sub> +0.5 | V    |
| $\Sigma I_{OL}$     | Output Current (total)        | 100                       | mA   |
| $\Sigma I_{OH}$     | Output Current (total)        | -100                      | mA   |
| P <sub>D</sub>      | Power Dissipation (Ta = 70°C) | 600                       | mW   |
| T <sub>SOLDER</sub> | Soldering Temperature (10 s)  | 260                       | °C   |
| T <sub>STG</sub>    | Storage temperature           | -65~150                   | °C   |
| T <sub>OPR</sub>    | Operating temperature         | -20~70                    | °C   |

### 4.2 DC Characteristics (TMP96C141F)

V<sub>cc</sub> = 5V ± 10%, Ta = -20~70°C (Typical values are for Ta = 25°C and V<sub>cc</sub> = 5V.)

| Symbol            | Parameter                                                                     | Min                                | Max                   | Unit                 | Test Condition                                                                                                             |
|-------------------|-------------------------------------------------------------------------------|------------------------------------|-----------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------|
| V <sub>IL</sub>   | Input Low Voltage (AD0~15)                                                    | -0.3                               | 0.8                   | V                    |                                                                                                                            |
| V <sub>IL1</sub>  | P2, P3, P4, P5, P6, P7, P8, P9                                                | -0.3                               | 0.3V <sub>cc</sub>    | V                    |                                                                                                                            |
| V <sub>IL2</sub>  | RESET, NMI, INT0 (P87)                                                        | -0.3                               | 0.25V <sub>cc</sub>   | V                    |                                                                                                                            |
| V <sub>IL3</sub>  | EA                                                                            | -0.3                               | 0.3                   | V                    |                                                                                                                            |
| V <sub>IL4</sub>  | X1                                                                            | -0.3                               | 0.2V <sub>cc</sub>    | V                    |                                                                                                                            |
| V <sub>IH</sub>   | Input High Voltage (AD0~15)                                                   | 2.2                                | V <sub>cc</sub> + 0.3 | V                    |                                                                                                                            |
| V <sub>IH1</sub>  | P2, P3, P4, P5, P6, P7, P8, P9                                                | 0.7V <sub>cc</sub>                 | V <sub>cc</sub> + 0.3 | V                    |                                                                                                                            |
| V <sub>IH2</sub>  | RESET, NMI, INT0 (P87)                                                        | 0.75V <sub>cc</sub>                | V <sub>cc</sub> + 0.3 | V                    |                                                                                                                            |
| V <sub>IH3</sub>  | EA                                                                            | V <sub>cc</sub> - 0.3              | V <sub>cc</sub> + 0.3 | V                    |                                                                                                                            |
| V <sub>IH4</sub>  | X1                                                                            | 0.8V <sub>cc</sub>                 | V <sub>cc</sub> + 0.3 | V                    |                                                                                                                            |
| V <sub>OL</sub>   | Output Low Voltage                                                            | 0.45                               | V                     |                      | I <sub>OL</sub> = 1.6mA                                                                                                    |
| V <sub>OH</sub>   | Output High Voltage                                                           | 2.4                                | V                     |                      |                                                                                                                            |
| V <sub>OH1</sub>  |                                                                               | 0.75V <sub>cc</sub>                | V                     |                      | I <sub>OH</sub> = -400μA                                                                                                   |
| V <sub>OH2</sub>  |                                                                               | 0.9V <sub>cc</sub>                 | V                     |                      | I <sub>OH</sub> = -100μA                                                                                                   |
|                   |                                                                               |                                    |                       |                      | I <sub>OH</sub> = -20μA                                                                                                    |
| I <sub>DAR</sub>  | Darlington Drive Current<br>(8 Output Pins max.)                              | -1.0                               | -3.5                  | mA                   | V <sub>EXT</sub> = 1.5V<br>R <sub>EXT</sub> = 1.1kΩ                                                                        |
| I <sub>LI</sub>   | Input Leakage Current                                                         | 0.02 (Typ)                         | ±5                    | μA                   | 0.0 ≤ V <sub>in</sub> ≤ V <sub>cc</sub>                                                                                    |
| I <sub>LO</sub>   | Output Leakage Current                                                        | 0.05 (Typ)                         | ±10                   | μA                   | 0.2 ≤ V <sub>in</sub> ≤ V <sub>cc</sub> - 0.2                                                                              |
| I <sub>cc</sub>   | Operating Current (RUN)<br>IDLE<br>STOP (Ta = -20~70°C)<br>STOP (Ta = 0~50°C) | 26 (Typ)<br>1.7 (Typ)<br>0.2 (Typ) | 50<br>10<br>50<br>10  | mA<br>mA<br>μA<br>μA | f <sub>osc</sub> = 20MHz<br>0.2 ≤ V <sub>in</sub> ≤ V <sub>cc</sub> - 0.2<br>0.2 ≤ V <sub>in</sub> ≤ V <sub>cc</sub> - 0.2 |
| V <sub>STOP</sub> | Power Down Voltage<br>(@STOP, RAM Back up)                                    | 2.0                                | 6.0                   | V                    | V <sub>IL2</sub> = 0.2V <sub>cc</sub> ,<br>V <sub>IH2</sub> = 0.8V <sub>cc</sub>                                           |
| R <sub>RST</sub>  | RESET Pull Up Register                                                        | 50                                 | 150                   | kΩ                   |                                                                                                                            |
| C <sub>IO</sub>   | Pin Capacitance                                                               |                                    | 10                    | pF                   | t <sub>osc</sub> = 1MHz                                                                                                    |
| V <sub>TH</sub>   | Schmitt Width<br>RESET, NMI, INT0 (P87)                                       | 0.4                                | 1.0 (Typ)             | V                    |                                                                                                                            |
| R <sub>K</sub>    | Pull Down/Up Register                                                         | 50                                 | 150                   | kΩ                   |                                                                                                                            |

Note : I-DAR is guaranteed for a total of up to 8 ports.

## 4.3 AC Electrical Characteristics (TMP96C141F)

$V_{CC} = 5V \pm 10\%$ ,  $TA = -20\sim70^\circ C$   
(4MHz~20MHz)

| No. | Symbol     | Parameterer                                                                          | Variable    |              | 16MHz |     | 20MHz |     | Unit |
|-----|------------|--------------------------------------------------------------------------------------|-------------|--------------|-------|-----|-------|-----|------|
|     |            |                                                                                      | Min         | Max          | Min   | Max | Min   | Max |      |
| 1   | $t_{osc}$  | Osc. Period (=x)                                                                     | 50          | 250          | 62.5  |     | 50    |     | ns   |
| 2   | $t_{CLK}$  | CLK width                                                                            | $2x - 40$   |              | 85    |     | 60    |     | ns   |
| 3   | $t_{AK}$   | A0-23 Valid $\rightarrow$ CLK Hold                                                   | $0.5x - 20$ |              | 11    |     | 5     |     | ns   |
| 4   | $t_{KA}$   | CLK Valid $\rightarrow$ A0-23 Hold                                                   | $1.5x - 70$ |              | 24    |     | 5     |     | ns   |
| 5   | $t_{AL}$   | A0-15 Valid $\rightarrow$ ALE fall                                                   | $0.5x - 15$ |              | 16    |     | 10    |     | ns   |
| 6   | $t_{LA}$   | ALE fall $\rightarrow$ A0-15 Hold                                                    | $0.5x - 15$ |              | 16    |     | 10    |     | ns   |
| 7   | $t_{LL}$   | ALE High width                                                                       | $x - 40$    |              | 23    |     | 10    |     | ns   |
| 8   | $t_{LC}$   | ALE fall $\rightarrow$ RD/WR fall                                                    | $0.5x - 30$ |              | 1     |     | -5    |     | ns   |
| 9   | $t_{CL}$   | RD/WR rise $\rightarrow$ ALE rise                                                    | $0.5x - 20$ |              | 11    |     | 5     |     | ns   |
| 10  | $t_{ACL}$  | A0-15 Valid $\rightarrow$ RD/WR fall                                                 | $x - 25$    |              | 38    |     | 25    |     | ns   |
| 11  | $t_{ACH}$  | A0-23 Valid $\rightarrow$ RD/WR fall                                                 | $1.5x - 50$ |              | 44    |     | 25    |     | ns   |
| 12  | $t_{CA}$   | RD/WR rise $\rightarrow$ A0-23 Hold                                                  | $0.5x - 20$ |              | 11    |     | 5     |     | ns   |
| 13  | $t_{ADL}$  | A0-15 Valid $\rightarrow$ D0-15 input                                                |             | $3.0x - 45$  |       | 143 |       | 105 | ns   |
| 14  | $t_{ADH}$  | A0-23 Valid $\rightarrow$ D0-15 input                                                |             | $3.5x - 65$  |       | 154 |       | 110 | ns   |
| 15  | $t_{RD}$   | RDfall $\rightarrow$ D0-15 input                                                     |             | $2.0x - 50$  |       | 75  |       | 50  | ns   |
| 16  | $t_{RR}$   | RD Low width                                                                         | $2.0x - 40$ |              | 85    |     | 60    |     | ns   |
| 17  | $t_{HR}$   | RDrise $\rightarrow$ D0-15 Hold                                                      | 0           |              | 0     |     | 0     |     | ns   |
| 18  | $t_{RAE}$  | RDrise $\rightarrow$ A0-15output                                                     | $x - 15$    |              | 48    |     | 35    |     | ns   |
| 19  | $t_{WW}$   | WR Low width                                                                         | $2.0x - 40$ |              | 85    |     | 60    |     | ns   |
| 20  | $t_{DW}$   | D0-15 Valid $\rightarrow$ WRrise                                                     | $2.0x - 50$ |              | 75    |     | 50    |     | ns   |
| 21  | $t_{WD}$   | WR rise $\rightarrow$ D0-15 Hold                                                     | $0.5x - 10$ |              | 21    |     | 15    |     | ns   |
| 22  | $t_{AEH}$  | A0-23 Valid $\rightarrow$ WAIT input<br><small>(<math>1WAIT + n mode</math>)</small> |             | $3.5x - 90$  |       | 129 |       | 85  | ns   |
| 23  | $t_{AWL}$  | A0-15 Valid $\rightarrow$ WAIT input<br><small>(<math>1WAIT + n mode</math>)</small> |             | $3.0x - 80$  |       | 108 |       | 70  | ns   |
| 24  | $t_{CW}$   | RD/WR fall $\rightarrow$ WAIT Hold<br><small>(<math>1WAIT + n mode</math>)</small>   | $2.0x + 0$  |              | 125   |     | 100   |     | ns   |
| 25  | $t_{APH}$  | A0-23 Valid $\rightarrow$ PORT input                                                 |             | $2.5x - 120$ |       | 36  |       | 5   | ns   |
| 26  | $t_{APH2}$ | A0-23 Valid $\rightarrow$ PORT Hold                                                  | $2.5x + 50$ |              | 206   |     | 175   |     | ns   |
| 27  | $t_{CP}$   | WR rise $\rightarrow$ PORT Valid                                                     |             | 200          |       | 200 |       | 200 | ns   |
| 28  | $t_{ASRH}$ | A0-23 Valid $\rightarrow$ RAS fall                                                   | $1.0x - 40$ |              | 23    |     | 10    |     | ns   |
| 29  | $t_{ASRL}$ | A0-15 Valid $\rightarrow$ RAS fall                                                   | $0.5x - 15$ |              | 16    |     | 10    |     | ns   |
| 30  | $t_{TRAC}$ | RAS fall $\rightarrow$ D0-15 input                                                   |             | $2.5x - 70$  |       | 86  |       | 55  | ns   |
| 31  | $t_{TRAH}$ | RAS fall $\rightarrow$ A0-15 Hold                                                    | $0.5x - 15$ |              | 16    |     | 10    |     | ns   |
| 32  | $t_{TRAS}$ | RAS Low width                                                                        | $2.0x - 40$ |              | 85    |     | 60    |     | ns   |
| 33  | $t_{TRP}$  | RAS High width                                                                       | $2.0x - 40$ |              | 85    |     | 60    |     | ns   |
| 34  | $t_{TRSH}$ | CAS fall $\rightarrow$ RAS rise                                                      | $1.0x - 35$ |              | 28    |     | 15    |     | ns   |
| 35  | $t_{TRSC}$ | RAS rise $\rightarrow$ CAS rise                                                      | $0.5x - 25$ |              | 6     |     | 0     |     | ns   |
| 36  | $t_{TRCD}$ | RAS fall $\rightarrow$ CAS fall                                                      | $1.0x - 40$ |              | 23    |     | 10    |     | ns   |
| 37  | $t_{TCAC}$ | CAS fall $\rightarrow$ D0-15 input                                                   |             | $1.5x - 65$  |       | 29  |       | 10  | ns   |
| 38  | $t_{TCAS}$ | CAS Low width                                                                        | $1.5x - 30$ |              | 64    |     | 40    |     | ns   |
|     |            |                                                                                      |             |              |       |     |       |     |      |
|     |            |                                                                                      |             |              |       |     |       |     |      |
|     |            |                                                                                      |             |              |       |     |       |     |      |
|     |            |                                                                                      |             |              |       |     |       |     |      |

## AC Measuring Conditions

- Output Level : High 2.2V /Low 0.8V , CL50pF  
(However CL = 100pF for AD0~AD15, AD0~AD23, ALE, RD, WR, HWR, R/W, CLK, RAS, CAS0~CAS2)
- Input Level : High 2.4V /Low 0.45V (AD0~AD15)  
High 0.8Vcc /Low 0.2Vcc (Except for AD0~AD15)

## (1) Read Cycle



## (2) Write Cycle



## 4.4 A/D Conversion Characteristics (TMP96C141F)

| Symbol                                              | Parameter                                   |                            | Min                   | Typ             | Max             | Unit |
|-----------------------------------------------------|---------------------------------------------|----------------------------|-----------------------|-----------------|-----------------|------|
| V <sub>REF</sub>                                    | Analog reference voltage                    |                            | V <sub>CC</sub> - 1.5 | V <sub>CC</sub> | V <sub>CC</sub> |      |
| A <sub>GND</sub>                                    | Analog reference voltage                    |                            | V <sub>SS</sub>       | V <sub>SS</sub> | V <sub>SS</sub> | V    |
| V <sub>AIN</sub>                                    | Analog input voltage range                  |                            | V <sub>SS</sub>       |                 | V <sub>CC</sub> |      |
| I <sub>REF</sub>                                    | Analog current for analog reference voltage |                            |                       | 0.5             | 1.5             | mA   |
| Error(Quantize error of $\pm 0.5$ LSB not included) | 4 $\leq f_C$                                | Low speed conversion mode  |                       | $\pm 1.5$ (TBD) | $\pm 4.0$       |      |
|                                                     | $\leq 16\text{MHz}$                         | High speed conversion mode |                       | $\pm 3.0$ (TBD) | $\pm 6.0$       |      |
|                                                     | 16 $\leq f_C$                               | Low speed conversion mode  |                       | $\pm 1.5$ (TBD) | $\pm 4.0$       |      |
|                                                     | $\leq 20\text{MHz}$                         | High speed conversion mode |                       | $\pm 4.0$ (TBD) | $\pm 8.0$       | LSB  |

## 4.5 Serial Channel Timing – I/O Interface Mode

## (1) SCLK Input Mode

V<sub>CC</sub> = 5V ± 10% TA = -20~70 °C

| Symbol           | Parameter                               | Variable                      |                             | 16MHz |     | 20MHz |     | Unit |
|------------------|-----------------------------------------|-------------------------------|-----------------------------|-------|-----|-------|-----|------|
|                  |                                         | Min                           | Max                         | Min   | Max | Min   | Max |      |
| t <sub>SCY</sub> | SCLK cycle                              | 16X                           |                             | 1     |     | 0.8   |     | μs   |
| t <sub>OSS</sub> | Output Data → Rising edge of SCLK       | t <sub>SCY</sub> /2 - 5X - 50 |                             | 137   |     | 100   |     | ns   |
| t <sub>OHS</sub> | SCLK rising edge → Output Data hold     | 5X - 100                      |                             | 212   |     | 150   |     | ns   |
| t <sub>HSD</sub> | SCLK rising edge → Input Data hold      | 0                             |                             | 0     |     | 0     |     | ns   |
| t <sub>SRD</sub> | SCLK rising edge → effective data input |                               | t <sub>SCY</sub> - 5X - 100 | 587   |     | 450   |     | ns   |

## (2) SCLK Output Mode

| Symbol           | Parameter                               | Variable                    |                             | 16MHz |     | 20MHz |       | Unit |
|------------------|-----------------------------------------|-----------------------------|-----------------------------|-------|-----|-------|-------|------|
|                  |                                         | Min                         | Max                         | Min   | Max | Min   | Max   |      |
| t <sub>SCY</sub> | SCLK cycle (programmable)               | 16X                         | 8192X                       | 1     | 512 | 0.8   | 409.6 | μs   |
| t <sub>OSS</sub> | Output Data → SCLK rising edge          | t <sub>SCY</sub> - 2X - 150 |                             | 725   |     | 550   |       | ns   |
| t <sub>OHS</sub> | SCLK rising edge → Output Data hold     | 2X - 80                     |                             | 45    |     | 20    |       | ns   |
| t <sub>HSD</sub> | SCLK rising edge → Input Data hold      | 0                           |                             | 0     |     | 0     |       | ns   |
| t <sub>SRD</sub> | SCLK rising edge → effective data input |                             | t <sub>SCY</sub> - 2X - 150 | 725   |     | 550   |       | ns   |

## 4.6 Timer/Counter Input Clock (TI0, TI4, TI5, TI6, TI7)

V<sub>CC</sub> = 5V ± 10% TA = -20~70 °C

| Symbol            | Parameter                    | Variable |     | 16MHz |     | 20MHz |     | Unit |
|-------------------|------------------------------|----------|-----|-------|-----|-------|-----|------|
|                   |                              | Min      | Max | Min   | Max | Min   | Max |      |
| t <sub>VCK</sub>  | Clock Cycle                  | 8X + 100 |     | 600   |     | 500   |     | ns   |
| t <sub>VCKL</sub> | Low level clock Pulse width  | 4X + 40  |     | 290   |     | 240   |     | ns   |
| t <sub>VCKH</sub> | High level clock Pulse width | 4X + 40  |     | 290   |     | 240   |     | ns   |

## 4.7 Interrupt Operation

V<sub>CC</sub> = 5V ± 10% TA = -20~70 °C

| Symbol             | Parameter                        | Variable |     | 16MHz |     | 20MHz |     | Unit |
|--------------------|----------------------------------|----------|-----|-------|-----|-------|-----|------|
|                    |                                  | Min      | Max | Min   | Max | Min   | Max |      |
| t <sub>INTAL</sub> | NMI, INT0 Low level Pulse width  | 4X       |     | 250   |     | 200   |     | ns   |
| t <sub>INTAH</sub> | NMI, INT0 High level Pulse width | 4X       |     | 250   |     | 200   |     | ns   |
| t <sub>INTBL</sub> | INT4~INT7 Low level Pulse width  | 8X + 100 |     | 600   |     | 500   |     | ns   |
| t <sub>INTBH</sub> | INT4~INT7 High level Pulse width | 8X + 100 |     | 600   |     | 500   |     | ns   |

## 4.8 Timing Chart for I/O Interface Mode



#### 4.9 Timing Chart for Bus Request (BUSRQ) / BUS Acknowledge (BUSAk)



| Symbol            | Parameter                                            | Variable |            | 16MHz |     | 20MHz |     | Unit |
|-------------------|------------------------------------------------------|----------|------------|-------|-----|-------|-----|------|
|                   |                                                      | Min      | Max        | Min   | Max | Min   | Max |      |
| t <sub>BRC</sub>  | BUSRQ set-up time for CLK                            | 120      |            | 120   |     | 120   |     | ns   |
| t <sub>CBAL</sub> | CLK → BUSAK falling edge                             |          | 1.5x + 120 |       | 214 |       | 195 | ns   |
| t <sub>CBAH</sub> | CLK → BUSAK rising edge                              |          | 0.5x + 40  |       | 71  |       | 65  | ns   |
| t <sub>ABA</sub>  | Output Buffer is off to BUSAK → Output buffer is on. | 0        | 80         | 0     | 80  | 0     | 80  | ns   |
| t <sub>BAA</sub>  | BUSAk → Output buffer is on.                         | 0        | 80         | 0     | 80  | 0     | 80  | ns   |

Note 1: The Bus will be released after the WAIT request is inactive, when the BUSRQ is set to "0" during "Wait" cycle.

Note 2: This line only shows the output buffer is off-states.

They don't indicate the signal level is fixed.

After the bus is released, the signal level is kept dynamically before the bus is released by the external capacitance.

Therefore, to fix the signal level by an external resistance under the bus is releasing, the design must be carefully because of the level-fix will be delayed.

The internal programmable pull-up/pull-down resistance is switched active/non-active by the internal signal.

#### 4.10 Typical characteristics

$V_{CC} = 5V$ ,  $T_a = 25^\circ C$ , unless otherwise noted.



Figure 5.1  $V_{CC}$  –  $f_{osc}$  TYPICAL CURVE



Figure 5.2  $f_{osc}$  –  $I_{CC}$  TYPICAL CURVE



Figure 5.3  $I_{CC}$  –  $V_{CC}$  TYPICAL CURVE



Figure 5.4  $V_{OUT}$  –  $I_{OL}$  TYPICAL CURVE



Figure 5.5  $V_{OUT}$  –  $I_{OH}$  TYPICAL CURVE

## 5. TABLE OF SPECIAL FUNCTION REGISTERS (SFRs)

(SFR ; Special Function Register)

The special function registers (SFRs) include the I/O ports and peripheral control registers allocated to the 128-byte addresses from 000000H to 00007FH.

- (1) I/O port
- (2) I/O port control
- (3) Timer control
- (4) Pattern Generator control
- (5) Watch Dog Timer control
- (6) Serial Channel control
- (7) A / D converter control
- (8) Interrupt control
- (9) Chip Select / Wait control

Configuration of the table

| Symbol | Name | Address | 7 | 6 |  |  | 1 | 0 |
|--------|------|---------|---|---|--|--|---|---|
|        |      |         |   |   |  |  |   |   |

→bit Symbol  
→Read / Write  
→Initial value after reset  
→Remarks

020289

Table5 I/O register address map

| ADDRESS | NAME | ADDRESS | NAME   | ADDRESS | NAME   | ADDRESS | NAME     |
|---------|------|---------|--------|---------|--------|---------|----------|
| 000000H | P0   | 20H     | TRUN   | 40H     | TREG6L | 60H     | ADREG0L  |
| 1H      | P1   | 21H     |        | 41H     | TREG6H | 61H     | ADREG0H  |
| 2H      | POCR | 22H     | TREG0  | 42H     | TREG7L | 62H     | ADREG1L  |
| 3H      |      | 23H     | TREG1  | 43H     | TREG7H | 63H     | ADREG1H  |
| 4H      | P1CR | 24H     | TMOD   | 44H     | CAP3L  | 64H     | ADREG2L  |
| 5H      | P1FC | 25H     | TFFCR  | 45H     | CAP3H  | 65H     | ADREG2H  |
| 6H      | P2   | 26H     | TREG2  | 46H     | CAP4L  | 66H     | ADREG3L  |
| 7H      | P3   | 27H     | TREG3  | 47H     | CAP4H  | 67H     | ADREG3H  |
| 8H      | P2CR | 28H     | P0MOD  | 48H     | T5MOD  | 68H     | B0CS     |
| 9H      | P2FC | 29H     | P1MOD  | 49H     | T5FFCR | 69H     | B1CS     |
| AH      | P3CR | 2AH     | PFPCR  | 4AH     |        | 6AH     | B2CS     |
| BH      | P3FC | 2BH     |        | 4BH     |        | 6BH     |          |
| CH      | P4   | 2CH     |        | 4CH     | PG0REG | 6CH     |          |
| DH      | P5   | 2DH     |        | 4DH     | PG1REG | 6DH     |          |
| EH      | P4CR | 2EH     |        | 4EH     | PG01CR | 6EH     |          |
| FH      |      | 2FH     |        | 4FH     |        | 6FH     |          |
| 10H     | P4FC | 30H     | TREG4L | 50H     | SC0BUF | 70H     | INTE0AD  |
| 11H     |      | 31H     | TREG4H | 51H     | SC0CR  | 71H     | INTE45   |
| 12H     | P6   | 32H     | TREG5L | 52H     | SC0MOD | 72H     | INTE67   |
| 13H     | P7   | 33H     | TREG5H | 53H     | BR0CR  | 73H     | INTET10  |
| 14H     | P6CR | 34H     | CAP1L  | 54H     | SC1BUF | 74H     | INTEPW10 |
| 15H     | P7CR | 35H     | CAP1H  | 55H     | SC1CR  | 75H     | INTET54  |
| 16H     | P6FC | 36H     | CAP2L  | 56H     | SC1MOD | 76H     | INTET76  |
| 17H     | P7FC | 37H     | CAP2H  | 57H     | BR1CR  | 77H     | INTE50   |
| 18H     | P8   | 38H     | T4MOD  | 58H     | ODE    | 78H     | INTE51   |
| 19H     | P9   | 39H     | TFF4CR | 59H     |        | 79H     |          |
| 1AH     | P8CR | 3AH     | T45CR  | 5AH     |        | 7AH     |          |
| 18H     | P9CR | 3BH     |        | 5BH     |        | 7BH     | IIMC     |
| 1CH     | P8FC | 3CH     |        | 5CH     | WDMOD  | 7CH     | DMA0V    |
| 1DH     | P9FC | 3DH     |        | 5DH     | WDCR   | 7DH     | DMA1V    |
| 1EH     |      | 3EH     |        | 5EH     | ADMOD  | 7EH     | DMA2V    |
| 1FH     |      | 3FH     |        | 5FH     |        | 7FH     | DMA3V    |

## (1) I/O Port

| Symbol | Name  | Address | 7   | 6   | 5   | 4   | 3          | 2   | 1   | 0   |
|--------|-------|---------|-----|-----|-----|-----|------------|-----|-----|-----|
| P0     | PORT0 | 00H     | P07 | P06 | P05 | P04 | P03        | P02 | P01 | P00 |
|        |       |         |     |     |     |     | R/W        |     |     |     |
|        |       |         |     |     |     |     | Input mode |     |     |     |
|        |       |         |     |     |     |     | Undefined  |     |     |     |
| P1     | PORT1 | 01H     | P17 | P16 | P15 | P14 | P13        | P12 | P11 | P10 |
|        |       |         |     |     |     |     | R/W        |     |     |     |
|        |       |         |     |     |     |     | Input mode |     |     |     |
| P2     | PORT2 | 06H     | 0   | 0   | 0   | 0   | 0          | 0   | 0   | 0   |
|        |       |         | P27 | P26 | P25 | P24 | P23        | P22 | P21 | P20 |
|        |       |         |     |     |     |     | R/W        |     |     |     |
| P3     | PORT3 | 07H     |     |     |     |     | Input mode |     |     |     |
|        |       |         |     |     |     |     | R/W        |     |     |     |
|        |       |         | 1   | 1   | 1   | 1   | 1          | 1   | 1   | 1   |
| P4     | PORT4 | 0CH     |     |     |     |     |            | P42 | P41 | P40 |
|        |       |         |     |     |     |     |            | R/W |     |     |
|        |       |         |     |     |     |     | Input mode |     |     |     |
| P5     | PORT5 | 0DH     |     |     |     |     | 0          | 1   | 1   |     |
|        |       |         |     |     |     |     | P53        | P52 | P51 | P50 |
|        |       |         |     |     |     |     | R          |     |     |     |
| P6     | PORT6 | 12H     | P67 | P66 | P65 | P64 | P63        | P62 | P61 | P60 |
|        |       |         |     |     |     |     | R/W        |     |     |     |
|        |       |         |     |     |     |     | Input mode |     |     |     |
| P7     | PORT7 | 13H     | 1   | 1   | 1   | 1   | 1          | 1   | 1   | 1   |
|        |       |         |     |     |     |     | P73        | P72 | P71 | P70 |
|        |       |         |     |     |     |     | R/W        |     |     |     |
| P8     | PORT8 | 18H     |     |     |     |     | Input mode |     |     |     |
|        |       |         |     |     |     |     | R/W        |     |     |     |
|        |       |         | 1   | 1   | 1   | 1   | 1          | 1   | 1   | 1   |
| P9     | PORT9 | 19H     |     |     | P95 | P94 | P93        | P92 | P91 | P90 |
|        |       |         |     |     |     |     | R/W        |     |     |     |
|        |       |         |     |     | 1   | 1   | 1          | 1   | 1   | 1   |

Note : When P30 pin is defined as RD signal output mode (P30F=1), clearing the output latch register P30 to "0" outputs the RD strobe from P30 pin for PSRAM, even when the internal address is accessed. If the output latch register P30 remains "1", the RD strobe is output only when the external address is accessed.

## Read/Write

R/W ; Either read or write is possible

R ; Only read is possible

W ; Only write is possible

Prohibit RMW ; Prohibit Read Modify Write. (Prohibit RES/SET/TSET/CHG/STCF/ANDCF/ORCF/XORCF Instruction)

## (2) I/O Port Control (1/2)

| Symbol                                                                                                                             | Name              | Address                  | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |  |  |
|------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------------------------|------|------|------|------|------|------|------|------|--|--|
| P0CR                                                                                                                               | PORT0<br>Control  | 02H<br>(Prohibit<br>RMW) | P07C | P06C | P05C | P04C | P03C | P02C | P01C | P00C |  |  |
|                                                                                                                                    |                   |                          | W    |      |      |      |      |      |      |      |  |  |
|                                                                                                                                    |                   |                          | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |  |  |
| 0 : IN 1 : OUT (When external access, set as AD7-0 and cleared to "0")                                                             |                   |                          |      |      |      |      |      |      |      |      |  |  |
| P1CR                                                                                                                               | PORT1<br>Control  | 04H<br>(Prohibit<br>RMW) | P17C | P16C | P15C | P14C | P13C | P12C | P11C | P10C |  |  |
|                                                                                                                                    |                   |                          | W    |      |      |      |      |      |      |      |  |  |
|                                                                                                                                    |                   |                          | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |  |  |
| <<Refer to the "P1FC">>                                                                                                            |                   |                          |      |      |      |      |      |      |      |      |  |  |
| P1FC                                                                                                                               | PORT1<br>Function | 05H<br>(Prohibit<br>RMW) | P17F | P16F | P15F | P14F | P13F | P12F | P11F | P10F |  |  |
|                                                                                                                                    |                   |                          | W    |      |      |      |      |      |      |      |  |  |
|                                                                                                                                    |                   |                          | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |  |  |
| P1FC/P1CR = 00 : IN, 01 : OUT, 10 : AD15-8, 11 : A15-8                                                                             |                   |                          |      |      |      |      |      |      |      |      |  |  |
| P2CR                                                                                                                               | PORT2<br>Control  | 08H<br>(Prohibit<br>RMW) | P27C | P26C | P25C | P24C | P23C | P22C | P21C | P20C |  |  |
|                                                                                                                                    |                   |                          | W    |      |      |      |      |      |      |      |  |  |
|                                                                                                                                    |                   |                          | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |  |  |
| <<Refer to the "P2FC">>                                                                                                            |                   |                          |      |      |      |      |      |      |      |      |  |  |
| P2FC                                                                                                                               | PORT2<br>Function | 09H<br>(Prohibit<br>RMW) | P27F | P26F | P25F | P24F | P23F | P22F | P21F | P20F |  |  |
|                                                                                                                                    |                   |                          | W    |      |      |      |      |      |      |      |  |  |
|                                                                                                                                    |                   |                          | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |  |  |
| P2FC/P2CR = 00 : IN, 01 : OUT, 10 : A7-0, 11 : A23-16                                                                              |                   |                          |      |      |      |      |      |      |      |      |  |  |
| P3CR                                                                                                                               | PORT3<br>Control  | 0AH<br>(Prohibit<br>RMW) | P37C | P36C | P35C | P34C | P33C | P32C |      |      |  |  |
|                                                                                                                                    |                   |                          | W    |      |      |      |      |      |      |      |  |  |
|                                                                                                                                    |                   |                          | 0    | 0    | 0    | 0    | 0    | 0    |      |      |  |  |
| 0 : IN 1 : OUT                                                                                                                     |                   |                          |      |      |      |      |      |      |      |      |  |  |
| P3FC                                                                                                                               | PORT3<br>Function | 0BH<br>(Prohibit<br>RMW) | P37F | P36F | P35F | P34F |      | P32F | P31F | P30F |  |  |
|                                                                                                                                    |                   |                          | W    |      |      |      |      |      |      |      |  |  |
|                                                                                                                                    |                   |                          | 0    | 0    | 0    | 0    |      | 0    | 0    | 0    |  |  |
| 0 : PORT 1 : RD<br>1 : RAS 1 : R/W 1 : BUSAK 1 : BUSRQ 1 : HWR 1 : WR 1 : RD |                   |                          |      |      |      |      |      |      |      |      |  |  |
| P4CR                                                                                                                               | PORT4<br>Control  | 0EH<br>(Prohibit<br>RMW) |      |      |      |      |      | P42C | P41C | P40C |  |  |
|                                                                                                                                    |                   |                          | W    |      |      |      |      |      |      |      |  |  |
|                                                                                                                                    |                   |                          |      |      |      |      |      | 0    | 0    | 0    |  |  |
| P4FC                                                                                                                               | PORT4<br>Function | 10H<br>(Prohibit<br>RMW) |      |      |      |      |      | P42F | P41F | P40F |  |  |
|                                                                                                                                    |                   |                          | W    |      |      |      |      |      |      |      |  |  |
|                                                                                                                                    |                   |                          |      |      |      |      |      | 0    | 0    | 0    |  |  |
| 0 : PORT 1 : CS/CAS                                                                                                                |                   |                          |      |      |      |      |      |      |      |      |  |  |

Note : With the TMP96C141/TMP96C141A/TMP96C041A, which requires an external ROM, PORT0 functions as AD0 to AD7; PORT1, AD8 to AD15; P30, the RD signal; P31, the WR signal, regardless of the values set in P0CR, P1CR, P1FC, P30F and P31F.

## I/O Port Control (2/2)

| Symbol | Name              | Address                  | 7    | 6    | 5    | 4    | 3         | 2           | 1         | 0        |
|--------|-------------------|--------------------------|------|------|------|------|-----------|-------------|-----------|----------|
| P6CR   | PORT6<br>Control  | 14H<br>(Prohibit<br>RMW) | P67C | P66C | P65C | P64C | P63C      | P62C        | P61C      | P60C     |
|        |                   |                          |      |      |      |      | W         |             |           |          |
|        |                   |                          | 0    | 0    | 0    | 0    | 0         | 0           | 0         | 0        |
| P7CR   | PORT7<br>Control  | 15H<br>(Prohibit<br>RMW) |      |      |      |      | 0 : IN    | 1 : OUT     |           |          |
|        |                   |                          |      |      |      |      |           | P73C        | P72C      | P71C     |
|        |                   |                          |      |      |      |      |           |             | W         | P70C     |
| P6FC   | PORT6<br>Function | 16H<br>(Prohibit<br>RMW) |      |      |      |      | 0 : IN    | 1 : OUT     |           |          |
|        |                   |                          | P67F | P66F | P65F | P64F | P63F      | P62F        | P61F      | P60F     |
|        |                   |                          | 0    | 0    | 0    | 0    | 0         | 0           | 0         | 0        |
| P7FC   | PORT7<br>Function | 17H<br>(Prohibit<br>RMW) |      |      |      |      | 0 : PORT  | 1 : PG0-OUT |           |          |
|        |                   |                          |      |      |      |      |           | P73F        | P72F      | P71F     |
|        |                   |                          |      |      |      |      |           | W           |           |          |
| P8CR   | PORT8<br>Control  | 1AH<br>(Prohibit<br>RMW) |      |      |      |      | 0 : PORT  | 0 : PORT    | 0 : PORT  |          |
|        |                   |                          | P87C | P86C | P85C | P84C | P83C      | P82C        | P81C      | P80C     |
|        |                   |                          | 0    | 0    | 0    | 0    | 0         | 0           | 0         | 0        |
| P9CR   | PORT9<br>Control  | 1BH<br>(Prohibit<br>RMW) |      |      |      |      | 0 : IN    | 1 : OUT     |           |          |
|        |                   |                          |      |      |      |      | P95C      | P94C        | P93C      | P92C     |
|        |                   |                          |      |      |      |      | 0         | 0           | 0         | 0        |
| P8FC   | PORT8<br>Function | 1CH<br>(Prohibit<br>RMW) |      |      |      |      | 0 : IN    | 1 : OUT     |           |          |
|        |                   |                          |      |      |      |      | P86F      |             | P83F      | P82F     |
|        |                   |                          |      |      |      |      | W         |             | W         | W        |
| P9FC   | PORT9<br>Function | 1DH<br>(Prohibit<br>RMW) |      |      |      |      | 0         |             | 0         | 0        |
|        |                   |                          |      |      |      |      | 0 : PORT  | 0 : PORT    | 0 : PORT  | 0 : PORT |
|        |                   |                          |      |      |      |      | 1 : TO6   | 1 : TO5     | 1 : TO4   | 1 : Tx0  |
|        |                   |                          |      |      |      |      | P95F      |             | P93F      | P92F     |
|        |                   |                          |      |      |      |      | W         |             | W         | W        |
|        |                   |                          |      |      |      |      | 0         |             | 0         | 0        |
|        |                   |                          |      |      |      |      | 0 : PORT  | 0 : PORT    | 0 : PORT  | 0 : PORT |
|        |                   |                          |      |      |      |      | 1 : SCLK1 | 1 : TxD1    | 1 : SCLK0 | 1 : Tx0  |
|        |                   |                          |      |      |      |      |           |             |           |          |

Note : The register P92F is used only in the TMP96CM40/TMP96PM40/TMP96C141A/TMP96C041A, and not available in the TMP96C141. (It cannot be defined as SCLK0).

## (3) Timer Control (1/3)

| Symbol | Name                                           | Address               | 7                                                                            | 6                        | 5                             | 4              | 3                        | 2                | 1               | 0                      |         |  |  |
|--------|------------------------------------------------|-----------------------|------------------------------------------------------------------------------|--------------------------|-------------------------------|----------------|--------------------------|------------------|-----------------|------------------------|---------|--|--|
| TRUN   | Timer Control                                  | 20H                   | PRRUN                                                                        |                          | T5RUN                         | T4RUN          | P1RUN                    | P0RUN            | T1RUN           | T0RUN                  |         |  |  |
|        |                                                |                       | R/W                                                                          |                          |                               |                |                          | R/W              |                 |                        |         |  |  |
|        |                                                |                       | 0                                                                            |                          | 0                             | 0              | 0                        | 0                | 0               | 0                      |         |  |  |
|        |                                                |                       | Prescaler & Timer Run/Stop CONTROL<br>0 : Stop & Clear<br>1 : Run (Count up) |                          |                               |                |                          |                  |                 |                        |         |  |  |
| TREG0  | 8bit Timer Register 0                          | 22H<br>(Prohibit RMW) |                                                                              |                          |                               |                |                          |                  |                 |                        |         |  |  |
| TREG1  | 8bit Timer Register 1                          | 23H<br>(Prohibit RMW) |                                                                              |                          |                               |                |                          |                  |                 |                        |         |  |  |
| TMOD   | 8bit Timer Source CLK & MODE<br>(Prohibit RMW) | 24H                   |                                                                              |                          |                               |                |                          |                  |                 |                        |         |  |  |
|        |                                                |                       | W                                                                            |                          |                               |                |                          |                  |                 |                        |         |  |  |
|        |                                                |                       | 0                                                                            | 0                        | 0                             | 0              | 0                        | 0                | 0               | 0                      |         |  |  |
|        |                                                |                       | 00 : 8bit Timer                                                              |                          | 00 : -                        |                | 00 : TO0TRG              |                  | 00 : T10 Input  |                        |         |  |  |
| TFFCR  | 8bit Timer Flip-Flop Control                   | 25H                   | 01 : 16bit Timer                                                             |                          | 01 : 26 - 1                   | PWM            | 01 : φT1                 |                  | 01 : φT1        |                        |         |  |  |
|        |                                                |                       | 10 : 8bit PPG                                                                |                          | 10 : 27 - 1                   |                | 10 : φT16                |                  | 10 : φT4        |                        |         |  |  |
|        |                                                |                       | 11 : 8bit PWM                                                                |                          | 11 : 28 - 1                   |                | 11 : φT256               |                  | 11 : φT16       |                        |         |  |  |
|        |                                                |                       |                                                                              |                          |                               |                |                          |                  |                 |                        |         |  |  |
| TREG2  | PWM Timer Register 2                           | 26H                   |                                                                              |                          |                               |                | DBEN                     | TFF1C1           | TFF1C0          | TFF1IE                 | TFF1IS  |  |  |
|        |                                                |                       |                                                                              |                          |                               |                | R/W                      | W                |                 | R/W                    |         |  |  |
|        |                                                |                       |                                                                              |                          |                               |                | 0                        | 0                | 0               | 0                      | 0       |  |  |
|        |                                                |                       |                                                                              |                          |                               |                | 1 : Double Buffer Enable | 00 : Invert TFF1 | 1 : TFF1        | 0 : Inverted by Enable | Timer 0 |  |  |
| TREG3  | PWM Timer Register 3                           | 27H                   |                                                                              |                          |                               |                | 01 : Set TFF1            |                  |                 |                        |         |  |  |
|        |                                                |                       |                                                                              |                          |                               |                | 10 : Clear TFF1          |                  |                 |                        |         |  |  |
|        |                                                |                       |                                                                              |                          |                               |                | 11 : Don't care          |                  |                 |                        |         |  |  |
|        |                                                |                       |                                                                              |                          |                               |                |                          |                  |                 |                        |         |  |  |
| P0MOD  | PWM0 Mode<br>(Prohibit RMW)                    | 28H                   | FF2RD                                                                        | DB2EN                    | PWM0INT                       | PWM0M          | T2CLK1                   | T2CLK0           | PWM0S1          | PWM0S0                 |         |  |  |
|        |                                                |                       | R                                                                            |                          |                               |                | W                        |                  |                 |                        |         |  |  |
|        |                                                |                       | -                                                                            | 0                        | 0                             | 0              | 0                        | 0                | 0               | 0                      |         |  |  |
|        |                                                |                       | TFF2 output value                                                            | 1 : Double Buffer Enable | 0 : Overflow interrupt        | 0 : PWM Mode   | 00 : φP1 (fc/4)          |                  | 00 : 26 - 1     |                        |         |  |  |
| P1MOD  | PWM1 Mode<br>(Prohibit RMW)                    | 29H                   |                                                                              |                          | 1 : Compare / match interrupt | 1 : Timer Mode | 01 : φP4 (fc/16)         |                  | 01 : 27 - 1     |                        |         |  |  |
|        |                                                |                       |                                                                              |                          | 1 : Compare / match interrupt | 1 : Timer Mode | 10 : φP16 (fc/64)        |                  | 10 : 28 - 1     |                        |         |  |  |
|        |                                                |                       |                                                                              |                          |                               |                | 11 : Don't care          |                  | 11 : Don't care |                        |         |  |  |
|        |                                                |                       |                                                                              |                          |                               |                |                          |                  |                 |                        |         |  |  |

### Timer Control (2/3)

| Symbol | Name                                        | Address                  | 7                                                                       | 6                                                                                                                                                       | 5                                                                      | 4                                                                                                                                                       | 3                                                                                                                                                       | 2                                                                                                                                                       | 1                                                                                                                                                       | 0                                                                                                                                                       |
|--------|---------------------------------------------|--------------------------|-------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |                                             |                          | FF3C1                                                                   | FF3C0                                                                                                                                                   | FF3TRG1                                                                | FF3TRG0                                                                                                                                                 | FF2C1                                                                                                                                                   | FF2C0                                                                                                                                                   | FF2TRG1                                                                                                                                                 | FF2TRG0                                                                                                                                                 |
|        |                                             |                          | W                                                                       |                                                                                                                                                         | R/W                                                                    |                                                                                                                                                         | W                                                                                                                                                       |                                                                                                                                                         | R/W                                                                                                                                                     |                                                                                                                                                         |
|        |                                             |                          | 0                                                                       | 0                                                                                                                                                       | 0                                                                      | 0                                                                                                                                                       | 0                                                                                                                                                       | 0                                                                                                                                                       | 0                                                                                                                                                       | 0                                                                                                                                                       |
| PFFCR  | PWM<br>Flip-Flop<br>Control                 | 2AH                      | 00 : Don't care<br>01 : Set TFF3<br>10 : Clear TFF3<br>11 : Don't care  | 00 : Prohibit TFF3<br>inverted<br>01 : Invert if matched<br>10 : Set if matched;<br>clear if<br>overflown<br>11 : Clear if matched;<br>set if overflown | 00 : Don't care<br>01 : Set TFF2<br>10 : Clear TFF2<br>11 : Don't care | 00 : Prohibit TFF2<br>inverted<br>01 : Invert if matched<br>10 : Set if matched;<br>clear if<br>overflown<br>11 : Clear if matched;<br>set if overflown | 00 : Prohibit TFF2<br>inverted<br>01 : Invert if matched<br>10 : Set if matched;<br>clear if<br>overflown<br>11 : Clear if matched;<br>set if overflown | 00 : Prohibit TFF2<br>inverted<br>01 : Invert if matched<br>10 : Set if matched;<br>clear if<br>overflown<br>11 : Clear if matched;<br>set if overflown | 00 : Prohibit TFF2<br>inverted<br>01 : Invert if matched<br>10 : Set if matched;<br>clear if<br>overflown<br>11 : Clear if matched;<br>set if overflown | 00 : Prohibit TFF2<br>inverted<br>01 : Invert if matched<br>10 : Set if matched;<br>clear if<br>overflown<br>11 : Clear if matched;<br>set if overflown |
| TREG4L | 16bit<br>Timer<br>Register4L                | 30H<br>(Prohibit<br>RMW) |                                                                         |                                                                                                                                                         |                                                                        |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |
| TREG4H | 16bit<br>Timer<br>Register4H                | 31H<br>(Prohibit<br>RMW) |                                                                         |                                                                                                                                                         |                                                                        |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |
| TREG5L | 16bit<br>Timer<br>Register5L                | 32H<br>(Prohibit<br>RMW) |                                                                         |                                                                                                                                                         |                                                                        |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |
| TREG5H | 16bit<br>Timer<br>Register5H                | 33H<br>(Prohibit<br>RMW) |                                                                         |                                                                                                                                                         |                                                                        |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |
| CAP1L  | Capture<br>Register1L                       | 34H                      |                                                                         |                                                                                                                                                         |                                                                        |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |
| CAP1H  | Capture<br>Register1H                       | 35H                      |                                                                         |                                                                                                                                                         |                                                                        |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |
| CAP2L  | Capture<br>Register2L                       | 36H                      |                                                                         |                                                                                                                                                         |                                                                        |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |
| CAP2H  | Capture<br>Register2H                       | 37H                      |                                                                         |                                                                                                                                                         |                                                                        |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |                                                                                                                                                         |
| T4MOD  | 16bit<br>Timer 4<br>Source<br>CLK &<br>MODE | 38H                      | CAP2T5<br>R/W<br>0                                                      | EQ5T5<br>W<br>0                                                                                                                                         | CAP1IN<br>W<br>0                                                       | CAP12M1<br>R/W<br>0                                                                                                                                     | CAP12M0<br>R/W<br>0                                                                                                                                     | CLE                                                                                                                                                     | T4CLK1<br>0                                                                                                                                             | T4CLK0<br>0                                                                                                                                             |
|        |                                             |                          | TFF5 INV TRG<br>0 : TRG Disable<br>1 : TRG Enable                       |                                                                                                                                                         | 0 : Soft-<br>Capture<br>1 : Don't<br>care                              | Capture Timming<br>00 : Disable<br>01 : TI4 ↑ TI5 ↑<br>10 : TI4 ↑ TI4 ↓<br>11 : TFF1 ↑ TFF1 ↓                                                           |                                                                                                                                                         | 1 : UCA4<br>Clear<br>Enable                                                                                                                             | Source Clock<br>00 : TI4<br>01 : φT1<br>10 : φT4<br>11 : φT6                                                                                            |                                                                                                                                                         |
| T4FFCR | 16bit<br>Timer 4<br>Flip-Flop<br>Control    | 39H                      | TF5C1<br>W<br>0                                                         | TF5C0<br>R/W<br>0                                                                                                                                       | CAP2T4<br>R/W<br>0                                                     | CAP1T4<br>R/W<br>0                                                                                                                                      | EQ5T4<br>R/W<br>0                                                                                                                                       | EQ4T4<br>W<br>0                                                                                                                                         | TF4C1<br>W<br>0                                                                                                                                         | TF4C0<br>W<br>0                                                                                                                                         |
|        |                                             |                          | 00 : Invert TFF5<br>01 : Set TFF5<br>10 : Clear TFF5<br>11 : Don't care |                                                                                                                                                         |                                                                        | TFF4 Invert Trigger<br>0 : Trigger Disable<br>1 : Trigger Enable                                                                                        |                                                                                                                                                         |                                                                                                                                                         | 00 : Invert TFF4<br>01 : Set TFF4<br>10 : Clear TFF4<br>11 : Don't care                                                                                 |                                                                                                                                                         |

## Timer Control (3/3)

| Symbol | Name                                        | Address                  | 7          | 6 | 5                                         | 4                                                                                             | 3                                                     | 2                                                                       | 1                              | 0     |
|--------|---------------------------------------------|--------------------------|------------|---|-------------------------------------------|-----------------------------------------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------------------------|--------------------------------|-------|
| T45CR  | T4, T5<br>Control                           | 3AH                      | -          |   |                                           |                                                                                               | PG1T                                                  | PG0T                                                                    | DB6EN                          | DB4EN |
|        |                                             |                          | R/W        |   |                                           |                                                                                               |                                                       |                                                                         | R/W                            |       |
|        |                                             |                          | 0          |   |                                           |                                                                                               | 0                                                     | 0                                                                       | 0                              | 0     |
|        |                                             |                          | Fix at "0" |   |                                           |                                                                                               | PG1 shift<br>trigger<br>0 : Timer 0, 1<br>1 : Timer 5 | PG0 shift<br>trigger<br>0 : Timer 0, 1<br>1 : Timer 4                   | 1 : Double<br>Buffer<br>Enable |       |
| TREG6L | 16bit<br>Timer<br>Register6L                | 40H<br>(Prohibit<br>RMW) |            |   |                                           |                                                                                               | -                                                     |                                                                         |                                |       |
| TREG6H | 16bit<br>Timer<br>Register6H                | 41H<br>(Prohibit<br>RMW) |            |   |                                           |                                                                                               | W                                                     |                                                                         |                                |       |
| TREG7L | 16bit<br>Timer<br>Register7L                | 42H<br>(Prohibit<br>RMW) |            |   |                                           |                                                                                               | -                                                     |                                                                         |                                |       |
| TREG7H | 16bit<br>Timer<br>Register7H                | 43H<br>(Prohibit<br>RMW) |            |   |                                           |                                                                                               | W                                                     |                                                                         |                                |       |
| CAP3L  | Capture<br>Register3L                       | 44H                      |            |   |                                           |                                                                                               | -                                                     |                                                                         |                                |       |
| CAP3H  | Capture<br>Register3H                       | 45H                      |            |   |                                           |                                                                                               | R                                                     |                                                                         |                                |       |
| CAP4L  | Capture<br>Register4L                       | 46H                      |            |   |                                           |                                                                                               | Undefined                                             |                                                                         |                                |       |
| CAP4H  | Capture<br>Register4H                       | 47H                      |            |   |                                           |                                                                                               | -                                                     |                                                                         |                                |       |
| T5MOD  | 16bit<br>Timer 5<br>Source<br>CLK &<br>MODE | 48H                      |            |   | CAP3IN                                    | CAP34M1 : CAP34M0                                                                             | CLE                                                   | T5CLK1                                                                  | T5CLK0                         |       |
|        |                                             |                          |            |   | W                                         |                                                                                               | R/W                                                   |                                                                         |                                |       |
|        |                                             |                          |            |   | 0                                         | 0 : 0                                                                                         | 0                                                     | 0                                                                       | 0                              | 0     |
|        |                                             |                          |            |   | 0 : Soft-<br>Capture<br>1 : Don't<br>care | Capture Timming<br>00 : Disable<br>01 : T16 ↑ T17 ↑<br>10 : T16 ↑ T16 ↓<br>11 : TFF1 ↑ TFF1 ↓ | 1 : UC5                                               | Source Clock<br>00 : T16<br>01 : φT1<br>10 : φT4<br>11 : φT16           |                                |       |
| T5FFCR | 16bit<br>Timer 5<br>Flip-Flop<br>Control    | 49H                      |            |   | CAP4T6                                    | CAP3T6 : EQ7T6                                                                                | EQ6T6                                                 | TFF6C1 : TFF6C0                                                         |                                |       |
|        |                                             |                          |            |   |                                           | R/W                                                                                           |                                                       | W                                                                       |                                |       |
|        |                                             |                          |            |   | 0                                         | 0 : 0                                                                                         | 0                                                     | 0                                                                       | 0                              | 0     |
|        |                                             |                          |            |   |                                           | TFF6 invert Trigger<br>0 : Trigger Disable<br>1 : Trigger Enable                              |                                                       | 00 : Invert TFF6<br>01 : Set TFF6<br>10 : Clear TFF6<br>11 : Don't care |                                |       |

## (4) Pattern Generator

| Symbol             | Name                     | Address | 7                | 6                      | 5               | 4                    | 3                | 2                      | 1               | 0                       |
|--------------------|--------------------------|---------|------------------|------------------------|-----------------|----------------------|------------------|------------------------|-----------------|-------------------------|
| PG0REG<br>Register | PG0<br>(Prohibit<br>RMW) | 4CH     | PG03             | PG02                   | PG01            | PG00                 | SA03             | SA02                   | SA01            | SA00                    |
|                    |                          |         | 0                | 0                      | W               | 0                    | 0                | 0                      | R/W             | Undefined               |
|                    |                          |         | 0                | 0                      | 0               | 0                    | 0                | 0                      | R/W             | Undefined               |
| PG1REG<br>Register | PG1<br>(Prohibit<br>RMW) | 4DH     | PG13             | PG12                   | PG11            | PG10                 | SA13             | SA12                   | SA11            | SA10                    |
|                    |                          |         | 0                | 0                      | W               | 0                    | 0                | 0                      | R/W             | Undefined               |
|                    |                          |         | 0                | 0                      | 0               | 0                    | 0                | 0                      | R/W             | Undefined               |
| PG01CR             | PG0, 1<br>Control        | 4EH     | PAT1             | CCW1                   | PG1M            | PG1TE                | PAT0             | CCW0                   | PG0M            | PG0TE                   |
|                    |                          |         | 0                | 0                      | 0               | 0                    | 0                | 0                      | R/W             | 0                       |
|                    |                          |         | 0: 8bit<br>write | 0: Normal<br>Rotation  | 0: 4bit<br>Step | PG1 trigger<br>input | 0: 8bit<br>write | 0: Normal<br>Rotation  | 0: 4bit<br>Step | PG0<br>trigger<br>input |
|                    |                          |         | 1: 4bit<br>write | 1: Reverse<br>Rotation | 1: 8bit<br>Step | 1: Enable            | 1: 4bit<br>write | 1: Reverse<br>Rotation | 1: 8bit<br>Step | 1: Enable               |

## (5) Watch Dog Timer

| Symbol                                  | Name                                         | Address | 7                     | 6                                                    | 5                  | 4                      | 3                                                                                | 2                                                          | 1                                                          | 0                                      |
|-----------------------------------------|----------------------------------------------|---------|-----------------------|------------------------------------------------------|--------------------|------------------------|----------------------------------------------------------------------------------|------------------------------------------------------------|------------------------------------------------------------|----------------------------------------|
| WD-MOD<br>Watch<br>Dog<br>Timer<br>Mode | Watch<br>Dog<br>Timer<br>Mode                | 5CH     | WDTE                  | WDTP1                                                | WDTP0              | WARM                   | HALTM1                                                                           | HALTM0                                                     | RESCR                                                      | DRVE                                   |
|                                         |                                              |         | 1                     | 0                                                    | 0                  | 0                      | 0                                                                                | 0                                                          | 0                                                          | R/W                                    |
|                                         |                                              |         | 1: WDT<br>Enable      | 00: 216/fc<br>01: 218/fc<br>10: 220/fc<br>11: 222/fc | Warming<br>up Time | 0: 214/fc<br>1: 216/fc | Standby Mode<br>00: RUN Mode<br>01: STOP Mode<br>10: IDLE Mode<br>11: Don't care | 1: Connect<br>internally<br>WDT out<br>pin to<br>Reset Pin | 1: Connect<br>internally<br>WDT out<br>pin to<br>Reset Pin | 1: Drive<br>the pin<br>in STOP<br>mode |
| WDCR                                    | Watch<br>Dog<br>Timer<br>Control<br>Register | 5DH     | -                     |                                                      |                    |                        |                                                                                  |                                                            |                                                            |                                        |
|                                         |                                              |         | W                     |                                                      |                    |                        |                                                                                  |                                                            |                                                            |                                        |
|                                         |                                              |         | -                     |                                                      |                    |                        |                                                                                  |                                                            |                                                            |                                        |
|                                         |                                              |         | B1H: WDT Disable Code |                                                      |                    |                        |                                                                                  |                                                            |                                                            |                                        |
|                                         |                                              |         | 4EH: WDT Clear Code   |                                                      |                    |                        |                                                                                  |                                                            |                                                            |                                        |

## (6) Serial Channel (1/2)

| Symbol  | Name                     | Address | 7                              | 6                                                                         | 5                                                                         | 4                                          | 3                                                           | 2                                                           | 1                                                                            | 0                                                                            |  |  |  |
|---------|--------------------------|---------|--------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------|--------------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------|--|--|--|
| SC0BUF  | Serial Channel 0 Buffer  | 50H     | RB7                            | RB6                                                                       | RB5                                                                       | RB4                                        | RB3                                                         | RB2                                                         | RB1                                                                          | RB0                                                                          |  |  |  |
|         |                          |         | TB7                            | TB6                                                                       | TB5                                                                       | TB4                                        | TB3                                                         | TB2                                                         | TB1                                                                          | TB0                                                                          |  |  |  |
|         |                          |         | R (Receiving)/W (Transmission) |                                                                           |                                                                           |                                            |                                                             |                                                             |                                                                              |                                                                              |  |  |  |
|         |                          |         | Undefined                      |                                                                           |                                                                           |                                            |                                                             |                                                             |                                                                              |                                                                              |  |  |  |
| SC0CR   | Serial Channel 0 Control | 51H     | RB8                            | EVEN                                                                      | PE                                                                        | OERR                                       | PERR                                                        | FERR                                                        | -                                                                            | -                                                                            |  |  |  |
|         |                          |         | R                              | R/W                                                                       |                                                                           | R (Cleared to 0 by reading)                |                                                             |                                                             | R/W                                                                          |                                                                              |  |  |  |
|         |                          |         | 0                              | 0                                                                         | 0                                                                         | 0                                          | 0                                                           | 0                                                           | 0                                                                            | 0                                                                            |  |  |  |
|         |                          |         | Receiving data bit 8           | Parity 0: Odd 1: Even                                                     | 1: Parity Enable                                                          | Overrun                                    | Parity                                                      | Framing                                                     | 0: SCLK0 1: Input SCLK0 pin (Note)                                           | 1: SCLK0                                                                     |  |  |  |
| SC0-MOD | Serial Channel 0 Mode    | 52H     | TB8                            | CTSE                                                                      | RXE                                                                       | WU                                         | SM1                                                         | SM0                                                         | SC1                                                                          | SC0                                                                          |  |  |  |
|         |                          |         | R/W                            |                                                                           |                                                                           |                                            |                                                             |                                                             |                                                                              |                                                                              |  |  |  |
|         |                          |         | 0                              | 0                                                                         | 0                                                                         | 0                                          | 0                                                           | 0                                                           | 0                                                                            | 0                                                                            |  |  |  |
|         |                          |         | Transmission data bit 8        | CTS 1: Enable                                                             | 1: Receive Enable                                                         | 1: Wake up Enable                          | 00: Unused 01: UART 7bit 10: UART 8bit 11: UART 9bit        | 00: Unused 01: UART 7bit 10: UART 8bit 11: UART 9bit        | 00: TO0 Trigger 01: Baud rate generator 10: Internal clock φ1 11: Don't care | 00: TO0 Trigger 01: Baud rate generator 10: Internal clock φ1 11: Don't care |  |  |  |
| BR0CR   | Baud Rate Control        | 53H     | -                              | BR0CK1                                                                    | BR0CK0                                                                    | BR0S3                                      | BR0S2                                                       | BR0S1                                                       | BR0S0                                                                        |                                                                              |  |  |  |
|         |                          |         | R/W                            |                                                                           |                                                                           |                                            |                                                             |                                                             |                                                                              |                                                                              |  |  |  |
|         |                          |         | 0                              | 0                                                                         | 0                                                                         | 0                                          | 0                                                           | 0                                                           | 0                                                                            | 0                                                                            |  |  |  |
|         |                          |         | Fix at "0"                     | 00: φT0 (fc/4)<br>01: φT2 (fc/16)<br>10: φT8 (fc/64)<br>11: φT32 (fc/256) | 00: φT0 (fc/4)<br>01: φT2 (fc/16)<br>10: φT8 (fc/64)<br>11: φT32 (fc/256) | Set frequency divisor 0~F ("1" prohibited) |                                                             |                                                             |                                                                              |                                                                              |  |  |  |
| SC1BUF  | Serial Channel 1 Buffen  | 54H     | RB7                            | RB6                                                                       | RB5                                                                       | RB4                                        | RB3                                                         | RB2                                                         | RB1                                                                          | RB0                                                                          |  |  |  |
|         |                          |         | TB7                            | TB6                                                                       | TB5                                                                       | TB4                                        | TB3                                                         | TB2                                                         | TB1                                                                          | TB0                                                                          |  |  |  |
|         |                          |         | R (Receiving)/W (Transmission) |                                                                           |                                                                           |                                            |                                                             |                                                             |                                                                              |                                                                              |  |  |  |
|         |                          |         | Undefined                      |                                                                           |                                                                           |                                            |                                                             |                                                             |                                                                              |                                                                              |  |  |  |
| SC1CR   | Serial Channel 1 Control | 55H     | RB8                            | EVEN                                                                      | PE                                                                        | OERR                                       | PERR                                                        | FERR                                                        | SCLKS                                                                        | IOC                                                                          |  |  |  |
|         |                          |         | R                              | R/W                                                                       |                                                                           | R (Cleared to 0 by reading)                |                                                             |                                                             | R/W                                                                          |                                                                              |  |  |  |
|         |                          |         | 0                              | 0                                                                         | 0                                                                         | 0                                          | 0                                                           | 0                                                           | 0                                                                            | 0                                                                            |  |  |  |
|         |                          |         | Receiving data bit 8           | Parity 0: Odd 1: Even                                                     | 1: Parity Enable                                                          | Overrun                                    | Parity                                                      | Framing                                                     | 0: SCLK1 1: Input SCLK1 pin (Note)                                           | 1: SCLK1                                                                     |  |  |  |
| SC1-MOD | Serial Channel 1 Mode    | 56H     | TB8                            | -                                                                         | RXE                                                                       | WU                                         | SM1                                                         | SM0                                                         | SC1                                                                          | SC0                                                                          |  |  |  |
|         |                          |         | R/W                            |                                                                           |                                                                           |                                            |                                                             |                                                             |                                                                              |                                                                              |  |  |  |
|         |                          |         | 0                              | 0                                                                         | 0                                                                         | 0                                          | 0                                                           | 0                                                           | 0                                                                            | 0                                                                            |  |  |  |
|         |                          |         | Transmission data bit 8        | Fix at "0"                                                                | 1: Receive Enable                                                         | 1: Wake up Enable                          | 00: I/O Interface 01: UART 7bit 10: UART 8bit 11: UART 9bit | 00: I/O Interface 01: UART 7bit 10: UART 8bit 11: UART 9bit | 00: TO0 Trigger 01: Baud rate generator 10: Internal clock φ1 11: Don't care | 00: TO0 Trigger 01: Baud rate generator 10: Internal clock φ1 11: Don't care |  |  |  |

Note : For TMP96C141, fix this bit to "0".

## (6) Serial Channel (2/2)

| Symbol | Name                     | Address | 7          | 6 | 5                                                                                                       | 4                                        | 3     | 2     | 1                                                | 0                   |
|--------|--------------------------|---------|------------|---|---------------------------------------------------------------------------------------------------------|------------------------------------------|-------|-------|--------------------------------------------------|---------------------|
| BR1CR  | Baud Rate Control        | 57H     | -          |   | BR1CK1                                                                                                  | BR1CK0                                   | BR1S3 | BR1S2 | BR1S1                                            | BR1S0               |
|        |                          |         | R/W        |   |                                                                                                         |                                          |       |       |                                                  | R/W                 |
|        |                          |         | 0          |   | 0                                                                                                       | 0                                        | 0     | 0     | 0                                                | 0                   |
|        |                          |         | Fix at "0" |   | 00: $\neq T_0$ (fc/4)<br>01: $\neq T_2$ (fc/16)<br>10: $\neq T_8$ (fc/64)<br>11: $\neq T_{32}$ (fc/256) | (fc/4)<br>(fc/16)<br>(fc/64)<br>(fc/256) |       |       | Set frequency divisor<br>0~F<br>("1" prohibited) |                     |
| ODE    | Serial Open Drain Enable | 58H     |            |   |                                                                                                         |                                          |       |       | ODE1                                             | ODE0                |
|        |                          |         |            |   |                                                                                                         |                                          |       |       |                                                  | R/W                 |
|        |                          |         |            |   |                                                                                                         |                                          |       |       | 0                                                | 0                   |
|        |                          |         |            |   |                                                                                                         |                                          |       |       | 1:P93<br>Open-drain                              | 1:P90<br>Open-drain |

## (7) A/D Converter Control

| Symbol   | Name                   | Address | 7      | 6       | 5              | 4            | 3            | 2             | 1     | 0                           |
|----------|------------------------|---------|--------|---------|----------------|--------------|--------------|---------------|-------|-----------------------------|
| ADMOD    | A/D Converter Mode reg | 5EH     | EOCF   | ADBF    | REPET          | SCAN         | ADCS         | ADS           | ADCH1 | ADCH0                       |
|          |                        |         | R      |         |                |              |              |               |       | R/W                         |
|          |                        |         | 0      | 0       | 0              | 0            | 0            | 0             | 0     | 0                           |
|          |                        |         | 1: End | 1: Busy | 1: Repeat mode | 1: Scan mode | 1: Slow mode | 1: START mode |       | Analog Input Channel Select |
| AD REG0L | AD Result Reg 0 low    | 60H     | ADR01  | ADR00   |                |              |              |               |       |                             |
|          |                        |         |        |         |                |              |              |               |       | R                           |
| AD REG0H | AD Result Reg 0 high   | 61H     | ADR09  | ADR08   | ADR07          | ADR06        | ADR05        | ADR04         | ADR03 | ADR02                       |
|          |                        |         |        |         |                |              |              |               |       | R                           |
| AD REG1L | AD Result Reg 1 low    | 62H     | ADR11  | ADR10   |                |              |              |               |       |                             |
|          |                        |         |        |         |                |              |              |               |       | R                           |
| AD REG1H | AD Result Reg 1 high   | 63H     | ADR19  | ADR18   | ADR17          | ADR16        | ADR15        | ADR14         | ADR13 | ADR12                       |
|          |                        |         |        |         |                |              |              |               |       | Undefined                   |
| AD REG2L | AD Result Reg 2 low    | 64H     | ADR21  | ADR20   |                |              |              |               |       |                             |
|          |                        |         |        |         |                |              |              |               |       | R                           |
| AD REG2H | AD Result Reg 2 high   | 65H     | ADR29  | ADR28   | ADR27          | ADR26        | ADR25        | ADR24         | ADR23 | ADR22                       |
|          |                        |         |        |         |                |              |              |               |       | R                           |
| AD REG3L | AD Result Reg 3 low    | 66H     | ADR31  | ADR30   |                |              |              |               |       |                             |
|          |                        |         |        |         |                |              |              |               |       | R                           |
| AD REG3H | AD Result Reg 3 high   | 67H     | ADR39  | ADR38   | ADR37          | ADR36        | ADR35        | ADR34         | ADR33 | ADR32                       |
|          |                        |         |        |         |                |              |              |               |       | Undefined                   |

\*1: Data to be stored in A/D Conversion Result Reg Low are the lower 2 bits of the conversion result. The contents of the lower 6 bits of this register are always read as "1".

## (8) Interrupt Control (1/2)

| Symbol    | Name                       | Address               | 7                    | 6      | 5      | 4      | 3                    | 2      | 1      | 0      |
|-----------|----------------------------|-----------------------|----------------------|--------|--------|--------|----------------------|--------|--------|--------|
| INTE-0AD  | INTerrupt Enable 0 & A/D   | 70H<br>(Prohibit RMW) | INTAD                |        |        |        | INT0                 |        |        |        |
|           |                            |                       | IADC                 | IADM2  | IADM1  | IADM0  | I0C                  | I0M2   | I0M1   | I0M0   |
|           |                            |                       | R/W                  | W      |        |        | R/W                  | W      |        |        |
| INTE45    | INTerrupt Enable 4/5       | 71H<br>(Prohibit RMW) | INT5                 |        |        |        | INT4                 |        |        |        |
|           |                            |                       | IS5C                 | IS5M2  | IS5M1  | IS5M0  | I4C                  | I4M2   | I4M1   | I4M0   |
|           |                            |                       | R/W                  | W      |        |        | R/W                  | W      |        |        |
| INTE67    | INTerrupt Enable 6/7       | 72H<br>(Prohibit RMW) | INT7                 |        |        |        | INT6                 |        |        |        |
|           |                            |                       | I7C                  | I7M2   | I7M1   | I7M0   | I6C                  | I6M2   | I6M1   | I6M0   |
|           |                            |                       | R/W                  | W      |        |        | R/W                  | W      |        |        |
| INTET10   | INTerrupt Enable Timer 1/0 | 73H<br>(Prohibit RMW) | INTT1 (Timer 1)      |        |        |        | INTT0 (Timer 0)      |        |        |        |
|           |                            |                       | IT1C                 | IT1M2  | IT1M1  | IT1M0  | IT0C                 | IT0M2  | IT0M1  | IT0M0  |
|           |                            |                       | R/W                  | W      |        |        | R/W                  | W      |        |        |
| INTE-PW10 | INTerrupt Enable PWm 1/0   | 74H<br>(Prohibit RMW) | INTT3 (Timer 3/PWM1) |        |        |        | INTT2 (Timer 2/PWM0) |        |        |        |
|           |                            |                       | IPW1C                | IPW1M2 | IPW1M1 | IPW1M0 | IPW0C                | IPW0M2 | IPW0M1 | IPW0M0 |
|           |                            |                       | R/W                  | W      |        |        | R/W                  | W      |        |        |
| INTET54   | INTerrupt Enable Treg 5/4  | 75H<br>(Prohibit RMW) | INTT5 (TREG5)        |        |        |        | INTT4 (TREG4)        |        |        |        |
|           |                            |                       | IT5C                 | IT5M2  | IT5M1  | IT5M0  | IT4C                 | IT4M2  | IT4M1  | IT4M0  |
|           |                            |                       | R/W                  | W      |        |        | R/W                  | W      |        |        |
| INTET76   | INTerrupt Enable Treg 7/6  | 76H<br>(Prohibit RMW) | INTT7 (TREG7)        |        |        |        | INTT6 (TREG6)        |        |        |        |
|           |                            |                       | IT7C                 | IT7M2  | IT7M1  | IT7M0  | IT6C                 | IT6M2  | IT6M1  | IT6M0  |
|           |                            |                       | R/W                  | W      |        |        | R/W                  | W      |        |        |
| INTE50    | INTerrupt Enable Serial 0  | 77H<br>(Prohibit RMW) | INTTX0               |        |        |        | INTRX0               |        |        |        |
|           |                            |                       | ITX0C                | ITX0M2 | ITX0M1 | ITX0M0 | IRX0C                | IRX0M2 | IRX0M1 | IRX0M0 |
|           |                            |                       | R/W                  | W      |        |        | R/W                  | W      |        |        |
| INTE51    | INTerrupt Enable Serial 1  | 78H<br>(Prohibit RMW) | INTTX1               |        |        |        | INTRX1               |        |        |        |
|           |                            |                       | ITX1C                | ITX1M2 | ITX1M1 | ITX1M0 | IRX1C                | IRX1M2 | IRX1M1 | IRX1M0 |
|           |                            |                       | R/W                  | W      |        |        | R/W                  | W      |        |        |



| IxxM2 | IxxM1 | IxxM0 | Function (Write)                    |
|-------|-------|-------|-------------------------------------|
| 0     | 0     | 0     | Prohibit interrupt request.         |
| 0     | 0     | 1     | Set interrupt request level to "1". |
| 0     | 1     | 0     | Set interrupt request level to "2". |
| 0     | 1     | 1     | Set interrupt request level to "3". |
| 1     | 0     | 0     | Set interrupt request level to "4". |
| 1     | 0     | 1     | Set interrupt request level to "5". |
| 1     | 1     | 0     | Set interrupt request level to "6". |
| 1     | 1     | 1     | Prohibit interrupt request          |

| IxxC | Function (Read)                | Function (Write)              |
|------|--------------------------------|-------------------------------|
| 0    | Indicate no interrupt request. | Clear interrupt request flag. |
| 1    | Indicate interrupt request.    | ----- Don't care -----        |

## Interrupt Control (2/2)

| Symbol | Name                         | Address               | 7     | 6     | 5     | 4      | 3      | 2                    | 1                  | 0                                |
|--------|------------------------------|-----------------------|-------|-------|-------|--------|--------|----------------------|--------------------|----------------------------------|
| DMA0V  | DMA 0 request Vector         | 7CH<br>(Prohibit RMW) | ..... | ..... | ..... | DMA0V8 | DMA0V7 | DMA0V6               | DMA0V5             | DMA0V4                           |
|        |                              |                       | ..... | ..... | ..... | W      |        |                      |                    |                                  |
|        |                              |                       | ..... | ..... | ..... | 0      | 0      | 0                    | 0                  | 0                                |
| DMA1V  | DMA 1 request Vector         | 7DH<br>(Prohibit RMW) | ..... | ..... | ..... | DMA1V8 | DMA1V7 | DMA1V6               | DMA1V5             | DMA1V4                           |
|        |                              |                       | ..... | ..... | ..... | W      |        |                      |                    |                                  |
|        |                              |                       | ..... | ..... | ..... | 0      | 0      | 0                    | 0                  | 0                                |
| DMA2V  | DMA 2 request Vector         | 7EH<br>(Prohibit RMW) | ..... | ..... | ..... | DMA2V8 | DMA2V7 | DMA2V6               | DMA2V5             | DMA2V4                           |
|        |                              |                       | ..... | ..... | ..... | W      |        |                      |                    |                                  |
|        |                              |                       | ..... | ..... | ..... | 0      | 0      | 0                    | 0                  | 0                                |
| DMA3V  | DMA 3 request Vector         | 7FH<br>(Prohibit RMW) | ..... | ..... | ..... | DMA3V8 | DMA3V7 | DMA3V6               | DMA3V5             | DMA3V4                           |
|        |                              |                       | ..... | ..... | ..... | W      |        |                      |                    |                                  |
|        |                              |                       | ..... | ..... | ..... | 0      | 0      | 0                    | 0                  | 0                                |
| IIMC   | Interrupt Input Mode Control | 7BH<br>(Prohibit RMW) | ..... | ..... | ..... | .....  | .....  | IOIE                 | IOLE               | NMIREE                           |
|        |                              |                       | ..... | ..... | ..... | .....  | .....  | W                    | W                  | W                                |
|        |                              |                       | ..... | ..... | ..... | .....  | .....  | 0                    | 0                  | 0                                |
|        |                              |                       |       |       |       |        |        | 1: INT0 input enable | 0: INT0 edge mode  | 1: Operate even at NMI rise edge |
|        |                              |                       |       |       |       |        |        |                      | 1: INT0 level mode |                                  |

## (9) Chip Select / Wait Controller

| Symbol | Name                                      | Address                  | 7                  | 6                    | 5         | 4               | 3         | 2            | 1                      | 0    |
|--------|-------------------------------------------|--------------------------|--------------------|----------------------|-----------|-----------------|-----------|--------------|------------------------|------|
| B0CS   | Block 0<br>CS/WAIT<br>control<br>register | 68H<br>(Prohibit<br>RMW) | B0E                | B0SYS                | B0CAS     | B0BUS           | B0W1      | B0W0         | B0C1                   | B0C0 |
|        |                                           |                          | W                  | W                    | W         | W               | W         | W            | W                      | W    |
|        |                                           |                          | 0                  | 0                    | 0         | 0               | 0         | 0            | 0                      | 0    |
|        |                                           |                          | 1:<br>CS<br>Enable | 1:<br>SYSTEM<br>only | 0:<br>CS0 | 0: 16bit<br>Bus | 00: 2WAIT |              | 00: 7FO0H~7FFFFH       |      |
|        |                                           |                          |                    |                      | 1:<br>CS1 | 1: 8bit<br>Bus  | 01: 1WAIT | 01: 400000H~ |                        |      |
| B1CS   | Block 1<br>CS/WAIT<br>control<br>register | 69H<br>(Prohibit<br>RMW) | B1E                | B1SYS                | B1CAS     | B1BUS           | B1W1      | B1W0         | B1C1                   | B1C0 |
|        |                                           |                          | W                  | W                    | W         | W               | W         | W            | W                      | W    |
|        |                                           |                          | 0                  | 0                    | 0         | 0               | 0         | 0            | 0                      | 0    |
|        |                                           |                          | 1:<br>CS<br>Enable | 1:<br>SYSTEM<br>only | 0:<br>CST | 0: 16bit<br>Bus | 00: 2WAIT |              | 00: 480H~7FFFH (Note3) |      |
|        |                                           |                          |                    |                      | 1:<br>CS1 | 1: 8bit<br>Bus  | 01: 1WAIT | 01: 400000H~ |                        |      |
| B2CS   | Block 2<br>CS/WAIT<br>control<br>register | 6AH<br>(Prohibit<br>RMW) | B2E                | B2SYS                | B2CAS     | B2BUS           | B2W1      | B2W0         | B2C1                   | B2C0 |
|        |                                           |                          | W                  | W                    | W         | W               | W         | W            | W                      | W    |
|        |                                           |                          | 1                  | 0                    | 0         | 0               | 0         | 0            | 0                      | 0    |
|        |                                           |                          | 1:<br>CS<br>Enable | 1:<br>SYSTEM<br>only | 0:<br>CS2 | 0: 16bit<br>Bus | 00: 2WAIT |              | 00: 8000H~             |      |
|        |                                           |                          |                    |                      | 1:<br>CS2 | 1: 8bit<br>Bus  | 01: 1WAIT | 01: 400000H~ |                        |      |

Note 1 : After reset, only "Block 2" is set to enable.

→ After reset, the program starts in 16-bit data bus, 2-wait state.

Note 2 : These registers can be accessed **only in system mode**.

Note 3 : TMP96C041A for internal RAM less is 80H~7FFFH.

## 6. PORT SECTION EQUIVALENT CIRCUIT DIAGRAM

- Reading The Circuit Diagram

Basically, the gate symbols written are the same as those used for the standard CMOS logic IC [74HCXX] series.

The dedicated signal is described below.

**STOP** : This signal becomes active “1” when the halt mode setting register is set to the STOP mode and the CPU executes the HALT instruction. When the drive enable bit [DRIVE] is set to “1”, however, STOP remains at “0”.

- The input protection resistans ranges from several tens of ohms to several hundreds of ohms.

### ■ P0 (AD0~AD7), P1 (AD8~15, A8~15), P2(A16~23, A0~7)



### ■ P30( $\overline{RD}$ ), P31( $\overline{WR}$ )



**■ P32~37, P40~41, P6, P7, P80~86, P91~92, P94~95****■ P42 ( $\overline{CS2}$ ,  $\overline{CAS2}$ )****■ P5 (AN0~3)**

## ■ P87 (INT0)



## ■ P90 (TXD0), P93 (TXD1)



**■ NMI****■ WDTOUT****■ CLK****■ EA, AM8/16****■ ALE**

## ■ RESET



## ■ X1, X2



## ■ VREF, AGND



## 7. Care Points and Restriction

### (1) Special Expression

① Explanation of a built-in I/O register : Register Symbol <Bit Symbol>

ex) TRUN<T0RUN> ... Bit T0RUN of Register TRUN

② Read, Modify and Write Instruction

An instruction which CPU executes following by one instruction.

1. CPU reads data of the memory.

2. CPU modifies the data.

3. CPU writes the data to the same memory.

ex1) SET 3,(TRUN) ... set bit3 of TRUN

ex2) INC 1,(100H) ... increment the data of 100H

- The representative Read, Modify and Write Instruction in the TLCS-900

SET imm, mem , RES imm, mem

CHG imm, mem , TSET imm, mem

INC imm, mem , DEC imm, mem

RLD A, mem , ADD imm, reg

③ 1 state

1 cycle clock divided by 2 oscillation frequency is called 1 state.

ex) The case of oscillation frequency is 20MHz

### (2) Care Points

①  $\overline{EA}$ , pin

Fix these pins  $V_{CC}$  or GND unless changing voltage.

② Warmingup Counter

The warmingup counter operates when the STOP mode is released even the system which is used an external oscillator. As a result, it takes warming up time from inputting the releasing request to outputting the system clock.

③ High Speed  $\mu$ DMA (DRAM refresh mode)

When the Bus is released ( $BUSAK = "0"$ ) for waiting to accept the interrupt, DRAM refresh is not performed because of the high-speed  $\mu$ DMA is generated by an interrupt.

④ Programmable Pull Up/Down Resistance

The programmable pull up/down resistors can be selected ON/OFF by program when they are used as the input ports. The case of they are used as the output ports, they can not be selected ON/OFF by program.

**⑤ Bus Releasing Function**

Refer to the “Note about the Bus Release” in 3.5 Functions of Ports because the pin state when the bus is released is written.

**⑥ WatchDog Timer**

When the bus is released, both internal memory and internal I/O can not be accessed. But the internal I/O continues to operate. So, the watch dog timer continues to run. Therefore, be care about the bus releasing time and set the detection timer of watch dog timer.

**⑦ WatchDog Timer**

The watch dog timer starts operation immediately after the reset is released. When the watch dog timer is not used, set watch dog timer to disable.

**⑧ CPU (High Speed,DMA)**

Only the “LDC cr, r”, “LDC r, cr” instruction can be used to access the control register like transfer source address register (DMA\$Sn) in the CPU.

## CMOS 16-bit MICROCONTROLLERS

## TMP96C141AF

## 1. OUTLINE AND DEVICE CHARACTERISTICS

TMP96C141AF is high-speed advanced 16-bit microcontrollers developed for controlling medium to large-scale equipment. The TMP96C141AF has the improved bus release function and serial interface for TMP96C141F. Otherwise, the devices function in the same way.

TMP96C141AF is housed in an 80-pin flat package, and is pin-compatible with TMP96C141F except the P92 (CTS0 / SCLK0).

Device characteristics are as follows:

- (1) Original 16-bit CPU
  - TLCS-90 instruction mnemonic upward compatible.
  - 16M-byte linear address space
  - General-purpose registers and register bank system
  - 16-bit multiplication / division and bit transfer/arithmetic instructions
  - High-speed micro DMA : 4 channels (1.6  $\mu$ s/2 bytes @20MHz)
- (2) Minimum instruction execution time : 200ns @20MHz
- (3) Internal RAM : 1K byte  
Internal ROM : None
- (4) External memory expansion
  - Can be expanded up to 16M bytes (for both programs and data).
  - Can mix 8- and 16-bit external data buses.
- (5) 8-bit timers : 2 channels
- (6) 8-bit PWM timers : 2 channels
- (7) 16-bit timers : 2 channels
- (8) Pattern generators : 4 bits, 2 channels
- (9) Serial interface : 2 channels
- (10) 10-bit A/D converter : 4 channels
- (11) Watchdog timer
- (12) Chip select/wait controller : 3 blocks
- (13) Interrupt functions
  - 3 CPU interrupts..... SWI instruction, privileged violation, and Illegal instruction
  - 14 internal interrupts
  - 6 external interrupts ] 7-level priority can be set.
- (14) I/O ports  
47 pins
- (15) Standby function : 3 halt modes (RUN, IDLE, STOP)





Figure1 TMP96C141A Block Diagram

## 2. PIN ASSIGNMENT AND FUNCTIONS

The assignment of input / output pins for TMP96C141A, their name and outline functions are described below.

### 2.1 Pin Assignment

Figure 2.1 shows pin assignment of TMP96C141AF.



Note : Because the TMP96C141A has an external ROM, P00 to P17 pins are fixed to AD0 to AD15; P30 to RD; and P31 to WR.

Figure 2.1 Pin Assignment (80-pin QFP)

## 2.2 Pin Names and Functions

The names of input/output pins and their functions are described below.

Table 2.2 Pin Names and Functions.

| Pin name                         | Number of pins | I/O                        | Functions                                                                                                                                                                                                                         |
|----------------------------------|----------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P00~P07<br>AD0~AD7               | 8              | I/O<br>Tri-state           | Port 0: I/O port that allows I/O to be selected on a bit basis<br>Address/data (lower): 0 - 7 for address/data bus                                                                                                                |
| P10~P17<br>AD8~AD15<br>A8~A15    | 8              | I/O<br>Tri-state<br>Output | Port 1: I/O port that allows I/O to be selected on a bit basis<br>Address data (upper): 8 - 15 for address/data bus<br>Address: 8 to 15 for address bus                                                                           |
| P20~P27<br>A0~A7<br>A16~A23      | 8              | I/O<br>Output<br>Output    | Port 2: I/O port that allows selection of I/O on a bit basis<br>(with pull-down resistor)<br>Address: 0 - 7 for address bus<br>Address: 16 - 23 for address bus                                                                   |
| P30<br><u>RD</u>                 | 1              | Output<br>Output           | Port 30: Output port<br>Read: Strobe signal for reading external memory                                                                                                                                                           |
| P31<br><u>WR</u>                 | 1              | Output<br>Output           | Port 31: Output port<br>Write: Strobe signal for writing data on pins AD0 - 7                                                                                                                                                     |
| P32<br><u>HWR</u>                | 1              | I/O<br>Output              | Port 32: I/O port (with pull-up resistor)<br>High write: Strobe signal for writing data on pins AD8 - 15                                                                                                                          |
| P33<br><u>WAIT</u>               | 1              | I/O<br>Input               | Port 33: I/O port (with pull-up resistor)<br>Wait: Pin used to request CPU bus wait                                                                                                                                               |
| P34<br><u>BUSRQ</u>              | 1              | I/O<br>Input               | Port 34: I/O port (with pull-up resistor)<br>Bus request: Signal used to request high impedance for AD0 - 15,<br>A0 - 23, RD, WR, HWR, R/W, RAS, CS0, CS1, and CS2 pins.<br>(For external DMAC)                                   |
| P35<br><u>BUSAK</u>              | 1              | I/O<br>Output              | Port 35: I/O port (with pull-up resistor)<br>Bus acknowledge: Signal indicating that AD0-15, A0-23, RD,<br>WR, HWR, R/W, RAS, CS0, CS1, and CS2 pins are at high impedance<br>after receiving BUSRQ. (For external DMAC)          |
| P36<br><u>R/W</u>                | 1              | I/O<br>Output              | Port 36: I/O port (with pull-up resistor)<br>Read/write: 1 represents read or dummy cycle; 0, write cycle.                                                                                                                        |
| P37<br><u>RAS</u>                | 1              | I/O<br>Output              | Port 37: I/O port (with pull-up resistor)<br>Row address strobe: Outputs RAS strobe for DRAM.                                                                                                                                     |
| P40<br><u>CS0</u><br><u>CAS0</u> | 1              | I/O<br>Output<br>Output    | Port 40: I/O port (with pull-up resistor)<br>Chip select 0: Outputs 0 when address is within specified address<br>area.<br>Column address strobe 0: Outputs CAS strobe for DRAM when<br>address is within specified address area. |

Note: With the external DMA controller, this device's built-in memory or built-in I/O cannot be accessed using the BUSRQ and BUSAK pins.

| Pin name             | Number of pins | I/O                     | Functions                                                                                                                                                                                                                          |
|----------------------|----------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P41<br>CS1<br>CAS1   | 1              | I/O<br>Output<br>Output | Port 41: I/O port (with pull-up resistor)<br>Chip select 1: Outputs 0 if address is within specified address area.<br>Column address strobe 1: Outputs CAS strobe for DRAM if address is within specified address area.            |
| P42<br>CS2<br>CAS2   | 1              | I/O<br>Output<br>Output | Port 42: I/O port (with pull-down resistor) (Note 1)<br>Chip select 2: Outputs 0 if address is within specified address area.<br>Column address strobe 2: Outputs CAS strobe for DRAM if address is within specified address area. |
| P50~P53<br>AN0~AN3   | 4              | Input<br>Input          | Port 5: Input port<br>Analog input: Input to A/D converter                                                                                                                                                                         |
| VREF                 | 1              | Input                   | Pin for reference voltage input to A/D converter                                                                                                                                                                                   |
| AGND                 | 1              | Input                   | Ground pin for A/D converter                                                                                                                                                                                                       |
| P60~P63<br>PG00~PG03 | 4              | I/O<br>Output           | Ports 60 - 63: I/O ports that allow selection of I/O on a bit basis (with pull-up resistor)<br>Pattern generator ports: 00 - 03                                                                                                    |
| P64~P67<br>PG10~PG13 | 4              | I/O<br>Output           | Ports 64 - 67: I/O ports that allow selection of I/O on a bit basis (with pull-up resistor)<br>Pattern generator ports: 10 - 13                                                                                                    |
| P70<br>TI0           | 1              | I/O<br>Input            | Port 70: I/O port (with pull-up resistor)<br>Timer input 0: Timer 0 input                                                                                                                                                          |
| P71<br>TO1           | 1              | I/O<br>Output           | Port 71: I/O port (with pull-up resistor)<br>Timer output 1: Timer 0 or 1 output                                                                                                                                                   |
| P72<br>TO2           | 1              | I/O<br>Output           | Port 72: I/O port (with pull-up resistor)<br>PWM output 2: 8-bit PWM timer 2 output                                                                                                                                                |
| P73<br>TO3           | 1              | I/O<br>Output           | Port 73: I/O port (with pull-up resistor)<br>PWM output 3: 8-bit PWM timer 3 output                                                                                                                                                |
| P80<br>TI4<br>INT4   | 1              | I/O<br>Input<br>Input   | Port 80: I/O port (with pull-up resistor)<br>Timer input 4: Timer 4 count/capture trigger signal input<br>Interrupt request pin 4: Interrupt request pin with programmable rising/falling edge                                     |
| P81<br>TI5<br>INT5   | 1              | I/O<br>Input<br>Input   | Port 81: I/O port (with pull-up resistor)<br>Timer input 5: Timer 4 count/capture trigger signal input<br>Interrupt request pin 5: Interrupt request pin with rising edge                                                          |
| P82<br>TO4           | 1              | I/O<br>Output           | Port 82: I/O port (with pull-up resistor)<br>Timer output 4: Timer 4 output pin                                                                                                                                                    |
| P83<br>TO5           | 1              | I/O<br>Output           | Port 83: I/O port (with pull-up resistor)<br>Timer output 5: Timer 4 output pin                                                                                                                                                    |

Note 1 : Case of the settable CS2 or CAS2; when TMP96C141AF is bus release, this pin is not added the internal pull-down resistor but is added the internal pull-up resistor.

| Pin name             | Number of pins | I/O                   | Functions                                                                                                                                                                                      |
|----------------------|----------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P84<br>TI6<br>INT6   | 1              | I/O<br>Input<br>Input | Port 84: I/O port (with pull-up resistor)<br>Timer input 6: Timer 5 count/capture trigger signal input<br>Interrupt request pin 6: Interrupt request pin with programmable rising/falling edge |
| P85<br>TI7<br>INT7   | 1              | I/O<br>Input<br>Input | Port 85: I/O port (with pull-up resistor)<br>Timer input 7: Timer 5 count/capture trigger signal input<br>Interrupt request pin 7: Interrupt request pin with rising edge                      |
| P86<br>TO6           | 1              | I/O<br>Output         | Port 86: I/O port (with pull-up resistor)<br>Timer output 6: Timer 5 output pin                                                                                                                |
| P87<br>INT0          | 1              | I/O<br>Input          | Port 87: I/O port (with pull-up resistor)<br>Interrupt request pin 0: Interrupt request pin with programmable level/rising edge                                                                |
| P90<br>TXD0          | 1              | I/O<br>Output         | Port 90: I/O port (with pull-up resistor)<br>Serial send data 0                                                                                                                                |
| P91<br>RXD0          | 1              | I/O<br>Input          | Port 91: I/O port (with pull-up resistor)<br>Serial receive data 0                                                                                                                             |
| P92<br>CTS0<br>SCLK0 | 1              | I/O<br>Input<br>I/O   | Port 92: I/O port (with pull-up resistor)<br>Serial data send enable 0 (Clear to Send)<br>Serial clock I/O 0                                                                                   |
| P93<br>TXD1          | 1              | I/O<br>Output         | Port 93: I/O port (with pull-up resistor)<br>Serial send data 1                                                                                                                                |
| P94<br>RXD1          | 1              | I/O<br>Input          | Port 94: I/O port (with pull-up resistor)<br>Serial receive data 1                                                                                                                             |
| P95<br>SCLK1         | 1              | I/O<br>I/O            | Port 95: I/O port (with pull-up resistor)<br>Serial clock I/O 1                                                                                                                                |
| WDtout               | 1              | Output                | Watchdog timer output pin                                                                                                                                                                      |
| NMI                  | 1              | Input                 | Non-maskable interrupt request pin: Interrupt request pin with falling edge. Can also be operated at rising edge by program.                                                                   |
| CLK                  | 1              | Output                | Clock output: Outputs $\lceil X1 \div 4 \rceil$ clock. Pulled-up during reset.                                                                                                                 |
| EA                   | 1              | Input                 | External access: 0 should be inputted with TMP96C141A.                                                                                                                                         |
| ALE                  | 1              | Output                | Address latch enable                                                                                                                                                                           |
| RESET                | 1              | Input                 | Reset: Initializes LSI. (With pull-up resistor)                                                                                                                                                |
| X1/X2                | 2              | I/O                   | Oscillator connecting pin                                                                                                                                                                      |
| VCC                  | 2              |                       | Power supply pin (+ 5V)                                                                                                                                                                        |
| VSS                  | 3              |                       | GND pin (0V)                                                                                                                                                                                   |

Note : Pull-up/pull-down resistor can be released from the pin by software (except the RESET pin).

### 3. OPERATION

This section describes the functions and basic operations of TMP96C141A device.

Check the 「7. Care Points and Restriction of TMP96C141」 because of the Care described. Regarding the function of TMP96C141A (not described), see the part of TMP96C141.

#### 3.1 CPU

TMP96C141A device has a built-in high-performance 16-bit CPU (900-CPU). (For CPU operation, see TLCS-900 CPU in the previous section.)

#### 3.2 Memory Map

TMP96C141A has two register modes. One is a minimum mode; in this mode, the area of program memory is 64K bytes maximum. The other is a maximum mode; in this mode, The area of program memory is 16M bytes maximum.

Both minimum and maximum modes are the data memory area of 16M bytes maximum.

That is, the program memory can locate 0H~FFFFH in minimum mode and can locate 0H ~ FFFFFFFH in maximum mode.

##### (1) Internal RAM

TMP96C141A has the RAM of 1K bytes. This RAM is located to 80H~47FH. The CPU can access the part of RAM (80H~FFH) with using the short instruction code of direct addressing mode.

##### (2) Internal I/O devices

TMP96C141A uses the address space of 128 bytes for the internal I/O devices area. This area is located to 0H~7FH.

The CPU can access the internal I/O devices area with using the short instruction code of direct addressing mode.

Check the access area of each addressing mode and the memory map in Fig. 3.2.



### Memory Map

Figure 3.2 is a memory map of the TMP96C141A.



Note : The start address after reset is 8000H. Resetting sets the stack pointer (XSP) on the system mode side to 100H.

Figure3.2 Memory map

### 3.3 Bus release function

TMP96C141A has the internal pull-up and pull-down resistors to fix the bus control singnals at bus release.

Show the table 3.3 of pin condition at bus release ( $\overline{\text{BUSAK}} = 0$ ).

Table 3.3 The condition of pins at the bus release ( $\overline{\text{BUSAK}} = "L"$ )

| pin name                                                                                                        | the status of pins at bus release                      |                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                 | port mode                                              | function mode                                                                                                                                                       |
| P00-P07<br>(AD0-AD7)<br>P10-P17<br>(AD8-15/A8-15)                                                               | the status is no-change.<br>(these pins are not "Hz".) | these pins are "Hz".                                                                                                                                                |
| P30 ( $\overline{\text{RD}}$ )<br>P31 ( $\overline{\text{WR}}$ )                                                | ↑                                                      | these pins are "Hz".<br>("Hz" status after these pins driven high level)                                                                                            |
| P32 ( $\overline{\text{HWR}}$ )<br>P37 ( $\overline{\text{RAS}}$ )                                              | ↑                                                      | The output buffer is "OFF" after these pins driven high.<br>These pins are added the internal resistor of pull-up. It's no relation for the value of output latch.  |
| P36 ( $\overline{\text{R/W}}$ )<br>P40 ( $\overline{\text{CS0/CAS0}}$ )<br>P41 ( $\overline{\text{CS1/CAS1}}$ ) | ↑                                                      | ↑                                                                                                                                                                   |
| P42 ( $\overline{\text{CS2/CAS2}}$ )                                                                            | ↑                                                      | (*) ↑                                                                                                                                                               |
| P20-P27<br>(A16-23)                                                                                             | ↑                                                      | The output buffer is "OFF" after these pins driven low.<br>These pins are added the internal resistor of pull-down. It's no relation for the value of output latch. |



: the difference with TMP96C141

That is, when it is used for bus release ( $\overline{\text{BUSAK}} = 0$ ), the pins of below need pull-up or pull-down resistor for an external circuit.

P00-P07 (AD0-AD7)  
P10-P17 (AD8-AD15)  
P30 ( $\overline{\text{RD}}$ )  
P31 ( $\overline{\text{WR}}$ )

(\*) P42 has the resistor of programmable pull-down, but when the bus are released, P42 pin is added a resistor of pull-up.

Case of the bus release function; show a sample of external bus interface in the Fig.3.3 (1).

When the bus is released, both internal memory and internal I/O can not be accessed. But the internal I/O continues to run. So, the watchdog timer also continues to run. Therefore, be care about bus releasing time and set the detection time of WDT.



Fig.3.3 (1) Example of the interface circuit (The case of using bus releasing function)

### 3.4 Serial function

TMP96C141A has two Serial I/O devices. Both channel 0 and channel 1 are same function except the handshake ( $\overline{CTS0}$  pin) function of the channel 0 and can use I/O interface mode.

Show the part of TMP96C141 in detail.

## 4. ELECTRICAL CHARACTERISTICS (PRELIMINARY)

### 4.1 Absolute Maximum (TMP96C141AF)

| Symbol              | Parameter                     | Rating                     | Unit |
|---------------------|-------------------------------|----------------------------|------|
| V <sub>CC</sub>     | Power Supply Voltage          | -0.5~6.5                   | V    |
| V <sub>IN</sub>     | Input Voltage                 | -0.5~V <sub>CC</sub> + 0.5 | V    |
| $\Sigma I_{OL}$     | Output Current (total)        | 100                        | mA   |
| $\Sigma I_{OH}$     | Output Current (total)        | -100                       | mA   |
| P <sub>D</sub>      | Power Dissipation (Ta = 85°C) | 500                        | mW   |
| T <sub>SOLDER</sub> | Soldering Temperature (10 s)  | 260                        | °C   |
| T <sub>STG</sub>    | Storage Temperature           | -65~150                    | °C   |
| T <sub>OPR</sub>    | Operating Temperature         | -40~85                     | °C   |

### 4.2 DC Characteristics (TMP96C141AF)

V<sub>CC</sub> = 5V ± 10%, TA = -40~85°C (4~16MHz) TA = -20~70°C (4~20MHz)

(Typical values are for Ta = 25°C and V<sub>CC</sub> = 5V)

| Symbol            | Parameter                                                                               | Min                                 | Max                   | Unit           | Test Condition                                                                                                             |
|-------------------|-----------------------------------------------------------------------------------------|-------------------------------------|-----------------------|----------------|----------------------------------------------------------------------------------------------------------------------------|
| V <sub>IL</sub>   | Input Low Voltage (AD0~15)<br>P2, P3, P4, P5, P6, P7, P8, P9<br>RESET, NMI, INT0 (P87)  | -0.3                                | 0.8                   | V              |                                                                                                                            |
| V <sub>IL1</sub>  |                                                                                         | -0.3                                | 0.3V <sub>CC</sub>    | V              |                                                                                                                            |
| V <sub>IL2</sub>  |                                                                                         | -0.3                                | 0.25V <sub>CC</sub>   | V              |                                                                                                                            |
| V <sub>IL3</sub>  | EA                                                                                      | -0.3                                | 0.3                   | V              |                                                                                                                            |
| V <sub>IL4</sub>  | X1                                                                                      | -0.3                                | 0.2V <sub>CC</sub>    | V              |                                                                                                                            |
| V <sub>IH</sub>   | Input High Voltage (AD0~15)<br>P2, P3, P4, P5, P6, P7, P8, P9<br>RESET, NMI, INT0 (P87) | 2.2                                 | V <sub>CC</sub> + 0.3 | V              |                                                                                                                            |
| V <sub>IH1</sub>  |                                                                                         | 0.7V <sub>CC</sub>                  | V <sub>CC</sub> + 0.3 | V              |                                                                                                                            |
| V <sub>IH2</sub>  |                                                                                         | 0.75V <sub>CC</sub>                 | V <sub>CC</sub> + 0.3 | V              |                                                                                                                            |
| V <sub>IH3</sub>  | EA                                                                                      | V <sub>CC</sub> - 0.3               | V <sub>CC</sub> + 0.3 | V              |                                                                                                                            |
| V <sub>IH4</sub>  | X1                                                                                      | 0.8V <sub>CC</sub>                  | V <sub>CC</sub> + 0.3 | V              |                                                                                                                            |
| V <sub>OL</sub>   | Output Low Voltage                                                                      |                                     | 0.45                  | V              | I <sub>OL</sub> = 1.6mA                                                                                                    |
| V <sub>OH</sub>   | Output High Voltage                                                                     | 2.4                                 |                       | V              | I <sub>OH</sub> = -400μA                                                                                                   |
| V <sub>OH1</sub>  |                                                                                         | 0.75V <sub>CC</sub>                 |                       | V              | I <sub>OH</sub> = -100μA                                                                                                   |
| V <sub>OH2</sub>  |                                                                                         | 0.9V <sub>CC</sub>                  |                       | V              | I <sub>OH</sub> = -20μA                                                                                                    |
| I <sub>DAR</sub>  | Darlington Drive Current<br>(8 Output Pins max.)                                        | -1.0                                | -3.5                  | mA             | V <sub>EXT</sub> = 1.5V<br>R <sub>EXT</sub> = 1.1kΩ                                                                        |
| I <sub>LI</sub>   | Input Leakage Current                                                                   | TBD (Typ)                           | ± 5                   | μA             | 0.0 ≤ V <sub>in</sub> ≤ V <sub>CC</sub>                                                                                    |
| I <sub>LO</sub>   | Output Leakage Current                                                                  | TBD (Typ)                           | ± 10                  | μA             | 0.2 ≤ V <sub>in</sub> ≤ V <sub>CC</sub> - 0.2                                                                              |
| I <sub>CC</sub>   | Operating Current (RUN)<br>IDLE<br>STOP (Ta = -20~70°C)<br>STOP (Ta = 0~50°C)           | TBD (Typ)<br>TBD (Typ)<br>TBD (Typ) | TBD<br>10<br>50<br>10 | mA<br>μA<br>μA | t <sub>osc</sub> = 20MHz<br>0.2 ≤ V <sub>in</sub> ≤ V <sub>CC</sub> - 0.2<br>0.2 ≤ V <sub>in</sub> ≤ V <sub>CC</sub> - 0.2 |
| V <sub>STOP</sub> | Power Down Voltage<br>(@STOP, RAM Back up)                                              | 2.0                                 | 6.0                   | V              | V <sub>IL2</sub> = 0.2V <sub>CC</sub> ,<br>V <sub>IH2</sub> = 0.8V <sub>CC</sub>                                           |
| R <sub>RST</sub>  | RESET Pull Up Register                                                                  | 50                                  | 150                   | kΩ             |                                                                                                                            |
| C <sub>IO</sub>   | Pin Capacitance                                                                         |                                     | 10                    | pF             | t <sub>osc</sub> = 1MHz                                                                                                    |
| V <sub>TH</sub>   | Schmitt Width<br>RESET, NMI, INT0 (P87)                                                 | 0.4                                 | TBD (Typ)             | V              |                                                                                                                            |
| R <sub>K</sub>    | Pull Down/Up Register                                                                   | 50                                  | 150                   | kΩ             |                                                                                                                            |

Note : I-DAR is guaranteed for a total of up to 8 ports.

#### 4.3 AC Electrical Characteristics (TMP96C141AF)

V<sub>CC</sub> = 5V ± 10%, TA = -40~85°C (4~16MHz) TA = -20~70°C (4~20MHz)

| No. | Symbol | Parameter                                                                       | Variavle  |            | 16MHz |     | 20MHz |     | Unit |
|-----|--------|---------------------------------------------------------------------------------|-----------|------------|-------|-----|-------|-----|------|
|     |        |                                                                                 | Min       | Max        | Min   | Max | Min   | Max |      |
| 1   | tosc   | Osc. Period (= x)                                                               | 50        | 250        | 62.5  |     | 50    |     | ns   |
| 2   | tCLK   | CLK width                                                                       | 2x - 40   |            | 85    |     | 60    |     | ns   |
| 3   | tAK    | A0-23 Valid → CLK Hold                                                          | 0.5x - 20 |            | 11    |     | 5     |     | ns   |
| 4   | tKA    | CLK Valid → A0-23 Hold                                                          | 1.5x - 70 |            | 24    |     | 5     |     | ns   |
| 5   | tAL    | A0-15 Valid → ALE fall                                                          | 0.5x - 15 |            | 16    |     | 10    |     | ns   |
| 6   | tLA    | ALE fall → A0-15 Hold                                                           | 0.5x - 15 |            | 16    |     | 10    |     | ns   |
| 7   | tLL    | ALE High width                                                                  | x - 40    |            | 23    |     | 10    |     | ns   |
| 8   | tLC    | ALE fall → RD/WR fall                                                           | 0.5x - 30 |            | 1     |     | -5    |     | ns   |
| 9   | tCL    | RD/WR rise → ALE rise                                                           | 0.5x - 20 |            | 11    |     | 5     |     | ns   |
| 10  | tACL   | A0-15 Valid → RD/WR fall                                                        | x - 25    |            | 38    |     | 25    |     | ns   |
| 11  | tACh   | A0-23 Valid → RD/WR fall                                                        | 1.5x - 50 |            | 44    |     | 25    |     | ns   |
| 12  | tCA    | RD/WR rise → A0-23 Hold                                                         | 0.5x - 20 |            | 11    |     | 5     |     | ns   |
| 13  | tADL   | A0-15 Valid → D0-15 input                                                       |           | 3.0x - 45  |       | 143 |       | 105 | ns   |
| 14  | tADH   | A0-23 Valid → D0-15 input                                                       |           | 3.5x - 65  |       | 154 |       | 110 | ns   |
| 15  | tRD    | RDfall → D0-15 input                                                            |           | 2.0x - 50  |       | 75  |       | 50  | ns   |
| 16  | tRR    | RD Low width                                                                    | 2.0x - 40 |            | -85   |     | 60    |     | ns   |
| 17  | tHR    | RDrise → D0-15 Hold                                                             | 0         |            | 0     |     | 0     |     | ns   |
| 18  | tRAE   | RDrise → A0-15output                                                            | x - 15    |            | 48    |     | 35    |     | ns   |
| 19  | tWW    | WR Low width                                                                    | 2.0x - 40 |            | 85    |     | 60    |     | ns   |
| 20  | tDW    | D0-15 Valid → WR rise                                                           | 2.0x - 50 |            | 75    |     | 50    |     | ns   |
| 21  | tWD    | WR rise → D0-15 Hold                                                            | 0.5x - 10 |            | 21    |     | 15    |     | ns   |
| 22  | tAEH   | A0-23 Valid → WAIT input<br><small>(<sup>1WAIT</sup><sub>+n mode</sub>)</small> |           | 3.5x - 90  |       | 129 |       | 85  | ns   |
| 23  | tAWL   | A0-15 Valid → WAIT input<br><small>(<sup>1WAIT</sup><sub>+n mode</sub>)</small> |           | 3.0x - 80  |       | 108 |       | 70  | ns   |
| 24  | tCW    | RD/WR fall → WAIT Hold<br><small>(<sup>1WAIT</sup><sub>+n mode</sub>)</small>   | 2.0x + 0  |            | 125   |     | 100   |     | ns   |
| 25  | tAPH   | A0-23 Valid → PORT input                                                        |           | 2.5x - 120 |       | 36  |       | 5   | ns   |
| 26  | tAPH2  | A0-23 Valid → PORT Hold                                                         | 2.5x + 50 |            | 206   |     | 175   |     | ns   |
| 27  | tCP    | WR rise → PORT Valid                                                            |           | 200        |       | 200 |       | 200 | ns   |
| 28  | tASRH  | A0-23 Valid → RAS fall                                                          | 1.0x - 40 |            | 23    |     | 10    |     | ns   |
| 29  | tASRL  | A0-15 Valid → RAS fall                                                          | 0.5x - 15 |            | 16    |     | 10    |     | ns   |
| 30  | tTRAC  | RAS fall → D0-15 input                                                          |           | 2.5x - 70  |       | 86  |       | 55  | ns   |
| 31  | tRAH   | RAS fall → A0-15 Hold                                                           | 0.5x - 15 |            | 16    |     | 10    |     | ns   |
| 32  | tRAS   | RAS Low width                                                                   | 2.0x - 40 |            | 85    |     | 60    |     | ns   |
| 33  | tRP    | RAS High width                                                                  | 2.0x - 40 |            | 85    |     | 60    |     | ns   |
| 34  | tRSH   | CAS fall → RAS rise                                                             | 1.0x - 35 |            | 28    |     | 15    |     | ns   |
| 35  | tRSC   | RAS rise → CAS rise                                                             | 0.5x - 25 |            | 6     |     | 0     |     | ns   |
| 36  | tRCRD  | RAS fall → CAS fall                                                             | 1.0x - 40 |            | 23    |     | 10    |     | ns   |
| 37  | tCAC   | CAS fall → D0-15 input                                                          |           | 1.5x - 65  |       | 29  |       | 10  | ns   |
| 38  | tCAS   | CAS Low width                                                                   | 1.5x - 30 |            | 64    |     | 40    |     | ns   |
| 39  | tds    | D0-15 Valid → CAS fall                                                          | 0.5x - 15 |            | 16    |     | 10    |     | ns   |

## AC Measuring Conditions

- Output Level : High 2.2V /Low 0.8V , CL50pF  
(However CL = 100pF for AD0~AD15, AD0~AD23, ALE, RD, WR, HWR, R/W, CLK, RAS, CAS0~CAS2)
  - Input Level : High 2.4V /Low 0.45V (AD0~AD15)  
High 0.8Vcc /Low 0.2Vcc (Except for AD0~AD15)

## (1) Read Cycle



## (2) Write Cycle



#### 4.4 A/D Conversion Characteristics (TMP96C141AF)

$V_{CC} = 5V \pm 10\%$ ,  $TA = -40\sim85^\circ C$  (4~16MHz)  $TA = -20\sim70^\circ C$  (4~20MHz)

| Symbol                                                              | Parameter                                   |                  | Min            | Typ |  | Max       | Unit |
|---------------------------------------------------------------------|---------------------------------------------|------------------|----------------|-----|--|-----------|------|
| $V_{REF}$                                                           | Analog reference voltage                    |                  | $V_{CC} - 1.5$ |     |  | $V_{CC}$  | V    |
| $A_{GND}$                                                           | Analog reference voltage                    |                  | $V_{SS}$       |     |  | $V_{SS}$  |      |
| $V_{AIN}$                                                           | Analog input voltage range                  |                  | $V_{SS}$       |     |  | $V_{CC}$  | mA   |
| $I_{REF}$                                                           | Analog current for analog reference voltage |                  |                | TBD |  | 1.5       |      |
| Total error<br>(Quantize error<br>of $\pm 0.5$ LSB not<br>included) | $4 \leq f_C \leq 16$ MHz                    | Low change mode  |                | TBD |  | $\pm 4.0$ | LSB  |
|                                                                     |                                             | High change mode |                | TBD |  | $\pm 6.0$ |      |
|                                                                     | $16 < f_C \leq 20$ MHz                      | Low change mode  |                | TBD |  | $\pm 4.0$ |      |
|                                                                     |                                             | High change mode |                | TBD |  | $\pm 8.0$ |      |

#### 4.5 Serial Channel Timing – I/O Interface Mode

(1) SCLK Input Mode  $V_{CC} = 5V \pm 10\%$ ,  $TA = -40\sim85^\circ C$  (4~16MHz)  $TA = -20\sim70^\circ C$  (4~20MHz)

| Symbol    | Parameter                               | Variable              |                      | 16MHz |     | 20MHz |     | Unit    |
|-----------|-----------------------------------------|-----------------------|----------------------|-------|-----|-------|-----|---------|
|           |                                         | Min                   | Max                  | Min   | Max | Min   | Max |         |
| $t_{SCY}$ | SCLK cycle                              | 16X                   |                      | 1     |     | 0.8   |     | $\mu s$ |
| $t_{OSS}$ | Output Data → Rising edge of SCLK       | $t_{SCY}/2 - 5X - 50$ |                      | 137   |     | 100   |     | ns      |
| $t_{OHS}$ | SCLK rising edge → Output Data hold     | 5X - 100              |                      | 212   |     | 150   |     | ns      |
| $t_{HSR}$ | SCLK rising edge → Input Data hold      | 0                     |                      | 0     |     | 0     |     | ns      |
| $t_{SRD}$ | SCLK rising edge → effective data input |                       | $t_{SCY} - 5X - 100$ | 587   |     | 450   |     | ns      |

(2) SCLK Output Mode  $V_{CC} = 5V \pm 10\%$ ,  $TA = -40\sim85^\circ C$  (4~16MHz)  $TA = -20\sim70^\circ C$  (4~20MHz)

| Symbol    | Parameter                               | Variable              |                      | 16MHz |     | 20MHz |       | Unit    |
|-----------|-----------------------------------------|-----------------------|----------------------|-------|-----|-------|-------|---------|
|           |                                         | Min                   | Max                  | Min   | Max | Min   | Max   |         |
| $t_{SCY}$ | SCLK cycle (programmable)               | 16X                   | 8192X                | 1     | 512 | 0.8   | 409.6 | $\mu s$ |
| $t_{OSS}$ | Output Data → SCLK rising edge          | $t_{SCY}/2 - X - 150$ |                      | 725   |     | 550   |       | ns      |
| $t_{OHS}$ | SCLK rising edge → Output Data hold     | 2X - 80               |                      | 45    |     | 20    |       | ns      |
| $t_{HSR}$ | SCLK rising edge → Input Data hold      | 0                     |                      | 0     |     | 0     |       | ns      |
| $t_{SRD}$ | SCLK rising edge → effective data input |                       | $t_{SCY} - 2X - 150$ | 725   |     | 550   |       | ns      |

#### 4.6 Timer/Counter Input Clock (T10, T14, T15, T16, T17)

$V_{CC} = 5V \pm 10\%$ ,  $TA = -40\sim85^\circ C$  (4~16MHz)  $TA = -20\sim70^\circ C$  (4~20MHz)

| Symbol     | Parameter                    | Variable   |     | 16MHz |     | 20MHz |     | Unit |
|------------|------------------------------|------------|-----|-------|-----|-------|-----|------|
|            |                              | Min        | Max | Min   | Max | Min   | Max |      |
| $t_{VCK}$  | Clock Cycle                  | $8X + 100$ |     | 600   |     | 500   |     | ns   |
| $t_{VCKL}$ | Low level clock Pulse width  | $4X + 40$  |     | 290   |     | 240   |     | ns   |
| $t_{VCKH}$ | High level clock Pulse width | $4X + 40$  |     | 290   |     | 240   |     | ns   |

#### 4.7 Interrupt Operation

$V_{CC} = 5V \pm 10\%$ ,  $TA = -40\sim85^\circ C$  (4~16MHz)  $TA = -20\sim70^\circ C$  (4~20MHz)

| Symbol      | Parameter                        | Variable   |     | 16MHz |     | 20MHz |     | Unit |
|-------------|----------------------------------|------------|-----|-------|-----|-------|-----|------|
|             |                                  | Min        | Max | Min   | Max | Min   | Max |      |
| $t_{INTAL}$ | NMI, INT0 Low level Pulse width  | 4X         |     | 250   |     | 200   |     | ns   |
| $t_{INTAH}$ | NMI, INT0 High level Pulse width | 4X         |     | 250   |     | 200   |     | ns   |
| $t_{INTBL}$ | INT4~INT7 Low level Pulse width  | $8X + 100$ |     | 600   |     | 500   |     | ns   |
| $t_{INTBH}$ | INT4~INT7 High level Pulse width | $8X + 100$ |     | 600   |     | 500   |     | ns   |

## 4.8 Timing Chart for I/O Interface Mode



## 4.9 Timing Chart for Bus Request (BUSRQ) / Bus Acknowledge (BUSAK)



| Symbol            | Parameter                                            | Variable |     | 16MHz      |     | 20MHz |     | Unit   |
|-------------------|------------------------------------------------------|----------|-----|------------|-----|-------|-----|--------|
|                   |                                                      | Min      | Max | Min        | Max | Min   | Max |        |
| t <sub>BRC</sub>  | BUSRQ set-up time for CLK                            | 120      |     | 120        |     | 120   |     | ns     |
| t <sub>CBAL</sub> | CLK → BUSAK falling edge                             |          |     | 1.5x + 120 |     | 245   |     | 220 ns |
| t <sub>BAH</sub>  | CLK → BUSAK rising edge                              |          |     | 0.5x + 40  |     | 71    |     | 65 ns  |
| t <sub>ABA</sub>  | Output Buffer is off to BUSAK → Output Buffer is on. | 0        | 80  | 0          | 80  | 0     | 80  | ns     |
| t <sub>BAA</sub>  | BUSAK → Output Buffer is off.                        | 0        | 80  | 0          | 80  | 0     | 80  | ns     |

(Note 1) : The Bus will be released after the WAIT request is inactive, when the BUSRQ is set to "0" during "Wait" cycle.

(Note 2) : The internal programmable pull-down resistor is added.

(Note 3) : The internal programmable pull-up resistor is added.

But the CS2/CAS2 pin does not have the internal programmable pull-up resistor. And in the condition of bus release, this pin is added the internal pull-up resistor.

## 5. TMP96C141/TMP96C141A/TMP96C041A Different points

TMP96C141/TMP96C141A/TMP96C041A have much the same function but they are different from following points.

| Parameter                                        | TMP96C141                                                                                                    | TMP96C141A                                                                                             | TMP96C041A                   |
|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|------------------------------|
| Internal RAM                                     | 1K byte                                                                                                      | 1K byte                                                                                                | not exist                    |
| Pin condition at bus release                     | TMP96C141<br>see Figure 3.5 (1)                                                                              | TMP96C141A<br>see Figure 3.3                                                                           | TMP96C041A<br>see Figure 3.3 |
| Mapping area of CS1 default setting (B1C1:0: 00) | 480H~7FFFH                                                                                                   | 480H~7FFFH                                                                                             | 80H~7FFFH                    |
| P92, $\overline{CTS0}$ , SCLK0                   | TMP96C141 does not have the SCLK0 function.<br><br>[ Serial channel 0 does not have the I/O interface mode.] | TMP96C141A/TMP96C041A have the SCLK0 function.<br><br>[ Serial channel 0 have the I/O interface mode.] |                              |

## CMOS 16-bit MICROCONTROLLERS

## TMP96C041AF

## 1. OUTLINE AND DEVICE CHARACTERISTICS

TMP96C041AF is high-speed advanced 16-bit microcontrollers developed for controlling medium to large-scale equipment. The TMP96C041A has the improved bus release function, serial interface and RAMless for TMP96C141F. Otherwise, the devices function in the same way.

TMP96C041AF is housed in an 80-pin flat package, and is pin-compatible with TMP96C141F except the P92 (CTS0/SCLK0).

Device characteristics are as follows:

- (1) Original 16-bit CPU
  - TLCS-90 instruction mnemonic upward compatible.
  - 16M-byte linear address space
  - General-purpose registers and register bank system
  - 16-bit multiplication / division and bit transfer/arithmetic instructions
  - High-speed micro DMA : 4 channels (1.6  $\mu$ s/2 bytes @20MHz)
- (2) Minimum instruction execution time : 200ns @20MHz
- (3) Internal RAM : None  
Internal ROM : None
- (4) External memory expansion
  - Can be expanded up to 16M bytes (for both programs and data).
  - Can mix 8- and 16-bit external data buses.
- (5) 8-bit timers : 2 channels
- (6) 8-bit PWM timers : 2 channels
- (7) 16-bit timers : 2 channels
- (8) Pattern generators : 4 bits, 2 channels
- (9) Serial interface : 2 channels
- (10) 10-bit A/D converter : 4 channels
- (11) Watchdog timer
- (12) Chip select/wait controller : 3 blocks
- (13) Interrupt functions
  - 3 CPU interrupts..... SWI instruction, privileged violation, and Illegal instruction
  - 14 internal interrupts
  - 6 external interrupts ] 7-level priority can be set.
- (14) I/O ports  
47 pins
- (15) Standby function : 3 halt modes (RUN, IDLE, STOP)





Figure1 TMP96C041A Block Diagram

## 2. PIN ASSIGNMENT AND FUNCTIONS

The assignment of input / output pins for TMP96C041A, their name and outline functions are described below.

### 2.1 Pin Assignment

Figure 2.1 shows pin assignment of TMP96C041AF.



Note : Because the TMP96C041A has an external ROM, P00 to P17 pins are fixed to AD0 to AD15; P30 to RD; and P31 to WR.

Figure 2.1 Pin Assignment (80-pin QFP)

## 2.2 Pin Names and Functions

The names of input/output pins and their functions are described below.

Table 2.2 Pin Names and Functions.

| Pin name                         | Number of pins | I/O                        | Functions                                                                                                                                                                                                                         |
|----------------------------------|----------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P00~P07<br>AD0~AD7               | 8              | I/O<br>Tri-state           | Port 0: I/O port that allows I/O to be selected on a bit basis<br>Address/data (lower): 0 - 7 for address/data bus                                                                                                                |
| P10~P17<br>AD8~AD15<br>A8~A15    | 8              | I/O<br>Tri-state<br>Output | Port 1: I/O port that allows I/O to be selected on a bit basis<br>Address data (upper): 8 - 15 for address/data bus<br>Address: 8 to 15 for address bus                                                                           |
| P20~P27<br>A0~A7<br>A16~A23      | 8              | I/O<br>Output<br>Output    | Port 2: I/O port that allows selection of I/O on a bit basis<br>(with pull-down resistor)<br>Address: 0 - 7 for address bus<br>Address: 16 - 23 for address bus                                                                   |
| P30<br><u>RD</u>                 | 1              | Output<br>Output           | Port 30: Output port<br>Read: Strobe signal for reading external memory                                                                                                                                                           |
| P31<br><u>WR</u>                 | 1              | Output<br>Output           | Port 31: Output port<br>Write: Strobe signal for writing data on pins AD0 - 7                                                                                                                                                     |
| P32<br><u>HWR</u>                | 1              | I/O<br>Output              | Port 32: I/O port (with pull-up resistor)<br>High write: Strobe signal for writing data on pins AD8 - 15                                                                                                                          |
| P33<br><u>WAIT</u>               | 1              | I/O<br>Input               | Port 33: I/O port (with pull-up resistor)<br>Wait: Pin used to request CPU bus wait                                                                                                                                               |
| P34<br><u>BUSRQ</u>              | 1              | I/O<br>Input               | Port 34: I/O port (with pull-up resistor)<br>Bus request: Signal used to request high impedance for AD0 - 15,<br>A0 - 23, RD, WR, HWR, R/W, RAS, CS0, CS1, and CS2 pins.<br>(For external DMAC)                                   |
| P35<br><u>BUSAK</u>              | 1              | I/O<br>Output              | Port 35: I/O port (with pull-up resistor)<br>Bus acknowledge: Signal indicating that AD0-15, A0-23, RD,<br>WR, HWR, R/W, RAS, CS0, CS1, and CS2 pins are at high impedance<br>after receiving BUSRQ. (For external DMAC)          |
| P36<br><u>R/W</u>                | 1              | I/O<br>Output              | Port 36: I/O port (with pull-up resistor)<br>Read/write: 1 represents read or dummy cycle; 0, write cycle.                                                                                                                        |
| P37<br><u>RAS</u>                | 1              | I/O<br>Output              | Port 37: I/O port (with pull-up resistor)<br>Row address strobe: Outputs RAS strobe for DRAM.                                                                                                                                     |
| P40<br><u>CS0</u><br><u>CAS0</u> | 1              | I/O<br>Output<br>Output    | Port 40: I/O port (with pull-up resistor)<br>Chip select 0: Outputs 0 when address is within specified address<br>area.<br>Column address strobe 0: Outputs CAS strobe for DRAM when<br>address is within specified address area. |

Note : With the external DMA controller, this device's built-in memory or built-in I/O cannot be accessed using the BUSRQ and BUSAK pins.

| Pin name             | Number of pins | I/O                     | Functions                                                                                                                                                                                                                         |
|----------------------|----------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P41<br>CS1<br>CAS1   | 1              | I/O<br>Output<br>Output | Port 41: I/O port (with pull-up resistor)<br>Chip select 1: Outputs 0 if address is within specified address area.<br>Column address strobe 1: Outputs CAS strobe for DRAM if address is within specified address area.           |
| P42<br>CS2<br>CAS2   | 1              | I/O<br>Output<br>Output | Port 42: I/O port (with pull-down resistor) (Note1)<br>Chip select 2: Outputs 0 if address is within specified address area.<br>Column address strobe 2: Outputs CAS strobe for DRAM if address is within specified address area. |
| P50~P53<br>AN0~AN3   | 4              | Input<br>Input          | Port 5: Input port<br>Analog input: Input to A/D converter                                                                                                                                                                        |
| VREF                 | 1              | Input                   | Pin for reference voltage input to A/D converter                                                                                                                                                                                  |
| AGND                 | 1              | Input                   | Ground pin for A/D converter                                                                                                                                                                                                      |
| P60~P63<br>PG00~PG03 | 4              | I/O<br>Output           | Ports 60 - 63: I/O ports that allow selection of I/O on a bit basis (with pull-up resistor)<br>Pattern generator ports: 00 - 03                                                                                                   |
| P64~P67<br>PG10~PG13 | 4              | I/O<br>Output           | Ports 64 - 67: I/O ports that allow selection of I/O on a bit basis (with pull-up resistor)<br>Pattern generator ports: 10 - 13                                                                                                   |
| P70<br>TI0           | 1              | I/O<br>Input            | Port 70: I/O port (with pull-up resistor)<br>Timer input 0: Timer 0 input                                                                                                                                                         |
| P71<br>TO1           | 1              | I/O<br>Output           | Port 71: I/O port (with pull-up resistor)<br>Timer output 1: Timer 0 or 1 output                                                                                                                                                  |
| P72<br>TO2           | 1              | I/O<br>Output           | Port 72: I/O port (with pull-up resistor)<br>PWM output 2: 8-bit PWM timer 2 output                                                                                                                                               |
| P73<br>TO3           | 1              | I/O<br>Output           | Port 73: I/O port (with pull-up resistor)<br>PWM output 3: 8-bit PWM timer 3 output                                                                                                                                               |
| P80<br>TI4<br>INT4   | 1              | Input<br>Input          | Port 80: I/O port (with pull-up resistor)<br>Timer input 4: Timer 4 count/capture trigger signal input<br>Interrupt request pin 4: Interrupt request pin with programmable rising/falling edge                                    |
| P81<br>TI5<br>INT5   | 1              | I/O<br>Input<br>Input   | Port 81: I/O port (with pull-up resistor)<br>Timer input 5: Timer 4 count/capture trigger signal input<br>Interrupt request pin 5: Interrupt request pin with rising edge                                                         |
| P82<br>TO4           | 1              | I/O<br>Output           | Port 82: I/O port (with pull-up resistor)<br>Timer output 4: Timer 4 output pin                                                                                                                                                   |
| P83<br>TO5           | 1              | I/O<br>Output           | Port 83: I/O port (with pull-up resistor)<br>Timer output 5: Timer 4 output pin                                                                                                                                                   |

Note 1 : Case of the settable CS2 or CAS2; when TMP96C041AF is bus release, this pin is not added the internal pull-down resistor but is added the internal pull-up resistor.

| Pin name                    | Number of pins | I/O                   | Functions                                                                                                                                                                                      |
|-----------------------------|----------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P84<br>TI6<br>INT6          | 1              | I/O<br>Input<br>Input | Port 84: I/O port (with pull-up resistor)<br>Timer input 6: Timer 5 count/capture trigger signal input<br>Interrupt request pin 6: Interrupt request pin with programmable rising/falling edge |
| P85<br>TI7<br>INT7          | 1              | I/O<br>Input<br>Input | Port 85: I/O port (with pull-up resistor)<br>Timer input 7: Timer 5 count/capture trigger signal input<br>Interrupt request pin 7: Interrupt request pin with rising edge                      |
| P86<br>TO6                  | 1              | I/O<br>Output         | Port 86: I/O port (with pull-up resistor)<br>Timer output 6: Timer 5 output pin                                                                                                                |
| P87<br>INT0                 | 1              | I/O<br>Input          | Port 87: I/O port (with pull-up resistor)<br>Interrupt request pin 0: Interrupt request pin with programmable level/rising edge                                                                |
| P90<br>TXD0                 | 1              | I/O<br>Output         | Port 90: I/O port (with pull-up resistor)<br>Serial send data 0                                                                                                                                |
| P91<br>RXD0                 | 1              | I/O<br>Input          | Port 91: I/O port (with pull-up resistor)<br>Serial receive data 0                                                                                                                             |
| P92<br><u>CTS0</u><br>SCLK0 | 1              | I/O<br>Input          | Port 92: I/O port (with pull-up resistor)<br>Serial data send enable 0 (Clear to Send)<br>Serial clock I/O 0                                                                                   |
| P93<br>TXD1                 | 1              | I/O<br>Output         | Port 93: I/O port (with pull-up resistor)<br>Serial send data 1                                                                                                                                |
| P94<br>RXD1                 | 1              | I/O<br>Input          | Port 94: I/O port (with pull-up resistor)<br>Serial receive data 1                                                                                                                             |
| P95<br>SCLK1                | 1              | I/O<br>I/O            | Port 95: I/O port (with pull-up resistor)<br>Serial clock I/O 1                                                                                                                                |
| WDTOUT                      | 1              | Output                | Watchdog timer output pin                                                                                                                                                                      |
| NMI                         | 1              | Input                 | Non-maskable interrupt request pin: Interrupt request pin with falling edge. Can also be operated at rising edge by program.                                                                   |
| CLK                         | 1              | Output                | Clock output: Outputs $\lceil X1 \div 4 \rceil$ clock. Pulled-up during reset.                                                                                                                 |
| EA                          | 1              | Input                 | External access: 0 should be inputted with TMP96C041A.                                                                                                                                         |
| ALE                         | 1              | Output                | Address latch enable                                                                                                                                                                           |
| RESET                       | 1              | Input                 | Reset: initializes LSI. (With pull-up resistor)                                                                                                                                                |
| X1/X2                       | 2              | I/O                   | Oscillator connecting pin                                                                                                                                                                      |
| VCC                         | 2              |                       | Power supply pin (+ 5V)                                                                                                                                                                        |
| VSS                         | 3              |                       | GND pin (0V)                                                                                                                                                                                   |

Note : Pull-up/pull-down resistor can be released from the pin by software (except the RESET pin).

### 3. OPERATION

This section describes the functions and basic operations of TMP96C041A device.

Check the 「7. Care Points and Restriction」 because of the Care described.

Regarding the functions of TMP96C041A (not described), see the part of TMP96C141.

#### 3.1 CPU

TMP96C041A device has a built-in high-performance 16-bit CPU (900-CPU). (For CPU operation, see TLCS-900 CPU in the previous section.)

#### 3.2 Memory Map

TMP96C041A has two register modes. One is a minimum mode; in this mode, the area of program memory is 64K bytes maximum. The other is a maximum mode; in this mode, the area of program memory is 16M bytes maximum.

Both minimum and maximum modes are the data memory area of 16M bytes maximum.

That is, the program memory can locate 0H~FFFFH in minimum mode and can locate 0H ~ FFFFFFFH in maximum mode.

##### (1) Internal I/O devices

TMP96C041A uses the address space of 128 bytes for the internal I/O devices area. This area is located to 0H~7FH.

The CPU can access the internal I/O devices area with using the short instruction code of direct addressing mode.

Check the access area of each addressing mode and the memory map in Fig. 3.2 (1).



## Memory Map

Figure 3.2 (1) is a memory map of the TMP96C041A.



Note : The start address after reset is 8000H. Resetting sets the stack pointer (XSP) on the system mode side to 100H.

Figure 3.2 (1) Memory map

(2) CS1 area (Chip select / wait controller)

TMP96C041A is expanded the part of address area for CS1 (only B1C1.0 = "00").  
Show the address area of CS1 in Fig 3.2 (2).

Fig.3.2 (2) CS1 address area

### 3.3 Bus release function

TMP96C041A has the internal pull-up and pull-down resistors to fix the bus control singnals at bus release.

Show the table 3.3 of pin condition at bus release ( $\overline{\text{BUSAK}} = 0$ ).

Table 3.3 The condition of pins at the bus release ( $\overline{\text{BUSAK}} = \text{"L"}$ )

| pin name                                          | the status of pins at bus release                     |                                                                                                                                                                     |
|---------------------------------------------------|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                   | port mode                                             | function mode                                                                                                                                                       |
| P00-P07<br>(AD0-AD7)<br>P10-P17<br>(AD8-15/A8-15) | the status is no-change.<br>(these pins are not "Hz") | these pins are "Hz".                                                                                                                                                |
| P30 (RD)<br>P31 (WR)                              | ↑                                                     | these pins are "Hz".<br>("Hz" status after these pins drived high level)                                                                                            |
| P32 (HWR)<br>P37 (RA\$)                           | ↑                                                     | The output buffer is "OFF" after these pins drived high.<br>These pins are added the internal resistor of pull-up. It's no relation for the value of output latch.  |
| P36 (R/\$V)<br>P40 (CS0/CAS0)<br>P41 (CS1/CAS1)   | ↑                                                     | ↑                                                                                                                                                                   |
| P42 (CS2/CAS2)                                    | ↑                                                     | (*) ↑                                                                                                                                                               |
| P20-P27<br>(A16-23)                               | ↑                                                     | The output buffer is "OFF" after these pins drived low.<br>These pins are added the internal resistor of pull-down. It's no relation for the value of output latch. |

 : the difference with TMP96C141

That is, when it is used for bus release ( $\overline{\text{BUSAK}} = 0$ ), the pins of below need pull-up or pull-down resistor for an external circuit.

P00-P07 (AD0-AD7)  
P10-P17 (AD8-AD15)  
P30 (RD)  
P31 (WR)

(\*) P42 has the resistor of programmable pull-down, but when the bus are released, P42 pin is added a resistor of pull-up.

Case of the bus release function; show a sample of external bus interface in the Fig.3.3 (1).

When the bus is released, both internal memory and internal I/O can not be accessed. But the internal I/O continues to run. So, the watchdog timer also continues to run. Therefore, be care about bus releasing time and set the detection time of WDT.



Fig.3.3 (1) Example of the interface circuit (The case of using bus releasing function)

### 3.4 Serial function

TMP96C041A has two Serial I/O devices. Both channel 0 and channel 1 are same function except the handshake ( $\overline{CTS0}$  pin) function of the channel 0 and can use I/O interface mode.

Show the part of TMP96C141 in detail.

## 4. ELECTRICAL CHARACTERISTICS (PRELIMINARY)

### 4.1 Absolute Maximum (TMP96C041AF)

| Symbol              | Parameter                     | Rating                    | Unit |
|---------------------|-------------------------------|---------------------------|------|
| V <sub>CC</sub>     | Power Supply Voltage          | -0.5~6.5                  | V    |
| V <sub>IN</sub>     | Input Voltage                 | -0.5~V <sub>CC</sub> +0.5 | V    |
| $\Sigma I_{OL}$     | Output Current (total)        | 100                       | mA   |
| $\Sigma I_{OH}$     | Output Current (total)        | -100                      | mA   |
| P <sub>D</sub>      | Power Dissipation (Ta = 85°C) | 500                       | mW   |
| T <sub>SOLDER</sub> | Soldering Temperature (10 s)  | 260                       | °C   |
| T <sub>STG</sub>    | Storage Temperature           | -65~150                   | °C   |
| T <sub>OPR</sub>    | Operating Temperature         | -40~85                    | °C   |

### 4.2 DC Characteristics (TMP96C041AF)

V<sub>CC</sub> = 5V ± 10%, TA = -40~85°C (4~16MHz) TA = -20~70°C (4~20MHz)

(Typical values are for Ta = 25°C and V<sub>CC</sub> = 5V)

| Symbol            | Parameter                                                                     | Min                                 | Max                   | Unit                 | Test Condition                                                                   |
|-------------------|-------------------------------------------------------------------------------|-------------------------------------|-----------------------|----------------------|----------------------------------------------------------------------------------|
| V <sub>IL</sub>   | Input Low Voltage (AD0~15)<br>P2, P3, P4, P5, P6, P7, P8, P9                  | -0.3                                | 0.8                   | V                    |                                                                                  |
| V <sub>IL1</sub>  | RESET, NMI, INT0 (P87)                                                        | -0.3                                | 0.3V <sub>CC</sub>    | V                    |                                                                                  |
| V <sub>IL2</sub>  | EA                                                                            | -0.3                                | 0.25V <sub>CC</sub>   | V                    |                                                                                  |
| V <sub>IL3</sub>  | X1                                                                            | -0.3                                | 0.3                   | V                    |                                                                                  |
| V <sub>IL4</sub>  |                                                                               | -0.3                                | 0.2V <sub>CC</sub>    | V                    |                                                                                  |
| V <sub>IH</sub>   | Input High Voltage (AD0~15)<br>P2, P3, P4, P5, P6, P7, P8, P9                 | 2.2                                 | V <sub>CC</sub> + 0.3 | V                    |                                                                                  |
| V <sub>IH1</sub>  | RESET, NMI, INT0 (P87)                                                        | 0.7V <sub>CC</sub>                  | V <sub>CC</sub> + 0.3 | V                    |                                                                                  |
| V <sub>IH2</sub>  | EA                                                                            | 0.75V <sub>CC</sub>                 | V <sub>CC</sub> + 0.3 | V                    |                                                                                  |
| V <sub>IH3</sub>  | X1                                                                            | V <sub>CC</sub> - 0.3               | V <sub>CC</sub> + 0.3 | V                    |                                                                                  |
| V <sub>IH4</sub>  |                                                                               | 0.8V <sub>CC</sub>                  | V <sub>CC</sub> + 0.3 | V                    |                                                                                  |
| V <sub>OL</sub>   | Output Low Voltage                                                            |                                     | 0.45                  | V                    | I <sub>OL</sub> = 1.6mA                                                          |
| V <sub>OH</sub>   | Output High Voltage                                                           | 2.4                                 |                       | V                    |                                                                                  |
| V <sub>OH1</sub>  |                                                                               | 0.75V <sub>CC</sub>                 |                       | V                    | I <sub>OH</sub> = -400μA                                                         |
| V <sub>OH2</sub>  |                                                                               | 0.9V <sub>CC</sub>                  |                       | V                    | I <sub>OH</sub> = -100μA                                                         |
| V <sub>OH3</sub>  |                                                                               |                                     |                       | V                    | I <sub>OH</sub> = -20μA                                                          |
| I <sub>DAR</sub>  | Darlington Drive Current<br>(8 Output Pins max.)                              | -1.0                                | -3.5                  | mA                   | V <sub>EXT</sub> = 1.5V<br>R <sub>EXT</sub> = 1.1kΩ                              |
| I <sub>LI</sub>   | Input Leakage Current                                                         | TBD (Typ)                           | ±5                    | μA                   | 0.0 ≤ V <sub>IN</sub> ≤ V <sub>CC</sub>                                          |
| I <sub>LO</sub>   | Output Leakage Current                                                        | TBD (Typ)                           | ±10                   | μA                   | 0.2 ≤ V <sub>IN</sub> ≤ V <sub>CC</sub> - 0.2                                    |
| I <sub>CC</sub>   | Operating Current (RUN)<br>IDLE<br>STOP (Ta = -20~70°C)<br>STOP (Ta = 0~50°C) | TBD (Typ)<br>TBD (Typ)<br>TBD (Typ) | TBD<br>10<br>50<br>10 | mA<br>mA<br>μA<br>μA | t <sub>osc</sub> = 20MHz                                                         |
| V <sub>STOP</sub> | Power Down Voltage<br>(@STOP, RAM Back up)                                    | 2.0                                 | 6.0                   | V                    | V <sub>IL2</sub> = 0.2V <sub>CC</sub> ,<br>V <sub>IH2</sub> = 0.8V <sub>CC</sub> |
| R <sub>RST</sub>  | RESET Pull Up Register                                                        | 50                                  | 150                   | kΩ                   |                                                                                  |
| C <sub>IO</sub>   | Pin Capacitance                                                               |                                     | 10                    | pF                   | t <sub>osc</sub> = 1MHz                                                          |
| V <sub>TH</sub>   | Schmitt Width<br>RESET, NMI, INT0 (P87)                                       | 0.4                                 | TBD (Typ)             | V                    |                                                                                  |
| R <sub>K</sub>    | Pull Down/Up Register                                                         | 50                                  | 150                   | kΩ                   |                                                                                  |

Note : I-DAR is guaranteed for a total of up to 8 ports.

#### 4.3 AC Electrical Characteristics (TMP96C041AF)

V<sub>CC</sub> = 5V ± 10%, TA = -40~85°C (4~16MHz) TA = -20~70°C (4~20MHz)

| No. | Symbol | Parameter                 | Variavle                                  |     | 16MHz      |     | 20MHz |     | Unit   |
|-----|--------|---------------------------|-------------------------------------------|-----|------------|-----|-------|-----|--------|
|     |        |                           | Min                                       | Max | Min        | Max | Min   | Max |        |
| 1   | tosc   | Osc. Period (= x)         | 50                                        | 250 | 62.5       |     | 50    |     | ns     |
| 2   | tCLK   | CLK width                 | 2x - 40                                   |     | 85         |     | 60    |     | ns     |
| 3   | tAK    | A0-23 Valid → CLK Hold    | 0.5x - 20                                 |     | 11         |     | 5     |     | ns     |
| 4   | tKA    | CLK Valid → A0-23 Hold    | 1.5x - 70                                 |     | 24         |     | 5     |     | ns     |
| 5   | tAL    | A0-15 Valid → ALE fall    | 0.5x - 15                                 |     | 16         |     | 10    |     | ns     |
| 6   | tLA    | ALE fall → A0-15 Hold     | 0.5x - 15                                 |     | 16         |     | 10    |     | ns     |
| 7   | tLL    | ALE High width            | x - 40                                    |     | 23         |     | 10    |     | ns     |
| 8   | tLC    | ALE fall → RD/WR fall     | 0.5x - 30                                 |     | 1          |     | -5    |     | ns     |
| 9   | tCL    | RD/WR rise → ALE rise     | 0.5x - 20                                 |     | 11         |     | 5     |     | ns     |
| 10  | tACL   | A0-15 Valid → RD/WR fall  | x - 25                                    |     | 38         |     | 25    |     | ns     |
| 11  | tACH   | A0-23 Valid → RD/WR fall  | 1.5x - 50                                 |     | 44         |     | 25    |     | ns     |
| 12  | tCA    | RD/WR rise → A0-23 Hold   | 0.5x - 20                                 |     | 11         |     | 5     |     | ns     |
| 13  | tADL   | A0-15 Valid → D0-15 input |                                           |     | 3.0x - 45  |     | 143   |     | 105 ns |
| 14  | tADH   | A0-23 Valid → D0-15 input |                                           |     | 3.5x - 65  |     | 154   |     | 110 ns |
| 15  | tRD    | RDfall → D0-15 input      |                                           |     | 2.0x - 50  |     | 75    |     | 50 ns  |
| 16  | tRR    | RD Low width              | 2.0x - 40                                 |     | 85         |     | 60    |     | ns     |
| 17  | tHR    | RDrise → D0-15 Hold       | 0                                         |     | 0          |     | 0     |     | ns     |
| 18  | tRAE   | RDrise → A0-15output      | x - 15                                    |     | 48         |     | 35    |     | ns     |
| 19  | tWV    | WR Low width              | 2.0x - 40                                 |     | 85         |     | 60    |     | ns     |
| 20  | tDW    | D0-15 Valid → WR rise     | 2.0x - 50                                 |     | 75         |     | 50    |     | ns     |
| 21  | tWD    | WR rise → D0-15 Hold      | 0.5x - 10                                 |     | 21         |     | 15    |     | ns     |
| 22  | tAEH   | A0-23 Valid → WAIT input  | ( $\frac{1}{2} + \frac{1}{2}$ )<br>x - 15 |     | 3.5x - 90  |     | 129   |     | 85 ns  |
| 23  | tAWL   | A0-15 Valid → WAIT input  | ( $\frac{1}{2} + \frac{1}{2}$ )<br>x - 15 |     | 3.0x - 80  |     | 108   |     | 70 ns  |
| 24  | tCW    | RD/WR fall → WAIT Hold    | ( $\frac{1}{2} + \frac{1}{2}$ )<br>x - 15 |     | 2.0x + 0   |     | 125   |     | 100 ns |
| 25  | tAPH   | A0-23 Valid → PORT input  |                                           |     | 2.5x - 120 |     | 36    |     | 5 ns   |
| 26  | tAPH2  | A0-23 Valid → PORT Hold   | 2.5x + 50                                 |     |            | 206 |       | 175 |        |
| 27  | tCP    | WR rise → PORT Valid      |                                           |     | 200        |     | 200   |     | 200 ns |
| 28  | tASRH  | A0-23 Valid → RAS fall    | 1.0x - 40                                 |     |            | 23  |       | 10  |        |
| 29  | tASRL  | A0-15 Valid → RAS fall    | 0.5x - 15                                 |     |            | 16  |       | 10  |        |
| 30  | tRAC   | RAS fall → D0-15 input    |                                           |     | 2.5x - 70  |     | 86    |     | 55 ns  |
| 31  | tRAH   | RAS fall → A0-15 Hold     | 0.5x - 15                                 |     |            | 16  |       | 10  |        |
| 32  | tRAS   | RAS Low width             | 2.0x - 40                                 |     |            | 85  |       | 60  |        |
| 33  | tRP    | RAS High width            | 2.0x - 40                                 |     |            | 85  |       | 60  |        |
| 34  | tRSH   | CAS fall → RAS rise       | 1.0x - 35                                 |     |            | 28  |       | 15  |        |
| 35  | tRSC   | RAS rise → CAS rise       | 0.5x - 25                                 |     |            | 6   |       | 0   |        |
| 36  | tRCD   | RAS fall → CAS fall       | 1.0x - 40                                 |     |            | 23  |       | 10  |        |
| 37  | tCAC   | CAS fall → D0-15 input    |                                           |     | 1.5x - 65  |     | 29    |     | 10 ns  |
| 38  | tCAS   | CAS Low width             | 1.5x - 30                                 |     |            | 64  |       | 40  |        |
| 39  | tDS    | D0-15 Valid → CAS fall    | 0.5x - 15                                 |     |            | 16  |       | 10  |        |

## AC Measuring Conditions

- Output Level : High 2.2V /Low 0.8V , CL50pF  
(However CL = 100pF for AD0~AD15, AD0~AD23, ALE, RD, WR, HWR, R/W, CLK, RAS, CAS0~CAS2)
  - Input Level : High 2.4V /Low 0.45V (AD0~AD15)  
High 0.8Vcc /Low 0.2Vcc (Except for AD0~AD15)

## (1) Read Cycle



## (2) Write Cycle



## 4.4 A/D Conversion Characteristics (TMP96C041AF)

 $V_{CC} = 5V \pm 10\%$ ,  $TA = -40 \sim 85^\circ C$  (4~16MHz)  $TA = -20 \sim 70^\circ C$  (4~20MHz)

| Symbol                                                              | Parameter                                   |                  | Min            | Typ | Max       | Unit |
|---------------------------------------------------------------------|---------------------------------------------|------------------|----------------|-----|-----------|------|
| $V_{REF}$                                                           | Analog reference voltage                    |                  | $V_{CC} - 1.5$ |     | $V_{CC}$  |      |
| $A_{GND}$                                                           | Analog reference voltage                    |                  | $V_{SS}$       |     | $V_{SS}$  |      |
| $V_{AIN}$                                                           | Analog input voltage range                  |                  | $V_{SS}$       |     | $V_{CC}$  |      |
| $I_{REF}$                                                           | Analog current for analog reference voltage |                  |                | TBD | 1.5       | mA   |
| Total error<br>(Quantize error<br>of $\pm 0.5$ LSB not<br>included) | 4 $\leq f_C \leq$ 16MHz                     | Low change mode  |                | TBD | $\pm 4.0$ | LSB  |
|                                                                     |                                             | High change mode |                | TBD | $\pm 6.0$ |      |
|                                                                     | 16 $< f_C \leq$ 20MHz                       | Low change mode  |                | TBD | $\pm 4.0$ |      |
|                                                                     |                                             | High change mode |                | TBD | $\pm 8.0$ |      |

## 4.5 Serial Channel Timing – I/O Interface Mode

## (1) SCLK Input Mode

 $V_{CC} = 5V \pm 10\%$ ,  $TA = -40 \sim 85^\circ C$  (4~16MHz)  $TA = -20 \sim 70^\circ C$  (4~20MHz)

| Symbol    | Parameter                               | Variable              |                      | 16MHz |     | 20MHz |     | Unit    |
|-----------|-----------------------------------------|-----------------------|----------------------|-------|-----|-------|-----|---------|
|           |                                         | Min                   | Max                  | Min   | Max | Min   | Max |         |
| $t_{SCY}$ | SCLK cycle                              | 16X                   |                      | 1     |     | 0.8   |     | $\mu s$ |
| $t_{OSS}$ | Output Data → Rising edge of SCLK       | $t_{SCY}/2 - 5X - 50$ |                      | 137   |     | 100   |     | ns      |
| $t_{OHS}$ | SCLK rising edge → Output Data hold     | 5X - 100              |                      | 212   |     | 150   |     | ns      |
| $t_{HSR}$ | SCLK rising edge → Input Data hold      | 0                     |                      | 0     |     | 0     |     | ns      |
| $t_{SRD}$ | SCLK rising edge → effective data input |                       | $t_{SCY} - 5X - 100$ | 587   |     | 450   |     | ns      |

## (2) SCLK Output Mode

 $V_{CC} = 5V \pm 10\%$ ,  $TA = -40 \sim 85^\circ C$  (4~16MHz)  $TA = -20 \sim 70^\circ C$  (4~20MHz)

| Symbol    | Parameter                               | Variable             |                      | 16MHz |     | 20MHz |       | Unit    |
|-----------|-----------------------------------------|----------------------|----------------------|-------|-----|-------|-------|---------|
|           |                                         | Min                  | Max                  | Min   | Max | Min   | Max   |         |
| $t_{SCY}$ | SCLK cycle (programmable)               | 16X                  | 8192X                | 1     | 512 | 0.8   | 409.6 | $\mu s$ |
| $t_{OSS}$ | Output Data → SCLK rising edge          | $t_{SCY} - 2X - 150$ |                      | 725   |     | 550   |       | ns      |
| $t_{OHS}$ | SCLK rising edge → Output Data hold     | 2X - 80              |                      | 45    |     | 20    |       | ns      |
| $t_{HSR}$ | SCLK rising edge → Input Data hold      | 0                    |                      | 0     |     | 0     |       | ns      |
| $t_{SRD}$ | SCLK rising edge → effective data input |                      | $t_{SCY} - 2X - 150$ | 725   |     | 550   |       | ns      |

## 4.6 Timer/Counter Input Clock (T10, T14, T15, T16, T17)

 $V_{CC} = 5V \pm 10\%$ ,  $TA = -40 \sim 85^\circ C$  (4~16MHz)  $TA = -20 \sim 70^\circ C$  (4~20MHz)

| Symbol     | Parameter                    | Variable |     | 16MHz |     | 20MHz |     | Unit |
|------------|------------------------------|----------|-----|-------|-----|-------|-----|------|
|            |                              | Min      | Max | Min   | Max | Min   | Max |      |
| $t_{VCK}$  | Clock Cycle                  | 8X + 100 |     | 600   |     | 500   |     | ns   |
| $t_{VCKL}$ | Low level clock Pulse width  | 4X + 40  |     | 290   |     | 240   |     | ns   |
| $t_{VCKH}$ | High level clock Pulse width | 4X + 40  |     | 290   |     | 240   |     | ns   |

## 4.7 Interrupt Operation

 $V_{CC} = 5V \pm 10\%$ ,  $TA = -40 \sim 85^\circ C$  (4~16MHz)  $TA = -20 \sim 70^\circ C$  (4~20MHz)

| Symbol      | Parameter                        | Variable |     | 16MHz |     | 20MHz |     | Unit |
|-------------|----------------------------------|----------|-----|-------|-----|-------|-----|------|
|             |                                  | Min      | Max | Min   | Max | Min   | Max |      |
| $t_{INTAL}$ | NMI, INT0 Low level Pulse width  | 4X       |     | 250   |     | 200   |     | ns   |
| $t_{INTAH}$ | NMI, INT0 High level Pulse width | 4X       |     | 250   |     | 200   |     | ns   |
| $t_{INTBL}$ | INT4~INT7 Low level Pulse width  | 8X + 100 |     | 600   |     | 500   |     | ns   |
| $t_{INTBH}$ | INT4~INT7 High level Pulse width | 8X + 100 |     | 600   |     | 500   |     | ns   |

## 4.8 Timing Chart for I/O Interface Mode



## 4.9 Timing Chart for Bus Request (BUSRQ) / Bus Acknowledge (BUSAk)



| Symbol            | Parameter                     | Variable |            | 16MHz |     | 20MHz |     | Unit |
|-------------------|-------------------------------|----------|------------|-------|-----|-------|-----|------|
|                   |                               | Min      | Max        | Min   | Max | Min   | Max |      |
| t <sub>BRC</sub>  | BUSRQ set-up time for CLK     | 120      |            | 120   |     | 120   |     | ns   |
| t <sub>CBAL</sub> | CLK → BUSAK falling edge      |          | 1.5x + 120 |       | 245 |       | 220 | ns   |
| t <sub>CBAH</sub> | CLK → BUSAK rising edge       |          | 0.5x + 40  |       | 71  |       | 65  | ns   |
| t <sub>ABA</sub>  | Output Buffer is off to BUSAK | 0        | 80         | 0     | 80  | 0     | 80  | ns   |
| t <sub>BAA</sub>  | BUSAk to Output Buffer is on  | 0        | 80         | 0     | 80  | 0     | 80  | ns   |

(Note 1): The Bus will be released after the WAIT request is inactive, when the BUSRQ is set to "0" during "Wait" cycle.

(Note 2): The internal programmable pull-down resistor is added.

(Note 3): The internal programmable pull-up resistor is added.

But the CS2/CAS2 pin does not have the internal programmable pull-up resistor. And in the condition of bus release, this pin is added the internal pull-up resistor.

## 5. TMP96C141/TMP96C141A/TMP96C041A Different points

TMP96C141/TMP96C141A/TMP96C041A have much the same function but they are different from following points.

| Parameter                                        | TMP96C141                                                                                               | TMP96C141A                                                                                        | TMP96C041A                   |
|--------------------------------------------------|---------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|------------------------------|
| Internal RAM                                     | 1K byte                                                                                                 | 1K byte                                                                                           | not exist                    |
| Pin condition at bus release                     | TMP96C141<br>see Figure 3.5 (1)                                                                         | TMP96C141A<br>see Figure 3.3                                                                      | TMP96C041A<br>see Figure 3.3 |
| Mapping area of CS1 default setting (B1C1/0: 00) | 480H~7FFFH                                                                                              | 480H~7FFFH                                                                                        | 80H~7FFFH                    |
| P92, CTS0, SCLK0                                 | TMP96C141 does not have the SCLK0 function.<br>[Serial channel 0 does not have the I/O interface mode.] | TMP96C141A/TMP96C041A have the SCLK0 function.<br>[Serial channel 0 have the I/O interface mode.] |                              |

**TOSHIBA**

**TMP96C041A**

---

## CMOS 16-bit MICROCONTROLLERS

## TMP96CM40F

## 1. OUTLINE AND DEVICE CHARACTERISTICS

TMP96CM40F is high-speed advanced 16-bit microcontrollers developed for controlling medium to large-scale equipment. The TMP96C141 does not have a ROM, the TMP96CM40F has a built-in ROM of 32K-byte, and the TMP96PM40 has a built-in OTP of 32K-byte.

TMP96CM40F is housed in an 80-pin flat package.

Device characteristics are as follows:

- (1) Original 16-bit CPU
  - TLCS-90 instruction mnemonic upward compatible.
  - 16M-byte linear address space
  - General-purpose registers and register bank system
  - 16-bit multiplication / division and bit transfer/arithmetic instructions
  - High-speed micro DMA : 4 channels (1.6  $\mu$ s/2 bytes @20MHz)
- (2) Minimum instruction execution time : 200ns @20MHz
- (3) Internal RAM : 1K byte  
Internal ROM : 32K byte
- (4) External memory expansion
  - Can be expanded up to 16M bytes (for both programs and data).
  - Can mix 8- and 16-bit external data buses.
- (5) 8-bit timers : 2 channels
- (6) 8-bit PWM timers : 2 channels
- (7) 16-bit timers : 2 channels
- (8) Pattern generators : 4 bits, 2 channels
- (9) Serial interface : 2 channels
- (10) 10-bit A/D converter : 4 channels
- (11) Watchdog timer
- (12) Chip select/wait controller : 3 blocks
- (13) Interrupt functions
  - 3 CPU interrupts..... SWI instruction, privileged violation, and Illegal instruction
  - 14 internal interrupts
  - 6 external interrupts [ ] 7-level priority can be set.
- (14) I/O ports : 65 pins
- (15) Standby function : 3 halt modes (RUN, IDLE, STOP)





: TMP96CM40 is added to SCL0 function.  
 (TMP96C141 does not have this function.)

Figure1 TMP96CM40 Block Diagram

## 2. PIN ASSIGNMENT AND FUNCTIONS

The assignment of input / output pins for TMP96CM40, their name and outline functions are described below.

### 2.1 Pin Assignment

Figure 2.1 shows pin assignment of TMP96CM40F.



Note : Because the TMP96C141 has an external ROM, P00 to P17 pins are fixed to AD0 to AD15; P30 to RD; and P31 to WR.

: TMP96CM40 is added to SCLK0 function. (TMP96C141 does not have this function.)

Figure 2.1 Pin Assignment (80-pin QFP)

## 2.2 Pin Names and Functions

The names of input/output pins and their functions are described below.

Table 2.2 Pin Names and Functions.

| Pin name                         | Number of pins | I/O                        | Functions                                                                                                                                                                                                                         |
|----------------------------------|----------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P00~P07<br>AD0~AD7               | 8              | I/O<br>Tri-state           | Port 0: I/O port that allows I/O to be selected on a bit basis<br>Address/data (lower): 0 - 7 for address/data bus                                                                                                                |
| P10~P17<br>AD8~AD15<br>A8~A15    | 8              | I/O<br>Tri-state<br>Output | Port 1: I/O port that allows I/O to be selected on a bit basis<br>Address data (upper): 8 - 15 for address/data bus<br>Address: 8 to 15 for address bus                                                                           |
| P20~P27<br>A0~A7<br>A16~A23      | 8              | I/O<br>Output<br>Output    | Port 2: I/O port that allows selection of I/O on a bit basis<br>(with pull-down resistor)<br>Address: 0 - 7 for address bus<br>Address: 16 - 23 for address bus                                                                   |
| P30<br><u>RD</u>                 | 1              | Output<br>Output           | Port 30: Output port<br>Read: Strobe signal for reading external memory                                                                                                                                                           |
| P31<br><u>WR</u>                 | 1              | Output<br>Output           | Port 31: Output port<br>Write: Strobe signal for writing data on pins AD0 - 7                                                                                                                                                     |
| P32<br><u>HWR</u>                | 1              | I/O<br>Output              | Port 32: I/O port (with pull-up resistor)<br>High write: Strobe signal for writing data on pins AD8 - 15                                                                                                                          |
| P33<br><u>WAIT</u>               | 1              | I/O<br>Input               | Port 33: I/O port (with pull-up resistor)<br>Wait: Pin used to request CPU bus wait                                                                                                                                               |
| P34<br><u>BUSRQ</u>              | 1              | I/O<br>Input               | Port 34: I/O port (with pull-up resistor)<br>Bus request: Signal used to request high impedance for AD0 - 15,<br>A0 - 23, RD, WR, HWR, R/W, RAS, CS0, CS1, and CS2 pins.<br>(For external DMAC)                                   |
| P35<br><u>BUSAk</u>              | 1              | I/O<br>Output              | Port 35: I/O port (with pull-up resistor)<br>Bus acknowledge: Signal indicating that AD0-15, A0-23, RD,<br>WR, HWR, R/W, RAS, CS0, CS1, and CS2 pins are at high impedance<br>after receiving BUSRQ. (For external DMAC)          |
| P36<br><u>R/W</u>                | 1              | I/O<br>Output              | Port 36: I/O port (with pull-up resistor)<br>Read/write: 1 represents read or dummy cycle; 0, write cycle.                                                                                                                        |
| P37<br><u>RAS</u>                | 1              | I/O<br>Output              | Port 37: I/O port (with pull-up resistor)<br>Row address strobe: Outputs RAS strobe for DRAM.                                                                                                                                     |
| P40<br><u>CS0</u><br><u>CAS0</u> | 1              | I/O<br>Output<br>Output    | Port 40: I/O port (with pull-up resistor)<br>Chip select 0: Outputs 0 when address is within specified address<br>area.<br>Column address strobe 0: Outputs CAS strobe for DRAM when<br>address is within specified address area. |

Note : With the external DMA controller, this device's built-in memory or built-in I/O cannot be accessed using the BUSRQ and BUSAk pins.

| Pin name                         | Number of pins | I/O                     | Functions                                                                                                                                                                                                                          |
|----------------------------------|----------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P41<br><u>CS1</u><br><u>CAS1</u> | 1              | I/O<br>Output<br>Output | Port 41: I/O port (with pull-up resistor)<br>Chip select 1: Outputs 0 if address is within specified address area.<br>Column address strobe 1: Outputs CAS strobe for DRAM if address is within specified address area.            |
| P42<br><u>CS2</u><br><u>CAS2</u> | 1              | I/O<br>Output<br>Output | Port 42: I/O port (with pull-down resistor) (Note 1)<br>Chip select 2: Outputs 0 if address is within specified address area.<br>Column address strobe 2: Outputs CAS strobe for DRAM if address is within specified address area. |
| P50~P53<br>AN0~AN3               | 4              | Input<br>Input          | Port 5: Input port<br>Analog input: Input to A/D converter                                                                                                                                                                         |
| VREF                             | 1              | Input                   | Pin for reference voltage input to A/D converter                                                                                                                                                                                   |
| AGND                             | 1              | Input                   | Ground pin for A/D converter                                                                                                                                                                                                       |
| P60~P63                          | 4              | I/O                     | Ports 60 - 63: I/O ports that allow selection of I/O on a bit basis (with pull-up resistor)                                                                                                                                        |
| PG00~PG03                        |                | Output                  | Pattern generator ports: 00 - 03                                                                                                                                                                                                   |
| P64~P67                          | 4              | I/O                     | Ports 64 - 67: I/O ports that allow selection of I/O on a bit basis (with pull-up resistor)                                                                                                                                        |
| PG10~PG13                        |                | Output                  | Pattern generator ports: 10 - 13                                                                                                                                                                                                   |
| P70<br>TI0                       | 1              | I/O<br>Input            | Port 70: I/O port (with pull-up resistor)<br>Timer input 0: Timer 0 input                                                                                                                                                          |
| P71<br>TO1                       | 1              | I/O<br>Output           | Port 71: I/O port (with pull-up resistor)<br>Timer output 1: Timer 0 or 1 output                                                                                                                                                   |
| P72<br>TO2                       | 1              | I/O<br>Output           | Port 72: I/O port (with pull-up resistor)<br>PWM output 2: 8-bit PWM timer 2 output                                                                                                                                                |
| P73<br>TO3                       | 1              | I/O<br>Output           | Port 73: I/O port (with pull-up resistor)<br>PWM output 3: 8-bit PWM timer 3 output                                                                                                                                                |
| P80<br>TI4<br>INT4               | 1              | Input<br>Input          | Port 80: I/O port (with pull-up resistor)<br>Timer input 4: Timer 4 count/capture trigger signal input<br>Interrupt request pin 4: Interrupt request pin with programmable rising/falling edge                                     |
| P81<br>TI5<br>INT5               | 1              | I/O<br>Input<br>Input   | Port 81: I/O port (with pull-up resistor)<br>Timer input 5: Timer 4 count/capture trigger signal input<br>Interrupt request pin 5: Interrupt request pin with rising edge                                                          |
| P82<br>TO4                       | 1              | I/O<br>Output           | Port 82: I/O port (with pull-up resistor)<br>Timer output 4: Timer 4 output pin                                                                                                                                                    |
| P83<br>TO5                       | 1              | I/O<br>Output           | Port 83: I/O port (with pull-up resistor)<br>Timer output 5: Timer 4 output pin                                                                                                                                                    |

Note 1 : Case of the settable CS2 or CAS2; when TMP96CM40F is bus release, this pin is not added the internal pull-down resistor but is added the internal pull-up resistor.

| Pin name             | Number of pins | I/O                   | Functions                                                                                                                                                                                      |
|----------------------|----------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P84<br>TI6<br>INT6   | 1              | I/O<br>Input<br>Input | Port 84: I/O port (with pull-up resistor)<br>Timer input 6: Timer 5 count/capture trigger signal input<br>Interrupt request pin 6: Interrupt request pin with programmable rising/falling edge |
| P85<br>TI7<br>INT7   | 1              | I/O<br>Input<br>Input | Port 85: I/O port (with pull-up resistor)<br>Timer input 7: Timer 5 count/capture trigger signal input<br>Interrupt request pin 7: Interrupt request pin with rising edge                      |
| P86<br>TO6           | 1              | I/O<br>Output         | Port 86: I/O port (with pull-up resistor)<br>Timer output 6: Timer 5 output pin                                                                                                                |
| P87<br>INT0          | 1              | I/O<br>Input          | Port 87: I/O port (with pull-up resistor)<br>Interrupt request pin 0: Interrupt request pin with programmable level/rising edge                                                                |
| P90<br>TXD0          | 1              | I/O<br>Output         | Port 90: I/O port (with pull-up resistor)<br>Serial send data 0                                                                                                                                |
| P91<br>RXD0          | 1              | I/O<br>Input          | Port 91: I/O port (with pull-up resistor)<br>Serial receive data 0                                                                                                                             |
| P92<br>CTS0<br>SCLK0 | 1              | I/O<br>Input<br>I/O   | Port 92: I/O port (with pull-up resistor)<br>Serial data send enable 0 (Clear to Send)<br>Serial clock I/O 0                                                                                   |
| P93<br>TXD1          | 1              | I/O<br>Output         | Port 93: I/O port (with pull-up resistor)<br>Serial send data 1                                                                                                                                |
| P94<br>RXD1          | 1              | I/O<br>Input          | Port 94: I/O port (with pull-up resistor)<br>Serial receive data 1                                                                                                                             |
| P95<br>SCLK1         | 1              | I/O<br>I/O            | Port 95: I/O port (with pull-up resistor)<br>Serial clock I/O 1                                                                                                                                |
| WDTOUT               | 1              | Output                | Watchdog timer output pin                                                                                                                                                                      |
| NMI                  | 1              | Input                 | Non-maskable interrupt request pin: Interrupt request pin with falling edge. Can also be operated at rising edge by program.                                                                   |
| CLK                  | 1              | Output                | Clock output: Outputs $\lceil X1 \div 4 \rceil$ clock. Pulled-up during reset.                                                                                                                 |
| EA                   | 1              | Input                 | External access: 0 should be inputted with TMP96C141.<br>1, with TMP96CM40 / TMP96PM40.                                                                                                        |
| ALE                  | 1              | Output                | Address latch enable                                                                                                                                                                           |
| RESET                | 1              | Input                 | Reset: Initializes LSI. (With pull-up resistor)                                                                                                                                                |
| X1/X2                | 2              | I/O                   | Oscillator connecting pin                                                                                                                                                                      |
| VCC                  | 2              |                       | Power supply pin (+ 5V)                                                                                                                                                                        |
| VSS                  | 3              |                       | GND pin (0V)                                                                                                                                                                                   |

Note : Pull-up/pull-down resistor can be released from the pin by software (except the RESET pin).  
 : TMP96CM40 is added to SCLK0 function. (TMP96C141 does not have this function.)

### 3. OPERATION

This section describes the functions and basic operations of TMP96M40 device. The function of CPU and internal I/O devices are the same function as TMP96C141.

Check the 「7. Care Points and Restriction of TMP96C141」 because of the Care described. Regarding the function of TMP96CM40 (not described), see the part of TMP96C141.

#### 3.1 CPU

TMP96CM40 device has a built-in high-performance 16-bit CPU (900-CPU). (For CPU operation, see TLCS-900 CPU in the previous section.)

#### 3.2 Memory Map

TMP96CM40 has two register modes. One is a minimum mode; in this mode, the area of program memory is 64K bytes maximum. The other is a maximum mode; in this mode, The area of program memory is 16M bytes maximum.

Both minimum and maximum modes are the data memory area of 16M bytes maximum.

That is, the program memory can locate 0H~FFFFH in minimum mode and can locate 0H ~ FFFFFFFH in maximum mode.

##### (1) Internal ROM

TMP96CM40 has the ROM of 32K bytes. This ROM is located to 80000H~FFFFH. After the RESET operation, instruction execution starts from address 8000H.

A part of the internal ROM area (8000H~81FFH) is interrupt entry area.



##### (2) Internal RAM

TMP96CM40 has the RAM of 1K bytes. This RAM is located to 80H~47FH. The CPU can access the part of RAM (80H~FFH, 128 bytes) with using the short instruction code of direct addressing mode.

##### (3) Internal I/O devices

TMP96CM40 uses the address space of 128 bytes for the internal I/O devices area. This area is located to 0H~7FH.

The CPU can access the internal I/O devices area with using the short instruction code of direct addressing mode.

Check the access area of each addressing mode and the memory map in Fig. 3.1.

### Memory Map

Figure 3.1 is a memory map of the TMP96CM40.



Note : The start address after reset is 8000H. Resetting sets the stack pointer (XSP) on the system mode side to 100H.

Figure3.1 Memory map

## 4. ELECTRICAL CHARACTERISTICS

### 4.1 Absolute Maximum

| Symbol              | Parameter                     | Rating                    | Unit |
|---------------------|-------------------------------|---------------------------|------|
| V <sub>cc</sub>     | Power Supply Voltage          | -0.5~6.5                  | V    |
| V <sub>IN</sub>     | Input Voltage                 | -0.5~V <sub>cc</sub> +0.5 | V    |
| $\Sigma I_{OL}$     | Output Current (total)        | 100                       | mA   |
| $\Sigma I_{OH}$     | Output Current (total)        | -100                      | mA   |
| P D                 | Power Dissipation (Ta = 85°C) | 500                       | mW   |
| T <sub>SOLDER</sub> | Soldering Temperature (10 s)  | 260                       | °C   |
| T <sub>STG</sub>    | Storage Temperature           | -65~150                   | °C   |
| T <sub>OPR</sub>    | Operating Temperature         | -40~85                    | °C   |

### 4.2 DC Characteristics

V<sub>cc</sub> = 5V ± 10%, TA = -40~85°C (4~16MHz) TA = -20~70°C (4~20MHz)

(Typical values are for Ta = 25°C and V<sub>cc</sub> = 5V)

| Symbol            | Parameter                                                                               | Min                                | Max                   | Unit           | Test Condition                                                                   |
|-------------------|-----------------------------------------------------------------------------------------|------------------------------------|-----------------------|----------------|----------------------------------------------------------------------------------|
| V <sub>IL</sub>   | Input Low Voltage (AD0~15)<br>P2, P3, P4, P5, P6, P7, P8, P9<br>RESET, NMI, INT0 (P87)  | -0.3                               | 0.8                   | V              |                                                                                  |
| V <sub>IL1</sub>  |                                                                                         | -0.3                               | 0.3V <sub>cc</sub>    | V              |                                                                                  |
| V <sub>IL2</sub>  |                                                                                         | -0.3                               | 0.25V <sub>cc</sub>   | V              |                                                                                  |
| V <sub>IL3</sub>  |                                                                                         | -0.3                               | 0.3                   | V              |                                                                                  |
| V <sub>IL4</sub>  |                                                                                         | -0.3                               | 0.2V <sub>cc</sub>    | V              |                                                                                  |
| V <sub>IH</sub>   | Input High Voltage (AD0~15)<br>P2, P3, P4, P5, P6, P7, P8, P9<br>RESET, NMI, INT0 (P87) | 2.2                                | V <sub>cc</sub> + 0.3 | V              |                                                                                  |
| V <sub>IH1</sub>  |                                                                                         | 0.7V <sub>cc</sub>                 | V <sub>cc</sub> + 0.3 | V              |                                                                                  |
| V <sub>IH2</sub>  |                                                                                         | 0.75V <sub>cc</sub>                | V <sub>cc</sub> + 0.3 | V              |                                                                                  |
| V <sub>IH3</sub>  |                                                                                         | V <sub>cc</sub> - 0.3              | V <sub>cc</sub> + 0.3 | V              |                                                                                  |
| V <sub>IH4</sub>  |                                                                                         | 0.8V <sub>cc</sub>                 | V <sub>cc</sub> + 0.3 | V              |                                                                                  |
| V <sub>OL</sub>   | Output Low Voltage                                                                      | 0.45                               | V                     |                | I <sub>OL</sub> = 1.6mA                                                          |
| V <sub>OH</sub>   | Output High Voltage                                                                     | 2.4                                | V                     |                |                                                                                  |
| V <sub>OH1</sub>  |                                                                                         | 0.75V <sub>cc</sub>                | V                     |                | I <sub>OH</sub> = -400μA                                                         |
| V <sub>OH2</sub>  |                                                                                         | 0.9V <sub>cc</sub>                 | V                     |                | I <sub>OH</sub> = -100μA                                                         |
|                   |                                                                                         |                                    |                       |                | I <sub>OH</sub> = -20μA                                                          |
| I <sub>DAR</sub>  | Darlington Drive Current<br>(8 Output Pins max.)                                        | -1.0                               | -3.5                  | mA             | V <sub>EXT</sub> = 1.5V<br>R <sub>EXT</sub> = 1.1kΩ                              |
| I <sub>LI</sub>   | Input Leakage Current                                                                   | 0.02 (Typ)                         | ±5                    | μA             | 0.0 ≤ V <sub>in</sub> ≤ V <sub>cc</sub>                                          |
| I <sub>LO</sub>   | Output Leakage Current                                                                  | 0.05 (Typ)                         | ±10                   | μA             | 0.2 ≤ V <sub>in</sub> ≤ V <sub>cc</sub> - 0.2                                    |
| I <sub>cc</sub>   | Operating Current (RUN)<br>IDLE<br>STOP (Ta = -20~70°C)<br>STOP (Ta = 0~50°C)           | 30 (Typ)<br>2.0 (Typ)<br>0.2 (Typ) | TBD<br>10<br>50       | mA<br>μA<br>μA | f <sub>c</sub> = 20MHz                                                           |
| V <sub>STOP</sub> | Power Down Voltage<br>(@STOP, RAM Back up)                                              | 2.0                                | 6.0                   | V              | V <sub>IL2</sub> = 0.2V <sub>cc</sub> ,<br>V <sub>IH2</sub> = 0.8V <sub>cc</sub> |
| R <sub>RST</sub>  | RESET Pull Up Register                                                                  | 50                                 | 150                   | kΩ             |                                                                                  |
| C <sub>IO</sub>   | Pin Capacitance                                                                         |                                    | 10                    | pF             | f <sub>c</sub> = 1MHz                                                            |
| V <sub>TH</sub>   | Schmitt Width<br>RESET, NMI, INT0 (P87)                                                 | 0.4                                | 1.0 (Typ)             | V              |                                                                                  |
| R <sub>K</sub>    | Pull Down/Up Register                                                                   | 50                                 | 150                   | kΩ             |                                                                                  |

Note : I-DAR is guaranteed for a total of up to 8 ports.

### 4.3 AC Electrical Characteristics

$V_{CC} = 5V \pm 10\%$ , TA = -40~85°C (4~16MHz) TA = -20~70°C (4~20MHz)

## AC Measuring Conditions

- Output Level : High 2.2V /Low 0.8V ,CL50pF  
(However CL = 100pF for AD0~AD15, AD0~AD23, ALE, RD, WR, HWR, R/W, CLK, RAS, CAS0~CAS2)
  - Input Level : High 2.4V /Low 0.45V (AD0~AD15)  
High 0.8Vcc /Low 0.2Vcc (Except for AD0~AD15)

## (1) Read Cycle



## (2) Write Cycle



#### 4.4 A/D Conversion Characteristics

$V_{CC} = 5V \pm 10\%$ ,  $TA = -40 \sim 85^\circ C$  (4~16MHz)  $TA = -20 \sim 70^\circ C$  (4~20MHz)

| Symbol                                                              | Parameter                                   |                  | Min            | Typ       | Max       | Unit |
|---------------------------------------------------------------------|---------------------------------------------|------------------|----------------|-----------|-----------|------|
| $V_{REF}$                                                           | Analog reference voltage                    |                  | $V_{CC} - 1.5$ |           | $V_{CC}$  |      |
| $A_{GND}$                                                           | Analog reference voltage                    |                  | $V_{SS}$       |           | $V_{SS}$  |      |
| $V_{AIN}$                                                           | Analog input voltage range                  |                  | $V_{SS}$       |           | $V_{CC}$  |      |
| $I_{REF}$                                                           | Analog current for analog reference voltage |                  |                | 0.5       | 1.5       | mA   |
| Total error<br>(Quantize error<br>of $\pm 0.5$ LSB not<br>included) | $4 \leq f_C \leq 16\text{MHz}$              | Low change mode  |                | $\pm 1.5$ | $\pm 4.0$ | LSB  |
|                                                                     |                                             | High change mode |                | $\pm 3.0$ | $\pm 6.0$ |      |
|                                                                     | $16 < f_C \leq 20\text{MHz}$                | Low change mode  |                | $\pm 1.5$ | $\pm 4.0$ |      |
|                                                                     |                                             | High change mode |                | $\pm 4.0$ | $\pm 8.0$ |      |

#### 4.5 Serial Channel Timing – I/O Interface Mode

(1) SCLK Input Mode  $V_{CC} = 5V \pm 10\%$ ,  $TA = -40 \sim 85^\circ C$  (4~16MHz)  $TA = -20 \sim 70^\circ C$  (4~20MHz)

| Symbol    | Parameter                               | Variable              |                      | 16MHz |     | 20MHz |     | Unit    |
|-----------|-----------------------------------------|-----------------------|----------------------|-------|-----|-------|-----|---------|
|           |                                         | Min                   | Max                  | Min   | Max | Min   | Max |         |
| $t_{SCY}$ | SCLK cycle                              | 16X                   |                      | 1     |     | 0.8   |     | $\mu s$ |
| $t_{OSS}$ | Output Data → Rising edge of SCLK       | $t_{SCY}/2 - 5X - 50$ |                      | 137   |     | 100   |     | ns      |
| $t_{OHS}$ | SCLK rising edge → Output Data hold     | 5X - 100              |                      | 212   |     | 150   |     | ns      |
| $t_{HSR}$ | SCLK rising edge → Input Data hold      | 0                     |                      | 0     |     | 0     |     | ns      |
| $t_{SRD}$ | SCLK rising edge → effective data input |                       | $t_{SCY} - 5X - 100$ | 587   |     | 450   |     | ns      |

(2) SCLK Output Mode  $V_{CC} = 5V \pm 10\%$ ,  $TA = -40 \sim 85^\circ C$  (4~16MHz)  $TA = -20 \sim 70^\circ C$  (4~20MHz)

| Symbol    | Parameter                               | Variable             |                      | 16MHz |     | 20MHz |       | Unit    |
|-----------|-----------------------------------------|----------------------|----------------------|-------|-----|-------|-------|---------|
|           |                                         | Min                  | Max                  | Min   | Max | Min   | Max   |         |
| $t_{SCY}$ | SCLK cycle (programmable)               | 16X                  | 8192X                | 1     | 512 | 0.8   | 409.6 | $\mu s$ |
| $t_{OSS}$ | Output Data → SCLK rising edge          | $t_{SCY} - 2X - 150$ |                      | 725   |     | 550   |       | ns      |
| $t_{OHS}$ | SCLK rising edge → Output Data hold     | 2X - 80              |                      | 45    |     | 20    |       | ns      |
| $t_{HSR}$ | SCLK rising edge → Input Data hold      | 0                    |                      | 0     |     | 0     |       | ns      |
| $t_{SRD}$ | SCLK rising edge → effective data input |                      | $t_{SCY} - 2X - 150$ | 725   |     | 550   |       | ns      |

#### 4.6 Timer/Counter Input Clock (TI0, TI4, TI5, TI6, TI7)

$V_{CC} = 5V \pm 10\%$ ,  $TA = -40 \sim 85^\circ C$  (4~16MHz)  $TA = -20 \sim 70^\circ C$  (4~20MHz)

| Symbol    | Parameter                    | Variable   |     | 16MHz |     | 20MHz |     | Unit |
|-----------|------------------------------|------------|-----|-------|-----|-------|-----|------|
|           |                              | Min        | Max | Min   | Max | Min   | Max |      |
| $t_{CK}$  | Clock Cycle                  | $8X + 100$ |     | 600   |     | 500   |     | ns   |
| $t_{CKL}$ | Low level clock Pulse width  | $4X + 40$  |     | 290   |     | 240   |     | ns   |
| $t_{CKH}$ | High level clock Pulse width | $4X + 40$  |     | 290   |     | 240   |     | ns   |

#### 4.7 Interrupt Operation

$V_{CC} = 5V \pm 10\%$ ,  $TA = -40 \sim 85^\circ C$  (4~16MHz)  $TA = -20 \sim 70^\circ C$  (4~20MHz)

| Symbol      | Parameter                        | Variable   |     | 16MHz |     | 20MHz |     | Unit |
|-------------|----------------------------------|------------|-----|-------|-----|-------|-----|------|
|             |                                  | Min        | Max | Min   | Max | Min   | Max |      |
| $t_{INTL}$  | NMI, INT0 Low level Pulse width  | 4X         |     | 250   |     | 200   |     | ns   |
| $t_{INTAH}$ | NMI, INT0 High level Pulse width | 4X         |     | 250   |     | 200   |     | ns   |
| $t_{INTBL}$ | INT4~INT7 Low level Pulse width  | $8X + 100$ |     | 600   |     | 500   |     | ns   |
| $t_{INTBH}$ | INT4~INT7 High level Pulse width | $8X + 100$ |     | 600   |     | 500   |     | ns   |

## 4.8 Timing Chart for I/O Interface Mode



## 4.9 Timing Chart for Bus Request (BUSRQ) / Bus Acknowledge (BUSAK)



| Symbol            | Parameter                     | Variable |            | 16MHz |     | 20MHz |     | Unit |
|-------------------|-------------------------------|----------|------------|-------|-----|-------|-----|------|
|                   |                               | Min      | Max        | Min   | Max | Min   | Max |      |
| t <sub>BRC</sub>  | BUSRQ set-up time for CLK     | 120      |            | 120   |     | 120   |     | ns   |
| t <sub>CBAL</sub> | CLK→BUSAK falling edge        |          | 1.5x + 120 |       | 214 |       | 195 | ns   |
| t <sub>CBAH</sub> | CLK→BUSAK rising edge         |          | 0.5x + 40  |       | 71  |       | 65  | ns   |
| t <sub>ABA</sub>  | Output Buffer is off to BUSAK | 0        | 80         | 0     | 80  | 0     | 80  | ns   |
| t <sub>BAA</sub>  | BUSAK to Output Buffer is on. | 0        | 80         | 0     | 80  | 0     | 80  | ns   |

Note 1 : The Bus will be released after the WAIT request is inactive, when the BUSRQ is set to "0" during "Wait" cycle.

Note 2 : This line only shows the output buffer is off-state.  
They don't indicate the signal level is fixed.

After the bus is released, the signal level is kept dynamically before the bus is released by the external capacitance.

Therefore, to fix the signal level by an external resistance under the bus is releasing, the design must be carefully because of the level-fix will be delayed.

The internal programmable pull-up/pull-down resistance is switched active/non-active by the internal signal.

#### 4.10 Typical characteristics

$V_{CC} = 5V$ ,  $T_a = 25^\circ C$  unless otherwise noted.



Figure 5.1  $V_{CC}$  -  $f_{OSC}$  TYPICAL CURVE



Figure 5.2  $f_{OSC}$  -  $I_{CC}$  TYPICAL CURVE



Figure 5.3  $I_{CC}$  -  $V_{CC}$  TYPICAL CURVE



Figure 5.4  $V_{OUT}$  -  $I_{OL}$  TYPICAL CURVE



Figure 5.5  $V_{OUT}$  -  $I_{OH}$  TYPICAL CURVE

## 5. TMP96C141/TMP96CM40/TMP96PM40 Different points

TMP96C141/TMP96CM40/TMP96PM40 have much the same function but they are different from following points.

| Parameter                                | TMP96C141                                                                                                         | TMP96CM40                                                                                              | TMP96PM40    |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--------------|
| Internal ROM                             | Not exist                                                                                                         | Mask ROM32K byte                                                                                       | PROM32K byte |
| P00 to P07,<br>AD0 to AD7                | Only AD0 to AD7                                                                                                   | After reset P00~P07                                                                                    |              |
| P10 to P17,<br>AD8 to AD15,<br>A8 to A15 | Only AD8 to AD15                                                                                                  | After reset P10~P17                                                                                    |              |
| P30, RD                                  | Only RD                                                                                                           | After reset P30                                                                                        |              |
| P31, WR                                  | Only WR                                                                                                           | After reset P31                                                                                        |              |
| P92, CTS0, SCLK0                         | TMP96C141 does not<br>have the SCLK0<br>function.<br>Serial channel 0<br>does not have the<br>I/O interface mode. | TMP96CM40/TMP96PM40<br>have the SCLK0 function.<br>Serial channel 0<br>have the I/O<br>interface mode. |              |

**TOSHIBA**

**TMP96CM40**

---

## CMOS 16-bit MICROCONTROLLERS

## TMP96PM40F

## 1. OUTLINE AND DEVICE CHARACTERISTICS

TMP96PM40F is high-speed advanced 16-bit microcontrollers developed for controlling medium to large-scale equipment. The TMP96C141 does not have a ROM, the TMP96CM40F has a built-in ROM of 32K-byte, and the TMP96PM40 has a built-in OTP of 32K-byte.

It is possible to do write / verify of program data with using a adapter socket and general purpose EPROM writer (TC571000 mode).

TMP96PM40 is pin compatible with TMP96CM40 (mask ROM type).

TMP96CM40F is housed in an 80-pin flat package.

| Product name | ROM                  | RAM     | Package | Adapter socket name |
|--------------|----------------------|---------|---------|---------------------|
| TMP96PM40F   | OTP type<br>32K×8bit | 1K×8bit | 80-FP   | BM1139A             |





: TMP96PM40 is added to SCLK0 function.  
(TMP96C141 does not have this function.)

Figure1 TMP96PM40 Block Diagram

## 2. PIN ASSIGNMENT AND FUNCTIONS

The assignment of input / output pins for TMP96PM40, their name and outline functions are described below.

### 2.1 Pin Assignment

Figure 2.1 shows pin assignment of TMP96PM40F.



Note : Because the TMP96C141 has an external ROM, P00 to P17 pins are fixed to AD0 to AD15; P30 to  $\overline{RD}$ ; and P31 to  $\overline{WR}$ .  
 : TMP96PM40 is added to SCLK0 function. (TMP96C141 does not have this function.)

Figure 2.1 Pin Assignment (80-pin QFP)

## 2.2 Pin Names and Functions

TMP96PM40 has MCU mode and PROM mode.

The names of input/output pins and their functions are described below.

### (1) MCU mode

Table 2.2(1) Pin Names and Functions.

| Pin name                      | Number of pins | I/O                         | Functions                                                                                                                                                                                                                      |
|-------------------------------|----------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P00~P07<br>AD0~AD7            | 8              | I/O<br>Tri-state            | Port 0: I/O port that allows I/O to be selected on a bit basis<br>Address/data (lower): 0 - 7 for address/data bus                                                                                                             |
| P10~P17<br>AD8~AD15<br>A8~A15 | 8              | I/O<br>Tri-state<br>Output  | Port 1: I/O port that allows I/O to be selected on a bit basis<br>Address data (upper): 8 - 15 for address/data bus<br>Address: 8 to 15 for address bus                                                                        |
| P20~P27<br>A0~A7<br>A16~A23   | 8              | I/O<br><br>Output<br>Output | Port 2: I/O port that allows selection of I/O on a bit basis<br>(with pull-down resistor)<br>Address: 0 - 7 for address bus<br>Address: 16 - 23 for address bus                                                                |
| P30<br>RD                     | 1              | Output<br>Output            | Port 30: Output port<br>Read: Strobe signal for reading external memory                                                                                                                                                        |
| P31<br>WR                     | 1              | Output<br>Output            | Port 31: Output port<br>Write: Strobe signal for writing data on pins AD0 - 7                                                                                                                                                  |
| P32<br>HWR                    | 1              | I/O<br>Output               | Port 32: I/O port (with pull-up resistor)<br>High write: Strobe signal for writing data on pins AD8 - 15                                                                                                                       |
| P33<br>WAIT                   | 1              | I/O<br>Input                | Port 33: I/O port (with pull-up resistor)<br>Wait: Pin used to request CPU bus wait                                                                                                                                            |
| P34<br>BUSRQ                  | 1              | I/O<br>Input                | Port34: I/O port (with pull-up resistor)<br>Bus request: Signal used to request high impedance for AD0 - 15,<br>A0 - 23, RD, WR, HWR, R/W, RAS, CS0, CS1, and CS2 pins.<br>(For external DMAC)                                 |
| P35<br>BUSAK                  | 1              | I/O<br>Output               | Port 35: I/O port (with pull-up resistor)<br>Bus acknowledge: Signal indicating that AD0-15, A0-23, RD,<br>WR, HWR, R/W, RAS, CS0, CS1, and CS2 pins are at high impedance<br>after receiving BUSRQ. (For external DMAC)       |
| P36<br>R/W                    | 1              | I/O<br>Output               | Port 36: I/O port (with pull-up resistor)<br>Read/write: 1 represents read or dummy cycle; 0, write cycle.                                                                                                                     |
| P37<br>RAS                    | 1              | I/O<br>Output               | Port 37: I/O port (with pull-up resistor)<br>Row address strobe: Outputs RAS strobe for DRAM.                                                                                                                                  |
| P40<br>CS0<br><br>CAS0        | 1              | I/O<br>Output<br><br>Output | Port 40: I/O port (with pull-up resistor)<br>Chip select 0: Outputs 0 when address is within specified address area.<br>Column address strobe 0: Outputs CAS strobe for DRAM when<br>address is within specified address area. |

Note : With the external DMA controller, this device's built-in memory or built-in I/O cannot be accessed using the BUSRQ and BUSAK pins.

| Pin name           | Number of pins | I/O                     | Functions                                                                                                                                                                                                                         |
|--------------------|----------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P41<br>CS1<br>CAST | 1              | I/O<br>Output<br>Output | Port 41: I/O port (with pull-up resistor)<br>Chip select 1: Outputs 0 if address is within specified address area.<br>Column address strobe 1: Outputs CAS strobe for DRAM if address is within specified address area.           |
| P42<br>CS2<br>CAS2 | 1              | I/O<br>Output<br>Output | Port 42: I/O port (with pull-down resistor) (Note1)<br>Chip select 2: Outputs 0 if address is within specified address area.<br>Column address strobe 2: Outputs CAS strobe for DRAM if address is within specified address area. |
| P50~P53<br>AN0~AN3 | 4              | Input<br>Input          | Port 5: Input port<br>Analog input: Input to A/D converter                                                                                                                                                                        |
| VREF               | 1              | Input                   | Pin for reference voltage input to A/D converter                                                                                                                                                                                  |
| AGND               | 1              | Input                   | Ground pin for A/D converter                                                                                                                                                                                                      |
| P60~P63            | 4              | I/O                     | Ports 60 - 63: I/O ports that allow selection of I/O on a bit basis (with pull-up resistor)                                                                                                                                       |
| PG00~PG03          |                | Output                  | Pattern generator ports: 00 - 03                                                                                                                                                                                                  |
| P64~P67            | 4              | I/O                     | Ports 64 - 67: I/O ports that allow selection of I/O on a bit basis (with pull-up resistor)                                                                                                                                       |
| PG10~PG13          |                | Output                  | Pattern generator ports: 10 - 13                                                                                                                                                                                                  |
| P70<br>TI0         | 1              | I/O<br>Input            | Port 70: I/O port (with pull-up resistor)<br>Timer input 0: Timer 0 input                                                                                                                                                         |
| P71<br>TO1         | 1              | I/O<br>Output           | Port 71: I/O port (with pull-up resistor)<br>Timer output 1: Timer 0 or 1 output                                                                                                                                                  |
| P72<br>TO2         | 1              | I/O<br>Output           | Port 72: I/O port (with pull-up resistor)<br>PWM output 2: 8-bit PWM timer 2 output                                                                                                                                               |
| P73<br>TO3         | 1              | I/O<br>Output           | Port 73: I/O port (with pull-up resistor)<br>PWM output 3: 8-bit PWM timer 3 output                                                                                                                                               |
| P80<br>TI4<br>INT4 | 1              | I/O<br>Input<br>Input   | Port 80: I/O port (with pull-up resistor)<br>Timer input 4: Timer 4 count/capture trigger signal input<br>Interrupt request pin 4: Interrupt request pin with programmable rising/falling edge                                    |
| P81<br>TI5<br>INT5 | 1              | I/O<br>Input<br>Input   | Port 81: I/O port (with pull-up resistor)<br>Timer input 5: Timer 4 count/capture trigger signal input<br>Interrupt request pin 5: Interrupt request pin with rising edge                                                         |
| P82<br>TO4         | 1              | I/O<br>Output           | Port 82: I/O port (with pull-up resistor)<br>Timer output 4: Timer 4 output pin                                                                                                                                                   |
| P83<br>TO5         | 1              | I/O<br>Output           | Port 83: I/O port (with pull-up resistor)<br>Timer output 5: Timer 4 output pin                                                                                                                                                   |

Note 1 : Case of the settable CS2 or CAS2; when TMP96PM40F is bus release, this pin is not added the internal pull-down resistor but is added the internal pull-up resistor.

| Pin name                        | Number of pins | I/O                            | Functions                                                                                                                                                                                      |
|---------------------------------|----------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P84<br>TI6<br>INT6              | 1              | I/O<br>Input<br>Input          | Port 84: I/O port (with pull-up resistor)<br>Timer input 6: Timer 5 count/capture trigger signal input<br>Interrupt request pin 6: Interrupt request pin with programmable rising/falling edge |
| P85<br>TI7<br>INT7              | 1              | I/O<br>Input<br>Input          | Port 85: I/O port (with pull-up resistor)<br>Timer input 7: Timer 5 count/capture trigger signal input<br>Interrupt request pin 7: Interrupt request pin with rising edge                      |
| P86<br>TO6                      | 1              | I/O<br>Output                  | Port 86: I/O port (with pull-up resistor)<br>Timer output 6: Timer 5 output pin                                                                                                                |
| P87<br>INT0                     | 1              | I/O<br>Input                   | Port 87: I/O port (with pull-up resistor)<br>Interrupt request pin 0: Interrupt request pin with programmable level/rising edge                                                                |
| P90<br>TXD0                     | 1              | I/O<br>Output                  | Port 90: I/O port (with pull-up resistor)<br>Serial send data 0                                                                                                                                |
| P91<br>RXD0                     | 1              | I/O<br>Input                   | Port 91: I/O port (with pull-up resistor)<br>Serial receive data 0                                                                                                                             |
| P92<br>CTS0<br><del>SCLK0</del> | 1              | I/O<br>Input<br><del>I/O</del> | Port 92: I/O port (with pull-up resistor)<br>Serial data send enable 0 (Clear to Send)<br><del>Serial clock I/O 0</del>                                                                        |
| P93<br>TXD1                     | 1              | I/O<br>Output                  | Port 93: I/O port (with pull-up resistor)<br>Serial send data 1                                                                                                                                |
| P94<br>RXD1                     | 1              | I/O<br>Input                   | Port 94: I/O port (with pull-up resistor)<br>Serial receive data 1                                                                                                                             |
| P95<br>SCLK1                    | 1              | I/O<br>I/O                     | Port 95: I/O port (with pull-up resistor)<br>Serial clock I/O 1                                                                                                                                |
| WDTOUT                          | 1              | Output                         | Watchdog timer output pin                                                                                                                                                                      |
| NMI                             | 1              | Input                          | Non-maskable interrupt request pin: Interrupt request pin with falling edge. Can also be operated at rising edge by program.                                                                   |
| CLK                             | 1              | Output                         | Clock output: Outputs $\lceil X1 \div 4 \rfloor$ clock. Pulled-up during reset.                                                                                                                |
| EA                              | 1              | Input                          | External access: 0 should be inputted with TMP96C141.<br>1, with TMP96CM40 / TMP96PM40.                                                                                                        |
| ALE                             | 1              | Output                         | Address latch enable                                                                                                                                                                           |
| RESET                           | 1              | Input                          | Reset: Initializes LSI. (With pull-up resistor)                                                                                                                                                |
| X1/X2                           | 2              | I/O                            | Oscillator connecting pin                                                                                                                                                                      |
| VCC                             | 2              |                                | Power supply pin (+ 5V)                                                                                                                                                                        |
| VSS                             | 3              |                                | GND pin (0V)                                                                                                                                                                                   |

Note : Pull-up/pull-down resistor can be released from the pin by software (except the RESET pin).

~~XXXX~~ : TMP96PM40 is added to SCLK0 function. (TMP96C141 does not have this function.)

## (2) PROM mode

Table 2.2 (2) Name and function of PROM mode

| Pin function     | Pin number | Input / Output | Function                            | Pin name (MCU mode) |  |
|------------------|------------|----------------|-------------------------------------|---------------------|--|
| A7~A0            | 8          | Input          | Memory address of program           | P27~P20             |  |
| A15~A8           | 8          | Input          |                                     | P17~P10             |  |
| A16              | 1          | Input          |                                     | P33                 |  |
| D7~D0            | 8          | I/O            | Memory data of program              | P07~P00             |  |
| CE               | 1          | Input          | Chip enable                         | P32                 |  |
| OE               | 1          | Input          | Output control                      | P30                 |  |
| PGM              | 1          | Input          | Program control                     | P31                 |  |
| VPP              | 1          | Power supply   | 12.75V/5V (Power supply of program) | EA                  |  |
| VCC              | 2          | Power supply   | 6.25V/5V                            | VCC                 |  |
| VSS              | 3          | Power supply   | 0V                                  | VSS                 |  |
| Pin function     | Pin number | Input / Output | Disposal of pin                     |                     |  |
| P34              | 1          | Input          | Fix to low level (security pin)     |                     |  |
| RESET            | 1          | Input          | Fix to low level (PROM mode)        |                     |  |
| CLK              | 1          | Input          |                                     |                     |  |
| ALE              | 1          | Output         | Open                                |                     |  |
| X1               | 1          | Input          | Crystal                             |                     |  |
| X2               | 1          | Output         |                                     |                     |  |
| P95~P94,<br>VREF | 3          | Input          | Fix to high level                   |                     |  |
| AGND             | 1          | Input          | 0V                                  |                     |  |
| P37~P35          |            |                |                                     |                     |  |
| P42~P40          |            |                |                                     |                     |  |
| P53~P50          |            |                |                                     |                     |  |
| P67~P60          |            |                |                                     |                     |  |
| P73~P70          | 36         | I/O            | open                                |                     |  |
| P87~P80          |            |                |                                     |                     |  |
| NMI,<br>WDTOUT   |            |                |                                     |                     |  |
| P93~P90          |            |                |                                     |                     |  |

### 3. OPERATION

This section describes the hardware and basic operation of TMP96PM40 device. TMP96PM40 is exchanged mask ROM of TMP96CM40 for PROM. The other specifications and functions are the same as TMP96CM40.

Check the 「7. Care Points and Restriction of TMP96C141」 because of the Care described. Regarding the function of TMP96PM40 (not described), see the part of TMP96C141.

#### 3.1 MCU mode

##### (1) Mode-setting and function

The MCU mode is set by opening the CLK pin (Output status).

In the MCU mode, the operation is same as that of TMP96CM40.

##### (2) Memory Map

The memory map of TMP96PM40 is same as that of TMP96CM40.

Figure 3.1 shows the memory map of TMP96PM40, and the accessing area by the respective addressing mode.

### Memory Map

Figure 3.1 is a memory map of the TMP96CM40.



Note : The start address after reset is 8000H. Resetting sets the stack pointer (XSP) on the system mode side to 100H.

Figure3.1 Memory map

### 3.2 PROM Mode

#### (1) Mode setting and Function

PROM mode is set by setting the **RESET** and **CLK** pins to the “L” level. The programming and verification for the internal PROM is achieved by using a general EPROM programmer with the adaptor socket. The device selection (ROM Type) use following conditions. (Set ROM type to TC571000D)

Size : 1Mbit(128K×8bit) VPP : 12.75V TPW: 0.1ms

Figure 3.2 shows the setting of pins PROM mode.



Figure 3.2 PROM Mode Pin Setting

## (2) Programming Flow Chart

The programming mode is set by applying 12.5V (programming voltage) to the VPP pin when the following pins are set as follows,

(VCC : 6.25V, RESET : "L" level, CLK : "L" level).

After the address and data have been fixed, the data on the Data Bus is programmed when the CE pin is set to "L" level (0.1ms pulse is required).

General programming procedure of an EPROM programmer is as follows,

- Write a data to a specified address for 0.1ms.
- Verify the data. If the readout data does not match the expected data, another writing is performed until the correct data is written (Max. 25 times).

Then, verify the data and increment the address.

The verification for all data is done under the condition of  $V_{pp} = V_{cc} = 5$  after all data were written.

Figure 3.3 shows the programming flow chart.



High Speed Program Writing.

Flow chart



Figure 3.3 Flow chart

**(3) Security Bit**

The TMP96PM40 has a Security Bit in PROM cell.

If The Security Bit is programmed to “0”, the content of the PROM is disable to be read in PROM mode.

How to program the Security Bit.

- 1) Set the PROM mode.
- 2) Set the security pin (Port34) to “1”.
- 3) Set programming address to “000000H”.
- 4) Set programming data to “FEH”.



## 4. ELECTRICAL CHARACTERISTICS

### 4.1 Absolute Maximum

| Symbol              | Parameter                     | Rating                    | Unit |
|---------------------|-------------------------------|---------------------------|------|
| V <sub>CC</sub>     | Power Supply voltage          | -0.5~6.5                  | V    |
| V <sub>IN</sub>     | Input voltage                 | -0.5~V <sub>CC</sub> +0.5 | V    |
| $\Sigma I_{OL}$     | Output Current (total)        | 100                       | mA   |
| $\Sigma I_{OH}$     | Output Current (total)        | -100                      | mA   |
| P <sub>D</sub>      | Power Dissipation (Ta = 70°C) | 500                       | mW   |
| T <sub>SOLDER</sub> | Soldering Temperature (10 s)  | 260                       | °C   |
| T <sub>STG</sub>    | Storage temperature           | -65~150                   | °C   |
| T <sub>OPR</sub>    | Operating temperature         | -40~85                    | °C   |

### 4.2 DC Characteristics

V<sub>CC</sub> = 5V ± 10%, TA = -20~70°C (4~20MHz) TA = -40~85°C (4~16MHz)

(Typical values are for Ta = 25°C and V<sub>CC</sub> = 5V.)

| Symbol            | Parameter                                     | Min                  | Max                  | Unit | Test Condition                                                                   |
|-------------------|-----------------------------------------------|----------------------|----------------------|------|----------------------------------------------------------------------------------|
| V <sub>IL</sub>   | Input Low Voltage (AD0~15)                    | -0.3                 | 0.8                  | V    |                                                                                  |
| V <sub>IL1</sub>  | P2, P3, P4, P5, P6, P7, P8, P9                | -0.3                 | 0.3V <sub>CC</sub>   | V    |                                                                                  |
| V <sub>IL2</sub>  | RESET, NMI, INT0 (P87)                        | -0.3                 | 0.25V <sub>CC</sub>  | V    |                                                                                  |
| V <sub>IL3</sub>  | EA                                            | -0.3                 | 0.3                  | V    |                                                                                  |
| V <sub>IL4</sub>  | X1                                            | -0.3                 | 0.2V <sub>CC</sub>   | V    |                                                                                  |
| V <sub>IH</sub>   | Input High Voltage (AD0~15)                   | 2.2                  | V <sub>CC</sub> +0.3 | V    |                                                                                  |
| V <sub>IH1</sub>  | P2, P3, P4, P5, P6, P7, P8, P9                | 0.7V <sub>CC</sub>   | V <sub>CC</sub> +0.3 | V    |                                                                                  |
| V <sub>IH2</sub>  | RESET, NMI, INT0 (P87)                        | 0.75V <sub>CC</sub>  | V <sub>CC</sub> +0.3 | V    |                                                                                  |
| V <sub>IH3</sub>  | EA                                            | V <sub>CC</sub> -0.3 | V <sub>CC</sub> +0.3 | V    |                                                                                  |
| V <sub>IH4</sub>  | X1                                            | 0.8V <sub>CC</sub>   | V <sub>CC</sub> +0.3 | V    |                                                                                  |
| V <sub>OL</sub>   | Output Low Voltage                            |                      | 0.45                 | V    | OL = 1.6mA                                                                       |
| V <sub>OH</sub>   | Output High Voltage                           | 2.4                  |                      | V    | OH = -400μA                                                                      |
| V <sub>OH1</sub>  |                                               | 0.75V <sub>CC</sub>  |                      | V    | OH = -100μA                                                                      |
| V <sub>OH2</sub>  |                                               | 0.9V <sub>CC</sub>   |                      | V    | OH = -20μA                                                                       |
| I <sub>DAR</sub>  | Darlington Drive Current (8 Output Pins max.) | -1.0                 | -3.5                 | mA   | V <sub>EXT</sub> = 1.5V<br>R <sub>EXT</sub> = 1.1kΩ                              |
| I <sub>LI</sub>   | Input Leakage Current                         | 0.02 (Typ)           | ±5                   | μA   | 0.0 ≤ Vin ≤ V <sub>CC</sub>                                                      |
| I <sub>LO</sub>   | Output Leakage Current                        | 0.05 (Typ)           | ±10                  | μA   | 0.2 ≤ Vin ≤ V <sub>CC</sub> - 0.2                                                |
| I <sub>CC</sub>   | Operating Current (RUN)                       | 30 (Typ)             | 60                   | mA   | f <sub>C</sub> = 20MHz                                                           |
|                   | IDLE                                          | 2.0 (Typ)            | 10                   | mA   |                                                                                  |
|                   | STOP (Ta = -20~70°C)                          | 0.2 (Typ)            | 50                   | μA   | 0.2 ≤ Vin ≤ V <sub>CC</sub> - 0.2                                                |
|                   | STOP (Ta = 0~50°C)                            |                      | 10                   | μA   | 0.2 ≤ Vin ≤ V <sub>CC</sub> - 0.2                                                |
| V <sub>STOP</sub> | Power Down Voltage (@STOP, RAM Back up)       | 2.0                  | 6.0                  | V    | V <sub>IL2</sub> = 0.2V <sub>CC</sub> ,<br>V <sub>IH2</sub> = 0.8V <sub>CC</sub> |
| R <sub>RST</sub>  | RESET Pull Up Register                        | 50                   | 150                  | kΩ   |                                                                                  |
| C <sub>IO</sub>   | Pin Capacitance                               |                      | 10                   | pF   | f <sub>C</sub> = 1MHz                                                            |
| V <sub>TH</sub>   | Schmitt Width<br>RESET, NMI, INT0 (P87)       | 0.4                  | 1.0 (Typ)            | V    |                                                                                  |
| R <sub>K</sub>    | Pull Down/Up Register                         | 50                   | 150                  | kΩ   |                                                                                  |

Note: I-DAR is guaranteed for a total of up to 8 ports.

## 4.3 AC Electrical Characteristics

Vcc = 5V ± 10% TA = -40~85°C (4~16MHz), TA = -20~70°C (4~20MHz)

| No. | Symbol | Paramerer                           | Variable  |     | 16MHz      |     | 20MHz |     | Unit   |
|-----|--------|-------------------------------------|-----------|-----|------------|-----|-------|-----|--------|
|     |        |                                     | Min       | Max | Min        | Max | Min   | Max |        |
| 1   | tosc   | Osc. Period (=x)                    | 50        | 250 | 62.5       |     | 50    |     | ns     |
| 2   | tCLK   | CLK width                           | 2x - 40   |     | 85         |     | 60    |     | ns     |
| 3   | tAK    | A0-23 Valid→CLK Hold                | 0.5x - 20 |     | 11         |     | 5     |     | ns     |
| 4   | tKA    | CLK Valid→A0-23 Hold                | 1.5x - 70 |     | 24         |     | 5     |     | ns     |
| 5   | tAL    | A0-15 Valid→ALE fall                | 0.5x - 15 |     | 16         |     | 10    |     | ns     |
| 6   | tLA    | ALE fall→A0-15 Hold                 | 0.5x - 15 |     | 16         |     | 10    |     | ns     |
| 7   | tLL    | ALE High width                      | x - 40    |     | 23         |     | 10    |     | ns     |
| 8   | tLC    | ALE fall→RD/WR fall                 | 0.5x - 30 |     | 1          |     | -5    |     | ns     |
| 9   | tCL    | RD/WR rise→ALE rise                 | 0.5x - 20 |     | 11         |     | 5     |     | ns     |
| 10  | tACL   | A0-15 Valid→RD/WR fall              | x - 25    |     | 38         |     | 25    |     | ns     |
| 11  | tACH   | A0-23 Valid→RD/WR fall              | 1.5x - 50 |     | 44         |     | 25    |     | ns     |
| 12  | tCA    | RD/WR rise→A0-23 Hold               | 0.5x - 20 |     | 11         |     | 5     |     | ns     |
| 13  | tADL*  | A0-15 Valid→D0-15 input             |           |     | 3.0x - 55  |     | 133   |     | 95 ns  |
| 14  | tADH   | A0-23 Valid→D0-15 input             |           |     | 3.5x - 65  |     | 154   |     | 110 ns |
| 15  | tRD    | RDfall → D0-15 input                |           |     | 2.0x - 50  |     | 75    |     | 50 ns  |
| 16  | tRR    | RD Low width                        | 2.0x - 40 |     |            | 85  |       | 60  |        |
| 17  | tHR    | RDrise→D0-15 Hold                   | 0         |     |            | 0   |       | 0   |        |
| 18  | tRAE   | RDrise→A0-15output                  | x - 15    |     |            | 48  |       | 35  |        |
| 19  | tWW    | WR Low width                        | 2.0x - 40 |     |            | 85  |       | 60  |        |
| 20  | tDW    | D0-15 Valid→WRrise                  | 2.0x - 50 |     |            | 75  |       | 50  |        |
| 21  | tWD    | WR rise →D0-15 Hold                 | 0.5x - 10 |     |            | 21  |       | 15  |        |
| 22  | tAEH   | A0-23 Valid→ WAIT input (WAIT mode) |           |     | 3.5x - 90  |     | 129   |     | 85 ns  |
| 23  | tAWL   | A0-15 Valid→ WAIT input (WAIT mode) |           |     | 3.0x - 80  |     | 108   |     | 70 ns  |
| 24  | tCW    | RD/WR fall→WAIT Hold (WAIT +n mode) | 2.0x + 0  |     |            | 125 |       | 100 |        |
| 25  | tAPH   | A0-23 Valid→ PORT input             |           |     | 2.5x - 120 |     | 36    |     | 5 ns   |
| 26  | tAPH2  | A0-23 Valid→ PORT Hold              | 2.5x + 50 |     |            | 206 |       | 175 |        |
| 27  | tCP    | WR rise→PORT Valid                  |           |     | 200        |     | 200   |     | 200 ns |
| 28  | tASRH  | A0-23 Valid→RAS fall                | 1.0x - 40 |     |            | 23  |       | 10  |        |
| 29  | tASRL  | A0-15 Valid→RAS fall                | 0.5x - 15 |     |            | 16  |       | 10  |        |
| 30  | tRAC   | RAS fall→D0-15 input                |           |     | 2.5x - 70  |     | 86    |     | 55 ns  |
| 31  | tRAH   | RAS fall→A0-15 Hold                 | 0.5x - 15 |     |            | 16  |       | 10  |        |
| 32  | tRAS   | RAS Low width                       | 2.0x - 40 |     |            | 85  |       | 60  |        |
| 33  | tRP    | RAS High width                      | 2.0x - 40 |     |            | 85  |       | 60  |        |
| 34  | tRSH   | CAS fall→RAS rise                   | 1.0x - 35 |     |            | 28  |       | 15  |        |
| 35  | tRSC   | RAS rise→CAS rise                   | 0.5x - 25 |     |            | 6   |       | 0   |        |
| 36  | tRCD   | RAS fall→CAS fall                   | 1.0x - 40 |     |            | 23  |       | 10  |        |
| 37  | tCAC   | CAS fall→D0-15 input                |           |     | 1.5x - 65  |     | 29    |     | 10 ns  |
| 38  | tCAS   | CAS Low width                       | 1.5x - 30 |     |            | 64  |       | 40  |        |
|     |        |                                     |           |     |            |     |       |     |        |
|     |        |                                     |           |     |            |     |       |     |        |
|     |        |                                     |           |     |            |     |       |     |        |

\* tADL value is different from TMP96C141/TMP96CM40.

## AC Measuring Conditions

- Output Level : High 2.2V /Low 0.8V , CL50pF  
(However CL = 100pF for AD0~AD15, AD0~AD23, ALE, RD, WR, HWR, R/W, CLK, RAS, CAS0~CAS2)
- Input Level : High 2.4V /Low 0.45V (AD0~AD15)  
High 0.8Vcc /Low 0.2Vcc (Except for AD0~AD15)

## (1) Read Cycle



## (2) Write Cycle



## 4.4 A/D Conversion Characteristics

V<sub>CC</sub> = 5V ± 10% TA = -40~85 °C (4~16MHz) TA = -20~70 °C (4~20MHz)

| Symbol                                                | Parameter                                   | Min                   | Typ   | Max             | Unit |
|-------------------------------------------------------|---------------------------------------------|-----------------------|-------|-----------------|------|
| V <sub>REF</sub>                                      | Analog reference voltage                    | V <sub>CC</sub> - 1.5 | V     | V <sub>CC</sub> | mA   |
| A <sub>GND</sub>                                      | Analog reference voltage                    | V <sub>SS</sub>       |       | V <sub>SS</sub> |      |
| V <sub>AIN</sub>                                      | Analog input voltage range                  | V <sub>SS</sub>       |       | V <sub>CC</sub> |      |
| I <sub>REF</sub>                                      | Analog current for analog reference voltage |                       | 0.5   | 1.5             |      |
| Total error(Quantize error of ± 0.5 LSB not included) | 4 ≤ f <sub>C</sub> ≤ 16MHz                  | Low change mode       | ± 1.5 | ± 4.0           | LSB  |
|                                                       |                                             | High change mode      | ± 3.0 | ± 6.0           |      |
|                                                       | 16 < f <sub>C</sub> ≤ 20MHz                 | Low change mode       | ± 1.5 | ± 4.0           |      |
|                                                       |                                             | High change mode      | ± 4.0 | ± 8.0           |      |

## 4.5 Serial Channel Timing – I/O Interface Mode

(1) SCLK Input Mode V<sub>CC</sub> = 5V ± 10% TA = -40~85 °C (4~16MHz) TA = -20~70 °C (4~20MHz)

| Symbol           | Parameter                               | Variable                      |                             | 16MHz |     | 20MHz |     | Unit |
|------------------|-----------------------------------------|-------------------------------|-----------------------------|-------|-----|-------|-----|------|
|                  |                                         | Min                           | Max                         | Min   | Max | Min   | Max |      |
| t <sub>SCY</sub> | SCLK cycle                              | 16X                           |                             | 1     |     | 0.8   |     | μs   |
| t <sub>OSS</sub> | Output Data → Rising edge of SCLK       | t <sub>SCY</sub> /2 - 5X - 50 |                             | 137   |     | 100   |     | ns   |
| t <sub>OHS</sub> | SCLK rising edge → Output Data hold     | 5X - 100                      |                             | 212   |     | 150   |     | ns   |
| t <sub>HSR</sub> | SCLK rising edge → Input Data hold      | 0                             |                             | 0     |     | 0     |     | ns   |
| t <sub>SRD</sub> | SCLK rising edge → effective data input |                               | t <sub>SCY</sub> - 5X - 100 | 587   |     | 450   |     | ns   |

(2) SCLK Output Mode V<sub>CC</sub> = 5V ± 10% TA = -40~85 °C (4~16MHz) TA = -20~70 °C (4~20MHz)

| Symbol           | Parameter                               | Variable                    |                             | 16MHz |     | 20MHz |       | Unit |
|------------------|-----------------------------------------|-----------------------------|-----------------------------|-------|-----|-------|-------|------|
|                  |                                         | Min                         | Max                         | Min   | Max | Min   | Max   |      |
| t <sub>SCY</sub> | SCLK cycle (programmable)               | 16X                         | 8192X                       | 1     | 512 | 0.8   | 409.6 | μs   |
| t <sub>OSS</sub> | Output Data → SCLK rising edge          | t <sub>SCY</sub> - 2X - 150 |                             | 725   |     | 550   |       | ns   |
| t <sub>OHS</sub> | SCLK rising edge → Output Data hold     | 2X - 80                     |                             | 45    |     | 20    |       | ns   |
| t <sub>HSR</sub> | SCLK rising edge → Input Data hold      | 0                           |                             | 0     |     | 0     |       | ns   |
| t <sub>SRD</sub> | SCLK rising edge → effective data input |                             | t <sub>SCY</sub> - 2X - 150 | 725   |     | 550   |       | ns   |

## 4.6 Timer/Counter Input Clock (T10, T14, T15, T16, T17)

V<sub>CC</sub> = 5V ± 10% TA = -40~85 °C (4~16MHz) TA = -20~70 °C (4~20MHz)

| Symbol            | Parameter                    | Variable |     | 16MHz |     | 20MHz |     | Unit |
|-------------------|------------------------------|----------|-----|-------|-----|-------|-----|------|
|                   |                              | Min      | Max | Min   | Max | Min   | Max |      |
| t <sub>VCK</sub>  | Clock Cycle                  | 8X + 100 |     | 600   |     | 500   |     | ns   |
| t <sub>VCKL</sub> | Low level clock Pulse width  | 4X + 40  |     | 290   |     | 240   |     | ns   |
| t <sub>VCKH</sub> | High level clock Pulse width | 4X + 40  |     | 290   |     | 240   |     | ns   |

## 4.7 Interrupt Operation

V<sub>CC</sub> = 5V ± 10% TA = -40~85 °C (4~16MHz) TA = -20~70 °C (4~20MHz)

| Symbol             | Parameter                        | Variable |     | 16MHz |     | 20MHz |     | Unit |
|--------------------|----------------------------------|----------|-----|-------|-----|-------|-----|------|
|                    |                                  | Min      | Max | Min   | Max | Min   | Max |      |
| t <sub>INTAL</sub> | NMI, INT0 Low level Pulse width  | 4X       |     | 250   |     | 200   |     | ns   |
| t <sub>INTAH</sub> | NMI, INT0 High level Pulse width | 4X       |     | 250   |     | 200   |     | ns   |
| t <sub>INTBL</sub> | INT4~INT7 Low level Pulse width  | 8X + 100 |     | 600   |     | 500   |     | ns   |
| t <sub>INTBH</sub> | INT4~INT7 High level Pulse width | 8X + 100 |     | 600   |     | 500   |     | ns   |

## 4.8 Timing Chart for I/O Interface Mode



## 4.9 Timing Chart for Bus Request (BUSRQ) / BUS Acknowledge (BUSAK)



| Symbol     | Parameter                       | Variable |              | 16MHz |     | 20MHz |     | Unit |
|------------|---------------------------------|----------|--------------|-------|-----|-------|-----|------|
|            |                                 | Min      | Max          | Min   | Max | Min   | Max |      |
| $t_{BRC}$  | BUSRQ set-up time for CLK       | 120      |              | 120   |     | 120   |     | ns   |
| $t_{CBAL}$ | CLK→BUSAK falling edge          |          | $1.5x + 120$ |       | 214 |       | 195 | ns   |
| $t_{CBAH}$ | CLK→BUSAK rising edge           |          | $0.5x + 40$  |       | 71  |       | 65  | ns   |
| $t_{ABA}$  | Output Buffer is off to BUSAK ↓ | 0        | 80           | 0     | 80  | 0     | 80  | ns   |
| $t_{BAA}$  | BUSAK ↑ to Output Buffer is on. | 0        | 80           | 0     | 80  | 0     | 80  | ns   |

(Note 1) : The Bus will be released after the  $\overline{WAIT}$  request is inactive, when the BUSRQ is set to "0" during "Wait" cycle.

(Note 2) : This line only shows the output buffer is off-state.

They don't indicate the signal level is fixed.

After the bus is released, the signal level is kept dynamically before the bus is released by the external capacitance.

Therefore, to fix the signal level by an external resistance under the bus is releasing, the design must be carefully because of the level-fix will be delayed.

The internal programmable pull-up/pull-down resistance is switched active/non-active by the internal signal.

#### 4.10 Read Operation (PROM Mode)

##### DC Characteristic, AC Characteristic

TA = -40~85°C V<sub>CC</sub> = 5V ± 10%

| Symbol           | Parameter                                                            | Condition             | Min                   | Max                   | Unit |
|------------------|----------------------------------------------------------------------|-----------------------|-----------------------|-----------------------|------|
| V <sub>PP</sub>  | V <sub>PP</sub> Read Voltage                                         | -                     | 4.5                   | 5.5                   | V    |
| V <sub>IH1</sub> | Input High Voltage (A0~A16, $\overline{CE}$ , $\overline{OE}$ , PGM) | -                     | 0.7 × V <sub>CC</sub> | V <sub>CC</sub> + 0.3 | V    |
| V <sub>IL1</sub> | Input Low Voltage (A0~A16, $\overline{CE}$ , $\overline{OE}$ , PGM)  | -                     | -0.3                  | 0.3 × V <sub>CC</sub> | V    |
| t <sub>ACC</sub> | Address to Output Delay                                              | C <sub>L</sub> = 50pF | -                     | 2.25TCYC + α          | ns   |

TCYC = 400ns (10MHz Clock)

α = 200ns

#### 4.11 Programming Operation (PROM Mode)

##### DC Characteristic, AC Characteristic

TA = 25 ± 5°C V<sub>CC</sub> = 6.25V ± 0.25V

| Symbol           | Parameter                                                            | Condition                | Min                      | Typ   | Max                      | Unit |
|------------------|----------------------------------------------------------------------|--------------------------|--------------------------|-------|--------------------------|------|
| V <sub>PP</sub>  | Programming Supply Voltage                                           | -                        | 12.50                    | 12.75 | 13.00                    | V    |
| V <sub>IH</sub>  | Input High Voltage (D0~D7)                                           | -                        | 0.2V <sub>CC</sub> + 1.1 |       | V <sub>CC</sub> + 0.3    | V    |
| V <sub>IL</sub>  | Input Low Voltage (D0~D7)                                            | -                        | -0.3                     |       | 0.2V <sub>CC</sub> - 0.1 | V    |
| V <sub>IH1</sub> | Input High Voltage (A0~A16, $\overline{CE}$ , $\overline{OE}$ , PGM) | -                        | 0.7V <sub>CC</sub>       |       | V <sub>CC</sub> + 0.3    | V    |
| V <sub>IL1</sub> | Input Low Voltage (A0~A16, $\overline{CE}$ , $\overline{OE}$ , PGM)  | -                        | -0.3                     |       | 0.3V <sub>CC</sub>       | V    |
| I <sub>CC</sub>  | V <sub>CC</sub> Supply Current                                       | f <sub>C</sub> = 10MHz   | -                        |       | 50                       | mA   |
| I <sub>PP</sub>  | V <sub>PP</sub> Supply Current                                       | V <sub>PP</sub> = 13.00V | -                        |       | 50                       | mA   |
| t <sub>PW</sub>  | PGM Program Pulse Width                                              | C <sub>L</sub> = 50pF    | 0.095                    | 0.1   | 0.105                    | ms   |



## 4.12 Read Operation Timing Chart (PROM Mode)



## 4.13 Programming Operation Timing Chart (PROM Mode)

High Speed Program Writing.



## NOTE

1. The power supply of V<sub>PP</sub> (12.75V) must be set power-on at the same time or the later time for a power supply of V<sub>CC</sub> and must be clear power-on at the same time or early time for a power supply of V<sub>CC</sub>.
2. The pulling up/down device on condition of V<sub>PP</sub> = 12.75V suffer a damage for the device.
3. The maximum spec of V<sub>PP</sub> pin is 14.0V. Be carefull a overshoot at the program writing.

#### 4.14 Typical Characteristics

$V_{CC} = 5V$ ,  $T_a = 25^\circ C$ , Unless otherwise noted.



Figure 5.1  $V_{CC}$  –  $f_{OSC}$  TYPICAL CURVE



Figure 5.2  $f_{OSC}$  –  $I_{CC}$  TYPICAL CURVE



Figure 5.3  $I_{CC}$  –  $V_{CC}$  TYPICAL CURVE



Figure 5.4  $V_{OUT}$  –  $I_{OL}$  TYPICAL CURVE



Figure 5.5  $V_{OUT}$  –  $I_{OH}$  TYPICAL CURVE

## 5. TMP96C141/TMP96CM40/TMP96PM40 Different Points

TMP96C141/TMP96CM40/TMP96PM40 have much the same function but they are different from following points.

| Parameter                                | TMP96C141                                                                                             | TMP96CM40                                                                                     | TMP96PM40    |
|------------------------------------------|-------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|--------------|
| Internal ROM                             | not exist                                                                                             | Mask ROM32K-byte                                                                              | PROM32K-byte |
| P00 to P07,<br>AD0 to AD7                | Only AD0 to AD7                                                                                       | After reset P00 to P07                                                                        |              |
| P10 to P17,<br>AD8 to AD15,<br>A8 to A15 | Only AD8 to AD15                                                                                      | After reset P10 to P17                                                                        |              |
| P30, RD                                  | Only RD                                                                                               | After reset P30                                                                               |              |
| P31, WR                                  | Only WR                                                                                               | After reset P31                                                                               |              |
| P92, CTS0, SCLK0                         | TMP96C141 does not have the SCLK0 function.<br>Serial channel 0 does not have the I/O interface mode. | TMP96CM40/TMP96PM40 have the SCLK0 function.<br>Serial channel 0 have the I/O interface mode. |              |



**TOSHIBA**

**TMP96PM40**

---

**TOSHIBA**

## CHAPTER 3 TLCS-900 APPLICATION CIRCUIT



## APPLICATION CIRCUIT

## (1) Resonator

The TLCS-900 incorporates the oscillation circuit, so that it can easily obtain the required clock by connecting the resonator to pins (X1 and X2).

Table 1 Ceramic Resonator (Murata Manufacturing Co., Ltd)

| Frequency | Product No.    | $C_1 = C_2$     | $R_d$ |
|-----------|----------------|-----------------|-------|
| 4MHz      | CSA 4.00MG     | 30pF            | 0 kΩ  |
| 4MHz      | CST 4.00MGW    | (Built-in 30pF) | 0 kΩ  |
| 8MHz      | CSA 8.0MT      | 30pF            | 0 kΩ  |
| 8MHz      | CST 8.0MT      | (Built-in 30pF) | 0 kΩ  |
| 12MHz     | CSA 12.0MT     | 30pF            | 0 kΩ  |
| 12MHz     | CST 12.0MT     | (Built-in 30pF) | 0 kΩ  |
| 16MHz     | CSA 16.00MX040 | 5pF             | 0 kΩ  |

220192

Table 2 Ceramic Resonator (KYOCERA CORPOLATION)

| Frequency | Product No. | $C_1$ | $C_2$ | $R_d$ |
|-----------|-------------|-------|-------|-------|
| 4MHz      | KBR-4.0MSA  | 33pF  | 82pF  | 0 kΩ  |
| 10MHz     | KBR-10.0M   | 33pF  | 33pF  | 0 kΩ  |
| 12MHz     | KBR-12.0M   | 33pF  | 33pF  | 0 kΩ  |

220192



030289

Figure1. Resonator Connection



## (3) Recommended Circuit for External Clock Input



Condition : Duty of point A  $50 \pm 5\% (@ V_{cc} / 2)$

$CL = 50pF$  (max) of point A, B

The single drive from X1 is recommended for application using STOP mode, because X2 is fixed to "H" level (X1:high-impedance) during stop.

## (4) POWER ON RESET Circuit



**TOSHIBA**

**CHAPTER4 PACKAGE**

TOSHIBA CORPORATION



## 100 pin MFP (Mini Flat Package)

PACKAGE NAME : QFP100-P-1414

Unit : mm





---

## OVERSEAS SUBSIDIARIES AND AFFILIATES

---

**Toshiba America  
Electronic Components, Inc.**

Headquarters—Irvine, CA  
Tel. (714) 455-2000 Fax (714) 859-3963  
**Wakefield, MA (Boston)**  
Tel.: (617) 224-0074 Fax. (617) 224-1096  
**Edison, NJ**  
Tel.: (908) 248-8070 Fax. (908) 248-8030  
**Norcross, GA (Atlanta)**  
Tel.: (404) 368-0203 Fax. (404) 368-0075  
**Altamonte Springs, FL (Orlando)**  
Tel.: (407) 332-0966 Fax: (407) 339-3777  
**Deerfield, IL (Chicago)**  
Tel.: (708) 945-1500 Fax: (708) 945-1044  
**Richardson, TX (Dallas)**  
Tel.: (214) 480-0470 Fax: (214) 235-4114  
**Sunnyvale, CA**  
Tel.: (408) 737-9844 Fax: (408) 737-9905  
**Irvine, CA**  
Tel.: (714) 453-0224 Fax (714) 453-0125  
**Denver, CO**  
Tel. (303) 220-9848 Fax (303) 220-9856  
**Microelectronics Center—  
Sunnyvale, CA**  
Tel.: (408) 739-0560 Fax: (408) 746-0577  
**Electron Tube & Device Division—  
Deerfield, IL**  
Tel. (708) 945-1500 Fax. (708) 945-1044  
**Advanced Materials Division—  
Westboro, MA**  
Tel.: (508) 836-3939 Fax: (508) 836-3969

**Vertex Semiconductor Corporation**  
(R & D)—San Jose, CA  
Tel.: (408) 456-8900 Fax. (408) 456-8910**Toshiba Display Devices, Inc.**  
Horseheads, NY  
Tel.: (607) 796-3500 Fax (607) 796-3564**Industria Mexicana  
Toshiba S.A. DE C.V.**  
**Mexico**  
Tel.: 5-65-00-88 Telex: 017-72-560  
Cable: Toshiba Mexico**Toshiba Electronics Europe GmbH**

**Düsseldorf Head Office**  
Tel (0211) 5296-0 Fax: (0211) 5296-400  
Telex: 2114689 = TOSHD  
**Stuttgart Office**  
Tel (07152) 6045-0 Fax: (07152) 6045-45  
Telex: 7245706 = TOSSD  
**München Office**  
Tel (089) 928091-0 Fax 089-92809142  
Telex: 5-213683 = TOSMD  
**Berlin Office**  
Tel (030) 8859700 Fax (030) 88597017  
Telex: 2114689 = TOSHD

**Toshiba Electronics France SARL**

**France**  
Tel (1) 48 12 48 12 Fax (1) 48 94 51 15  
Telex: 232 030F

**Toshiba Electronics Italiana S.R.L**

**Italy**  
Tel 039-6057234 Fax 039-6057252  
Telex: 326423 SIAVBC

**Toshiba Electronics España, S.A.**

**Spain**  
Tel (1) 3143693 Fax (1) 3143610

**Toshiba Electronics (UK) Limited**

**U.K.**  
Tel 0276-694600 Fax: 0276-691583  
Telex: 858803 = TOSHEC

**Toshiba Electronics Scandinavia AB**

**Sweden**  
Tel 46-8-704 0900 Fax: 46-8-80 8459  
Telex: 14169 TSBSTK S

**Toshiba Semiconductor GmbH**

**F.R. Germany**  
Tel (0531) 3199-0 Fax: (0531) 3199-299  
Telex: 952368

**Toshiba Electronics Asia (Singapore) Pte. Ltd.**

**Singapore Head Office**  
Tel: 278-5252 Fax 271-5155  
**Bangkok Office**  
Tel (2) 501-1635~6 Fax (2) 501-1638

**Toshiba Electronics Trading  
(Malaysia) Sdn. Bhd.**

**Kuala Lumpur Head Office**  
Tel: 60-3-756-5308 Fax: 60-3-756-5561  
**Penang Office**  
Tel: 60-4-368-523 Fax: 60-4-368-515

**Toshiba Electronics Asia, Ltd.**

**Hong Kong Head Office**  
Tel. 852-3756111 Fax: 852-3750969  
Telex: 38501 TSBEH HX

**Seoul Office**  
Tel. (2) 757-2472~4 Fax (2) 757-2475  
**Shanghai Office**  
Tel: 86-21-472-3077, 86-21-472-3592  
Fax: 86-21-472-7028

**Guangzhou Office**  
Tel.: 86-20-3311122, 86-20-3311133  
Fax: 86-20-3311299

**Toshiba Electronics Taiwan Corp.**

**Taipei Head Office**  
Tel. 2-514-9988 Fax: 2-514-7892  
**Kaohsiung Office**  
Tel.: (07) 222-0826 Fax (07) 223-0046

**Toshiba Electronics Malaysia Sdn. Bhd.**

**Malaysia**  
Tel.: 03-352-6001-7 Fax: 03-352-6139  
Telex: TOEL MA 39506

**Toshiba Display Devices (Thailand)**

**Thailand**  
Tel.: (2) 501-1200 Fax: (2) 501-1209

**Toshiba Semiconductor (Thailand) Co., Ltd.**

**Thailand**  
Tel.: (2) 513-9648 Fax: (2) 513-9653

9307

---

In Touch with Tomorrow  
**TOSHIBA**

**TOSHIBA CORPORATION**  
INTERNATIONAL OPERATIONS—ELECTRONIC COMPONENTS  
1-1, SHIBAURA 1-CHOME, MINATO-KU TOKYO, 105-01, JAPAN  
Tel (03) 3457-3914 Fax (03) 3451-0576 Telex: J22587

