## Appendix B Instruction Lists



Explanation of symbols used in this document

1. Size

| В | 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. |
|------------|-------------------------------------------------------------------------------|
|            | 8 bit register:W,A,B,C,D,E,H,L                                                |
|            | 16 bit register: WA, BC, DE, HL, IX, IY, IZ, SP                               |
|            | 32 bit register: XWA, XBC, XDE, XHL, XIX, XIY, XIZ, XSP                       |
| r          | 8/16/32-bit general-purpose registers                                         |
|            |                                                                               |
| Cr         | All 8/16/32-bit CPU control registers                                         |
|            | DMASO to 3, DMADO to 3, DMACO to 3, DMAMO to 3, INTNEST                       |
|            |                                                                               |
| А          | A register (8 bits)                                                           |
| F          | Flag registers (8 bits)                                                       |
| F <i>'</i> | 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></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 to + 7FH                                            |
| d16        | 16-bit displacement: – 8000H to + 7FFFH                                       |
|            |                                                                               |
| сс         | 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                                 |
|            | 1                                                                             |

#### 3. Cord

| Z  | The code crepresent 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 (SZHVNC)

| -   | Flag doesn't change.                                               |
|-----|--------------------------------------------------------------------|
| *   | Flag changes by executing instruction.                             |
| 0   | Flag is cleared to "0".                                            |
| 1   | Flag is set to "1".                                                |
| Р   | Flag changes by executing instruction (It works as parity flag).   |
| V V | Flag changes by executing instruction (It works as overflow flag). |
| Х   | 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 = 100 ns at 20 MHz oscillation

1 state = 80 ns at 25 MHz oscillation

# ■ 900/H Instruction Lists (1/10)

(1) Load

| Group | Size                                                               | N                                                                                    | Inemonic                                                                                                  | Codes                                                                                               | (16 hex)                     | Function                                                                                                                                                                                                                  | SZHVNC   | Length<br>(byte)                                                    | 9                                      | Stat                   | e                    |
|-------|--------------------------------------------------------------------|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------------------------------------------------------------------|----------------------------------------|------------------------|----------------------|
| LD    | BWL<br>BWL<br>BWL<br>BWL<br>BWL<br>BWL<br>BW-<br>BW-<br>BW-<br>BW- | LD<br>LD<br>LD<br>LD<br>LD<br>LD<br>LD<br>CW><br>LD<br>CW><br>LD<br>CW><br>LD<br>CW> | R,r<br>r,R<br>r,#3<br>R,#<br>r,#<br>R,(mem)<br>(mem),R<br>(#8),#<br>(mem),#<br>(#16),(mem)<br>(mem),(#16) | C8+zz+r<br>C8+zz+r<br>20+zz+R<br>C8+zz+r<br>80+zz+mem<br>B0+mem<br>80+zz+mem<br>80+zz+mem<br>B0+mem | :40+zz+R<br>:#8:#<br>:00+z:# | $R \leftarrow r$ $r \leftarrow R$ $r \leftarrow #3$ $R \leftarrow #$ $r \leftarrow #$ $R \leftarrow (mem)$ $(mem) \leftarrow R$ $(#8) \leftarrow #$ $(#8) \leftarrow #$ $(#16) \leftarrow (mem)$ $(mem) \leftarrow (#16)$ |          | 2<br>2<br>2<br>1+#<br>2+#<br>2+M<br>2+M<br>2+#<br>2+#<br>4+M<br>4+M | 2.<br>2.<br>3.<br>4.<br>5.<br>5.<br>8. | 2.<br>3.               | 2<br>5<br>6<br>6<br> |
| PUSH  | B<br>B<br>-WL<br>BWL<br>BW-<br>BW-                                 | PUSH<br>PUSH<br>PUSH<br>PUSH<br>PUSH <w><br/>PUSH<w></w></w>                         |                                                                                                           | 18<br>14<br>18+zz+R<br>C8+zz+r<br>09+z<br>80+zz+mer                                                 | :04<br>:#<br>n:04            | $(-XSP) \leftarrow F$<br>$(-XSP) \leftarrow A$<br>$(-XSP) \leftarrow R$<br>$(-XSP) \leftarrow r$<br>$(-XSP) \leftarrow \#$<br>$(-XSP) \leftarrow (mem)$                                                                   | <br><br> | 1<br>1<br>2<br>1+#<br>2+M                                           |                                        | 3.<br>4.               | 6<br>-               |
| РОР   | B<br>B<br>-WL<br>BWL<br>BW-                                        | POP<br>POP<br>POP<br>POP<br>POP <w></w>                                              | F<br>A<br>R<br>r<br>(mem)                                                                                 | 19<br>15<br>38+zz+R<br>C8+zz+r<br>B0+mem                                                            | :05<br>:04+z                 | F ← (XSP+)<br>A ← (XSP+)<br>R ← (XSP+)<br>r ← (XSP+)<br>(mem) ← (XSP+)                                                                                                                                                    | *****    | 1<br>1<br>2<br>2+M                                                  |                                        | <br><br>4.<br>5.<br>7. | 7                    |
| LDA   | -WL                                                                | LDA                                                                                  | R,mem                                                                                                     | B0+mem                                                                                              | :10+zz+R                     | R ← mem                                                                                                                                                                                                                   |          | 2+M                                                                 |                                        | 4.                     |                      |
| LDAR  | -WL                                                                | LDAR                                                                                 | R,\$+4+d16                                                                                                | F3:13:d10                                                                                           | 6:20+zz+R                    | R ← PC+d16                                                                                                                                                                                                                |          | 5                                                                   |                                        | 7.                     | 7                    |

# (2) Exchange

| Group | Size            | Mr             | nemonic    | Codes (16 hex)             |     | Function          |                        | SZHVNC | Length<br>(byte) | State             |          |
|-------|-----------------|----------------|------------|----------------------------|-----|-------------------|------------------------|--------|------------------|-------------------|----------|
| EX    | B<br>BW-<br>BW- | EX<br>EX<br>EX | <b>,</b> - | 16<br>C8+zz+r<br>80+zz+men |     | F↔<br>R↔<br>(mem) | r                      | *****  | 2                | 2<br>3. 3<br>6. 6 | <br><br> |
| MIRR  | -W-             | MIRR           | r          | D8+r                       | :16 | r<0:№             | ISB>←r <msb:0></msb:0> |        | 2                | 3                 |          |

## ■ 900/H Instruction Lists (2/10)

#### (3) Load/Increment/Decrement & Compare Increment/Decrement Size

| Group | Size | Mnemonic                         | Codes (16 hex) | Function                                                                         | SZHVNC | Length<br>(byte) | State |
|-------|------|----------------------------------|----------------|----------------------------------------------------------------------------------|--------|------------------|-------|
|       | BW-  | LDI <w><br/>[(XDE+),(XHL+)]</w>  | 83+zz :10      | (XDE+) ← (XHL+)<br>BC ← BC-1                                                     | 0①0-   | 2                | 8.8   |
|       | BW-  | LDI <w><br/>(XIX+),(XIY+)</w>    | 85+zz :10      | (XIX+) ← (XIY+)<br>BC ← BC-1                                                     | 0①0-   | 2                | 8.8   |
|       | BW-  | LDIR <w><br/>[(XDE+),(XHL+)]</w> | 83+zz :11      | repeat<br>(XDE+) ← (XHL+)<br>BC ← BC-1<br>until BC=0                             | 000-   | 2                | 7n+1  |
|       | BW-  | LDIR <w><br/>(XIX+),(XIY+)</w>   | 85+zz :11      | repeat<br>(XIX+) ← (XIY+)<br>BC ← BC-1<br>until BC=0                             | 000-   | 2                | 7n+1  |
| LDxx  | BW-  | LDD <w><br/>[(XDE-),(XHL-)]</w>  | 83+zz :12      | (XDE-) ← (XHL-)<br>BC ← BC-1                                                     | 0①0-   | 2                | 8.8   |
|       | BW-  | LDD <w><br/>(XIX-),(XIY-)</w>    | 85+zz :12      | $\begin{array}{rrrr} (XIX-) \leftarrow (XIY-) \\ BC \leftarrow BC-1 \end{array}$ | 0①0-   | 2                | 8.8   |
|       | BW-  | LDDR <w><br/>[(XDE-),(XHL-)]</w> | 83+zz :13      | repeat<br>(XDE-) ← (XHL-)<br>BC ← BC-1<br>until BC=0                             |        | 2                | 7n+1  |
|       | BW-  | LDDR <w><br/>(XIX-),(XIY-)</w>   | 85+zz :13      | repeat<br>(XIX-) ← (XIY-)<br>BC ← BC-1<br>until BC=0                             |        | 2                | 7n+1  |
|       | BW-  | CPI [A/WA,(R+)]                  | 80+zz+R :14    | A/WA - (R+)<br>BC ← BC-1                                                         | *@*①1- | 2                | 6.6   |
| 0.0   | BW-  | CPIR [A/WA,(R+)]                 | 80+zz+R :15    | repeat<br>A/WA - (R+)<br>BC ← BC-1<br>until A/WA=(R)<br>or BC=0                  | *@*①1- | 2                | 6n+1  |
| CPxx  | BW-  | CPD [A/WA,(R-)]                  | 80+zz+R :16    | A/WA - (R-)<br>BC ← BC-1                                                         | *@*①1- | 2                | 6.6   |
| -     | BW-  | CPDR [A/WA,(R-)]                 | 80+zz+R :17    | repeat<br>A/WA - (R-)<br>BC ← BC-1<br>until A/WA=(R)<br>or BC=0                  | *@*①1- | 2                | 6n+1  |

Note 1: (1); If BC = 0 after execution, the P/V flag is set to 0, otherwise 1.

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

# ■ 900/H Instruction Lists (3/10)

#### (4) Arithmetic Operations

| Group | Size                                   | Mn                                             | emonic                                       | Codes (16 hex)                                                                                         | Function                                                                                                                                                                                         | SZHVNC                                                   | Length<br>(byte)               | State                                                    |
|-------|----------------------------------------|------------------------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|--------------------------------|----------------------------------------------------------|
| ADD   | BWL<br>BWL<br>BWL<br>BWL<br>BW-        | ADD<br>ADD<br>ADD<br>ADD<br>ADD<br>ADD <w></w> | R,r<br>r,#<br>R,(mem)<br>(mem),R<br>(mem),#  | C8+zz+r :80+R<br>C8+zz+r :C8:#<br>80+zz+mem:80+R<br>80+zz+mem:88+R<br>80+zz+mem:38:#                   | $\begin{array}{rrrr} R & \leftarrow R + r \\ r & \leftarrow r + \# \\ R & \leftarrow R + (mem) \\ (mem) \leftarrow (mem) + R \\ (mem) \leftarrow (mem) + \# \end{array}$                         | ***V0*<br>***V0*<br>***V0*<br>***V0*                     | 2<br>2+#<br>2+M<br>2+M<br>2+M  | 2. 2. 2<br>3. 4. 6<br>4. 4. 6<br>6. 6. 10<br>7. 8        |
| ADC   | BWL<br>BWL<br>BWL<br>BWL<br>BW-        | ADC<br>ADC<br>ADC<br>ADC<br>ADC<br>ADC <w></w> | R,r<br>r,#<br>R,(mem)<br>(mem),R<br>(mem),#  | C8+zz+r :90+R<br>C8+zz+r :C9:#<br>80+zz+mem:90+R<br>80+zz+mem:98+R<br>80+zz+mem:39:#                   | R ← R + r + CY<br>r ← r + # + CY<br>R ← R+(mem)+CY<br>(mem) ←(mem)+R+CY<br>(mem) ←(mem)+#+CY                                                                                                     | ***V0*<br>***V0*<br>***V0*<br>***V0*                     | 2<br>2+#<br>2+M<br>2+M<br>2+M# | 2. 2. 2<br>3. 4. 6<br>4. 4. 6<br>6. 6. 10<br>7. 8        |
| SUB   | BWL<br>BWL<br>BWL<br>BWL<br>BW-        | SUB<br>SUB<br>SUB<br>SUB<br>SUB <w></w>        | R,r<br>r,#<br>R,(mem)<br>(mem),R<br>(mem),#  | C8+zz+r :A0+R<br>C8+zz+r :CA:#<br>80+zz+mem:A0+R<br>80+zz+mem:A8+R<br>80+zz+mem:3A:#                   | $\begin{array}{rrrr} R & \leftarrow R - r \\ r & \leftarrow r - \# \\ R & \leftarrow R - (mem) \\ (mem) \leftarrow (mem) - R \\ (mem) \leftarrow (mem) - \# \end{array}$                         | ***V1*<br>***V1*<br>***V1*<br>***V1*<br>***V1*           | 2<br>2+#<br>2+M<br>2+M<br>2+M  | 2. 2. 2<br>3. 4. 6<br>4. 4. 6<br>6. 6. 10<br>7. 8        |
| SBC   | BWL<br>BWL<br>BWL<br>BWL<br>BW-        | SBC<br>SBC<br>SBC<br>SBC<br>SBC <w></w>        | R,r<br>r,#<br>R,(mem)<br>(mem),R<br>(mem),#  | C8+zz+r :B0+R<br>C8+zz+r :CB:#<br>80+zz+mem:B0+R<br>80+zz+mem:B8+R<br>80+zz+mem:3B:#                   | $\begin{array}{rcl} R & \leftarrow R - r - CY \\ r & \leftarrow r - \# - CY \\ R & \leftarrow R - (mem) - CY \\ (mem) \leftarrow (mem) - R - CY \\ (mem) \leftarrow (mem) - \# - CY \end{array}$ |                                                          | 2<br>2+#<br>2+M<br>2+M<br>2+M# | 2. 2. 2<br>3. 4. 6<br>4. 4. 6<br>6. 6. 10<br>7. 8        |
| СР    | BWL<br>BW-<br>BWL<br>BWL<br>BWL<br>BW- | CP<br>CP<br>CP<br>CP<br>CP<br>CP <w></w>       | R,r<br>r,#3<br>R,(mem)<br>(mem),R<br>(mem),# | C8+zz+r :F0+R<br>C8+zz+r :D8+#3<br>C8+zz+r :CF:#<br>80+zz+mem:F0+R<br>80+zz+mem:F8+R<br>80+zz+mem:3F:# | R - r<br>r - #3<br>r - #<br>R - (mem)<br>(mem) - R<br>(mem) - #                                                                                                                                  | ***V1*<br>***V1*<br>***V1*<br>***V1*<br>***V1*<br>***V1* | 2<br>2+#<br>2+M<br>2+M<br>2+M  | 2. 2. 2<br>2. 2<br>3. 4. 6<br>4. 4. 6<br>4. 4. 6<br>5. 6 |
| INC   | B<br>-WL<br>BW-                        | INC<br>INC<br>INC <w></w>                      | #3,r<br>#3,r<br>#3,(mem)                     | C8+r :60+#3<br>C8+zz+r :60+#3<br>80+zz+mem:60+#3                                                       | r ← r + #3<br>r ← r + #3<br>(mem) ← (mem) + #3                                                                                                                                                   | ***V0-<br><br>***V0-                                     | 2<br>2<br>2+M                  | 2<br>2. 2<br>6. 6                                        |
| DEC   | B<br>-WL<br>BW-                        | DEC<br>DEC<br>DEC <w></w>                      | #3,r<br>#3,r<br>#3,(mem)                     | C8+r :68+#3<br>C8+zz+r :68+#3<br>80+zz+mem:68+#3                                                       | r ← r - #3<br>r ← r - #3<br>(mem) ← (mem) - #3                                                                                                                                                   | ***V1-<br><br>***V1-                                     | 2<br>2<br>2+M                  | 2<br>2. 2<br>6. 6                                        |
| NEG   | BW-                                    | NEG                                            | r                                            | C8+zz+r :07                                                                                            | r ← 0 - r                                                                                                                                                                                        | ***V1*                                                   | 2                              | 2.2                                                      |
| EXTZ  | -WL                                    | EXTZ                                           | r                                            | C8+zz+r :12                                                                                            | r≺high> ← O                                                                                                                                                                                      |                                                          | 2                              | 3. 3                                                     |
| EXTS  | -WL                                    | EXTS                                           | r                                            | C8+zz+r :13                                                                                            | r <high> ← r<low.<br>MSB&gt;</low.<br></high>                                                                                                                                                    |                                                          | 2                              | 3. 3                                                     |
| DAA   | B                                      | DAA                                            | r                                            | C8+r :10                                                                                               | Decimal adjustment<br>after addition or<br>subtraction                                                                                                                                           | ***P-*                                                   | 2                              | 4                                                        |
| 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.

# ■ 900/H Instruction Lists (4/10)

| Group | Size              | Mnemonic                                | Codes (16 hex)                                   | Function                                                                                                   | SZHVNC      | Length<br>(byte) | State                   |
|-------|-------------------|-----------------------------------------|--------------------------------------------------|------------------------------------------------------------------------------------------------------------|-------------|------------------|-------------------------|
| MUL   | BW-<br>BW-<br>BW- | MUL RR,r<br>MUL rr,#<br>MUL RR,(mem)    | C8+zz+r :40+R<br>C8+zz+r :08:#<br>80+zz+mem:40+R | RR ← R×r<br>rr ← r×#<br>RR ← R×(mem)                                                                       |             | 2<br>2+#<br>2+M  | 11.14<br>12.15<br>13.16 |
| MULS  | BW-<br>BW-<br>BW- | MULS RR,r<br>MULS rr,#<br>MULS RR,(mem) | C8+zz+r :48+R<br>C8+zz+r :09:#<br>80+zz+mem:48+R | RR ← R×r ;signed<br>rr ← r×# ;signed<br>RR ←R×(mem);signed                                                 |             | 2<br>2+#<br>2+M  | 9.12<br>10.13<br>11.14  |
| DIV   | BW-<br>BW-<br>BW- | DIV RR,r<br>DIV rr,#<br>DIV RR,(mem)    | C8+zz+r :50+R<br>C8+zz+r :0A:#<br>80+zz+mem:50+R | R ← RR÷r<br>r ← rr÷#<br>R ← RR÷(mem)                                                                       | V<br>V<br>V | 2+#              | 15.23<br>15.23<br>16.24 |
| DIVS  | BW-<br>BW-<br>BW- | DIVS RR,r<br>DIVS rr,#<br>DIVS RR,(mem) | C8+zz+r :58+R<br>C8+zz+r :0B:#<br>80+zz+mem:58+R | R ← RR÷r ;signed<br>r ← rr÷# ;signed<br>R ← RR÷(mem);signed                                                | V           | 2+#              | 18.26<br>18.26<br>19.27 |
| MULA  | -W-               | MULA rr                                 | D8+r :19                                         | Multiply and add<br>signed<br><u>rr← rr+(XDE)</u> × <u>(XHL)</u><br>32bit 32bit 16bit 16bit<br>XHL ← XHL-2 | **-V        | 2                | 19                      |
|       | -W-               | MINC1 #,r<br>(#=2**n)<br>(1<=n<=15)     | D8+r :38:#-1                                     | modulo increment<br>;+1<br>if (r mod #)=(#-1)<br>then r←r-(#-1)<br>else r←r+1                              |             | 4                | 5                       |
| MINC  | -W-               | MINC2 #,r<br>(#=2**n)<br>(2<=n<=15)     | D8+r :39:#-2                                     | modulo increment<br>;+2<br>if (r mod #)=(#-2)<br>then r←r-(#-2)<br>else r←r+2                              |             | 4                | 5                       |
| -     | -W-               | MINC4 #,r<br>(#=2**n)<br>(3<=n<=15)     | D8+r :3A:#-4                                     | modulo increment<br>;+4<br>if (r mod #)=(#-4)<br>then r←r-(#-4)<br>else r←r+4                              |             | 4                | 5                       |
|       | -W-               | MDEC1 #,r<br>(#=2**n)<br>(1<=n<=15)     | D8+r :3C:#-1                                     | modulo decrement<br>;-1<br>if (r mod #)=0<br>then r←r+(#-1)<br>else r←r-1                                  |             | 4                | 4                       |
| MDEC  | -W-               | MDEC2 #,r<br>(#=2**n)<br>(2<=n<=15)     | D8+r :3D:#-2                                     | modulo decrement<br>;-2<br>if (r mod #)=0<br>then r←r+(#-2)<br>else r←r-2                                  |             | 4                | 4                       |
|       | -W-               | MDEC4                                   | D8+r :3E:#-4                                     | modulo decrement<br>;-4<br>if (r mod #)=0<br>then r←r+(#-4)<br>else r←r-4                                  |             | 4                | 4                       |

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×8 bits, 16/8 bits), word register (16 bits) is specified; when the operation is in words (16 bits×16 bits, 32/16 bits), long word register (32 bits) is specified.

# ■ 900/H Instruction Lists (5/10)

# (5) Logical operations

| Group | Size                            | Mnemonic                                |                                             | Codes (16 hex)                                                                       | Function                                                                                    | SZHVNC                                         | Length<br>(byte)  | State                                             |
|-------|---------------------------------|-----------------------------------------|---------------------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|------------------------------------------------|-------------------|---------------------------------------------------|
| AND   | BWL<br>BWL<br>BWL<br>BWL<br>BW- | AND<br>AND<br>AND<br>AND<br>AND <w></w> | R,r<br>r,#<br>R,(mem)<br>(mem),R<br>(mem),# | C8+zz+r :C0+R<br>C8+zz+r :CC:#<br>80+zz+mem:C0+R<br>80+zz+mem:C8+R<br>80+zz+mem:3C:# | R ← R and r<br>r ← r and #<br>R ← R and (mem)<br>(mem) ← (mem) and R<br>(mem) ← (mem) and # | **1P00<br>**1P00<br>**1P00<br>**1P00<br>**1P00 | 2+#<br>2+M<br>2+M | 2. 2. 2<br>3. 4. 6<br>4. 4. 6<br>6. 6. 10<br>7. 8 |
| OR    | BWL<br>BWL<br>BWL<br>BWL<br>BW- | OR<br>OR<br>OR<br>OR<br>OR <w></w>      | R,r<br>r,#<br>R,(mem)<br>(mem),R<br>(mem),# | C8+zz+r :E0+R<br>C8+zz+r :CE:#<br>80+zz+mem:E0+R<br>80+zz+mem:E8+R<br>80+zz+mem:3E:# | R ← R or r<br>r ← r or #<br>R ← R or (mem)<br>(mem) ← (mem) or R<br>(mem) ← (mem) or #      | **0P00<br>**0P00<br>**0P00<br>**0P00<br>**0P00 | 2+#<br>2+M<br>2+M | 2. 2. 2<br>3. 4. 6<br>4. 4. 6<br>6. 6. 10<br>7. 8 |
| XOR   | BWL<br>BWL<br>BWL<br>BWL<br>BW- | XOR<br>XOR<br>XOR<br>XOR<br>XOR <w></w> | R,r<br>r,#<br>R,(mem)<br>(mem),R<br>(mem),# | C8+zz+r :D0+R<br>C8+zz+r :CD:#<br>80+zz+mem:D0+R<br>80+zz+mem:D8+R<br>80+zz+mem:3D:# | R ← R xor r<br>r ← r xor #<br>R ← R xor (mem)<br>(mem) ← (mem) xor R<br>(mem) ← (mem) xor # | **0P00<br>**0P00<br>**0P00<br>**0P00<br>**0P00 | 2+#<br>2+M<br>2+M | 2. 2. 2<br>3. 4. 6<br>4. 4. 6<br>6. 6. 10<br>7. 8 |
| CPL   | BW-                             | CPL                                     | r                                           | C8+zz+r :06                                                                          | r ← not r                                                                                   | 1-1-                                           | 2                 | 2.2                                               |

## ■ 900/H Instruction Lists (6/10)

#### (6) Bit operations

| Group                    | Size                 | Mn                                        | emonic                               | Codes (                                | 16 hex)          | Function                                                                                                | SZHVNC           | Length<br>(byte)     | State                |
|--------------------------|----------------------|-------------------------------------------|--------------------------------------|----------------------------------------|------------------|---------------------------------------------------------------------------------------------------------|------------------|----------------------|----------------------|
| LDCF                     | BW-<br>BW-<br>B<br>B | LDCF<br>LDCF<br>LDCF<br>LDCF              | #4,r<br>A ,r<br>#3,(mem)<br>A ,(mem) | C8+zz+r<br>C8+zz+r<br>B0+men<br>B0+men |                  | CY ← r<#4><br>CY ← r <a><br/>CY ← (mem)&lt;#3&gt;<br/>CY ← (mem)<a></a></a>                             | *<br>*<br>*      | 3<br>2<br>2+M<br>2+M | 3.3<br>3.3<br>6<br>6 |
| STCF                     | BW-<br>BW-<br>B<br>B | STCF<br>STCF<br>STCF<br>STCF              | #4,r<br>A ,r<br>#3,(mem)<br>A ,(mem) | C8+zz+r<br>C8+zz+r<br>B0+mem<br>B0+mem |                  | r<#4> ← CY<br>r <a> ← CY<br/>(mem)&lt;#3&gt; ← CY<br/>(mem)<a> ← CY</a></a>                             | <br>             | 3<br>2<br>2+M<br>2+M | 3.3<br>3.3<br>7<br>7 |
| ANDCF                    | BW-<br>BW-<br>B<br>B | ANDCF<br>ANDCF<br>ANDCF<br>ANDCF<br>ANDCF | #4,r<br>A ,r<br>#3,(mem)<br>A ,(mem) | C8+zz+r<br>C8+zz+r<br>B0+mem<br>B0+mem |                  | CY ← CY and r<#4><br>CY ← CY and r <a><br/>CY ← CY and (mem)&lt;#3&gt;<br/>CY ← CY and (mem)<a></a></a> | *<br>*<br>*<br>* | 3<br>2<br>2+M<br>2+M | 3.3<br>3.3<br>6<br>6 |
| ORCF                     | BW-<br>BW-<br>B<br>B | ORCF<br>ORCF<br>ORCF<br>ORCF              | #4,r<br>A ,r<br>#3,(mem)<br>A ,(mem) | C8+zz+r<br>C8+zz+r<br>B0+mem<br>B0+mem |                  | CY ← CY or r<#4><br>CY ← CY or r <a><br/>CY ← CY or (mem)&lt;#3&gt;<br/>CY ← CY or (mem)<a></a></a>     | *<br>*<br>*<br>* | 3<br>2<br>2+M<br>2+M | 3.3<br>3.3<br>6<br>6 |
| XORCF                    | BW-<br>BW-<br>B<br>B | XORCF<br>XORCF<br>XORCF<br>XORCF          | #4,r<br>A ,r<br>#3,(mem)<br>A ,(mem) | C8+zz+r<br>C8+zz+r<br>B0+mem<br>B0+mem |                  | CY ← CY xor r<#4><br>CY ← CY xor r <a><br/>CY ← CY xor (mem)&lt;#3&gt;<br/>CY ← CY xor (mem)<a></a></a> | *<br>*<br>*      | 3<br>2<br>2+M<br>2+M | 3.3<br>3.3<br>6<br>6 |
| RCF<br>SCF<br>CCF<br>ZCF | <br><br>             | RCF<br>SCF<br>CCF<br>ZCF                  |                                      | 10<br>11<br>12<br>13                   |                  | CY ← 0<br>CY ← 1<br>CY ← not CY<br>CY ← not "Z" flag                                                    |                  | 1<br>1<br>1<br>1     | 2<br>2<br>2<br>2     |
| BIT                      | BW-<br>B             | BIT<br>BIT                                | #4,r<br>#3,(mem)                     | C8+zz+r<br>B0+mem                      | :33:#4<br>:C8+#3 | Z ← not r<#4><br>Z ← not (mem)<#3>                                                                      | X*1X0-<br>X*1X0- | 3<br>2+M             | 3.3<br>6             |
| RES                      | BW-<br>B             | RES<br>RES                                | #4,r<br>#3,(mem)                     | C8+zz+r<br>B0+mem                      | :30:#4<br>:B0+#3 | r<#4> ← 0<br>(mem)<#3> ← 0                                                                              |                  | 3<br>2+M             | 3.3<br>7             |
| SET                      | BW-<br>B             | SET<br>SET                                | #4,r<br>#3,(mem)                     | C8+zz+r<br>B0+mem                      | :31:#4<br>:B8+#3 | r<#4> ← 1<br>(mem)<#3> ← 1                                                                              |                  | 3<br>2+M             | 3.3<br>7             |
| CHG                      | ВW-<br>В             | CHG<br>CHG                                | #4,r<br>#3,(mem)                     | C8+zz+r<br>B0+mem                      | :32:#4<br>:C0+#3 | r<#4> ← not r<#4><br>(mem)<#3>←not (mem)<#3>                                                            |                  | 3<br>2+M             | 3.3<br>7             |
| TSET                     | BW-<br>B             | TSET<br>TSET                              | #4,r<br>#3,(mem)                     | C8+zz+r<br>B0+mem                      | :34:#4<br>:A8+#3 | Z←not r<#4> : r<#4>←1<br>Z ← not (mem)<#3><br>(mem)<#3> ← 1                                             | X*1X0-<br>X*1X0- | 3<br>2+M             | 4.4<br>7             |
| BS1                      | -W-<br>-W-           | BS1F<br>BS1B                              | A,r<br>A,r                           | D8+r<br>D8+r                           | :0E<br>:0F       | A ← 1 search r ;<br>Forward<br>A ← 1 search r ;<br>Backward                                             | ①                |                      | 3<br>3               |

Note: (1); 0 is set when the bit searched for is found, otherwise 1 is set and an undefined value is set in the A register.

### ■ 900/H Instruction Lists (7/10)

## (7) Special operations and CPU control

| Group | Size       | M          | nemonic      | Codes              | (16 hex)  |                            | Function                                | SZHVNC | Length<br>(byte) | State          |
|-------|------------|------------|--------------|--------------------|-----------|----------------------------|-----------------------------------------|--------|------------------|----------------|
| NOP   |            | NOP        |              | 00                 |           | no ope                     | ration                                  |        | 1                | 2              |
| EI    |            | EI         | [#3]         | 06                 | :#3       | Sets i<br>flag.<br>IFF←#3  | nterrupt enable                         |        | 2                | 3              |
| DI    |            | DI         |              | 06                 | :07       | Disabl<br>IFF←7            | es interrupt.                           |        | 2                | 4              |
| PUSH  | -W-        | PUSH       | SR           | 02                 |           | (-XSP)                     | ←SR                                     |        | 1                | 3              |
| POP   | -W-        | РОР        | SR           | 03                 |           | SR←(XS                     | P+)                                     | *****  | 1                | 4              |
| SWI   |            | SWI        | [#3]         | F8+#3              |           | PUSH                       | re interrupt<br>PC&SR<br>(FFFF00H+4×#3) |        | 1                | 19             |
| HALT  |            | HALT       |              | 05                 |           | CPU ha                     | lt                                      |        | 1                | 6              |
| LDC   | BWL<br>BWL | LDC<br>LDC | cr,r<br>r,cr | C8+zz+r<br>C8+zz+r |           | cr ← r<br>r ← c            |                                         |        |                  | 3.3.3<br>3.3.3 |
| LDX   | B          | LDX        | (#8),#       | F7:00:#8           | 3:00:#:00 | (#8) ←                     | #                                       |        | 6                | 8              |
| LINK  | L          | LINK       | r,d16        | E8+r               | :0C:d16   |                            | ,XSP<br>SP,d16                          |        | 4                | 8              |
| UNLK  | L          | UNLK       | r            | E8+r               | :0D       | LD X:<br>POP r             | SP,r                                    |        | 2                | 7              |
| LDF   |            | LDF        | #3           | 17                 | :#3       |                            | egister bank.<br>#3 (0 at reset)        |        | 2                | 2              |
| INCF  |            | INCF       |              | 0C                 |           | Switch<br>banks.<br>RFP← R | es register<br>RFP + 1                  |        | 1                | 2              |
| DECF  |            | DECF       |              | 0D                 |           | Switch<br>banks.<br>RFP← R | es register<br>RFP - 1                  |        | 1                | 2              |
| SCC   | BW-        | scc        | cc,r         | C8+zz+r            | :70+cc    |                            | then r ← 1<br>else r ← O                |        | 2                | 2.2            |

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

# ■ 900/H Instruction Lists (8/10)

#### (8) Rotate and Shift

| Group | Size              | Mn                        | emonic               | Codes (16 hex)                                | Function                        | SZHVNC                     | Length<br>(byte) | State                 |
|-------|-------------------|---------------------------|----------------------|-----------------------------------------------|---------------------------------|----------------------------|------------------|-----------------------|
| RLC   | BWL<br>BWL<br>BW- | RLC<br>RLC<br>RLC <w></w> | #4,r<br>A,r<br>(mem) | C8+zz+r :E8:#4<br>C8+zz+r :F8<br>80+zz+mem:78 | CY <b>←</b> MSB←0 − <b>←</b>    | **0P0*<br>**0P0*<br>**0P0* | 2                | 3+n/4<br>3+n/4<br>6.6 |
| RRC   | BWL<br>BWL<br>BW- | RRC<br>RRC<br>RRC <w></w> | #4,r<br>A,r<br>(mem) | C8+zz+r :E9:#4<br>C8+zz+r :F9<br>80+zz+mem:79 |                                 | **0P0*<br>**0P0*<br>**0P0* | 2                | 3+n/4<br>3+n/4<br>6.6 |
| RL    | BWL<br>BWL<br>BW- | RL<br>RL<br>RL <w></w>    | #4,r<br>A,r<br>(mem) | C8+zz+r :EA:#4<br>C8+zz+r :FA<br>80+zz+mem:7A | <br>CY]←MSB←0]←                 | **0P0*<br>**0P0*<br>**0P0* | 2                | 3+n/4<br>3+n/4<br>6.6 |
| RR    | BWL<br>BWL<br>BW- | RR<br>RR<br>RR <w></w>    | #4,r<br>A,r<br>(mem) | C8+zz+r :EB:#4<br>C8+zz+r :FB<br>80+zz+mem:7B | →[MSB→0]→[CY]                   | **0P0*<br>**0P0*<br>**0P0* | 2                | 3+n/4<br>3+n/4<br>6.6 |
| SLA   | BWL<br>BWL<br>BW- | SLA<br>SLA<br>SLA <w></w> | #4,r<br>A,r<br>(mem) | C8+zz+r :EC:#4<br>C8+zz+r :FC<br>80+zz+mem:7C | CY <mark>← MSB←0 ←</mark> 0     | **0P0*<br>**0P0*<br>**0P0* | 2                | 3+n/4<br>3+n/4<br>6.6 |
| SRA   | BWL<br>BWL<br>BW- | SRA<br>SRA<br>SRA <w></w> | #4,r<br>A,r<br>(mem) | C8+zz+r :ED:#4<br>C8+zz+r :FD<br>80+zz+mem:7D | MSB→0→<br>CY                    | **0P0*<br>**0P0*<br>**0P0* | 2                | 3+n/4<br>3+n/4<br>6.6 |
| SLL   | BWL<br>BWL<br>BW- | SLL<br>SLL<br>SLL <w></w> | #4,r<br>A,r<br>(mem) | C8+zz+r :EE:#4<br>C8+zz+r :FE<br>80+zz+mem:7E | <u>[CY]</u> ← <u>MSB</u> ←0]← 0 | **0P0*<br>**0P0*<br>**0P0* | 2                | 3+n/4<br>3+n/4<br>6.6 |
| SRL   | BWL<br>BWL<br>BW- | SRL<br>SRL<br>SRL <w></w> | #4,r<br>A,r<br>(mem) | C8+zz+r :EF:#4<br>C8+zz+r :FF<br>80+zz+mem:7F | 0 →[MSB→0]→[CY]                 | **0P0*<br>**0P0*<br>**0P0* | 2                | 3+n/4<br>3+n/4<br>6.6 |
| RLD   | B                 | RLD                       | [A,](mem)            | 80+mem :06                                    | Areg mem v<br>7-4 3-0 7-4 3-0   | **0P0-                     | 2+M              | 14                    |
| RRD   | B                 | RRD                       | [A,](mem)            | 80+mem :07                                    | Areg mem<br>7-4 3-0 7-4 3-0     | **0P0-                     | 2+M              | 14                    |

Note 1: When #4/A is used to specify the number of shifts, module 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.

Note 3: RLCA, RRCA, RLA, RRA, SLAA, SRAA, SLLA, and SRLA In the TLCS-900, these flags change.

## ■ 900/H Instruction Lists (9/10)

# (9) Jump, Call and Return

| Group | Size | Mnemonic                             | Codes (16 hex)                     | Function                                                                                        | SZHVNC        | Length<br>(byte)        | State                                         |
|-------|------|--------------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------|---------------|-------------------------|-----------------------------------------------|
| JP    |      | JR [cc,]\$+2+d8<br>JRL [cc,]\$+3+d16 | 1B :#24<br>60+cc :d8<br>70+cc :d16 | PC ← #16<br>PC ← #24<br>if cc then PC ← PC+d8<br>if cc then PC ← PC+d16<br>if cc then PC ← mem  |               | 3<br>4<br>2<br>3<br>2+M | 5<br>6<br>5/2 (T/F)<br>5/2 (T/F)<br>7/4 (T/F) |
| CALL  |      |                                      | 1D :#24<br>1E :d16                 | PUSH PC : JP #16<br>PUSH PC : JP #24<br>PUSH PC : JR \$+3+d16<br>if cc then<br>PUSH PC : JP mem |               | 3                       | 9<br>10<br>10<br>12/4 (T/F)                   |
| DJNZ  |      | DJNZ<br>[r,]\$+3/4+d8                | C8+zz+r :1C:d8                     | r←r-1<br>if r≠0 then JR \$+3+d8                                                                 |               | 3                       | 6 (r≠0)<br>4 (r=0)                            |
| RET   |      | RET<br>RET CC<br>RETD d16<br>RETI    |                                    | POP PC<br>if cc then POP PC<br>RET : ADD XSP,d16<br>POP SR&PC                                   | <br><br>***** |                         | 9<br>12/4 (T/F)<br>11<br>12                   |

Note 1: (T/F) represents the number of states at true / false.

# ■ Instruction Lists of 900/H (10/10)

## (10) Addressing mode

| type  | mode      | state |  |  |  |  |
|-------|-----------|-------|--|--|--|--|
| R     | R         | + 0   |  |  |  |  |
| r     | r         | + 1   |  |  |  |  |
|       | (R)       | + 0   |  |  |  |  |
|       | (R + d8)  | + 1   |  |  |  |  |
|       | (#8)      | + 1   |  |  |  |  |
|       | (#16)     | + 2   |  |  |  |  |
|       | (#24)     | + 3   |  |  |  |  |
| (mem) | (r)       | + 1   |  |  |  |  |
|       | (r + d16) | + 3   |  |  |  |  |
|       | (r + r8)  | + 3   |  |  |  |  |
|       | (r + r16) | + 3   |  |  |  |  |
|       | ( – r)    | + 1   |  |  |  |  |
|       | (r + )    | + 1   |  |  |  |  |

#### (11) Interrupt

|      | mode                         | operation                                                                                        | state    |
|------|------------------------------|--------------------------------------------------------------------------------------------------|----------|
|      | ral-purpose<br>pt processing | PUSH PC<br>PUSH SR<br>IFF ← accepted level + 1<br>INTNEST ← INTNEST + 1<br>JP (FFFF00H + vector) | 18       |
|      | I/O to MEM                   | (DMADn + ) ← (DMASn)                                                                             | 8. 8. 12 |
|      | I/O to MEM                   | (DMADn – ) ← (DMASn)                                                                             | 8. 8. 12 |
| HDMA | MEM to I/O                   | (DMADn) ← (DMASn + )                                                                             | 8. 8. 12 |
|      | MEM to I/O                   | (DMADn) ← (DMASn – )                                                                             | 8. 8. 12 |
|      | I/O to I/O                   | (DMADn) ← (DMASn)                                                                                | 8. 8. 12 |
|      | Counter                      | DMASn ← DMASn + 1                                                                                | 5        |

(Note) For details of interrupt processing, refer to Chapter2 "3.3 Interrupts".

# Appendix C Instruction Code Maps (1/4)

# 1-byte op code instructions

| H/L | 0     | 1     | 2            | 3                          | 4            | 5        | 6           | 7             | 8              | 9            | Α               | В                    | С                    | D            | E               | F            |
|-----|-------|-------|--------------|----------------------------|--------------|----------|-------------|---------------|----------------|--------------|-----------------|----------------------|----------------------|--------------|-----------------|--------------|
| 0   | NOP   | X     | PUSH<br>SR   | POP<br>SR                  | X            | 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>A | EX<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, n       | nnn      |             |               |                |              |                 | POP                  | RR                   |              |                 |              |
| 5   |       |       |              |                            |              |          |             |               |                |              |                 | POP                  | XRR                  |              |                 |              |
| 6   | F     | LT    | LE           | ULE                        | PE/OV        | M/MI     | z           | JR<br>C       | cc,PC +<br>(T) | d<br>GE      | GT              | UGT                  | PO/NOV               | P/PL         | NZ              | NC           |
| 7   | F     | LT    | LE           | ULE                        | PE/OV        | M/MI     | Z           | JRL<br>C      | cc,PC +<br>(T) | dd<br>GE     | GT              | UGT                  | PO/NOV               | P/PL         | NZ              | NC           |
| 8   | (XWA) | (XBC) | (XDE)        | scr<br>(XHL)               |              | (XIY)    | (XIZ)       | (XSP)         | (XWA<br>+ d)   | (XBC<br>+ d) | (XDE<br>+ d)    | scr<br>(XHL<br>+ d)  | : B<br>(XIX<br>+ d)  | (XIY<br>+ d) | (XIZ<br>+ d)    | (XSP<br>+ d) |
| 9   | (XWA) | (XBC) | (XDE)        | scr.<br>(XHL)              |              | (XIY)    | (XIZ)       | (XSP)         | (XWA<br>+ d)   | (XBC<br>+ d) | (XDE<br>+ d)    | scr.<br>(XHL<br>+ d) | . W<br>(XIX<br>+ d)  | (XIY<br>+ d) | (XIZ<br>+ d)    | (XSP<br>+ d) |
| Α   | (XWA) | (XBC) | (XDE)        |                            | . L<br>(XIX) | (XIY)    | (XIZ)       | (XSP)         | (XWA<br>+ d)   | (XBC<br>+ d) | (XDE<br>+ d)    | sci<br>(XHL<br>+ d)  | r. L<br>(XIX<br>+ d) | (XIY<br>+ d) | (XIZ<br>+ d)    | (XSP<br>+ d) |
| в   | (XWA) | (XBC) | (XDE)        | d<br>(XHL)                 |              | (XIY)    | (XIZ)       | (XSP)         | (XWA<br>+ d)   | (XBC<br>+ d) | (XDE<br>+ d)    | d<br>(XHL<br>+ d)    | st<br>(XIX<br>+ d)   | (XIY<br>+ d) | (XIZ<br>+ d)    | (XSP<br>+ d) |
| с   | (n)   | (nn)  | scr<br>(nnn) | <sup>.</sup> . B<br> (mem) | ( – xrr)     | (xrr + ) |             | reg. B<br>r   | w              | А            | В               | reg<br>C             | g. B<br>D            | E            | Н               | L            |
| D   | (n)   | (nn)  |              | . W<br> (mem)              | ( – xrr)     | (xrr + ) |             | reg. W<br>rr  | WA             | вс           | DE              | reg<br>HL            | . W<br>IX            | IY           | IZ              | SP           |
| E   | (n)   | (nn)  |              | r. L<br> (mem)             | ( – xrr)     | (xrr + ) |             | reg. L<br>xrr | XWA            | ХВС          | XDE             | reg<br>XHL           | g. L<br>XIX          | XIY          | XIZ             | XSP          |
| F   | (n)   | (nn)  |              | st<br> (mem)               | ( – xrr)     | (xrr + ) |             | LDX<br>(n), n | 0              | 1            | 2               | SWI<br>3             | n<br>4               | 5            | 6               | 7            |

Note 1: Codes in blank parts are undefined instructions (i.e., illegal instructions). Note 2: Dummy instructions are assigned to codes 01H and 04H. Do not use them.

## Appendix C Instruction Code Maps (2/4)

### 1st byte: reg

| H/L | 0            | 1    | 2          | 3          | 4                 | 5    | 6                | 7        | 8     | 9         | A            | В            | С                 | D      | Е     | F            |
|-----|--------------|------|------------|------------|-------------------|------|------------------|----------|-------|-----------|--------------|--------------|-------------------|--------|-------|--------------|
|     | U            | I    | 2          | LD         | PUSH              | POP  | CPL              | ,<br>NEG | MUL   | MULS      |              |              | LINK L            | UNLK L | BS1F  | BS1B         |
| 0   |              |      |            |            | 1030              | FUF  | BW               | BW       |       | IVIULS    |              | BW           |                   |        | DJIF  | <u>W</u>     |
|     |              |      |            | r,#        | r                 | r    | r                | r        | rr,#  | rr,#      | rr,#         | rr,#         | r, dd             | r      | A, r  | A, r         |
| 1   | DAA <u>B</u> |      | EXTZ<br>WL | EXTS<br>WL | PAA<br><u>WL</u>  |      | MIRR<br><u>W</u> |          |       | MULA<br>W | $\mathbb{N}$ | $\mathbb{N}$ | DJNZ<br>BW        |        |       |              |
|     | r            |      | r          | r          | r                 |      | r                |          |       | r         | $  \land$    | $  \land$    | r, d              |        |       |              |
| 2   | ANDCF        | ORCF | XORCF      | LDCF       | STCF<br>BW        |      |                  |          | ANDCF | ORCF      | XORCF        | LDCF         | STCF              |        | LDC   | LDC          |
|     | #, r         | #, r | #, r       | #, r       | <u> </u>          |      |                  |          | A, r  | A, r      | A, r         | A, r         | <u>BW</u><br>A, r |        | cr, r | r, cr        |
| 3   | RES          | SET  | CHG        | BIT        | TSET              |      |                  |          | MINC1 | MINC2     | MINC4        | $\backslash$ | MDEC1             | MDEC2  | MDEC4 | $\mathbb{N}$ |
|     | #, r         | #, r | #, r       | #, r       | <u>BW</u><br>#, r |      |                  |          |       | #, r      | W            |              |                   | #, r   | w     |              |
| 4   |              |      |            | MUL        | R, r              |      |                  | BW       |       |           |              | MULS         | R, r              |        |       | BW           |
|     |              |      |            |            |                   |      |                  | <u></u>  |       |           |              |              |                   |        |       |              |
| 5   |              |      |            | DIV        | R, r              |      |                  | BW       |       |           |              | DIVS         | R, r              |        |       | BW           |
|     |              |      |            |            |                   |      |                  |          |       |           |              |              |                   |        |       |              |
| 6   |              |      |            | INC        | #3, r             |      |                  |          |       |           |              | DEC          | #3, r             |        |       |              |
|     | 8            | 1    | 2          | 3          | 4                 | 5    | 6                | 7        | 8     | 1         | 2            | 3            | 4                 | 5      | 6     | 7            |
| 7   |              |      |            |            |                   |      |                  | scc      | cc, r |           |              |              |                   |        |       | <u>BW</u>    |
|     | F            | LT   | LE         | ULE        | PE/OV             | M/MI | Z                | С        | (T)   | GE        | GT           | UGT          | PO/NOV            | P/PL   | NZ    | NC           |
| 8   |              |      |            | ADD        | R, r              |      |                  |          |       |           |              | LD           | R, r              |        |       |              |
|     |              |      |            |            |                   |      |                  |          |       |           |              |              |                   |        |       |              |
| 9   |              |      |            | ADC        | R, r              |      |                  |          |       |           |              | LD           | r, R              |        |       |              |
|     |              |      |            |            |                   |      |                  |          |       |           |              |              |                   |        |       |              |
| Α   |              |      |            | SUB        | R, r              |      |                  |          | 0     | 1         | 2            | LD<br>3      | r, #3<br>4        | 5      | 6     | 7            |
|     |              |      |            |            |                   |      |                  |          |       | -         | 2            |              |                   |        |       |              |
| В   |              |      |            | SBC        | R, r              |      |                  |          |       |           |              | EX           | R, r              |        |       | <u>BW</u>    |
| с   |              |      |            | AND        | R, r              |      |                  |          | ADD   | ADC       | SUB          | SBC          | AND               | XOR    | OR    | СР           |
|     |              |      |            | /          |                   |      |                  |          | r, #  | r, #      | r, #         | r, #         | r, #              | r, #   | r, #  | r, #         |
| D   |              |      |            | XOR        | R, r              |      |                  |          |       |           |              | СР           | r, #3             |        |       | BW           |
|     |              |      |            |            |                   |      |                  |          | 0     | 1         | 2            | 3            | 4                 | 5      | 6     | 7            |
| Е   |              |      |            | OR         | R, r              |      |                  |          | RLC   | RRC       | RL           | RR           | SLA               | SRA    | SLL   | SRL          |
|     |              |      |            |            |                   |      |                  |          | #, r  | #, r      | #, r         | #, r         | #, r              | #, r   | #, r  | #, r         |
| F   |              |      |            | СР         | R, r              |      |                  |          | RLC   | RRC       | RL           | RR           | SLA               | SRA    | SLL   | SRL          |
|     |              |      |            |            |                   |      |                  |          | A, r  | A, r      | A, r         | A, r         | A, r              | A, r   | A, r  | A, r         |

Register specified by the 1st byte code. (Any CPU registers can be specified.)
Register specified by the 2nd byte code. (Only eight current registers can be specified.)
Operand size is a byte.
Operand size is a word.
Operand size is a long word.

r R B W L

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            | А   | В          | С            | D   | E   | F             |
|-----|-----|------|-----|-------------------|-------------------|------|-----|-------------------|-----|--------------|-----|------------|--------------|-----|-----|---------------|
| 0   |     |      |     |                   | PUSH<br><u>BW</u> |      | RLD | RLD <u>B</u>      |     |              |     |            |              |     |     |               |
|     |     |      |     |                   | (mem)             |      |     | nem)              |     |              |     |            |              |     |     |               |
| 1   | LDI | LDIR | LDD | LDDR<br><u>BW</u> | CPI               | CPIR | CPD | CPDR<br><u>BW</u> |     | LD <u>BW</u> |     |            |              |     |     |               |
|     |     |      |     |                   |                   |      |     |                   |     | (nn), (m)    |     |            |              |     |     |               |
| 2   |     |      |     | LD                | R, (men           | n)   |     |                   |     |              |     |            |              |     |     |               |
| 3   |     |      |     | EX                | (mem),            | R    |     | <u>BW</u>         | ADD | ADC          | SUB | SBC<br>(me | AND<br>m) ,# | XOR | OR  | CP <u>BW</u>  |
| 4   |     |      |     | MUL               | R, (men           | n)   |     | <u>BW</u>         |     |              |     | MULS       | R, (mer      | n)  |     | <u>BW</u>     |
| 5   |     |      |     | DIV               | R, (men           | n)   |     | BW                |     |              |     | DIVS       | R, (mer      | n)  |     | <u>BW</u>     |
| 6   |     |      |     | INC               | #3, (me           | em)  |     | BW                |     |              |     | DEC        | #3, (m       | em) |     | BW            |
| ľ   | 8   | 1    | 2   | 3                 | 4                 | 5    | 6   | 7                 | 8   | 1            | 2   | 3          | 4            | 5   | 6   | 7             |
| 7   |     |      |     |                   |                   |      |     |                   | RLC | RRC          | RL  | RR<br>(m   | SLA<br>em)   | SRA | SLL | SRL <u>BW</u> |
| 8   |     |      |     | ADD               | R, (men           | n)   |     |                   |     |              |     | ADD        | (mem),       | R   |     |               |
| 9   |     |      |     | ADC               | R, (men           | n)   |     |                   |     |              |     | ADC        | (mem),       | R   |     |               |
| A   |     |      |     | SUB               | R, (men           | n)   |     |                   |     |              |     | SUB        | (mem),       | R   |     |               |
| в   |     |      |     | SBC               | R, (men           | n)   |     |                   |     |              |     | SBC        | (mem),       | R   |     |               |
| с   |     |      |     | AND               | R, (men           | n)   |     |                   |     |              |     | AND        | (mem),       | R   |     |               |
| D   |     |      |     | XOR               | R, (men           | n)   |     |                   |     |              |     | XOR        | (mem),       | R   |     |               |
| E   |     |      |     | OR                | R, (men           | n)   |     |                   |     |              |     | OR         | (mem),       | R   |     |               |
| F   |     |      |     | СР                | R, (men           | n)   |     |                   |     |              |     | СР         | (mem),       | R   |     |               |

 $\underline{B} : Operand size is a byte.$  $\underline{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    | А                | В        | С             | 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 <u>B</u><br>(m), (nn) |            | LD <u>W</u><br>(m), (nn) |           |                |      |                  |          |               |      |     |                   |
| 2   |                       |     |                       | LDA   | R, mem                   |            |                          | W         | ANDCF          | ORCF | XORCF<br>A, (mer |          | STCF <u>B</u> |      |     |                   |
| 3   |                       |     |                       | LDA   | R, mem                   |            |                          | Ĺ         |                |      |                  |          |               |      |     |                   |
| 4   |                       |     |                       | LD    | (mem),                   | R          |                          | B         |                |      |                  |          |               |      |     |                   |
| 5   |                       |     |                       | LD    | (mem),                   | R          |                          | W         |                |      |                  |          |               |      |     |                   |
| 6   |                       |     |                       | LD    | (mem),                   | R          |                          | Ĺ         |                |      |                  |          |               |      |     |                   |
| 7   |                       |     |                       |       |                          |            |                          |           |                |      |                  |          |               |      |     |                   |
| 8   |                       |     |                       | ANDCF | #3, (me                  | em)        |                          | B         |                |      |                  | ORCF     | #3, (men      | ר)   |     | В                 |
|     | 0                     | 1   | 2                     | 3     | 4                        | 5          | 6                        | 7         | 0              | 1    | 2                | 3        | 4             | 5    | 6   | 7                 |
| 9   |                       |     |                       |       | #3, (me                  | em)        |                          | B         |                |      |                  | LDCF     | #3, (men      | ו)   |     | B                 |
|     | 0                     | 1   | 2                     | 3     | 4                        | 5          | 6                        | 7         | 0              | 1    | 2                | 3        | 4             | 5    | 6   | 7                 |
| А   |                       |     |                       | STCF  |                          |            |                          | <u>B</u>  |                |      |                  | TSET     | #3, (men      |      |     | B                 |
|     | 0                     | 1   | 2                     | 3     | 4                        | 5          | 6                        | 7         | 0              | 1    | 2                | 3        | 4             | 5    | 6   | 7                 |
| В   |                       |     | _                     | RES   | #3, (me                  |            | _                        | <u>B</u>  |                |      | _                | SET      | #3, (men      |      | _   | B                 |
|     | 0                     | 1   | 2                     | 3     | 4                        | 5          | 6                        | 7         | 0              | 1    | 2                | 3        | 4             | 5    | 6   | 7                 |
| с   | •                     |     | •                     | CHG   | #3, (me                  |            | ~                        | <u>B</u>  |                |      | •                | BIT      | #3, (men      |      | ~   | <u>_</u> <u>B</u> |
|     | 0                     | 1   | 2                     | 3     | 4                        | 5          | 6                        | 7         | 0              | 1    | 2                | 3        | 4             | 5    | 6   | 7                 |
| D   | F                     | LT  | LE                    | ULE   | PE/OV                    | N.A./N.A.I | z                        | JP<br>C   | cc, mem<br>(T) | GE   | GT               | UGT      | PO/NOV        | וס/ס | NZ  | NC                |
|     | r                     | L I | LE                    | ULE   | FL/UV                    |            | 2                        |           |                |      |                  | 001      | FUNUV         | F/FL | INZ |                   |
| E   | F                     | LT  | LE                    | ULE   | PE/OV                    | M/MI       | z                        | CALL<br>C | cc, mem<br>(T) | GE   | GT               | UGT      | PO/NOV        | P/PL | NZ  | NC                |
| F   |                       |     |                       |       |                          |            |                          | RET       | сс             |      | yte cod          | e is BOH | H.)           |      |     |                   |
|     | F                     | LT  | LE                    | ULE   | PE/OV                    | M/MI       | z                        | 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

| 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                                     | <u>8-bit</u> 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)                                                         | 64 KB                                              | 16MB (linear)                                                                                                                                                                                                                 |
| Data space                                                                                         | 16MB (bank)                                        | 16MB (linear)                                                                                                                                                                                                                 |
| Instruction set/instruction<br>mnemonic                                                            | TLCS-90                                            | TLCS-90 + α<br>α = enhancement of 16-bit multiply /<br>divide instructions and bit<br>operation instruction. 32-bit<br>load/operation instructions,<br>C compiler instructions, register<br>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 + ),<br>(Reg + disp16),<br>(Reg + Reg16),<br>(nnn)                                                                                                                              |
| General-purpose register                                                                           | TLCS-90                                            | TLCS-90 + $\alpha$<br>$\alpha$ = Uses as 32 bits and register bank,<br>and adds a system stack pointer.                                                                                                                       |
| Flag (F)                                                                                           | SZIHXVNC                                           | s       z       "0"       H       "0"       V       N       C         I flag is extended to IFF2 to 0 of status register.X flag is deleted.                                                                                   |
| Reset                                                                                              | PC ← 0000H<br>(SP does not change.)                | PC ← (Vector base address)<br>XSP← 100H                                                                                                                                                                                       |
| Built-in ROM address<br>Built-in RAM address<br>Built-in I/O address<br>Direct addressing area (n) | 0000H to<br>to FFxxH<br>FFxxH~FFFFH<br>FF00H~FFFFH | undefined<br>0080H to<br>0000H~007FH<br>0000H~00FFH                                                                                                                                                                           |
| Interrupt<br>Interrupt start address                                                               | 0000H + (8 × V)                                    | Vector base address + 4 x V                                                                                                                                                                                                   |
| Register to be saved<br>Mask register<br>Mask level                                                | PC & AF<br>IFF<br>0~1                              | PC & SR<br>IFF2~0<br>0~7                                                                                                                                                                                                      |

| Series Item            | TLCS-90                                                                                                                                                                                                                            | TLCS-900            |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| Instruction            |                                                                                                                                                                                                                                    |                     |
| ① ADD R, r (word type) | S/Z/V flags don't change.                                                                                                                                                                                                          | S/Z/V flag changes. |
|                        | S/Z/V flag changes expect add<br>16 bit register.                                                                                                                                                                                  |                     |
| Shift of A register    | RLCA<br>RRCA<br>RLA<br>RRA<br>SLAA<br>SLAA<br>SLAA<br>SRLA<br>S/Z/V flags don't change in these<br>instruction.<br>RLC A<br>RRC A<br>RL A<br>RR A<br>SLA A<br>SLA A<br>SRA A<br>SLL A<br>SRL A<br>SLL A<br>SRL A<br>SLL A<br>SRL A | S/Z/V flag changes. |

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