# NANDだけで作る自作16bitCPU「NLP-16A」 ISA

### ■命令ビットフィールド

|     | 15 12             | ? 11                        8 | 7                             | 4 3 0              |
|-----|-------------------|-------------------------------|-------------------------------|--------------------|
|     | 命                 | 令名                            | 内部動作(太字は                      | <b>命令名</b> の動作を参照) |
| IR1 | OP Code 4/2bit    | ALU op code 4/6bit            | Flag 4bit                     | Reg Address1(RA1)  |
| IR2 | Reg Address2(RA2) | Reg Address3(RA3)             | ┃8bit 即値(RA2, 3ど <sup>-</sup> | ちらかで 0x01を指定時)     |
| IR3 |                   | 16bit即値(RA2, 3どち              | 5らかで0x03を指定時)                 |                    |

命令は可変長で, IR1, 2, 3はそれぞれ1, 2, 3ワード目

### ■Flagフィールド 仕様

|                   | Flagフィールド |     |          |     |
|-------------------|-----------|-----|----------|-----|
|                   | フラグが真で実行  |     | フラグが偽で実行 |     |
| <u> </u>          | サフィックス    | 値   | サフィックス   | 值   |
| NOP(No Operation) | . nop     | 0x0 | 無し       | 0x1 |
| CarryもしくはBorrow   | . c       | 0x9 | . nc     | 0x8 |
| 演算結果がオーバーフロー      | . v       | 0xB | . nv     | 0xA |
| 演算結果が0            | . Z       | 0xD | . nz     | 0xC |
| 演算結果が負            | .s        | 0xF | .ns      | 0xE |

0x1(サブィックス無し)は常に実行(通常)

#### ■ALU op codeフィールド 仕様

| 演算機能        | ALU 6bit opcode | ALU 4bit opcode | 補足          |
|-------------|-----------------|-----------------|-------------|
| ADD         | 0x0A            | 0x0A            |             |
| ADC         | 0x0E            | 0x0E            | carry付      |
| SUB         | 0x09            | 0x09            | <br>        |
| SBB<br>INC  | 0x0D<br>0x1B    | 0x0D            | borrow付     |
| INCC        | 0x16<br>0x1F    |                 | carry付      |
| DEC         | 0x18            |                 | Carryry     |
| DECB        | 0x1C            |                 | borrow付     |
|             |                 |                 |             |
| AND         | 0x06            |                 |             |
| OR<br>NOT   | 0x12            |                 |             |
| NOT         | 0x14            |                 |             |
| XOR         | 0x16            | 1               | <u> </u>    |
| SHL         | 0x20            |                 | <br>  論理シフト |
| SHR         | 0x20<br>0x30    |                 |             |
| SAL         | 0x24            |                 | <br>算術シフト   |
| SAR         | 0x34            |                 |             |
| ROL         | 0x22            |                 | ロール         |
| ROR         | 0x32            |                 |             |
| <del></del> |                 |                 |             |
| 転送          | 0x00            | 0x00            |             |

## ■Reg Addressフィールド 仕様

| レジスタ種類    | 記号 アドレス                             |                           |
|-----------|-------------------------------------|---------------------------|
|           |                                     |                           |
| 汎用レジスタ    | RegA 0x5 RegB 0x6 RegC 0x7 RegD 0x8 |                           |
| ポインタレジスタ  | IP 0xD   SP 0xE   IV 0x2            | IVは割込みベクタ                 |
| 命令レジスタ    | IR1 0x0   IR2 0x1   IR3 0x3         | IR2は8bit定数<br>IR3は16bit定数 |
| 特殊レジスタ    | ZR OxF Addr OxC Flag Ox4            | ZRはゼロレジスタ<br>Addrはアクセス不可  |
| MEM, MMIO | MEM 0xB                             | MEM, I/Oアクセス用             |
|           | レーアウトは命令内で使用不可                      |                           |

|                                                      | アセツ | •                                     |                                                       |                                                                                    |                                                                                                                    |                                                                                                                                                                        |                                                                                                                                 |                                                                                                   |
|------------------------------------------------------|-----|---------------------------------------|-------------------------------------------------------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
|                                                      |     |                                       |                                                       |                                                                                    |                                                                                                                    |                                                                                                                                                                        | 大字は命令名の重                                                                                                                        |                                                                                                   |
|                                                      |     | 1 /01 1 :                             | 命令                                                    | 名                                                                                  |                                                                                                                    |                                                                                                                                                                        | op codeで演算                                                                                                                      |                                                                                                   |
| IR1                                                  |     | <u>de 4/2bit</u>                      |                                                       |                                                                                    | code 4/6bit                                                                                                        |                                                                                                                                                                        |                                                                                                                                 | Address 1                                                                                         |
| IR2                                                  | Re  | g Address                             | 2                                                     |                                                                                    | Address 3                                                                                                          | 8bit 即値(RA2,                                                                                                                                                           |                                                                                                                                 | 0x01を指定時)                                                                                         |
| IR3                                                  |     |                                       |                                                       | 16bit即                                                                             | P値(RA2, 3と                                                                                                         | ゛ちらかで0x03を指                                                                                                                                                            | 定時)                                                                                                                             |                                                                                                   |
|                                                      |     |                                       | \                                                     | - ^ ^                                                                              |                                                                                                                    | 510 (                                                                                                                                                                  | \ 5.0                                                                                                                           |                                                                                                   |
|                                                      |     |                                       | 演算系                                                   |                                                                                    |                                                                                                                    |                                                                                                                                                                        | <u>(LU op) RA3 ⇒</u>                                                                                                            |                                                                                                   |
| IR1                                                  | 0   | 0                                     | ALU                                                   | <mark>J op code</mark>                                                             |                                                                                                                    | Flag                                                                                                                                                                   |                                                                                                                                 | RA1                                                                                               |
| IR2                                                  |     | RÁ2                                   |                                                       |                                                                                    | RA3                                                                                                                | 8bit 即値(RA2,                                                                                                                                                           |                                                                                                                                 | 0x01を指定時)                                                                                         |
| IR3                                                  |     |                                       |                                                       | 16bit則                                                                             | D値(RA2, 3と                                                                                                         | 「ちらかで0x03を指                                                                                                                                                            | <u>定時)                                    </u>                                                                                  |                                                                                                   |
|                                                      |     |                                       |                                                       |                                                                                    |                                                                                                                    |                                                                                                                                                                        |                                                                                                                                 |                                                                                                   |
|                                                      |     | 1                                     |                                                       | 實算命令_                                                                              |                                                                                                                    |                                                                                                                                                                        | <u>ALU op) Acc ⇒</u>                                                                                                            |                                                                                                   |
| IR1                                                  | 0   | 1                                     | ALU                                                   | <mark>J op code</mark>                                                             | : 6bit                                                                                                             | Flag                                                                                                                                                                   |                                                                                                                                 | RA1                                                                                               |
|                                                      |     |                                       |                                                       |                                                                                    |                                                                                                                    |                                                                                                                                                                        |                                                                                                                                 |                                                                                                   |
|                                                      |     |                                       | 令(即值                                                  | 代入も含                                                                               |                                                                                                                    |                                                                                                                                                                        | RA2 ⇒ RA1                                                                                                                       |                                                                                                   |
| IR1                                                  | 0   | 0 0                                   | 0                                                     | 0 0                                                                                | <u> </u>                                                                                                           | Flag                                                                                                                                                                   |                                                                                                                                 | RA1                                                                                               |
| IR2                                                  |     | RA2                                   |                                                       | ХХ                                                                                 | ( X X                                                                                                              |                                                                                                                                                                        |                                                                                                                                 | 0x01を指定時)                                                                                         |
| IR3                                                  |     |                                       |                                                       | 16bit即                                                                             | D値(RA2, 3と                                                                                                         | ゛ちらかで0x03を指2                                                                                                                                                           | 定時)                                                                                                                             |                                                                                                   |
|                                                      |     |                                       |                                                       |                                                                                    |                                                                                                                    |                                                                                                                                                                        |                                                                                                                                 |                                                                                                   |
|                                                      |     |                                       | JMP1                                                  | 命令                                                                                 |                                                                                                                    | RA2 (                                                                                                                                                                  | (ALU op) RA3 =                                                                                                                  | ⇒ IP                                                                                              |
| IR1                                                  | 0   | 0                                     | ALU                                                   | J op code                                                                          | 6bit                                                                                                               | Flag                                                                                                                                                                   | 1                                                                                                                               | 1 0 1                                                                                             |
| IR2                                                  |     | RA2                                   |                                                       |                                                                                    | RA3                                                                                                                | 8bit 即値(RA2,                                                                                                                                                           | 3どちらかで(                                                                                                                         | 0x01を指定時)                                                                                         |
| IR3                                                  |     |                                       |                                                       | 16bit即                                                                             | D値(RA2, 3と                                                                                                         | うらかで0x03を指摘                                                                                                                                                            | 定時)                                                                                                                             |                                                                                                   |
|                                                      |     |                                       |                                                       |                                                                                    |                                                                                                                    |                                                                                                                                                                        |                                                                                                                                 |                                                                                                   |
|                                                      |     |                                       | PUSH                                                  | 命令                                                                                 |                                                                                                                    | SP,                                                                                                                                                                    | $RA1 \Rightarrow MEM$                                                                                                           | N[SP]                                                                                             |
| IR1                                                  | 1   | 1 0                                   | 1                                                     | 0 0                                                                                | 0 0                                                                                                                | Flag                                                                                                                                                                   |                                                                                                                                 | RA1                                                                                               |
|                                                      |     |                                       |                                                       |                                                                                    |                                                                                                                    |                                                                                                                                                                        | •                                                                                                                               |                                                                                                   |
|                                                      |     |                                       | P0P1                                                  | 命令                                                                                 |                                                                                                                    | MEM[S                                                                                                                                                                  | $P] \Rightarrow RA1,$                                                                                                           | SP++                                                                                              |
| IR1                                                  | 1   | 1 0                                   | 0                                                     | 0 0                                                                                | 0 0                                                                                                                | Flag                                                                                                                                                                   | _                                                                                                                               | RA1                                                                                               |
|                                                      |     |                                       |                                                       |                                                                                    |                                                                                                                    |                                                                                                                                                                        | •                                                                                                                               |                                                                                                   |
|                                                      |     |                                       | CALL                                                  | 命令                                                                                 |                                                                                                                    | PUSH IP,                                                                                                                                                               | RA2 (ALU op)                                                                                                                    | $RA3 \Rightarrow IP$                                                                              |
| IR1                                                  | 1   | 0 1                                   | 1                                                     |                                                                                    | code 4bit                                                                                                          | Flag                                                                                                                                                                   | 1 1                                                                                                                             | 1 0 1                                                                                             |
| IR2                                                  |     | RA2                                   |                                                       |                                                                                    | RA3                                                                                                                | 8bit 即値(RA2,                                                                                                                                                           | 3どちらかで(                                                                                                                         | 0x01を指定時)                                                                                         |
| IR3                                                  |     |                                       |                                                       | 16bit則                                                                             | D値(RA2, 3と                                                                                                         | ちらかで0x03を指                                                                                                                                                             |                                                                                                                                 |                                                                                                   |
|                                                      |     |                                       |                                                       |                                                                                    | , ,                                                                                                                | •                                                                                                                                                                      |                                                                                                                                 |                                                                                                   |
|                                                      |     |                                       | RET <sub>1</sub>                                      | 命令                                                                                 |                                                                                                                    | MEM[S                                                                                                                                                                  | $[SP] \Rightarrow [P, \dots]$                                                                                                   | SP++                                                                                              |
| IR1                                                  | 1   | 1 Λ                                   | 0                                                     | 0 0                                                                                | 0 0                                                                                                                |                                                                                                                                                                        | 1                                                                                                                               | 1 0 1                                                                                             |
|                                                      |     | 1 0                                   | U                                                     | 0 0                                                                                | , , ,                                                                                                              | Flag                                                                                                                                                                   |                                                                                                                                 |                                                                                                   |
|                                                      |     | 1 0                                   | U                                                     | 0 0                                                                                | <u> </u>                                                                                                           | Flag                                                                                                                                                                   |                                                                                                                                 | 1 0 1                                                                                             |
| TD1                                                  |     | 1 0                                   |                                                       | <del>000</del>                                                                     | <u>)                                    </u>                                                                       |                                                                                                                                                                        | (ALU op) RA3]                                                                                                                   |                                                                                                   |
| IR1                                                  | 1   | 0 0                                   |                                                       | 命令                                                                                 | code 4bit                                                                                                          |                                                                                                                                                                        | (ALU op) RA3]                                                                                                                   |                                                                                                   |
|                                                      | 1   | · •                                   | LOAD                                                  | 命令                                                                                 |                                                                                                                    | MEM[RA2<br>Flag                                                                                                                                                        |                                                                                                                                 | ⇒ RA1<br>RA1                                                                                      |
| IR2                                                  | 1   | 0 0                                   | LOAD                                                  | 命令<br>ALU or                                                                       | code 4bit                                                                                                          | MEM[RA2                                                                                                                                                                | 3どちらかで(                                                                                                                         | ⇒ RA1<br>RA1                                                                                      |
|                                                      | 1   | 0 0                                   | LOAD                                                  | 命令<br>ALU or                                                                       | code 4bit                                                                                                          | MEM[RA2<br>Flag<br>8bit 即値(RA2,                                                                                                                                        | 3どちらかで(                                                                                                                         | ⇒ RA1<br>RA1                                                                                      |
| IR2                                                  | 1   | 0 0                                   | LOAD                                                  | 命令<br>ALU or<br>16bit即                                                             | code 4bit                                                                                                          | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指                                                                                                                          | 3どちらかで(                                                                                                                         | ⇒ RA1<br>RA1<br>0x01を指定時)                                                                         |
| IR2<br>IR3                                           | 1   | 0 0                                   | LOAD<br>0                                             | 命令<br>ALU or<br>16bit即                                                             | code 4bit                                                                                                          | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,                                                                                                                         | <br>  3どちらかで(<br> <br> 定時)                                                                                                      | ⇒ RA1<br>RA1<br>0x01を指定時)                                                                         |
| IR2<br>IR3<br>IR1                                    | 1   | 0 0<br>RA2                            | LOAD<br>0                                             | 命令<br>ALU or<br>16bit即                                                             | o code 4bit<br>RA3<br>P値(RA2, 3と                                                                                   | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>RA1 ⇒ N                                                                                                              | 3どちらかで(<br>定時)<br>IEM[RA2(ALU o                                                                                                 | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1                                                                  |
| IR2<br>IR3                                           | 1   | 0 0<br>RA2                            | LOAD<br>0                                             | 命令<br>ALU op<br>16bit即<br>命令<br>ALU op                                             | o code 4bit<br>RA3<br>P値(RA2, 3と<br>o code 4bit<br>RA3                                                             | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,                                                                                                                         | 3どちらかで(<br>定時)<br>MEM[RA2 (ALU o)<br>3どちらかで(                                                                                    | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1                                                                  |
| IR2<br>IR3<br>IR1<br>IR2                             | 1   | 0 0<br>RA2                            | LOAD<br>0                                             | 命令<br>ALU op<br>16bit即<br>命令<br>ALU op                                             | o code 4bit<br>RA3<br>P値(RA2, 3と<br>o code 4bit<br>RA3                                                             | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指)<br>RA1 ⇒ M<br>Flag<br>8bit 即値(RA2,                                                                                      | 3どちらかで(<br>定時)<br>MEM[RA2 (ALU o)<br>3どちらかで(                                                                                    | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1                                                                  |
| IR2<br>IR3<br>IR1<br>IR2                             | 1   | 0 0<br>RA2                            | LOAD<br>0<br>STORI                                    | 命令<br>ALU op<br>16bit即<br>命令<br>ALU op                                             | o code 4bit<br>RA3<br>P値(RA2, 3と<br>o code 4bit<br>RA3                                                             | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA1 ⇒ M<br>Flag<br>8bit 即値(RA2,                                                                                       | 3どちらかで(<br>定時)<br>MEM[RA2 (ALU o)<br>3どちらかで(<br>定時)                                                                             | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)                                                        |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3                      |     | 0 0<br>RA2                            | LOAD<br>0<br>STORI                                    | 命令<br>ALU op<br>16bit即<br>命令<br>ALU op                                             | o code 4bit<br>RA3<br>P値(RA2, 3と<br>o code 4bit<br>RA3<br>P値(RA2, 3と                                               | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA1 → M<br>Flag<br>8bit 即値(RA2,                                                                                       | 3どちらかで(<br>定時)<br>MEM[RA2 (ALU o)<br>3どちらかで(                                                                                    | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)                                                        |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3                      |     | 0 0<br>RA2                            | LOAD 0 STORI                                          | 命令<br>ALU or<br>16bit即<br>命令<br>ALU or<br>16bit即                                   | o code 4bit<br>RA3<br>P値(RA2, 3と<br>o code 4bit<br>RA3<br>P値(RA2, 3と                                               | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA1 → N<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA2                                                                  | 3どちらかで(<br>定時)<br>//EM[RA2 (ALU o)<br>// 3どちらかで(<br>定時)<br>// 2 >/= RA3 ⇒ F                                                     | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)                                                        |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3<br>IR1<br>IR2        |     | 0 0<br>RA2<br>0 0<br>RA2              | LOAD 0 STORI                                          | 命令<br>ALU or<br>16bit即<br>命令<br>ALU or<br>16bit即<br>較)命令                           | O code 4bit<br>RA3<br>P値(RA2, 3と<br>O code 4bit<br>RA3<br>P値(RA2, 3と<br>O 0 1                                      | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA1 → M<br>Flag<br>8bit 即値(RA2,                                                                                       | 3どちらかで(<br>定時)<br>//EM[RA2 (ALU o)<br>3どちらかで(<br>定時)<br>// RA3 ⇒ F<br>1 1<br>3どちらかで(                                            | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)                                                        |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3                      |     | 0 0<br>RA2<br>0 0<br>RA2              | LOAD 0 STORI                                          | 命令<br>ALU or<br>16bit即<br>命令<br>ALU or<br>16bit即<br>較)命令                           | O code 4bit<br>RA3<br>P値(RA2, 3と<br>O code 4bit<br>RA3<br>P値(RA2, 3と<br>O 0 1                                      | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA1 → N<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA2<br>Flag<br>8bit 即値(RA2,                                          | 3どちらかで(<br>定時)<br>//EM[RA2 (ALU o)<br>3どちらかで(<br>定時)<br>// RA3 ⇒ F<br>1 1<br>3どちらかで(                                            | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)                                                        |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3<br>IR1<br>IR2        |     | 0 0 RA2                               | LOAD 0 STORI 1 CMP(LL:                                | 命令 ALU or 16bit即 命令 ALU or 16bit即 較)命令 1 0                                         | O code 4bit<br>RA3<br>P値(RA2, 3と<br>O code 4bit<br>RA3<br>P値(RA2, 3と<br>O 0 1<br>RA3<br>P値(RA2, 3と                 | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>RA1 → M<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>RA2<br>Flag<br>8bit 即値(RA2,                                        | 3どちらかで(<br>定時)<br>MEM[RA2(ALU of<br>3どちらかで(<br>定時)<br>2 >/= RA3 ⇒ F<br>1<br>3どちらかで(<br>定時)                                      | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)  lag 1 1 1 0x01を指定時)                                   |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3<br>IR1<br>IR2<br>IR3 |     | 0 0<br>RA2<br>0 0<br>RA2              | LOAD 0 STORI 1 CMP(LL:                                | 命令 ALU or 16bit即 命令 ALU or 16bit即 較)命令 1 0                                         | O code 4bit<br>RA3<br>P値(RA2, 3と<br>O code 4bit<br>RA3<br>P値(RA2, 3と<br>O 0 1<br>RA3<br>P値(RA2, 3と                 | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指;<br>RA1 → M<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指;<br>RA2<br>Flag<br>8bit 即値(RA2,                                        | 3どちらかで(<br>定時)<br>//EM[RA2 (ALU o)<br>3どちらかで(<br>定時)<br>// RA3 ⇒ F<br>1 1<br>3どちらかで(                                            | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)  lag 1 1 1 0x01を指定時)                                   |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3<br>IR1<br>IR2        |     | 0 0 RA2                               | LOAD 0 STORI 1 CMP(LL:                                | 命令 ALU or 16bit即 命令 ALU or 16bit即 較)命令 1 0                                         | o code 4bit<br>RA3<br>P値(RA2, 3と<br>O code 4bit<br>RA3<br>P値(RA2, 3と<br>O 1<br>RA3<br>P値(RA2, 3と                   | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>RA1 → M<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>RA2<br>Flag<br>8bit 即値(RA2,                                        | 3どちらかで(<br>定時)<br>MEM[RA2(ALU of<br>3どちらかで(<br>定時)<br>2 >/= RA3 ⇒ F<br>1<br>3どちらかで(<br>定時)                                      | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)  lag 1 1 1 0x01を指定時)                                   |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3<br>IR1<br>IR2<br>IR3 |     | 0 0 RA2 (X 0 RA2 INT(ソフ 1 1           | LOAD<br>0  STORI  1  CMP(比i  0                        | 命令 ALU or 16bit即 命令 ALU or 16bit即 較)命令 1 0                                         | O code 4bit<br>RA3<br>P値(RA2, 3と<br>O code 4bit<br>RA3<br>P値(RA2, 3と<br>D 0 1<br>RA3<br>P値(RA2, 3と<br>み)命令<br>0 0  | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA1 → N<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>PUSH IF                 | 3どちらかで(<br>定時)<br>MEM[RA2(ALU of<br>3どちらかで(<br>定時)<br>2 >/= RA3 ⇒ F<br>1<br>3どちらかで(<br>定時)                                      | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)  lag 1 1 1 0x01を指定時)                                   |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3<br>IR1<br>IR2<br>IR3 |     | 0 0 RA2 (X 0 RA2 INT(ソフ 1 1           | LOAD<br>0  STORI  1  CMP(比i  0                        | 命令<br>ALU or<br>16bit即<br>命令<br>ALU or<br>16bit即<br>1 (0<br>16bit即<br>ア割り込る<br>1 1 | O code 4bit<br>RA3<br>P値(RA2, 3と<br>O code 4bit<br>RA3<br>P値(RA2, 3と<br>O 0 1<br>RA3<br>P値(RA2, 3と<br>O 0 0        | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA1 → N<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>PUSH IF                 | 3どちらかで(<br>主時) MEM[RA2 (ALU o) 3どちらかで(<br>主時) 2 >/= RA3 ⇒ F 1 3どちらかで(<br>主時) 2 -/= RA3 ⇒ F 1 1 3どちらかで(<br>またり 1 3どちらかで(         | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)  lag 1 1 1 0x01を指定時)  JMP IV X X X                     |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3<br>IR1<br>IR2<br>IR3 |     | 0 0 RA2 (X 0 RA2 INT(ソフ 1 1           | LOAD<br>0  STORI  1  CMP(比I  0  トウェ  1                | 命令 ALU or 16bit即 命令 ALU or 16bit即 較)命令 1 (0 16bit即 ア割り込み 1 1                       | O code 4bit<br>RA3<br>P値(RA2, 3と<br>O code 4bit<br>RA3<br>P値(RA2, 3と<br>D 0 1<br>RA3<br>P値(RA2, 3と<br>み)命令<br>0 0  | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA1 → N<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>PUSH IF                 | 3どちらかで(<br>主時) MEM[RA2 (ALU o) 3どちらかで(<br>主時) 2 >/= RA3 ⇒ F 1 3どちらかで(<br>主時) 2 -/= RA3 ⇒ F 1 1 3どちらかで(<br>またり 1 3どちらかで(         | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)  lag 1 1 1 0x01を指定時)                                   |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3<br>IR1<br>IR2<br>IR3 |     | 0 0 RA2 RA2 RA2 INT(ソフ 1 1 IRET(書 1 1 | LOAD<br>0  STORI  1  CMP(比)  0  トウェ  1                | 命令 ALU or 16bit即 命令 ALU or 16bit即 較)命令 1 (0 16bit即 ア割り込る 1 1                       | O code 4bit<br>RA3<br>P値(RA2, 3と<br>O code 4bit<br>RA3<br>P値(RA2, 3と<br>O 0 1<br>RA3<br>P値(RA2, 3と<br>O 0 0        | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA1 → N<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>PUSH IF<br>Flag         | 3どちらかで(<br>定時)<br>MEM[RA2 (ALU o)<br>3どちらかで(<br>定時)<br>2 >/= RA3 ⇒ F<br>1<br>3どちらかで(<br>定時)<br>P, PUSH Flag, 、<br>X             | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)  lag 1 1 1 0x01を指定時)  JMP IV X X X                     |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3<br>IR1<br>IR2<br>IR3 |     | 0 0 RA2 RA2 RA2 INT(ソフ 1 1 IRET(書 1 1 | LOAD<br>0  STORI  1  CMP(比)  0  トウェ  1                | 命令 ALU or 16bit即 命令 ALU or 16bit即 較)命令 1 (0 16bit即 ア割り込み 1 1                       | O code 4bit<br>RA3<br>P値(RA2, 3と<br>O code 4bit<br>RA3<br>P値(RA2, 3と<br>O 0 1<br>RA3<br>P値(RA2, 3と<br>O 0 0        | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>RA1 → M<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>Flag<br>Flag<br>Flag        | 3どちらかで(<br>主時) MEM[RA2 (ALU o) 3どちらかで(<br>主時) 2 >/= RA3 ⇒ F 1 3どちらかで(<br>主時) 2 -/= RA3 ⇒ F 1 1 3どちらかで(<br>またり 1 3どちらかで(         | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)  lag 1 1 1 0x01を指定時)  JMP IV X X X  Reg                |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3<br>IR1<br>IR2<br>IR3 |     | 0 0 RA2 RA2 RA2 INT(ソフ 1 1 IRET(書 1 1 | LOAD<br>0  STORI  1  CMP(比)  0  トウェ  1                | 命令 ALU or 16bit即 命令 ALU or 16bit即 較)命令 1 (0 16bit即 ア割り込る 1 1                       | O code 4bit<br>RA3<br>P値(RA2, 3と<br>O code 4bit<br>RA3<br>P値(RA2, 3と<br>O 0 1<br>RA3<br>P値(RA2, 3と<br>O 0 0        | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA1 → N<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指<br>PUSH IF<br>Flag         | 3どちらかで(<br>定時)<br>MEM[RA2 (ALU o)<br>3どちらかで(<br>定時)<br>2 >/= RA3 ⇒ F<br>1<br>3どちらかで(<br>定時)<br>P, PUSH Flag, 、<br>X             | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)  lag 1 1 1 0x01を指定時)  JMP IV X X X                     |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3<br>IR1<br>IR2<br>IR3 |     | 0 0 RA2                               | LOAD<br>O  STORI  1  CMP(比  O  トウェ  1  引込み  O  割り込  1 | 命令 ALU or 16bit即 命令 ALU or 16bit即 較)命令 1 (bit即 下割り込 1 1 1 Jターン) 0 (by許可)命 1 1      | O code 4bit<br>RA3<br>P値(RA2, 3と<br>O code 4bit<br>RA3<br>P値(RA2, 3と<br>O 0 1<br>RA3<br>P値(RA2, 3と<br>O 0 0<br>の 0 | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>RA1 → M<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>Flag<br>Flag<br>Flag | 3どちらかで(<br>定時)<br>MEM[RA2(ALU of<br>3どちらかで(<br>定時)<br>2 >/= RA3 ⇒ F<br>1 3どちらかで(<br>定時)<br>2 PUSH Flag, X<br>POP Flag, RET<br>X | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)  lag 1 1 1 0x01を指定時)  JMP IV X X X   X X X  eg X X X X |
| IR2<br>IR3<br>IR1<br>IR2<br>IR3<br>IR1<br>IR2<br>IR3 |     | 0 0 RA2                               | LOAD<br>O  STORI  1  CMP(比  O  トウェ  1  引込み  O  割り込  1 | 命令 ALU or 16bit即 命令 ALU or 16bit即 較)命令 1 (0 16bit即 ア割り込る 1 1                       | O code 4bit<br>RA3<br>P値(RA2, 3と<br>O code 4bit<br>RA3<br>P値(RA2, 3と<br>O 0 1<br>RA3<br>P値(RA2, 3と<br>O 0 0<br>の 0 | MEM[RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>RA1 → M<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>RA2<br>Flag<br>8bit 即値(RA2,<br>ちらかで0x03を指,<br>Flag<br>Flag<br>Flag | 3どちらかで(<br>定時)<br>MEM[RA2 (ALU o)<br>3どちらかで(<br>定時)<br>2 >/= RA3 ⇒ F<br>1<br>3どちらかで(<br>定時)<br>P, PUSH Flag, 、<br>X             | ⇒ RA1 RA1 0x01を指定時)  p) RA3] RA1 0x01を指定時)  lag 1 1 1 0x01を指定時)  JMP IV X X X   X X X  eg X X X X |