

CMOS 8-BIT SINGLE CHIP MICROCOMPUTER  
**S1C88**  
コアCPUマニュアル



本資料のご使用につきましては、次の点にご留意願います。

---

1. 本資料の内容については、予告なく変更することがあります。
2. 本資料の一部、または全部を弊社に無断で転載、または、複製など他の目的に使用することは堅くお断りします。
3. 本資料に掲載される応用回路、プログラム、使用方法等はあくまでも参考情報であり、これらに起因する第三者の権利(工業所有権を含む)侵害あるいは損害の発生に対し、弊社は如何なる保証を行うものではありません。また、本資料によって第三者または弊社の工業所有権の実施権の許諾を行うものではありません。
4. 特性表の数値の大小は、数直線上の大小関係で表しています。
5. 本資料に掲載されている製品のうち、「外国為替および外国貿易法」に定める戦略物資に該当するものについては、輸出する場合、同法に基づく輸出許可が必要です。
6. 本資料に掲載されている製品は、一般民生用です。生命維持装置その他、きわめて高い信頼性が要求される用途を前提としていません。よって、弊社は本(当該)製品をこれらの用途に用いた場合の如何なる責任についても負いかねます。

## 製品型番変更のご案内

2001年4月1日より、弊社半導体製品の製品型番が以下のとおり変更となりますので、4月1日以降のご発注につきましては変更後の製品型番にてお願い申し上げます。

なお、製品型番の詳細仕様につきましては、弊社営業担当にお問い合わせください。

## 製品型番体系

### デバイス



### 開発ツール



\*1: ツールの種類は、新旧型番対応表を参照してください。(マニュアル類には一桁で記載されているものもあります。)

\*2: マニュアル類には、実際のバージョンは記載されておりません。

## 新旧型番対応表

### S1C88ファミリ

| 旧型番       | 新型番      | 旧型番       | 新型番      |
|-----------|----------|-----------|----------|
| E0C88104  | S1C88104 | E0C88365  | S1C88365 |
| E0C88112  | S1C88112 | E0C88F360 | S1C8F360 |
| E0C88308  | S1C88308 | E0C88408  | S1C88408 |
| E0C88316  | S1C88316 | E0C88409  | S1C88409 |
| E0C88317  | S1C88317 | E0C88816  | S1C88816 |
| E0C88348  | S1C88348 | E0C88832  | S1C88832 |
| E0C88P348 | S1C8P348 | E0C88862  | S1C88862 |
| E0C88349  | S1C88349 | E0C88F816 | S1C8F816 |

## 開発ツール新旧型番対応表

### S1C88ファミリ関係の開発ツール

| 旧型番      | 新型番          | 旧型番         | 新型番          |
|----------|--------------|-------------|--------------|
| 881SAIF  | S5U1C88000H4 | DEV88816    | S5U1C88816D  |
| ADP88348 | S5U1C88348X  | DEV88832    | S5U1C88832D  |
| ADP88360 | S5U1C88360X  | DEV88862    | S5U1C88862D  |
| DEV88104 | S5U1C88104D  | DMT88348-DB | S5U1C88348T  |
| DEV88112 | S5U1C88112D  | ICE88UR     | S5U1C88000H5 |
| DEV88308 | S5U1C88308D  | PRC88316    | S5U1C88316P  |
| DEV88316 | S5U1C88316D  | PRC88348    | S5U1C88348P  |
| DEV88317 | S5U1C88317D  | PRC88365    | S5U1C88365P  |
| DEV88348 | S5U1C88348D  | PRC88409    | S5U1C88409P  |
| DEV88365 | S5U1C88365D  | PRC88816    | S5U1C88816P  |
| DEV88408 | S5U1C88408D  | SAP88       | S5U1C88000S  |
| DEV88409 | S5U1C88409D  | URS88348    | S5U1C88348Y  |

### S1C63/88ファミリ関係の開発ツール

| 旧型番      | 新型番          |
|----------|--------------|
| ADS00002 | S5U1C88000X1 |
| GWH00002 | S5U1C88000W2 |
| URM00002 | S5U1C88000W1 |



CMOS 8-bit Single Chip Microcomputer

# **S1C88 Core CPU Manual**

はじめに 本書はCMOS 8ビットシングルチップマイクロコンピュータS1C88 FamilyのコアCPU S1C88のアーキテクチャとその動作および命令セットについて解説します。

なお、S1C88 Familyの各デバイスごとにメモリ構成や周辺回路の構成が異なりますので、基本機能以外の内容についてはそれぞれのマニュアルをご覧ください。



## - 目 次 -

|                                    |    |
|------------------------------------|----|
| <b>1 概要</b>                        | 1  |
| 1.1 特長                             | 1  |
| 1.2 命令セットの特長                       | 1  |
| 1.3 ブロック図                          | 1  |
| 1.4 入出力信号                          | 2  |
| <b>2 アーキテクチャ</b>                   | 4  |
| 2.1 アドレス空間とCPUモデル                  | 4  |
| 2.2 演算部とレジスタ                       | 5  |
| 2.2.1 ALU                          | 5  |
| 2.2.2 レジスタ構成                       | 5  |
| 2.2.3 フラグ                          | 6  |
| 2.2.4 補数演算とオーバーフロー                 | 8  |
| 2.2.5 10進演算とアンパック演算                | 9  |
| 2.2.6 乗除算                          | 11 |
| 2.3 プログラムメモリ                       | 12 |
| 2.3.1 プログラムメモリの構成                  | 12 |
| 2.3.2 PC(プログラムカウンタ)とCB(コードバンク)レジスタ | 12 |
| 2.3.3 バンク管理                        | 13 |
| 2.3.4 分岐命令                         | 13 |
| 2.4 データメモリ                         | 16 |
| 2.4.1 データメモリの構成                    | 16 |
| 2.4.2 ページレジスタEP、XP、YP              | 16 |
| 2.4.3 スタック                         | 17 |
| 2.4.4 メモリマップドI/O                   | 18 |
| <b>3 CPUの動作と処理状態</b>               | 19 |
| 3.1 タイミングジェネレータとバス制御               | 19 |
| 3.1.1 バスサイクル                       | 19 |
| 3.1.2 ウェイトステート                     | 20 |
| 3.2 処理状態の概要                        | 21 |
| 3.3 リセット状態                         | 22 |

|                           |           |
|---------------------------|-----------|
| 3.4 プログラム実行状態 .....       | 23        |
| 3.5 例外処理状態 .....          | 23        |
| 3.5.1 例外処理の種類と優先度 .....   | 24        |
| 3.5.2 例外処理要因とベクタ .....    | 24        |
| 3.5.3 割り込み .....          | 24        |
| 3.5.4 例外処理のシーケンス .....    | 25        |
| 3.6 パス権解放状態 .....         | 28        |
| 3.7 スタンバイ状態 .....         | 29        |
| 3.7.1 HALT状態 .....        | 29        |
| 3.7.2 SLEEP状態 .....       | 30        |
| <b>4 命令セット .....</b>      | <b>31</b> |
| 4.1 アドレッシングモード .....      | 31        |
| 4.2 命令のフォーマット .....       | 34        |
| 4.3 命令セット一覧表 .....        | 35        |
| 4.3.1 機能分類 .....          | 35        |
| 4.3.2 記号の意味 .....         | 36        |
| 4.3.3 機能別命令一覧表 .....      | 37        |
| 4.4 命令の詳細説明 .....         | 54        |
| <b>APPENDIX</b>           |           |
| A. オペコードマップ .....         | 179       |
| B. アドレッシングモード別命令一覧表 ..... | 182       |
| C. 命令索引 .....             | 194       |

# 1 概要

S1C88はEPSONオリジナルのアーキテクチャを採用したCMOS 8ビットシングルチップマイクロコンピュータS1C88 FamilyのコアCPUです。

最大16Mバイトのアドレス空間と高速・豊富な命令セットを持ち、広範囲な動作電圧に対応するとともに低消費電力を特長としています。

また、統一アーキテクチャのもとにメモリマップドI/O方式の周辺回路インターフェースを採用しており、今後のFamily拡充にも柔軟に対応します。

## 1.1 特長

S1C88は以下の特長を持っています。

アドレス空間 最大16Mバイト

命令サイクル 1~15サイクル(1サイクル=2クロック)

命令セット 608種類

レジスタ構成 データレジスタ 2

インデックスレジスタ 3

(1つはデータレジスタとして使用可)

プログラムカウンタ

スタックポインタ

システムコンディションフラグ

カスタマイズコンディションフラグ

例外処理要因 リセット、ゼロ除算、割り込み

例外処理ベクタ 最大128ベクタ

スタンバイ機能 HALT/SLEEP

周辺回路インターフェース メモリマップドI/O方式

## 1.2 命令セットの特長

- (1) マシンサイクル効率の高い、高速かつ豊富な命令セットを採用しています。
- (2) 12種類のアドレッシングモードにより、メモリ管理が容易に行えます。
- (3) アドレス計算などに有効な16ビット演算機能を持っています。
- (4) 10進演算モード、パック/アンパック命令など、強力な10進演算機能があります。
- (5) カストマイズドフラグ命令により、各種の特定用途向けマイコンの実現をサポートしています。
- (6) リロケータブルプログラミングが可能な命令体系となっており、ソフトウェアのライブラリ化が容易に実現できます。

## 1.3 ブロック図

図1.3.1にS1C88のブロック図を示します。



図1.3.1 S1C88ブロック図

## 1.4 入出力信号

表1.4.1(a)、表1.4.1(b)にS1C88と周辺回路間の入出力信号を示します。

表1.4.1(a) 入出力信号一覧 (1)

| 種 別      | 名 称                      | 信 号 名     | 入出力 | 機 能                                                                                                                           |
|----------|--------------------------|-----------|-----|-------------------------------------------------------------------------------------------------------------------------------|
| 電源       | 電源                       | VDD       | 入力  | + 側電源を入力します。                                                                                                                  |
|          | グランド                     | VSS       | 入力  | - 側電源(GND)を入力します。                                                                                                             |
| クロック     | クロック入力                   | CLK       | 入力  | 周辺回路からのシステムクロックを入力します。                                                                                                        |
|          | クロック出力                   | PK<br>PL  | 出力  | CLK端子に入力されるシステムクロックの2相分周信号を以下の位相で出力します。<br> |
| アドレスバス   | アドレスバス                   | A00~A23   | 出力  | 24ビットのアドレスバスです。                                                                                                               |
| データバス    | データバス                    | D0~D7     | 入出力 | 8ビットの双方向データバスです。                                                                                                              |
| バス制御信号   | ウェイト                     | WAIT      | 入力  | メモリアクセス時のアクセスタイム伸長用ウェイストートの挿入を制御します。<br>LOWレベルの入力で有効です。                                                                       |
|          | リード                      | RD        | 出力  | メモリ(周辺回路)リード信号です。<br>データの読み出し時にLOWレベルとなります。                                                                                   |
|          | ライト                      | WR        | 出力  | メモリ(周辺回路)ライト信号です。<br>データの書き込み時にLOWレベルとなります。                                                                                   |
|          | リード割り込み<br>ベクタアドレス       | RDIV      | 出力  | 割り込みベクタアドレスリード信号です。ベクタアドレスの読み出し時にLOWレベルとなります。                                                                                 |
|          | リセット                     | SR        | 入力  | LOWレベルの入力によりCPUがリセット状態となります。                                                                                                  |
| システム制御信号 | モード設定                    | MODE      | 入力  | CPUの動作モードを周辺回路より設定します。<br>LOW: ミニマムモード<br>HIGH: マキシマムモード                                                                      |
|          | カスタマイズ<br>コンディション<br>フラグ | F0~F3     | 入力  | 周辺回路より入力されるステータス信号です。<br>周辺回路により信号の意味が異なります。                                                                                  |
|          | マイクロ<br>スリープ             | USLP      | 出力  | CPUがSLP(SLEEP)命令によりSLEEP状態に入る1サイクル前にHIGHレベルとなります。本信号をもとに周辺回路は発振停止の制御を行います。                                                    |
|          | バス権要求                    | BREQ      | 入力  | 周辺回路がDMA転送を行う場合のバス権要求信号です。本端子へのLOWレベル入力によりCPUはバスを解放します。アドレスバス、データバス、およびリード/ライト信号がハイインピーダンス状態となります。                            |
|          | バス権要求<br>アクノリッジ          | BACK      | 出力  | バス権を周辺回路に解放したことを示す応答信号です。バス権解放時にLOWレベルとなります。                                                                                  |
|          | スタック<br>ポインタページ          | SPP0~SPP7 | 入力  | 周辺回路により指定されるスタックポインタのページアドレスです。スタックポインタがメモリをアクセスする際に、このアドレスがアドレスバスのページ部(AD16~AD23)に出力されます。                                    |

各信号のタイミング等については、3章の"CPUの動作と処理状態"を参照してください。

表1.4.1(b) 入出力信号一覧 (2)

| 種別      | 名称            | 信号名            | 入出力 | 機能                                                                                                                                                                                                                                                                                                                     |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
|---------|---------------|----------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|---|---|-----------|---|---|----------------|---|---|--------|---|---|--------|
| 割り込み信号  | ノンマスカブル割り込み   | NMI            | 入力  | ソフトウェアによるマスクが不可能な割り込み信号です。入力は立ち下がりエッジにてセンスされます。                                                                                                                                                                                                                                                                        |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
|         | 割り込み要求3       | IRQ3           | 入力  | ソフトウェアによるマスクが可能な割り込み信号です。割り込み優先度はレベル3で、入力はLOWレベルにてセンスされます。                                                                                                                                                                                                                                                             |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
|         | 割り込み要求2       | IRQ2           | 入力  | ソフトウェアによるマスクが可能な割り込み信号です。割り込み優先度はレベル2で、入力はLOWレベルにてセンスされます。                                                                                                                                                                                                                                                             |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
|         | 割り込み要求1       | IRQ1           | 入力  | ソフトウェアによるマスクが可能な割り込み信号です。割り込み優先度はレベル1で、入力はLOWレベルにてセンスされます。                                                                                                                                                                                                                                                             |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
|         | 割り込みマスク       | IMASK          | 入力  | 周辺回路より入力される割り込みマスク信号です。周辺回路部に構成されるスタックポインタのページ部等をアクセスする際に本端子にLOWレベルが入力され、以下の割り込みがマスクされます。<br>NMI, IRQ3, IRQ2, IRQ1                                                                                                                                                                                                     |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
|         | 割り込みアクノリッジ    | IACK           | 出力  | 割り込み要求を受け付けたことを示す応答信号です。割り込み受け付け時にLOWレベルとなります。周辺回路は本信号を受けてベクタアドレスをホールドします。なお、本信号はリセットおよびゼロ除算による例外処理の実行時においてもLOWレベルとなります。                                                                                                                                                                                               |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
|         | インターラプトフラグ    | I0F<br>I1F     | 出力  | システムコンディションフラグ(SC)内のインターラプトフラグ(I0, I1)をモニタ出力しています。                                                                                                                                                                                                                                                                     |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
| ステータス信号 | 第1オペコードフェッチ信号 | SYNC           | 出力  | CPUが第1オペコードをフェッチする際にアクティブとなる信号です。第1オペコードフェッチのバスサイクル期間中、HIGHレベルとなります。<br>また、本信号の立ち上がりエッジにて割り込みがサンプリングされます。                                                                                                                                                                                                              |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
|         | 停止信号          | STOP           | 出力  | CPUが以下の状態に入ったとき、LOWレベルとなります。<br>・HALT命令によるCPUの停止<br>・SLP命令によるCPUの停止<br>・BREQへのLOWレベル入力によるバスの解放                                                                                                                                                                                                                         |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
|         | データバスステータス    | DBS0<br>DBS1   | 出力  | データバスの状態を以下のとおり示す2ビットのステータス信号です。                                                                                                                                                                                                                                                                                       |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
|         |               |                |     | <table> <thead> <tr> <th>DSB1</th> <th>DSB0</th> <th>ステート</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>0</td> <td>ハイインピーダンス</td> </tr> <tr> <td>0</td> <td>1</td> <td>割り込みベクタアドレスリード</td> </tr> <tr> <td>1</td> <td>0</td> <td>メモリライト</td> </tr> <tr> <td>1</td> <td>1</td> <td>メモリリード</td> </tr> </tbody> </table> | DSB1 | DSB0 | ステート | 0 | 0 | ハイインピーダンス | 0 | 1 | 割り込みベクタアドレスリード | 1 | 0 | メモリライト | 1 | 1 | メモリリード |
| DSB1    | DSB0          | ステート           |     |                                                                                                                                                                                                                                                                                                                        |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
| 0       | 0             | ハイインピーダンス      |     |                                                                                                                                                                                                                                                                                                                        |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
| 0       | 1             | 割り込みベクタアドレスリード |     |                                                                                                                                                                                                                                                                                                                        |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
| 1       | 0             | メモリライト         |     |                                                                                                                                                                                                                                                                                                                        |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |
| 1       | 1             | メモリリード         |     |                                                                                                                                                                                                                                                                                                                        |      |      |      |   |   |           |   |   |                |   |   |        |   |   |        |

注! 入出力信号はS1C88 Familyの各デバイスによって周辺回路の信号の追加など、表の内容と異なる場合があります。それらの信号については各デバイスのマニュアルを参照してください。

# 2 アーキテクチャ

S1C88は最大16Mバイトのアドレス空間を持ち、大規模なアプリケーションにも対応できます。ここでは、このアドレス空間とメモリ管理、レジスタの構成等について説明します。

## 2.1 アドレス空間とCPUモデル

S1C88にはアドレス空間の大きさと乗除算命令のありなしにより、MODEL0～MODEL3の4種類のCPUモデルが設定されています。各モデルの違いは表2.1.1のとおりで、マイコンの用途、アプリケーションの規模によって選択できるようになっています。

MODEL2、MODEL3については、さらにプログラミング領域を最大64Kバイトとするミニマムモードと最大8MバイトとするマキシマムモードのいずれかがコアCPUのMODE端子の設定によって選択できます。

各CPUモデルに対するメモリマップの概念を図2.1.1に示します。

表2.1.1 CPUモデル

| CPUモデル | アドレス空間 | 乗除算命令 |
|--------|--------|-------|
| MODEL0 | 64Kバイト | なし    |
| MODEL1 | 64Kバイト | あり    |
| MODEL2 | 16Mバイト | なし    |
| MODEL3 | 16Mバイト | あり    |

表2.1.2 動作モードの設定(MODEL2、MODEL3)

| MODE | 動作モード    | プログラミング領域 |
|------|----------|-----------|
| 0    | ミニマムモード  | 最大64Kバイト  |
| 1    | マキシマムモード | 最大8Mバイト   |



図2.1.1 メモリマップ

プログラムメモリは32Kバイトごとのパンク、データメモリは64Kバイトごとのページに分けて管理されます。

☞ "2.3 プログラムメモリ"、"2.4 データメモリ"

注! S1C88 Familyの各デバイスによってメモリの構成が異なります。各デバイスのマニュアルを参照してください。

## 2.2 演算部とレジスタ

### 2.2.1 ALU ///////////////////////////////////////////////////

ALU(算術論理演算ユニット)は2種類のテンポラリレジスタTEMP 0とTEMP 1にストアされた8ビットまたは16ビットデータ間の演算を行います。

ALUの機能は表2.2.1.1のとおりです。

演算結果は16ビットのテンポラリレジスタTEMP 2に一旦ストアされた後、演算命令にしたがったレジスタ/メモリにストアされるか、アドレスデータとして使用されます。

また、演算結果によりZ(ゼロ)フラグ、C(キャリー)フラグ、V(オーバーフロー)フラグ、N(ネガティブ)フラグがセット/リセットされます。

☞ "2.2.3 フラグ"

### 2.2.2 レジスタ構成 ///////////////////////////////////////////////////

S1C88のレジスタ構成を図2.2.2.1に示します。

表2.2.1.1 ALUの演算機能

| 演算機能      | 演算命令               | 16ビット演算 |
|-----------|--------------------|---------|
| 加算        | ADD, ADC           |         |
| 減算        | SUB, SBC           |         |
| 論理積       | AND                |         |
| 論理和       | OR                 |         |
| 排他的論理和    | XOR                |         |
| 比較        | CP                 |         |
| ビットテスト    | BIT                |         |
| 1加算/減算    | INC, DEC           |         |
| 乗算        | MLT                |         |
| 除算        | DIV                |         |
| 補数        | CPL, NEG           |         |
| ローテート     | RL, RLC, RR, RRC   |         |
| シフト       | SLA, SLL, SRA, SRL |         |
| パック/アンパック | PACK, UPCK         |         |
| 符号拡張      | SEP                |         |

標準部 (MODEL0 ~ MODEL3共通)

|                            |                |                          |
|----------------------------|----------------|--------------------------|
| 7 (15) <b>B</b>            | 0 7 <b>A</b> 0 | データレジスタ A、B、(BA)         |
| 7 (15) <b>H</b>            | 0 7 <b>L</b> 0 | インデックス(データ)レジスタ HL、(H、L) |
| 15 <b>IX</b>               | 0              | インデックスレジスタ IX            |
| 15 <b>IY</b>               | 0              | インデックスレジスタ IY            |
| 15 <b>PC</b>               | 0              | プログラムカウンタ                |
| 15 <b>SP</b>               | 0              | スタックポインタ                 |
| 7 <b>BR</b>                | 0              | ベースレジスタ                  |
| SC <b>I1 0 U D N V C Z</b> |                | システムコンディションフラグ           |
| CC <b>F3 F2 F1 F0</b>      |                | カスタマイズコンディションフラグ         |

拡張部 (MODEL2、MODEL3)

|             |   |                  |
|-------------|---|------------------|
| 7 <b>NB</b> | 0 | ニューコードバンクレジスタ    |
| 7 <b>CB</b> | 0 | コードバンクレジスタ       |
| 7 <b>EP</b> | 0 | エクスパンドページレジスタ    |
| 7 <b>XP</b> | 0 | IX用エクスパンドページレジスタ |
| 7 <b>YP</b> | 0 | IY用エクスパンドページレジスタ |

図2.2.2.1 レジスタ構成

#### Aレジスタ、Bレジスタ

Aレジスタ、Bレジスタはそれぞれ8ビットのデータレジスタで、他のレジスタやデータメモリとのデータ転送や演算、即値データの転送、演算が行えます。8ビット転送/演算においてはそれ単独に、16ビット転送/演算においてはBレジスタを上位8ビットとするBAペアで使用します。

#### HLレジスタ

HLレジスタは16ビットのインデックスレジスタで、データメモリの間接アドレッシングに使用します(ページ内のアドレスを指定)。他のレジスタやデータメモリとの16ビットデータ転送や演算が行えます。また、Hレジスタ、Lレジスタの8ビットずつに分けてデータレジスタとしても使用できます。この場合のLレジスタはIXレジスタ、IYレジスタによる間接アドレッシングの際のディスプレースメントとして使用することもできます。

☞ "2.4 データメモリ"

☞ "4.1 アドレッシングモード"

#### IXレジスタ、IYレジスタ

IXレジスタ、IYレジスタはそれぞれ16ビットのインデックスレジスタで、データメモリの間接アドレッシングに使用します(ページ内のアドレスを指定)。他のレジスタやデータメモリとの16ビットデータ転送や演算が行えます。

☞ "2.4 データメモリ"

☞ "4.1 アドレッシングモード"

#### PC(プログラムカウンタ)

PCはプログラムメモリのアドレッシングを行う16ビットのカウンタレジスタで、次に実行する命令のアドレスを示します。

☞ "2.3 プログラムメモリ"

#### SP(スタックポインタ)

SPは16ビットのカウンタレジスタでスタックアドレス(スタックページ内のアドレス)を示します。他のレジスタやデータメモリとの16ビットデータ転送や演算が行えます。

☞ "2.4.3 スタック"

**BR(ベースレジスタ)**

BRは8ビットのインデックスレジスタで、8ビット絶対アドレッシング(アドレスの下位8ビットを指定)の際にページ内の上位8ビットのアドレス指定に使用されます。

☞ "4.1 アドレッシングモード"

**SC(システムコンディションフラグ)**

SCは8ビットのフラグで、演算結果を示すZ、C、V、Nフラグ、演算モードを設定するD、Uフラグ、割り込み優先レベルを設定するI0、I1フラグで構成されます。

☞ "2.2.3 フラグ"

**CC(カスタマイズコンディションフラグ)**

CCは周辺回路によって設定された各種の状態を示す4ビットのフラグで、周辺回路によってセット/リセットされ、分岐命令の条件の1つとして使用されます。

☞ "2.2.3 フラグ"

**NB(ニューコードバンクレジスタ)**

NBレジスタはプログラムメモリのバンクを指定する8ビットのレジスタです。NBレジスタはCPUモデルのMODEL2およびMODEL3に設定されています。

☞ "2.3 プログラムメモリ"

**CB(コードバンクレジスタ)**

CBレジスタはプログラムメモリの現在選択されているバンクを示す8ビットのレジスタです。NBレジスタにデータを設定した場合、そのデータがCBレジスタにロードされ、新たなバンクが選択されます。CBレジスタはCPUモデルのMODEL2およびMODEL3に設定されています。

☞ "2.3 プログラムメモリ"

**EP、XP、YP(エクスパンドページレジスタ)**

これらのレジスタはデータメモリのページを指定する8ビットのレジスタです。

EPレジスタはHLレジスタによる間接アドレッシング、あるいは即値データによる絶対アドレッシングの際に使用されます。

XPレジスタはIXレジスタによる間接アドレッシング、YPレジスタはIYレジスタによる間接アドレッシングの際に使用されます。

これらのレジスタはCPUモデルのMODEL2およびMODEL3に設定されています。

☞ "2.4.2 ページレジスタEP、XP、YP"

☞ "4.1 アドレッシングモード"

**2.2.3 フラグ**

S1C88にはCPU内部の演算結果の状態などを表すシステムコンディションフラグ(SC)と周辺回路の状態を表すカスタマイズコンディションフラグ(CC)が設定されています。

**システムコンディションフラグ (SC)**

図2.2.3.1 システムコンディションフラグ (SC)

システムコンディションフラグは図2.2.3.1に示すとおり、8ビットのフラグで構成されたレジスタSCとなっています。

システムコンディションフラグのZ(ゼロ)、C(キャリー)、V(オーバーフロー)、N(ネガティブ)フラグは演算の結果によりセット/リセットされ、I0、I1(インタラプト)フラグは割り込みによりセット/リセットされます。また、これらのフラグは以下の命令によっても操作できます。

|            |               |
|------------|---------------|
| AND SC,#nn | (任意のフラグをリセット) |
| OR SC,#nn  | (任意のフラグをセット)  |
| XOR SC,#nn | (任意のフラグを反転)   |
| LD SC,#nn  | (フラグのライト)     |
| LD SC,A    | (フラグのライト)     |
| POP SC     | (フラグの復帰)      |
| RETE       | (フラグの復帰)      |

Z、C、V、NフラグはJRS命令やCARS命令などの条件ジャンプ/コール命令実行の際の条件判定に使用されます。

☞ "4.4 命令の詳細説明"

以下、各フラグについて説明します。

**(1) Z(ゼロ)フラグ**

Zフラグは演算命令の実行結果が'0'になった場合に'1'にセット、結果が'0'以外の場合に'0'にリセットされます。

## (2) C(キャリー)フラグ

Cフラグは加算命令の実行によりキャリー(最上位ビットから桁上げ)が発生した場合、または減算命令/比較命令の実行によりボロー(最上位ビットに借り)が発生した場合に'1'にセット、それ以外の場合に'0'にリセットされます。ただし、1加減算命令(INC、DEC命令)の実行ではCフラグは変化しません。

また、ローテート/シフト命令の実行によってもCフラグは変化します。

乗除算命令(MLT、DIV命令)を実行した場合は'0'にリセットされます。

## (3) V(オーバーフロー)フラグ

Vフラグは演算を行った結果が8ビットまたは16ビットで補数表現可能な範囲を越えた場合に'1'にセット、範囲内の場合に'0'にリセットされます。補数表現の範囲は8ビットが-128～127、16ビットが-32768～32767になります。

ただし、演算命令の中でも論理演算命令(デステイニエーションがSCの場合を除くAND、OR、XOR命令)、ビット操作命令(BIT命令)、1加減算命令(INC、DEC命令)の実行ではVフラグは変化しません。乗算命令(MLT命令)を実行した場合は'0'にリセットされます。除算命令(DIV命令)を実行した場合は、商が8ビットを越えるときに'1'にセットされます。

Cフラグが絶対値演算のオーバー(アンダー)フローを示すのに対し、Vフラグは補数演算のオーバーフローを示します。オーバーフローが起こりうる補数演算を行う場合はVフラグをチェックして、'1'のときには演算結果を補正する必要があります。

☞ "2.2.4 補数演算とオーバーフロー"

## (4) N(ネガティブ)フラグ

Nフラグは演算を行った結果がマイナス(最上位ビットが'1')になった場合に'1'にセット、プラス(最上位ビットが'0')の場合に'0'にリセットされます。ただし、1加減算命令(INC、DEC命令)の実行ではNフラグは変化しません。

## (5) D(デシマル)フラグ

Dフラグは8ビット加減算命令の実行の際に10進演算(演算結果が10進補正される)を行うように設定するビットで、'1'を設定することにより10進演算を行い、'0'で16進演算を行います。

☞ "2.2.5 10進演算とアンパック演算"

## (6) U(アンパック)フラグ

Uフラグは8ビット加減算の実行の際にアンパック演算(上位4ビットを'0'として演算)を行うように設定するビットで、'1'を設定することによりアンパック演算を行い、'0'で通常の8ビット演算を行います。

☞ "2.2.5 10進演算とアンパック演算"

## (7) I0、I1(インタラプト)フラグ

I0およびI1フラグは割り込み優先レベルを設定するビットで、この2ビットで設定したレベルより高いレベルの割り込みのみCPUは受け付けます。

また、割り込みが発生した際にも、そのレベル以下の割り込みをマスクするよう、新たな値が自動設定されます。

☞ "3.5.3 割り込み"

命令セット一覧表等では命令の実行により変化するフラグを"↑"を付けて示しています。Dフラグ、Uフラグは"↑"を付けて、その命令が10進演算、アンパック演算可能であることを示しています。

## カスタマイズコンディションフラグ (CC)



図2.2.3.2 カスタマイズコンディションフラグ (CC)

カスタマイズコンディションフラグは図2.2.3.2に示すとおり、4ビットのフラグで構成されたレジスタCCとなっています。

CCの各フラグはF0～F3の名称となっており、周辺回路からS1C88のF0～F3端子に入力される信号によって変化します。ここには周辺回路の状態を示す信号が入力されますので、各フラグに反映された周辺回路の状態によってプログラムを分岐させることができます。

S1C88はCCフラグによって特定用途向けマイコンが容易に実現できるように配慮されています。

CCフラグはJRS命令やCARS命令の条件ジャンプ/コール命令実行の際の条件判定に使用されます。

☞ "4.4 命令の詳細説明"

2.2.4 補数演算とオーバーフロー//////////  
S1C88内部ではマイナスのデータを扱うために補数表現が用いられます。以下に補数表現と補数を用いた演算について説明します。

### 補数

マイクロコンピュータでマイナス(負)の数を扱う場合、一般的には補数表現が用いられます。補数には2の補数と1の補数の2種類の表現方法があり、通常単に補数といった場合、2の補数を指します。S1C88でもマイナスの数は2の補数で表しています。

任意の数Nの補数は以下の式で表され、2の補数表現が可能な範囲は8ビットの場合が-128 ~ 127、16ビットの場合が-32768 ~ 32767になります。1の補数表現が可能な範囲は8ビットの場合が-127 ~ 127、16ビットの場合が-32767 ~ 32767になります。

#### ----- 2の補数 -----

8ビット  $-N = 2^8 - N = 256 - N$

127 = 0111 1111b

126 = 0111 1110b

:

2 = 0000 0010b

1 = 0000 0001b

0 = 0000 0000b

-1 = 1111 1111b (= 1 0000 0000b - 0000 0001b)

-2 = 1111 1110b (= 1 0000 0000b - 0000 0010b)

:

-127 = 1000 0001b (= 1 0000 0000b - 0111 1111b)

-128 = 1000 0000b (= 1 0000 0000b - 1000 0000b)

#### ----- 16ビット -----

16ビット  $-N = 2^{16} - N = 65536 - N$

32767 = 0111 1111 1111 1111b

32766 = 0111 1111 1111 1110b

:

2 = 0000 0000 0000 0010b

1 = 0000 0000 0000 0001b

0 = 0000 0000 0000 0000b

-1 = 1111 1111 1111 1111b

(= 1 0000 0000 0000 0000b - 0000 0000 0000 0001b)

-2 = 1111 1111 1111 1110b

(= 1 0000 0000 0000 0000b - 0000 0000 0000 0010b)

:

-32767 = 1000 0000 0000 0001b

(= 1 0000 0000 0000 0000b - 0111 1111 1111 1111b)

-32768 = 1000 0000 0000 0000b

(= 1 0000 0000 0000 0000b - 1000 0000 0000 0000b)

補数表現した場合、マイナスの数の最上位ビットは必ず'1'になります。この最上位ビットの内容がN(ネガティブ)フラグに反映されます。

なお、8ビットのデータを補数に変換するための命令として"CPL"命令(1の補数に変換)と"NEG"命令(2の補数に変換)が、8ビットの補数を16ビットに拡張するための命令として"SEP"命令が用意されています。

#### 例: NEG命令とSEP命令

| 命令        | B reg.    | A reg.    | Nフラグ |
|-----------|-----------|-----------|------|
| LD A,#127 | 0000 0000 | 0111 1111 | 0    |
| NEG A     | 0000 0000 | 1000 0001 | 1    |
| SEP       | 1111 1111 | 1000 0001 | 1    |

#### ----- 1の補数 -----

8ビット  $-N = 2^8 - 1 - N = 255 - N (= \bar{N})$

127 = 0111 1111b

126 = 0111 1110b

:

2 = 0000 0010b

1 = 0000 0001b

0 = 0000 0000b

-1 = 1111 1110b (= 1111 1111b - 0000 0001b)

-2 = 1111 1101b (= 1111 1111b - 0000 0010b)

:

-126 = 1000 0001b (= 1111 1111b - 0111 1110b)

-127 = 1000 0000b (= 1111 1111b - 0111 1111b)

#### ----- 16ビット -----

16ビット  $-N = 2^{16} - 1 - N = 65535 - N (= \bar{N})$

32767 = 0111 1111 1111 1111b

32766 = 0111 1111 1111 1110b

:

2 = 0000 0000 0000 0010b

1 = 0000 0000 0000 0001b

0 = 0000 0000 0000 0000b

-1 = 1111 1111 1111 1111b

(= 1111 1111 1111 1111b - 0000 0000 0000 0001b)

-2 = 1111 1111 1111 1101b

(= 1111 1111 1111 1111b - 0000 0000 0000 0010b)

:

-32767 = 1000 0000 0000 0001b

(= 1111 1111 1111 1111b - 0111 1111 1111 1111b)

-32768 = 1000 0000 0000 0000b

(= 1111 1111 1111 1111b - 0111 1111 1111 1111b)

## 補数演算とV(オーバーフロー)フラグ

アドレス計算などの絶対値による演算の場合、8ビットでは0~255、16ビットでは0~65535の範囲で正しい演算結果が得られます。演算によりオーバーフローあるいはアンダーフローが発生し範囲を外れた場合は、C(キャリー)フラグが'1'にセットされます。

演算数、被演算数が補数になっている場合の正しい演算結果の範囲は、8ビットが-128~127、16ビットが-32768~32767となり、Cフラグのみでは演算結果が正しいかどうか判断できません。この判断を行うためにV(オーバーフロー)フラグが設定されており、補数表現の範囲を越えた場合にVフラグが'1'にセットされます。

なお、ALUは絶対値演算、補数演算を区別してはいませんので、Cフラグ、Vフラグのセット/リセットは単に演算結果が上記の範囲内にあるかどうかで行われます。したがって、絶対値演算においてもVフラグが'1'にセットされる場合があります。この場合のVフラグは意味を持ちませんので、プログラムでVフラグを確認する必要はありません。Vフラグでオーバーフローが判断できるのは補数演算の場合に限られますので、アプリケーションで扱うデータが符号付きかどうかを判断してください。

以下に8ビットの演算例とその演算結果によるVフラグ、Cフラグの変化を示します。

### 例: "ADD A,B"命令による加算例

| A reg.    | B reg.    | 結果(A reg.) | Vフラグ | Cフラグ |
|-----------|-----------|------------|------|------|
| 0101 1010 | 1010 0101 | 1111 1111  | 0    | 0    |
| 0101 1011 | 1010 0101 | 0000 0000  | 0    | 1    |
| 0101 1011 | 0010 0101 | 1000 0000  | 1    | 0    |

### "SUB A,B"命令による減算例

| A reg.    | B reg.    | 結果(A reg.) | Vフラグ | Cフラグ |
|-----------|-----------|------------|------|------|
| 0101 1010 | 0101 1010 | 0000 0000  | 0    | 0    |
| 0101 1010 | 0101 1011 | 1111 1111  | 0    | 1    |
| 0101 1010 | 1101 1010 | 1000 0000  | 1    | 1    |

## 2.2.5 10進演算とアンパック演算 ///////////////

S1C88では以下の8ビット演算命令実行時、通常の16進演算の他に10進演算、アンパック演算、およびその組み合わせによって演算を行うように設定することができます。この設定はD(デシマル)フラグ、U(アンパック)フラグによって行います。

### 10進演算とアンパック演算が可能な演算命令

|     |     |     |     |     |
|-----|-----|-----|-----|-----|
| ADD | ADC | SUB | SBC | NEG |
|-----|-----|-----|-----|-----|

いずれも8ビット演算命令で、命令セット一覧表等ではDフラグ、Uフラグの部分に" "を付けて、10進演算、アンパック演算が可能であることを示しています。

### 10進演算

Dフラグを'1'にセットして8ビット算術演算(ADD、ADC、SUB、SBC、NEG)命令を実行すると、2桁の10進演算が行われます。演算結果はBCD(2進化10進数)コードで得られます。

10進演算を行う場合は演算命令の実行前に"OR SC,#00010000B"命令等でDフラグを'1'に設定します。また、演算数および被演算数はBCDコードが対象となりますので、BCDコードを設定してから演算を実行してください。BCDコードになっていない場合は、正しい結果が得られません。

### 10進演算時のSCフラグ

10進演算実行後、演算結果によってSCのN/V/C/Zフラグは下記のように設定されます。

N: 常時 リセット(0)

V: 常時 リセット(0)

C: 2桁の10進数に対して

桁上げまたは桁借りがあったとき セット(1)

桁上げまたは桁借りがないとき リセット(0)

Z: 演算結果=0のとき セット(1)

演算結果≠0のとき リセット(0)

### 例: "ADD A,B"命令による10進演算例

| A reg. | B reg. | A reg.(和) | SC |   |   |   |
|--------|--------|-----------|----|---|---|---|
|        |        |           | N  | V | C | Z |
| 55     | 28     | 83        | 0  | 0 | 0 | 0 |
| 74     | 98     | 72        | 0  | 0 | 1 | 0 |

### "SUB A,B"命令による10進演算例

| A reg. | B reg. | A reg.(差) | SC |   |   |   |
|--------|--------|-----------|----|---|---|---|
|        |        |           | N  | V | C | Z |
| 55     | 55     | 00        | 0  | 0 | 0 | 1 |
| 55     | 28     | 27        | 0  | 0 | 0 | 0 |
| 74     | 98     | 76        | 0  | 0 | 1 | 0 |

### アンパック演算

Uフラグを'1'にセットして8ビット算術演算(ADD、ADC、SUB、SBC、NEG)命令を実行すると、下記に示すアンパック形式での演算を行うことができます。

アンパック演算は、上位4ビットのデータを無視し、下位4ビットのみを対象に演算を行います。実行後は下位4ビットのみの演算結果が出力され、上位4ビットは'0'が出力されます。

アンパック演算は、メモリ1アドレスに対して1桁のデータを格納するため、演算項の桁合わせが容易に行えます。(この場合の桁合わせはメモリアドレスのポインティングのみとなります。)

#### <ADD命令の例>

|   | MSB | 2 <sup>4</sup> | 2 <sup>3</sup> | LSB |             |
|---|-----|----------------|----------------|-----|-------------|
|   |     | 不定データ          | 被加数            |     | レジスタ or メモリ |
| + |     | 不定データ          | 加数             |     | レジスタ or メモリ |
|   |     | 0              | 結果(和)          |     | レジスタ or メモリ |

#### アンパック演算時のSCフラグ

アンパック演算は下位4ビットデータのみを対象にしますので、SCフラグも下位4ビットの演算結果によって変化します。

アンパック演算実行後、演算結果によってSCのN/V/C/Zフラグは下記のように設定されます。

N: 2<sup>3</sup>ビットが'1'のとき セット(1)  
2<sup>3</sup>ビットが'0'のとき リセット(0)

V: 4ビットの補数表現(-8 ~ 7)

を越えたとき セット(1)  
以内のとき リセット(0)

C: 2<sup>3</sup>ビットからの桁上げ、2<sup>3</sup>ビットへの桁借りが  
あったとき セット(1)  
ないとき リセット(0)

Z: 下位4ビット=0のとき セット(1)  
下位4ビット≠0のとき リセット(0)

### アンパック演算補助命令

アンパック形式とパック形式(通常の8ビットデータ形式)を相互に変換する"PACK"、"UPCK"命令が用意されており、容易にフォーマット変換ができます。

PACK命令: BAレジスタのアンパック形式データをパック形式に変換し、Aレジスタに格納します。

| B reg. | A reg. | A reg. |
|--------|--------|--------|
| * m *  | n      | m n    |

#### 例: PACKの実行例

| 設定値              | 結果            | SC            |
|------------------|---------------|---------------|
| BA reg.<br>38C4H | A reg.<br>84H | N V C Z<br>不变 |

UPCK命令: Aレジスタの8ビットデータをアンパック形式に変換し、BAレジスタに格納します。

| A reg. | B reg. | A reg. |
|--------|--------|--------|
| m n    | 0 m 0  | n      |

#### 例: UPCKの実行例

| 設定値           | 結果               | SC            |
|---------------|------------------|---------------|
| A reg.<br>84H | BA reg.<br>0804H | N V C Z<br>不变 |

#### 例: "ADD A,B"命令によるアンパック演算例

| 設定値           | 結果            | SC               |
|---------------|---------------|------------------|
| A reg.<br>20H | B reg.<br>D0H | A reg.(和)<br>00H |
| 0             | 0             | N                |
| 0             | 0             | V                |
| 0             | 0             | C                |
| 1             | 0             | Z                |

2.2.6 乗除算 ////////////////////////////////////////////////  
 S1C88のMODEL1およびMODEL3は乗除算機能を持っています。MODEL0およびMODEL2ではこの機能および以下に説明する乗除算命令は使用できません。

### 乗算

乗算はMLT命令によって行います。

MLT命令を実行すると、Lレジスタ×Aレジスタの演算が行われ、積がHLレジスタに格納されます。この演算結果により、SCのN/V/C/Zフラグは次のように設定されます。

N: HLレジスタ(積)の最上位ビットが

'1'のとき セット(1)  
 '0'のとき リセット(0)

V: 常時 リセット(0)

C: 常時 リセット(0)

Z: HLレジスタ(積)が

0000Hのとき セット(1)  
 0000H以外のとき リセット(0)

以下にMLT命令の実行例を示します。

| 設定値    |        |            | 結果 SC |   |   |   |
|--------|--------|------------|-------|---|---|---|
| L reg. | A reg. | HL reg.(積) | N     | V | C | Z |
| 00H    | 64H    | 0000H      | 0     | 0 | 0 | 1 |
| 64H    | 58H    | 2260H      | 0     | 0 | 0 | 0 |
| C8H    | 58H    | 44C0H      | 0     | 0 | 0 | 0 |
| A5H    | 93H    | 5EBFH      | 0     | 0 | 0 | 0 |
| C8H    | A5H    | 80E8H      | 1     | 0 | 0 | 0 |

乗算は上記の設定値を符号なし8ビットデータとして扱い、符号なしの演算を行いますので、演算結果により設定されるNフラグは符号を表しません。したがって、上記例のC8H×A5Hのように負の数どうしの乗算を行った場合でも、Nフラグが'0'に設定されないことがあります。

### 除算

除算はDIV命令によって行います。

DIV命令を実行すると、HLレジスタ÷Aレジスタの演算が行われ、商がLレジスタに、剰余がHレジスタに格納されます。

商が8ビットを越える場合はV(オーバーフロー)フラグがセットされ、HLレジスタの内容は被除数が保持されます。

Aレジスタに'0'を設定してDIV命令を実行した場合はゼロ除算例外処理が発生します。

この演算結果により、SCのN/V/C/Zフラグは次のように設定されます。

N: Lレジスタ(商)の最上位ビットが

'1'のとき セット(1)  
 '0'のとき リセット(0)

V: 商が8ビット以内に

納まらないとき セット(1)  
 納まるとき リセット(0)

C: 常時 リセット(0)

Z: Lレジスタ(商)が

00Hのとき セット(1)  
 00H以外のとき リセット(0)

### SCの動作例

| 設定値     |        | SC |   |   |   | 備考     |
|---------|--------|----|---|---|---|--------|
| HL reg. | A reg. | N  | V | C | Z |        |
| nz      | nz     | ↑  | ↑ | 0 | ↑ |        |
| 0000H   | nz     | 0  | 0 | 0 | 1 |        |
| nz      | 00H    | 1  | 1 | 0 | 0 | ゼロ除算   |
| 0000H   | 00H    | 1  | 1 | 0 | 0 | 例外処理発生 |

nzは'0'以外の8ビットまたは16ビットデータを表します。

### 除算実行例

以下にDIV命令の実行例を示します。

| 設定値     |        | 結果 SC |       |        |   |   |   |   |
|---------|--------|-------|-------|--------|---|---|---|---|
| HL reg. | A reg. | L(商)  | H(剰余) | A reg. | N | V | C | Z |
| 1A16H   | 64H    | 42H   | 4EH   | 64H    | 0 | 0 | 0 | 0 |
| 332CH   | 64H    | 83H   | 00H   | 64H    | 1 | 0 | 0 | 0 |
| 0000H   | 58H    | 00H   | 00H   | 58H    | 0 | 0 | 0 | 1 |
| 0301H   | 02H    | 01H   | 03H   | 02H    | 1 | 1 | 0 | 0 |

上記例の0301H ÷ 02Hは商が8ビットを越えるため、HLレジスタの値が保持され結果が出力されません。このような場合は、下記のように被除数を上位8ビット、下位8ビットに分離して除算を行います。

### <0301H ÷ 02Hの実行例>

```

  LD  HL,#0003H ;被除数=上位8ビット
  LD  A,#02H      ;除数
  DIV                      ;L=商, H=剰余
  LD  [hhll],L          ;商(上位8ビット)をメモリに格納
  LD  L,#01H          ;被除数=Hレジスタ+下位8ビット
  DIV                      ;

```

| 設定値     |        | 結果 SC |       |        |   |   |   |   |
|---------|--------|-------|-------|--------|---|---|---|---|
| HL reg. | A reg. | L(商)  | H(剰余) | A reg. | N | V | C | Z |
| 0003H   | 02H    | 01H   | 01H   | 02H    | 0 | 0 | 0 | 0 |
| 0101H   | 02H    | 80H   | 01H   | 02H    | 1 | 0 | 0 | 0 |

商 : 0180H  
剰余: 01H

## 2.3 プログラムメモリ

### 2.3.1 プログラムメモリの構成

S1C88のアドレス空間16Mバイトの中で前半の8Mバイト(アドレス000000H ~ 7FFFFFFH)がプログラミング領域として使用できるようになっています。ただし、MODEL0とMODEL1についてはアドレス空間が最大64Kバイトのため、プログラミング領域もそれ以内に制限されます。



8ビットCPUの論理空間64Kバイトを越えるメモリを管理するため、S1C88ではバンクマッピング方式を採用しています。最大8Mバイトのプログラムメモリはバンク0 ~ バンク255まで、それぞれ32Kバイトのバンクに分割されます。

64Kバイトの論理空間上には2つのバンクがアドレス0000H ~ FFFFHとして論理的に連続するように配置され、そのアドレス空間内でプログラムを実行します。論理空間内のアドレスングはPC(プログラムカウンタ)が行います。

論理空間のアドレス0000H ~ 7FFFHにはコモンバンクとしてバンク0(アドレス000000H ~ 007FFFH)が配置され、この物理アドレスは常時固定となります。アドレス000000H ~ 0000FFHは例外処理(割り込み等)のベクタが割り付けられます。

#### ☞ "3.5.2 例外処理要因とベクタ"

コモンエリアが固定のため、各バンクに例外処理ベクタを割り付ける必要はありません。また、汎用的なサブルーチン等もコモンエリアに記述することができます。

後半のアドレス8000H ~ FFFFHのバンクエリアにはCB(コードバンク)レジスタで選択されるバンクが配置されます。この部分に配置するバンクはプログラムで任意に選択できます。ただし、MODEL0とMODEL1についてはバンク1に固定、MODEL2とMODEL3のミニマムモードについては任意に選択された1つのバンクに固定されます。

### 2.3.2 PC(プログラムカウンタ)と

#### CB(コードバンク)レジスタ

PC(プログラムカウンタ)は実行するプログラムのアドレスを保持しています。PCの内容は64Kバイトの論理空間内のアドレスで、物理アドレスが連続しない32Kずつのコモンエリアとバンクエリアを論理的に連続したプログラムメモリとしてアドレスングしています。

コモンエリアは物理アドレスのバンク0に固定されていますが、バンクエリアは256バンクの中から任意の1バンクを選択できるようになっています。(MODEL2とMODEL3)

このバンクエリアに割り当てるバンクアドレス(0 ~ 255)を示すレジスタがCB(コードバンク)です。実際にメモリをアクセスするためにアドレスバスに出力される物理アドレスはCPU内部で図2.3.2.1のように生成されます。

#### コモンエリアのアクセス (0000H ~ 7FFFH)



#### バンクエリアのアクセス (8000H ~ FFFFH)



図2.3.2.1 論理アドレスと物理アドレス(MODEL2/3)

図に示すとおり、16ビットのPCの中でアドレスバスに出力されるのは最上位ビットを除く15ビットです。その内容はアドレスバスのA00 ~ A14に出力されます。PCの最上位ビットは'0'でコモンエリア、'1'でバンクエリアを示しており、この内容によってCBをアドレスバスに出力するかどうかを決定します。コモンエリアの場合はアドレスバスのA15 ~ A22に00Hが出力され、バンクエリアの場合はCBの内容8ビットが出力されます。アドレスバスのA23はデータメモリ領域専用で、最大8Mバイトのプログラムメモリアクセス時には常時'0'を出力します。以上のようにPCの最上位ビットはアドレスバスに出力されませんので、システム開発時には注意してください。

MODEL0とMODEL1についてはアドレスバスが16ビットのため、PCの内容がそのまま出力されます。

"LD BA,PC"命令、"LD HL,PC"命令のPC値  
 "LD BA,PC"命令、"LD HL,PC"命令はPC値をBAレジスタおよびHLレジスタに読み込む命令です。読み込むPC値を"PC"、本命令の置かれている先頭アドレスを"PC"とすると、  

$$\text{PC} \quad \text{PC} + 2$$
 で示されるPC値がBAおよびHLレジスタに読み込まれます。たとえば、"LD BA,PC"命令が100H番地に置かれているとすると、BAレジスタには102Hが読み込まれます。

### 2.3.3 バンク管理

プログラムの実行は基本的に論理空間に割り当てられたバンク内に限られています。バンクが変更されるのは、プログラムによって分岐命令が実行される時点での他のバンクが指定されている場合です。

注! プログラムの実行によりPCのカウントがオーバーフローした場合でもCBは更新されません。再びコモンエリアの先頭からの実行となります。

以下にバンク指定の方法と、分岐命令実行時の動作について説明します。

なお、バンク変更にかかる記載事項はMODEL2およびMODEL3にのみ摘要されます。

#### リセット時のバンク設定

イニシャルリセット時にCBは'1'に初期化され、バンクエリアにはバンク1が割り当てられます。

コモンエリアはバンク0に固定されますので、論理アドレスは物理アドレスと同様になります。

この設定は別のバンクがプログラムで指定され、分岐命令によって実際に分岐が行われるまで変更されません。

#### バンクの指定

選択されているバンクを示すCBはプログラムによって直接変更することはできません。

バンク指定用にはNB(ニューコードバンク)レジスタが用意されており、分岐命令実行直前に分岐先のバンクアドレス(0~255)を以下の命令によって書き込んでおきます。

LD NB,A (Aレジスタによる指定)  
 LD NB,#bb(8ビット即値データによる指定)

NBの内容はその直後の分岐命令の実行により実際に分岐が行われる時点でCBにロードされ、新たなバンクがバンクエリアに選択されます。条件ジャンプなどにおいて条件が合わずに分岐が行われない場合は、CBの内容が逆にNBにロードされます。

したがって、NBに値を設定せずに分岐命令を実行した場合はその時点の論理空間内に分岐するようになっています。



図2.3.3.1 バンクの変更

### 2.3.4 分岐命令

分岐命令はPCとCBを変更してプログラムを任意のアドレスに分岐させます。分岐命令の種類は動作の違いにより、以下のように分類されます。

表2.3.4.1 分岐命令の種類

| 種類         | 条件     | 命令            |
|------------|--------|---------------|
| PC相対ジャンプ   | 条件/無条件 | JRS、JRL、DJR   |
| 間接ジャンプ     | 無条件    | JP            |
| PC相対コール    | 条件/無条件 | CARS、CARL     |
| 間接コール      | 無条件    | CALL          |
| リターン       | 無条件    | RET、RETS、RETE |
| ソフトウェア割り込み | 無条件    | INT           |

上記の分岐命令それぞれの中にも無条件に分岐する無条件分岐命令とフラグの状態によって分岐する数種類の条件分岐命令があります。

条件分岐命令の条件が満たされていない場合は、分岐が行われずにその分岐命令の次の命令を実行します。

☞ "4.4 命令の詳細説明"

#### PC相対ジャンプ命令(JRS、JRL、DJR)

PC相対ジャンプはPCにオペランドで指定された相対アドレスを加え、そのアドレスに分岐させる命令で、リロケータブルなプログラミングを可能にしています。

相対アドレスは分岐実行時のアドレスから分岐先アドレスまでのディスプレースメントで、1または2バイトで指定します。

指定できる相対アドレスは"JRS"命令、"DJR"命令が8ビット補数表現の-128~127、"JRL"命令が16ビット補数表現の-32768~32767の範囲です。

なお、この相対アドレスはPCに加算されるため分岐先のアドレスは論理アドレスとなります。直前のNBの設定によって他のバンクにも分岐できますが、分岐先はあくまでも論理空間内で物理的な相対アドレスの指定はできません。

図2.3.4.1にPC相対ジャンプの動作を示します。

"JRS"命令は無条件ジャンプと20種類の条件ジャンプ命令が設定されています。

"JRL"命令は無条件ジャンプと4種類の条件ジャンプ命令が設定されています。



図2.3.4.1

PC相対ジャンプの動作 (MODEL2/3の例)

"DJR NZ,rr"命令はBレジスタの'1'減算を行い、その結果が"0"以外の場合に"JRS"の無条件ジャンプ命令を実行します。この命令によって、Bレジスタをカウンタとしたその初期値分の繰り返しルーチンが簡単に記述できます。

例: 50 cycle時間のウェイトルーチン  
 LD B,#12 ;初期値をBレジスタにセット(2 cycle)  
 DJR NZ,\$ ;Bレジスタが0になるまで繰り返す(48 cycle)

### 間接ジャンプ命令(JP)

間接ジャンプは分岐先のアドレスを間接的に指定する命令です。

"JP [kk]"命令はアドレス00kk(kk=00H ~ FFH、ページは'0'固定)のメモリの内容をPCの下位8ビットに、アドレス00kk+1のメモリの内容をPCの上位8ビットにそれぞれロードして、そのアドレスに無条件に分岐します。ここで指定するアドレス00kkは例外処理やソフトウェア割り込みのベクタ領域となっています。

"JP HL"命令はHLレジスタの内容をアドレスとして無条件に分岐します。この命令は演算結果等をそのまま分岐先アドレスにすることができるため、ジャンプテーブルの作成などに有効です。

### PC相対コール命令(CARS、CARL)

PC相対コールはPCにオペランドで指定された相対アドレスを加え、そのアドレスからのサブルーチンをコールする命令です。

相対アドレスは分岐実行時のアドレスから分岐先アドレスまでのディスプレースメントで、1または2バイトで指定します。

指定できる相対アドレスは"CARS"命令が8ビット補数表現の-128 ~ 127、"CARL"命令が16ビット補数表現の-32768 ~ 32767の範囲です。

なお、この相対アドレスはPCに加算されるため分岐先のアドレスは論理アドレスとなります。直前のNBの設定によって他のバンクにも分岐できますが、分岐先はあくまでも論理空間内で物理的な相対アドレスの指定はできません。

サブルーチンコール実行時にはリターン情報としてPC値(コール命令の次の命令の先頭アドレス)がスタックに退避されます。

MODEL2/3のマキシマムモードではPC値以外にCB値もスタックに退避され、リターン時にはコール元のバンクに戻るようになっています。

MODEL2/3のミニマムモードではMODEL0/1と同様、PC値のみのスタックとなるため、64Kバイト以上のプログラムメモリを使用することはできません。

図2.3.4.2にPC相対コールの動作を示します。

"CARS"命令は無条件コールと20種類の条件コール命令が設定されています。

"CARL"命令は無条件コールと4種類の条件コール命令が設定されています。

### 間接コール命令(CALL)

間接コールはサブルーチンのアドレスを間接的に指定するコール命令です。

"CALL [hhll]"命令はアドレスhhll(hhll=0000H ~ FFFFH、ページはEPレジスタによって指定)のメモリの内容をPCの下位8ビットに、アドレスhhll+1のメモリの内容をPCの上位8ビットにそれぞれロードして、そのアドレスのサブルーチンを無条件にコールします。

サブルーチンコール実行時にはPC相対コールと同様、リターン情報としてPC値(コール命令の次の命令の先頭アドレス)とCB値(MODEL2/3マキシマムモードの場合)がスタックに退避されます。

### リターン命令(RET、RETS、RETE)

リターン命令はコール命令によって呼び出されたサブルーチンからコール元のルーチンに戻るための命令です。

リターン命令はサブルーチンコール実行時にスタックに退避されているPC値(コール命令の次の命令の先頭アドレス)を元に戻します。MODEL2/3のマキシマムモードではCB値の復帰も行われ、コールしたバンクに戻ります。

MODEL2/3のミニマムモードではMODEL0/1と同様、PC値のみ復帰します。



図2.3.4.2 PC相対コールの動作 (MODEL2/3マキシマムモードの例)

ミニマムモードでコール命令の実行時、または実行後にバンクの変更を行っている場合は、リターン命令を実行しても正常なアドレスへ戻ることはできません。

"RET"命令はリターン情報そのままに、コール命令の次の命令の先頭アドレスに処理を戻します。

"RETS"命令はリターン情報のPC値に'2'を加えてリターンしますので、コール命令の次の2バイト命令をスキップすることができます。



図2.3.4.3 サブルーチンからのリターン

"RETE"命令はソフトウェア割り込みルーチンや例外処理ルーチン専用のリターン命令で、リターン情報にSC(システムコンディションフラグ)の内容が含まれていることが"RET"命令との違いです。

☞ "3.5 例外処理状態"

#### ソフトウェア割り込み命令(INT)

ソフトウェア割り込み"INT [kk]"はアドレス00kk (kk=00H ~ FFH、ページは0'固定)のベクタアドレスを指定して、その割り込みルーチンを実行させる命令です。間接コール命令の一種ですが、分岐前にSC(システムコンディションフラグ)もスタックに退避されます。したがって、この命令により実行される割り込みルーチンは必ず"RETE"命令でリターンする必要があります。

☞ "3.5 例外処理状態"

#### 相対分岐命令のPC値

JRS命令、CARS命令、DJR命令

JRS命令、CARS命令、DJR命令は符号付き8ビットPC相対ジャンプ命令で、PC値に相対値rr(-128 ~ 127)を符号付きで加算し分岐先を決定します。分岐先アドレスを"PC"、本命令の置かれている先頭アドレスを"PC"とすると、

$$PC \quad PC' + rr + (n-1)$$

となります。

ここでnは命令のバイト数を示します。たとえば、"JRS LE,rr"命令が100H番地に置かれているとすると分岐先アドレスは102H+rr番地となります。

JRL命令、CARL命令

JRL命令、CARL命令は符号付き16ビットPC相対ジャンプ命令で、PC値に相対値qqrr(-32768 ~ 32767)を符号付きで加算し分岐先を決定します。分岐先アドレスを"PC"、本命令の置かれている先頭アドレスを"PC"とすると、

$$PC \quad PC' + qqrr + 2$$

となります。

たとえば、"JRL C,qqrr"命令が100H番地に置かれているとすると分岐先アドレスは102H+qqrr番地となります。

## 2.4 データメモリ

### 2.4.1 データメモリの構成 ///////////////

S1C88のアドレス空間(最大16Mバイト)の中でプログラムメモリとして使用する領域を除くすべてをデータメモリとして使用することができます。データメモリ領域にはRAMや表示メモリ、周辺回路を制御するI/Oメモリなどが配置されます。データメモリは64Kバイトを1つのページとして管理します。

図2.4.1.1にデータメモリの構成を示します。

MODEL0/1においてはアドレス空間が64Kバイトのため、ページによる管理を考慮する必要はありません。MODEL2/3は最大で256ページの構成となります。

### 2.4.2 ページレジスタEP、XP、YP ///////////////

データメモリの物理空間は64Kバイトのページに論理的に区切られています。したがって、物理アドレスの上位8ビットがページ部、下位16ビットが論理アドレスとして管理されます。ページ内のアドレス指定はアレッシングモードにしたがってインデックスレジスタ、即値データ等によって行います。MODEL2とMODEL3にはページ部の指定用として3組のページレジスタEP、XP、YPが設定されており、アレッシングモードの指定にしたがって使い分けられます。図2.4.2.1にアレッシングモードとページレジスタの対応を示します。

☞ "4.1 アレッシングモード"



図2.4.1.1 データメモリの構成



図2.4.2.1 データメモリのアレッシング

### 2.4.3 スタック ////////////////

スタックはLIFO(Last In, First Out)形式でアクセスされるメモリで、S1C88ではデータメモリのRAM領域に割り当てられます。

スタックはサブルーチンコールや例外処理(割り込み)などが発生した場合にCPUのレジスタ情報を退避するのに使用されます。またプログラムの任意の場所でレジスタの退避等を行うことができます。以下、スタックにデータを記憶させることを"プッシュ"、記憶したデータを取り出すことを"ポップ"と記述します。

#### スタックポインタSP

データはスタックの最上位アドレスから順番にプッシュされ、逆にデータを取り出すときには最後にプッシュされたデータから順にポップされます。このプッシュとポップを行うスタックのアドレスを示すレジスタがSP(スタックポインタ)です。

SPは1バイトデータのプッシュにより'1'減算(プリデクリメント)され、1バイトデータのポップにより'1'加算(ポストインクリメント)されます。



図2.4.3.1 スタックの動作

物理メモリ内でのスタックの位置は周辺回路からコアCPUに入力されるSPP0～SPP7(スタックポインタページ)信号によってページアドレスが決定され、スタックアクセス時にはSPP0～SPP7の内容がそのままアドレスバスのページ部(A16～A23)に出力されます。そのページ内のアドレスはSPによって指定されます。一般的にはSPの初期値としてアドレス0000Hを設定することにより、そのページの最終アドレスFFFFHから下位のアドレスに向かってデータが順にプッシュされます。

注! SP(スタックポインタ)はイニシャルリセット時は不定ですので、スタックが使用される前に必ずプログラム("LD SP, \*\*"命令)で初期化を行ってください。

#### サブルーチンコールとスタック

コール命令を実行すると、サブルーチンに分岐する前にリターンアドレスとしてコール命令の次の命令の先頭アドレスとCB(MODEL2/3のマキシマムモードの場合)がスタックにプッシュされます。スタックにプッシュされたリターン情報はリターン命令の実行によりポップされ、PCとCBに再設定されます。

サブルーチンの中からさらに別のサブルーチンをコールするようなネスティングはスタックが割り当てられたページの使用可能なメモリの範囲内で何レベルまででも可能です。



図2.4.3.2 サブルーチンコール実行時のスタック消費

MODEL2/3のマキシマムモードでは、サブルーチンコールによりスタックを3バイト(CB, PC)消費します。MODEL0/1およびMODEL2/3のミニマムモードではCBを除くPCの2バイト分を消費します。

#### 例外処理とスタック

例外処理(割り込み等)発生時もサブルーチンコールと同様にリターン情報がスタックにプッシュされます。このときのリターン情報にはリターンアドレスPCとCB(MODEL2/3のマキシマムモード)のほかにSCも含まれます。



図2.4.3.3 例外処理発生時のスタック消費

MODEL2/3のマキシマムモードでは、例外処理の発生によりスタックを4バイト(CB、PC、SC)消費します。MODEL0/1およびMODEL2/3のミニマムモードではCBを除くPCとSCの3バイト分を消費します。

### その他のスタック操作

サブルーチンコールや例外処理(割り込み等)でのリターン情報のプッシュは自動的に行われますが、汎用レジスタのプッシュは行われません。サブルーチンや例外処理ルーチンから汎用レジスタの内容を分岐前の状態にして戻りたい場合は、ルーチンの最初と最後にそれぞれレジスタの内容をプッシュ/ポップする命令を配置する必要があります。

レジスタのプッシュ/ポップは"PUSH"命令と"POP"命令によって行えます。この命令によってプッシュ/ポップできるレジスタは以下のとおりです。

A、B、L、H、BR、SC、EP\*、IP(XPとYP)\*、  
BA、HL、IX、IY

\*はMODEL0/1にはありません。

また、上記のSCを除くすべてのレジスタを1命令でプッシュする"PUSH ALL"、"PUSH ALE"命令と、1命令でポップする"POP ALL"、"POP ALE"命令も用意されています。

|            |                |           |               |
|------------|----------------|-----------|---------------|
| PUSH ALL = | <u>PUSH BA</u> | POP ALL = | <u>POP BR</u> |
|            | PUSH HL        |           | POP IY        |
|            | PUSH IX        |           | POP IX        |
|            | PUSH IY        |           | POP HL        |
|            | PUSH BR        |           | POP BA        |
| PUSH ALE = | <u>PUSH BA</u> | POP ALE = | <u>POP IP</u> |
|            | PUSH HL        |           | POP EP        |
|            | PUSH IX        |           | POP BR        |
|            | PUSH IY        |           | POP IY        |
|            | PUSH BR        |           | POP IX        |
|            | PUSH EP        |           | POP HL        |
|            | PUSH IP        |           | POP BA        |

オペランドの"All"はMODEL0/1用で、"ALE"はMODEL2/3で拡張されているレジスタEPとIP(XPとYP)のプッシュ/ポップも行います。

構造化プログラミングにおいてはサブルーチンに渡す引数などをスタック領域にストアするといったことがよく行われますが、上記の"PUSH"命令や"POP"命令を使用せずにSPを操作したりスタック領域の直接アクセスが容易に行える命令等も用意されています。

ADD、SUB、CP、INC、DEC、LD

### 4.4 命令の詳細説明

注! スタックは汎用RAM領域に割り当てられますので、データ領域とスタック領域が重ならないよう注意してください。

### 2.4.4 メモリマップドI/O ///////////////////////////////

S1C88 FamilyはS1C88をコアCPUとして、その周辺に入出力ポート等、各種の回路を内蔵します。

S1C88では、それらの周辺回路の制御にメモリマップドI/O方式を採用しており、周辺回路の制御ビットやデータをやり取りするためのレジスタがデータメモリ領域に配置されます。

このメモリ領域を汎用RAMと区別するためにI/Oメモリと呼びますが、ページの管理やアクセスの方法はデータメモリと共通ですので、通常のメモリアクセスの命令を使って周辺回路を制御することができます。



図2.4.4.1 周辺回路とメモリマップドI/O

LCD ドライバ内蔵の機種ではデータメモリの一部をセグメントデータ用の表示メモリとして使用します。表示メモリ領域の各ビットはセグメントと1対1に対応し、ビットをオン/オフさせることにより対応したセグメントが点灯/消灯します。

このセグメントの制御も通常のメモリアクセスの命令で行うことができます。

注! 機種によってはI/Oメモリの一部や表示メモリがライトオンリーになっている場合があります。その場合、その部分を論理演算および算術演算命令等で直接ビット操作(リード/モディファイ/ライト)を行うことはできません。ビット操作を行う場合は同じ内容のバッファをリード/ライト可能なメモリ上に設定しておき、バッファ上でデータを変更してから本来のメモリに書き込みを行う必要があります。

周辺回路とI/Oメモリおよび表示メモリの詳細についてはS1C88 Familyの各機種のマニュアルを参照してください。

# 3 CPUの動作と処理状態

CPUはシステムクロックに同期して動作します。また、CPUの処理にはプログラムをシーケンシャルに実行している状態やスタンバイ状態等各種の状態があります。

ここでは割り込みなども含む各種の処理状態と、動作のタイミングについて説明します。

## 3.1 タイミングジェネレータとバス制御

はじめに、CPU動作の基準となるクロックとバスの制御について説明します。

### 3.1.1 バスサイクル

S1C88のタイミングジェネレータは入力されたクロックCLKから2相分周した信号PK、PLを作りCLKをステートに分解します。1ステートはCLKの1/2サイクルとなり、命令実行の単位となる1バスサイクルは4ステートの構成となります。



図3.1.1.1 ステートとバスサイクル

命令セット一覧表などでサイクルとして示された数値はこのバスサイクル数を表しています。

S1C88では各バスサイクルでのデータバスの状態を2ビットのステータス信号DBS0、DBS1で外部に出力しています。周辺回路はこの信号によってバスドライバの方向制御等を容易に行うことができます。

DBS0、DBS1により示されるデータバスのステートは表3.1.1.1のとおりです。

表3.1.1.1 データバスのステート

| DBS1 | DBS0 | ステート           |
|------|------|----------------|
| 0    | 0    | ハイインピーダンス      |
| 0    | 1    | 割り込みベクタアドレスリード |
| 1    | 0    | メモリライト         |
| 1    | 1    | メモリリード         |

以下に各バスサイクルのタイミングチャートを示します。

### ハイインピーダンス

内部レジスタアクセス時にはデータバスがハイインピーダンスとなります。また、読み出し信号RDと書き込み信号WRが共にHIGHレベルに固定され、アドレスバスはバスサイクルの期間中ダミーアドレスを出力します。



図3.1.1.2 内部レジスタアクセス時のバスサイクル

### 割り込みベクタアドレスリード

割り込みベクタアドレスはT2～T3ステートの間にデータバスから読み込まれます。

このリードに際しては読み出し信号RDが outputされず、割り込みベクタアドレス専用のリード信号RDIVが outputされます。アドレスバスはバスサイクルの期間中ダミーアドレスを出力します。



図3.1.1.3 割り込みベクタアドレスリード時のバスサイクル

### メモリライト

メモリライト時はT2～T4ステートの間データバスに書き込みデータが出力され、T3ステートにおいて書き込み信号WRが出力されます。アドレスバスはバスサイクルの期間中対象アドレスを出力します。



図3.1.1.4 メモリライト時のバスサイクル

### メモリリード

メモリリード時はT2～T3ステートの間読み出し信号RDが出力され、データバス上のデータを読み込みます。アドレスバスはバスサイクルの期間中対象アドレスを出力します。



図3.1.1.5 メモリリード時のバスサイクル

### 3.1.2 ウェイットステート

S1C88はバスラインに接続された低速デバイスのアクセスを確実に行うために、ウェイットステートを挿入してバスサイクルを伸ばすことができます。

S1C88ではウェイットステートとしてアクセスタイム伸長用のウェイトを挿入する機能を持っており、WAIT端子の入力信号によってその制御を行います。

WAIT信号のサンプリングは、T3ステートのCLKの立ち上がりエッジで行われます。このときのWAIT信号がLOWレベルの場合にT3ステートとT4ステートの間にウェイットステートTw1、Tw2を挿入し、アクセスタイムを伸ばします。WAIT信号がHIGHレベルの場合、ウェイットステートは挿入されません。ウェイットステートTw1、Tw2はWAIT信号がLOWレベルの間、連続して挿入されます。ウェイットステートの挿入を解除するためのサンプリングはTw2ステートのCLKの立ち上がりエッジで行われ、WAIT信号がHIGHレベルに戻っている場合は以降のウェイットステートが挿入されずにT4ステートを開始します。

なお、ウェイットステートはメモリ空間上に接続されたデバイスをアクセスするときにのみ挿入され、内部レジスタをアクセスするときには挿入されません。

以下に、割り込みベクタアドレスリード、メモリライト、メモリリードの各サイクルにおけるウェイットステート挿入のタイミングチャートを示します。



図3.1.2.1 割り込みベクタアドレスリードサイクルのウェイット挿入



図3.1.2.2 メモリライトサイクルのウェイト挿入



図3.1.2.3 メモリリードサイクルのウェイト挿入

### 3.2 処理状態の概要

S1C88の動作をその処理の内容により分類するリセット状態、プログラム実行状態、例外処理状態、バス権解放状態、スタンバイ状態の5種類になります。

表3.2.1に処理状態の分類を、図3.2.1に状態遷移図を示します。

表3.2.1 処理状態の分類

| 処理状態      |       | 概 要                                                                                |
|-----------|-------|------------------------------------------------------------------------------------|
| リセット状態    |       | CPUがリセットされ、停止している状態                                                                |
| プログラム実行状態 |       | CPUがプログラムを順次実行している状態                                                               |
| 例外処理状態    |       | リセット、割り込み等の例外処理要因によって起動される例外処理(ペクタアドレスのフェッチ、PCとSCの退避、PCに対する分岐アドレスの設定)を実行している過渡的な状態 |
| バス権解放状態   |       | 外部からのバス権要求信号により外部バスを解放している状態                                                       |
| スタンバイ状態   | HALT  | CPUを停止し、消費電力を低減させている状態                                                             |
|           | SLEEP | CPUおよび周辺回路を停止し、消費電力を低減させている状態                                                      |



図3.2.1 状態遷移図

### 3.3 リセット状態

リセット状態とは、S1C88がリセットされ停止している状態を示します。SR端子にLOWレベルを入力することによりS1C88がリセットされます。リセットはCLKと非同期に行われますので、すべての処理状態から即時リセット状態に移行します。

リセットにより一部の内部レジスタが初期化されます。表3.3.1にレジスタの初期設定値を示します。

図3.3.1にリセット状態とリセット解除後のシーケンスを示します。

SR端子がLOWレベルのリセット期間中はアドレスバス、データバス、リード/ライト信号がハイインピーダンスになります。ただし、アドレスバスとリード/ライト信号はCPU内部でブルアップされるため、HIGHレベルが出力されます。

SR端子がHIGHレベルになるとリセットが解除され、CLKの立ち下がりエッジが2回入力された時点で最初のバスサイクルを開始します。このバスサイクルではアドレスバスにダミーアドレスが出力され、次のバスサイクルで割り込みアクノリッジIACKがイネーブルになります。

これにより、ベクタテーブルに格納されているスタートアドレスを、不定の状態にあるPC(プログラムカウンタ)にロードするリセットの例外処理を開始します。また、このときにNB(ニューコードバンクレジスタ)の初期値01HをCB(コードバンクレジスタ)にロードする処理も同時に進行します。このため、リセット後のバンクエリアにはバンク1(008000H～00FFFFH)が選択されます。

以上の処理により、イニシャルリセット後は000000H～000001Hのメモリに格納されたスタートアドレスからプログラムの実行を開始します。

表3.3.1 内部レジスタの初期設定値

| レジスタ名称           | 記号 | ビット長 | 初期値 |
|------------------|----|------|-----|
| データレジスタA         | A  | 8    | 不定  |
| データレジスタB         | B  | 8    | 不定  |
| インデックス(データ)レジスタL | L  | 8    | 不定  |
| インデックス(データ)レジスタH | H  | 8    | 不定  |
| インデックスレジスタIX     | IX | 16   | 不定  |
| インデックスレジスタIY     | IY | 16   | 不定  |
| プログラムカウンタ        | PC | 16   | 不定* |
| スタックポインタ         | SP | 16   | 不定  |
| ベースレジスタ          | BR | 8    | 不定  |
| ゼロフラグ            | Z  | 1    | 0   |
| キャリーフラグ          | C  | 1    | 0   |
| オーバーフローフラグ       | V  | 1    | 0   |
| ネガティブフラグ         | N  | 1    | 0   |
| デシマルフラグ          | D  | 1    | 0   |
| アンパックフラグ         | U  | 1    | 0   |
| インタラプトフラグ0       | IO | 1    | 1   |
| インタラプトフラグ1       | I1 | 1    | 1   |
| ニューコードバンクレジスタ    | NB | 8    | 01H |
| コードバンクレジスタ       | CB | 8    | 不定* |
| エクスパンドページレジスタ    | EP | 8    | 00H |
| IX用エクスパンドページレジスタ | XP | 8    | 00H |
| IY用エクスパンドページレジスタ | YP | 8    | 00H |

\* リセット例外処理によって、0バンクのメモリの先頭(000000H～000001H)に格納されている値がPCにロードされます。また、このとき同時にNBの初期値01HがCBにロードされます。

レジスタNB、CB、EP、XPおよびYPはMODEL2/3にのみ設定されており、MODEL0/1にはありません。

注! リセットで初期化されないレジスタは、必要に応じてプログラムで初期化を行う必要があります。



図3.3.1 リセット状態とリセット解除後のシーケンス

### 3.4 プログラム実行状態

プログラム実行状態とは、S1C88がプログラムを順次実行している状態を示します。

S1C88では、命令の第1オペコードのフェッチが直前の命令の最終サイクルに重複して行われます。したがって、S1C88の1命令の実行サイクルは第2オペコードのフェッチサイクル、第1オペランドのリードサイクル、第1実行サイクルのいずれか(命令により異なる)から始まり、次の命令の第1オペコードのフェッチサイクルで完了します。1サイクル命令については、次の命令の第1オペコードのフェッチサイクルのみとなります。また、オペランドのリードサイクル後、実行サイクルをはさまずに第1オペコードのフェッチサイクルに移行する場合もあります。

第1オペコードのフェッチサイクルでは、その期間中SYNC信号がHIGHレベルになります。

図3.4.1に以下のプログラムと条件による命令の実行サイクルの例を示します。

| プログラムリスト |    |    |     |             |
|----------|----|----|-----|-------------|
| 001000   | 44 | 6E | LD  | A, [BR:6EH] |
| 001002   | CE | 10 | SUB | A, [IX+34H] |
| 001005   | 50 |    | LD  | L,A         |
| 001006   | 69 |    | LD  | [HL],B      |

  

| レジスタおよびメモリの条件 |   |       |  |  |
|---------------|---|-------|--|--|
| B             | = | 7FH   |  |  |
| H             | = | 81H   |  |  |
| BR            | = | 83H   |  |  |
| IX            | = | 8000H |  |  |
| EP            | = | 00H   |  |  |
| XP            | = | 00H   |  |  |
| M(008034H)    | = | 27H   |  |  |
| M(00836EH)    | = | 9BH   |  |  |



図3.4.1 命令の実行サイクル例

〈第1オペコード〉

### 3.5 例外処理状態

例外処理状態とは、割り込みなどの例外処理要因によってS1C88が通常のプログラム実行を中断して処理の流れを変える過渡的な状態を示します。

例外処理のシーケンスを図3.5.1に示します。

例外処理は例外処理要因が発生した時点で実行している命令のサイクル終了時に開始されます。

例外処理フローに示すとおり、中断したルーチンを再開するためのリターン情報をスタックに退避後、例外処理要因に対応したベクタアドレスから例外処理ルーチン(ユーザーが設定した処理ルーチン)のスタートアドレスをPCにロードしてその処理ルーチンに分岐します。ただし、リセット例外処理についてはリターン情報の退避は行われません。

この例外処理ルーチンに分岐するまでの過渡的な状態が例外処理状態で、分岐後は通常のプログラム実行状態になります。

ユーザーが作成する例外処理ルーチンはサブルーチンの形式を取りますが、スタックにSCが退避されるためリターン命令は必ず"RETE"命令を使用する必要があります。"RETE"命令により、例外処理で中断されていたルーチンの実行を再開します。



図3.5.1 例外処理フロー

## 3.5.1 例外処理の種類と優先度 ////////////////

例外処理の種類と優先度を表3.5.1.1に示します。

表3.5.1.1 例外処理の種類と優先度

| 優先度              | 種類    | 例外処理の開始タイミング                                             |
|------------------|-------|----------------------------------------------------------|
| 高<br>↑<br>↓<br>低 | リセット  | SR端子がLOWレベルからHIGHレベルに変化後の最初のフェッチサイクル                     |
|                  | ゼロ除算  | 除数ゼロでDIV命令(除算)を実行した場合のDIV命令実行直後                          |
|                  | NMI   | <ノンマスカブル割り込み><br>NMI端子に立ち下がりエッジが入力された時点で実行中の命令または例外処理終了時 |
|                  | IRQ3  | <割り込み要求3><br>IRQ3端子にLOWレベルが入力された時点で実行中の命令または例外処理終了時      |
|                  | IRQ2  | <割り込み要求2><br>IRQ2端子にLOWレベルが入力された時点で実行中の命令または例外処理終了時      |
|                  | IRQ1  | <割り込み要求1><br>IRQ1端子にLOWレベルが入力された時点で実行中の命令または例外処理終了時      |
|                  | INT命令 | <ソフトウェア割り込み><br>INT命令の実行                                 |

例外処理要因には優先順位が設定されており、複数の要因が同時に発生した場合は優先度の高い例外処理が先に実行されます。

また、例外処理状態において新たな例外処理要因が発生した場合は、その時点の例外処理終了後(例外処理ルーチンの実行前)に新たな例外処理が実行されます。

たとえば、IRQ3の例外処理中にNMIが発生した場合、IRQ3の例外処理の最後にNMIのサンプリングが行われ、ユーザーの処理ルーチンとしてはNMI処理ルーチンがIRQ3処理ルーチンより先に実行されます。IRQ3の処理ルーチンはNMIの処理ルーチン終了後に実行されます。

このため、割り込みによる例外処理ではその割り込みより優先度の低い割り込みがマスクされるようになっています。

INT命令による例外処理はプログラムによって開始できますので、優先度は設定されません。

## 3.5.2 例外処理要因とベクタ ////////////////

例外処理ルーチンのスタートアドレスは、各例外処理要因に対応したベクタアドレスにベクタとして設定しておきます。

このベクタが例外処理の最後にPCにロードされ、例外処理ルーチンへ分岐します。

表3.5.2.1に例外処理要因とベクタアドレスの対応を示します。

ベクタはCPUモデルにかかわらず論理アドレスを示す2バイトのアドレス情報に固定されています。MODEL2/3においてもユーザーが作成した例外処理ルーチンのバンクをベクタにより指定することはできません。したがって、どのバンクのプログラムを実行している場合でも共通の例外処理ルーチンに分

表3.5.2.1 例外処理要因とベクタアドレスの対応

| 例外処理要因      | ベクタアドレス           | ベクタアドレス発生元 |
|-------------|-------------------|------------|
| リセット        | 000000H ~ 000001H | CPU内部      |
| ゼロ除算        | 000002H ~ 000003H | CPU内部      |
| NMI         | 000004H ~ 000005H | CPU内部      |
| IRQ1 ~ IRQ3 | 000006H ~ 0000FFH | 周辺回路       |
| INT命令       | 000000H ~ 0000FFH | 命令のオペランド   |

岐させるために、ベクタにより指定される例外処理ルーチンの先頭をコモンエリア内(000000H ~ 007FFFFH)に配置する必要があります。

IRQ1 ~ IRQ3のベクタアドレスは周辺回路によって設定されます。INT命令の場合は命令のオペランドがそのままベクタアドレスとなり、他の例外処理要因も含めると最大128ベクタまで確保できます。

## 3.5.3 割り込み ////////////////

割り込みにはNMI、IRQ3、IRQ2、IRQ1の4種類があり、それぞれには表3.5.3.1に示す割り込み優先レベルが設定されています。

表3.5.3.1 割り込み優先レベル

| 優先度              | 割り込み優先レベル | 割り込み要因 |
|------------------|-----------|--------|
| 高<br>↑<br>↓<br>低 | 4         | NMI    |
|                  | 3         | IRQ3   |
|                  | 2         | IRQ2   |
|                  | 1         | IRQ1   |

割り込みはインターフラグI0、I1によってマスク(割り込みを受け付けないように設定)することができます。プログラムによってI0、I1の2ビットに割り込み優先レベルを設定すると、それより高い優先レベルの割り込みのみが受け付けられます。このうち、レベル4の優先度を持っているNMIはI0とI1の設定にかかわらず常時受け付けられます。

また、割り込み要因の発生により例外処理が実行されるときI0とI1は受け付けた割り込みと同じレベルに設定され、同一レベル以下の割り込みがマスクされます。このマスクの設定はSC(システムコンディションフラグ)のスタック退避後に行われますので、割り込み処理ルーチンを"RETE"命令で終了した時点でSCが元の状態に戻り、割り込みマスクも元の優先レベルに戻ります。

割り込み処理ルーチン内で同一レベル以下の多重割り込みを許可したい場合は、そのルーチンの中で再度優先レベルの設定を行ってください。

なお、NBおよびSCの内容を変更する命令を実行している最中は割り込みを受け付けません。その間に発生した割り込みの例外処理は、次の命令終了後に開始されます。

### 3.5.4 例外処理のシーケンス

例外処理のサンプリングはSYNC信号の立ち上がりエッジ(命令の第1オペコードフェッチサイクル開始時)で行われます。ここで例外処理要因が発生している場合、CPUは割り込みアクノリッジ信号IACKを出力し例外処理を開始します。IRQ1～IRQ3割り込みの場合、割り込みを発生させた周辺回路はIACK信号を受けてベクタアドレスをホールドします。

以下に各例外処理のシーケンスを示します。



図3.5.4.1 例外処理のシーケンス - リセット -

表3.5.3.2 割り込みマスクの設定

| I1 | I0 | 受け付け可能な割り込み        |
|----|----|--------------------|
| 1  | 1  | NMI                |
| 1  | 0  | NMI IRQ3           |
| 0  | 1  | NMI IRQ3 IRQ2      |
| 0  | 0  | NMI IRQ3 IRQ2 IRQ1 |

表3.5.3.3 割り込み受け付け後のI0とI1

| 受け付けた割り込み要因 | I1 | I0 |
|-------------|----|----|
| NMI         | 1  | 1  |
| IRQ3        | 1  | 1  |
| IRQ2        | 1  | 0  |
| IRQ1        | 0  | 1  |

### 3 CPUの動作と処理状態



図3.5.4.2 例外処理のシーケンス - ゼロ除算 -



図3.5.4.3 例外処理のシーケンス - NMI -



図3.5.4.4 例外処理のシーケンス - IRQ1 ~ IRQ3 -



図3.5.4.5 例外処理のシーケンス - INT命令 -

### 3.6 バス権解放状態

S1C88ではDMA(Direct Memory Access)転送など、CPU外部からのバス権要求に対してバスを解放する機能を持っています。この外部からの要求に応答してバスを解放している状態をバス権解放状態といいます。

バス権解放状態ではアドレスバス(A00～A23)、データバス(D0～D7)、およびリード/ライト信号(RD/WR)がハイインピーダンスとなり、バスマスター(バス権解放要求を出したCPU外部のデバイス)がバスに接続されたメモリなどの他のデバイスを直接アクセスすることができます。

図3.6.1にプログラム実行状態からのバス権解放のシーケンスを示します。

バスマスターとなるデバイスはCPUのBREQ端子にLOWレベルを入力して、バス権の解放を要求します。

この信号に対してCPUは各バスサイクルのT2ステート(ウェイトが挿入されている場合はTw1ステート)のCLKの立ち下がりエッジおよびT4ステートのCLKの立ち下がりエッジで2度のサンプリングを行います。T4ステートのサンプリングの時点でT2ステートに引き続きBREQ信号がLOWレベルだった場合、CPUは実行中の命令をそのバスサイクルで中断し、BACK信号をLOWレベルにしてバス権解放状態に移行します。外部バスマスターはこのBACK信号を受けてバスの制御を開始します。

なお、外部バスマスターはバス権解放要求からバスの使用が終了するまでBREQ信号をLOWレベルで保持しておく必要があります。

バス権解放状態移行後、CPUはTz1およびTz2ステートを挿入し、Tz2ステートのCLKの立ち下がりエッジでBREQ信号のサンプリングを行います。このサンプリングでHIGHレベルが検出されるまでTz1/Tz2ステートは連続して挿入されます。HIGHレベルを検出した場合、CPUは次のTz2ステートのCLKの立ち上がりエッジでBACK信号をHIGHレベルに戻し、そのTz2ステート終了直後に通常のバスサイクルに復帰して中断していた処理を再開します。

前記の例外処理状態が各命令の区切りで挿入できるのに対し、バス権解放状態はバスサイクルの区切りで挿入することができます。ただし、IACK信号を出力する例外処理(INT命令以外)を実行中で、IACK信号がLOWレベルとなっている期間はバス権解放要求を受け付けません。

以上、プログラム実行状態からバス権解放状態への移行について説明しましたが、スタンバイ状態でもHALT状態からはバス権解放状態に移行することができます。

HALT状態でのバス解放要求信号のサンプリングが、Th2ステート(後述)のCLKの立ち下がりエッジで行われる点がプログラム実行状態とは異なります。図3.6.2にHALT状態からのバス権解放のシーケンスを示します。



図3.6.1 プログラム実行状態からのバス権解放シーケンス



図3.6.2 HALT状態からのバス権解放シーケンス

### 3.7 スタンバイ状態

S1C88にはCPUの動作を停止させる機能があり、これによって消費電力を大幅に低減することができます。アプリケーションプログラムがある期間CPUに実行させる処理がない場合にこの機能を用いてCPUを停止させることができます。低消費電力化のためにCPUを停止させた状態がスタンバイ状態で、この状態にも以下に説明するHALT状態とSLEEP状態の2種類があります。

#### 3.7.1 HALT状態

HALT状態はCPUのみが停止するもので、"HALT"命令によって移行することができます。

HALT状態からはリセットまたは任意の割り込み(NMI、IRQ1 ~ IRQ3)によって例外処理に移行することができ、割り込みによる再起動の場合は例外処

理ルーチン実行後"RETE"命令によって"HALT"命令の次の命令からプログラムの実行を再開できます。発振回路などの周辺回路はHALT状態の間も動作しているため、MCU(S1C88 Family)の外部にCPU再起動用の割り込み回路などを設ける必要もなく、再起動も瞬時に行われます。

CPU内のレジスタ等は"HALT"命令実行時点の内容がHALT状態の間も保持されます。

図3.7.1.1にHALT状態への移行と再起動のシーケンスを示します。

HALT状態ではTh1およびTh2ステートが連続して挿入されます。この間Th2ステートのCLKの立ち下がりエッジで割り込みのサンプリングが行われ、割り込み要因の発生により即時例外処理に移行します。



図3.7.1.1 HALT状態への移行と再起動のシーケンス

## 3.7.2 SLEEP状態 ///////////////////////////////////////////////////////////////////

SLEEP状態はCPUとMCU内部の周辺回路の動作が停止するもので、"SLP"命令によって移行することができます。

SLEEP状態からはリセットまたはMCU外部からの割り込み(NMI、 $\overline{\text{IRQ1}} \sim \overline{\text{IRQ3}}$ )によって例外処理に移行することができ、割り込みによる再起動の場合は例外処理ルーチン実行後"RETE"命令によって"SLP"命令の次の命令からプログラムの実行を再開できます。

SLEEP状態では発振回路などの周辺回路も停止するため、HALT状態に比べて消費電力が大幅に低減できます。ただし、再起動の際に発振回路の安定待ち時間が必要となりますので、瞬時の立ち上げの必要のない長時間のスタンバイに有効です。

SLEEP状態でも規定電圧の印加によりCPU内のレジスタ等は"SLP"命令実行時点の内容が保持されます。

図3.7.2.1にSLEEP状態への移行と再起動のシーケンスを示します。

SLEEP状態で外部割り込みが発生すると、周辺回路が動作を開始し発振回路も発振を開始します。発振開始時はCPUへのCLK入力が周辺回路によってマスクされ、ある程度の安定待ち時間(数10msec ~ 数sec)経過後にCPUへの入力が開始されます。CPUは最初に入力されたCLKの立ち下がりエッジで割り込みをサンプリングし例外処理を開始します。



図3.7.2.1 SLEEP状態への移行と再起動のシーケンス

# 4 命令セット

S1C88はマシンサイクル効率が高い、高速かつ豊富な命令セットを持っています。命令の数は608個(MODEL3)でリロケータブルプログラミングが可能な命令体系となっています。ここでは、メモリ管理のためのアドレッシングモードと各命令の詳細について説明します。

## 4.1 アドレッシングモード

S1C88は以下に説明する12種類のアドレッシングモードを持っており、いろいろな状況に応じたアドレス指定が簡潔かつ的確に行えます。

以下の説明と例は、基本的にソース側を対象としています。

表4.1.1 アドレッシングモードの種類

| No. | アドレッシングモード                |
|-----|---------------------------|
| 1   | 即値データアドレッシング              |
| 2   | レジスタ直接アドレッシング             |
| 3   | レジスタ間接アドレッシング             |
| 4   | ディスプレースメント付きレジスタ間接アドレッシング |
| 5   | インデックスレジスタ付きレジスタ間接アドレッシング |
| 6   | 8ビット絶対アドレッシング             |
| 7   | 16ビット絶対アドレッシング            |
| 8   | 8ビット間接アドレッシング             |
| 9   | 16ビット間接アドレッシング            |
| 10  | 符号付き8ビットPC相対アドレッシング       |
| 11  | 符号付き16ビットPC相対アドレッシング      |
| 12  | インプライドレジスタアドレッシング         |

### 即値データアドレッシング

即値データアドレッシングは演算や転送のソースデータに即値データを用いる場合のアドレッシングモードです。命令のソースオペランドを="#"で続く8ビット即値データ、または16ビット即値データで直接ソースデータとして指定します。

命令セットの表記においては、以下の記号によって即値データを表します。

表4.1.2 即値データのシンボル

| 記号    | 用途     | サイズ   | 指定範囲    |
|-------|--------|-------|---------|
| #nn   | 汎用データ  | 8ビット  | 0~255   |
| #hh   | BR設定用  | 8ビット  | 0~255   |
| #bb   | NB設定用  | 8ビット  | 0~255   |
| #pp   | ページ設定用 | 8ビット  | 0~255   |
| #mmnn | 汎用データ  | 16ビット | 0~65535 |

例: LD A, #03H



図4.1.1 即値データアドレッシング

### レジスタ直接アドレッシング

レジスタ直接アドレッシングは、ソースまたはディスティネーションにレジスタを指定する場合のアドレッシングモードです。

命令セットの表記においては、オペランドに以下のレジスタ名をそのまま使用します。

### レジスタ表記の種類

8ビット: A、B、L、H、BR、SC、NB、EP、XP、YP

16ビット: BA、HL、IX、IY、PC、SP、IP(XP&YP)

NB、EP、XP、YP、IPについてはMODEL2/3のみ使用可能です。

ソースオペランドにこのモードを用いた場合、指定したレジスタの内容が演算や転送のソースデータになります。ディスティネーションオペランドに用いた場合は、そのレジスタに対してデータのストアや演算などの操作が行われます。

例: LD A,B



図4.1.2 レジスタ直接アドレッシング

### レジスタ間接アドレッシング

レジスタ間接アドレッシングはデータメモリをアクセスするためのアドレッシングモードで、インデックスレジスタによってデータメモリのアドレスを間接的に指定します。

アドレス指定に使用するインデックスレジスタはHL、IX、IYの3種類で、その内容がアクセスされるデータメモリのアドレスとなります。

命令セットにおいては、インデックスレジスタ名を[]で囲んで[HL]、[IX]、[IY]と表記します。

ソースオペランドにこのモードを用いた場合、指定したインデックスレジスタの内容がデータメモリのアドレスとなり、そのアドレスにストアされている内容がソースデータとなります。ディスティネーションオペランドに用いた場合は、指定されたデータメモリに対してデータのストアや演算などの操作が行われます。

MODEL2/3ではページ部の指定も必要になり、これにはエクスパンドページレジスタEP(HL用)、XP(IX用)、YP(IY用)が使用されます。



図4.1.3 レジスタ間接アドレッシング

### ディスプレースメント付きレジスタ間接

#### アドレッシング

ディスプレースメント付きレジスタ間接アドレッシングはデータメモリをアクセスするためのアドレッシングモードで、レジスタとディスプレースメントによってデータメモリのアドレスを指定します。データメモリのアドレスは、指定したレジスタの内容にディスプレースメント(符号付き8ビットデータ、-128～127)を加算した値となります。

アドレス指定に使用するレジスタはIX、IY、SPで、命令セットにおいては、符号付き8ビットデータによるディスプレースメントに記号ddを使用し、[IX+dd]、[IY+dd]、[SP+dd]と表記します。

ソースオペランドにこのモードを用いた場合、指定されたレジスタの内容にディスプレースメントを加算した値がデータメモリのアドレスとなり、そのアドレスにストアされている内容がソースデータとなります。ディスティネーションオペランドに用いた場合は、指定されたデータメモリに対してデータのストアや演算などの操作が行われます。

MODEL2/3ではページ部の指定も必要になり、これにはエクスパンドページレジスタXP(IX用)、YP(IY用)が使用されます。SP(スタックポインタ)を使用する場合のページ指定は各機種ごとに周辺回路上で設定されるSP用のページレジスタの内容がそのまま用いられます。

図4.1.4 ディスプレースメント付き  
レジスタ間接アドレッシング

### インデックスレジスタ付きレジスタ間接

#### アドレッシング

インデックスレジスタ付きレジスタ間接アドレッシングは、ディスプレースメント付きレジスタ間接アドレッシングと同様のモードで、ディスプレースメントに8ビットデータではなくLレジスタの内容を使用します。

この場合、Lレジスタの内容は符号付き8ビットデータ(-128～127)として扱われます。

アドレス指定にはインデックスレジスタIXとIYを使用し、ディスプレースメントとして使用されるレジスタはLレジスタに固定されます。命令セットにおいては、[IX+L]、[IY+L]と表記します。

MODEL2/3ではページ部の指定も必要になり、これにはエクスパンドページレジスタXP(IX用)、YP(IY用)が使用されます。

図4.1.5 インデックスレジスタ付き  
レジスタ間接アドレッシング

### 8ビット絶対アドレッシング

8ビット絶対アドレッシングはデータメモリをアクセスするためのアドレッシングモードで、8ビット絶対アドレスによってアドレスの下位8ビットを直接指定します。アドレスの上位8ビットはBRレジスタの内容により間接的に指定されます。

命令セットにおいては、アドレス指定を行う8ビット絶対アドレス(0～255)に記号//を使用し、[BR://]と表記します。

ソースオペランドにこのモードを用いた場合、BRレジスタの内容をアドレスの上位8ビット、指定した8ビット絶対アドレスを下位8ビットとしてアドレス指定されたデータメモリにストアされている内容がソースデータとなります。ディスティネーションオペランドに用いた場合は、指定されたデータメモリに対してデータのストアや演算などの操作が行われます。

MODEL2/3ではページ部の指定も必要になり、これにはエクスパンドページレジスタEPが使用されます。



図4.1.6 8ビット絶対アドレッシング

### 16ビット絶対アドレッシング

16ビット絶対アドレッシングはデータメモリをアクセスするためのアドレッシングモードで、16ビット絶対アドレスによってアドレスを直接指定します。命令セットにおいては、アドレス指定を行う16ビット絶対アドレス(0 ~ 65535)に記号hh//lを使用し、[hh//l]と表記します。

ソースオペランドにこのモードを用いた場合、指定した16ビット絶対アドレスが直接データメモリのアドレスとなり、そのアドレスにストアされている内容がソースデータとなります。ディスティネーションオペランドに用いた場合は、指定されたデータメモリに対してデータのストアや演算などの操作が行われます。

MODEL2/3ではページ部の指定も必要になり、これにはエクスパンドページレジスタEPが使用されます。



図4.1.7 16ビット絶対アドレッシング

### 8ビット間接アドレッシング

8ビット間接アドレッシングは分岐命令における分岐先アドレスにベクタ領域(000000H ~ 0000FFH)の内容を使用するアドレッシングモードで、ベクタアドレスを8ビット絶対アドレスで指定します。指定したメモリアドレスの内容をPC(プログラムカウンタ)の下位8ビット、次のアドレスの内容をPCの上位8ビットにそれぞれロードして分岐を行います。

MODEL2/3ではNBレジスタの設定により分岐先バンクの選択も行われます。

命令セットにおいては、アドレス指定を行う8ビット絶対アドレス(0 ~ 255)に記号kkを使用し、[kk]と表記します。

このアドレッシングモードの命令は"JP [kk]"、"INT [kk]"の2種類です。



図4.1.8 8ビット間接アドレッシング

### 16ビット間接アドレッシング

16ビット間接アドレッシングは"CALL [hh//l]"命令のアドレッシングモードで、分岐先アドレスを16ビット絶対アドレス(0 ~ 65535)で間接的に指定します。指定したデータメモリアドレスの内容をPC(プログラムカウンタ)の下位8ビット、次のアドレスの内容をPCの上位8ビットにそれぞれロードして分岐を行います。

MODEL2/3ではページ部の指定も必要になり、これにはエクスパンドページレジスタEPが使用されます。また、NBレジスタの設定により分岐先バンクの選択も行われます。



図4.1.9 16ビット間接アドレッシング

### 符号付き8ビットPC相対アドレッシング

符号付き8ビットPC相対アドレッシングは分岐命令で使用されるアドレッシングモードです。オペランドで指定された符号付き8ビット相対アドレス(-128 ~ 127)が分岐実行時のPCに加算され、そのアドレスに分岐します。

分岐実行時のPC値は次のようにになっています。

2バイト命令: PC = 命令の先頭アドレス + 1

3バイト命令: PC = 命令の先頭アドレス + 2

命令セットの表記においては、符号付き8ビット相対アドレス(-128 ~ 127)に記号rrを使用します。

MODEL2/3ではNBレジスタの設定により分岐先バンクの選択も行われます。



図4.1.10 符号付き8ビットPC相対アドレッシング

### 符号付き16ビットPC相対アドレッシング

符号付き16ビットPC相対アドレッシングは分岐命令で使用されるアドレッシングモードです。オペランドで指定された符号付き16ビット相対アドレス(-32768 ~ 32767)が分岐実行時のPCに加算され、そのアドレスに分岐します。

分岐実行時のPC値は命令の先頭アドレス+2となります。

命令セットの表記においては、符号付き16ビット相対アドレス(-32768 ~ 32767)に記号qqrrを使用します。

MODEL2/3ではNBレジスタの設定により分岐先バンクの選択も行われます。



図4.1.11 符号付き16ビットPC相対アドレッシング

### インプライドレジスタアドレッシング

インプライドレジスタアドレッシングはオペランドを持たずに、暗黙的にレジスタが指定されるレジスタ直接アドレッシングモードです。

このアドレッシングモードの命令はMLT、DIV、SEP、PACK、UPCKの5種類です。

## 4.2 命令のフォーマット

S1C88の1命令は1バイトから4バイトのコードで次のように構成されています。

- 1 オペコード
- 2 オペコード オペコード  
(CEH/CFH)
- 3 オペコード オペランド
- 4 オペコード オペコード オペランド  
(CEH/CFH)
- 5 オペコード オペランド オペランド
- 6 オペコード オペコード オペランド オペランド  
(CEH/CFH)

図4.2.1 命令のフォーマット

### オペコード

S1C88の命令セットは608種類(MODEL3)あり、1バイトのオペコードではすべての命令を表現できません。そこで、コードのCEHとCFHを拡張コードとして第1オペコードに使用し、続く1バイトを第2オペコードとして命令を拡張しています。16ビット演算/転送命令およびスタック操作命令をコードCFHで、その他の命令をコードCEHでそれぞれ拡張しています。

また、各命令のアドレッシングモードは、第1または第2オペコードの下位3ビットで指定されます。レジスタ直接アドレッシング、レジスタ間接アドレッシング、インデックスレジスタ付きレジスタ間接アドレッシングの命令がオペコードのみで構成されます。

### オペランド

8ビットの即値データアドレッシング、ディスプレースメント付きレジスタ間接アドレッシング、8ビット絶対アドレッシング(ソースをレジスタで指定している場合)、8ビット間接アドレッシング、符号付き8ビットPC相対アドレッシングの命令は1バイトのオペランドを持っており、8ビットデータによる指定値がそのままオペランドとなります。

16ビットの即値データアドレッシング、8ビット絶対アドレッシング(ソースを即値で指定している場合)、16ビット絶対アドレッシング、16ビット間接アドレッシング、符号付き16ビットPC相対アドレッシングの命令は2バイトのオペランドを持っており、16ビットデータによる指定値の下位8ビットが第1オペランド、上位8ビットが第2オペランドとなります。(8ビット絶対アドレッシングの場合は、アドレス指定が第1オペランド、即値データが第2オペランドとなります。)

## 4.3 命令セット一覧表

ここではS1C88の命令セットを機能別に分類した一覧表を掲載しています。

なお、"APPENDIX"にもアドレッシングモード別一覧表が掲載されていますので、必要に応じて参照してください。

### 4.3.1 機能分類

命令の機能分類を表4.3.1.1に示します。

表4.3.1.1 命令の機能分類

| 機能分類           | 二ーモニック | オペレーション      | 機能分類          | 二ーモニック  | オペレーション    |
|----------------|--------|--------------|---------------|---------|------------|
| 8ビット<br>算術論理演算 | ADD    | 加算           | 16ビット<br>算術演算 | ADD     | 加算         |
|                | ADC    | キャリー付き加算     |               | ADC     | キャリー付き加算   |
|                | SUB    | 減算           |               | SUB     | 減算         |
|                | SBC    | キャリー付き減算     |               | SBC     | キャリー付き減算   |
|                | AND    | 論理積          |               | CP      | 比較         |
|                | OR     | 論理和          |               | INC     | 1加算        |
|                | XOR    | 排他的論理和       |               | DEC     | 1減算        |
|                | CP     | 比較           |               | BIT     | ビットテスト     |
|                | INC    | 1加算          |               | LD      | ロード        |
|                | DEC    | 1減算          |               | EX      | ワード交換      |
|                | MLT    | 乗算           |               | STACK制御 | PUSH プッシュ  |
|                | DIV    | 除算           |               | POP ポップ |            |
|                | CPL    | 1の補数         |               | JRS     | 相対ショートジャンプ |
|                | NEG    | 2の補数         |               | JRL     | 相対ロングジャンプ  |
| 8ビット転送         | LD     | ロード          |               | JP      | 間接ジャンプ     |
|                | EX     | バイト交換        |               | DJR     | ループ        |
|                | SWAP   | ニブル交換        |               | CARS    | 相対ショートコール  |
| ローテート<br>/シフト  | RL     | キャリー付き左ローテート |               | CARL    | 相対ロングコール   |
|                | RLC    | 左ローテート       |               | CALL    | 間接コール      |
|                | RR     | キャリー付き右ローテート |               | RET     | リターン       |
|                | RRC    | 右ローテート       |               | RETE    | 例外処理リターン   |
|                | SLA    | 算術左シフト       |               | RETS    | スキップリターン   |
|                | SLL    | 論理左シフト       |               | INT     | ソフトウェア割り込み |
|                | SRA    | 算術右シフト       |               |         |            |
|                | SRL    | 論理右シフト       |               |         |            |
| 演算補助           | PACK   | パック          | システム制御        | NOP     | ノーオペレーション  |
|                | UPCK   | アンパック        |               | HALT    | HALT状態移行   |
|                | SEP    | 符号拡張         |               | SLP     | SLEEP状態移行  |

## 4.3.2 記号の意味 //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

次項の機能別命令一覧表で使われている記号の意味を表4.3.2.1に示します。

表4.3.2.1 記号の意味

| レジスタ関係 |                         | メモリ関係   |                       |
|--------|-------------------------|---------|-----------------------|
| A      | データレジスタA                | [HL]    | HLレジスタで指定されるメモリ       |
| A(H)   | Aレジスタの上位4ビット            | [HL](H) | [HL]の上位4ビット           |
| A(L)   | Aレジスタの下位4ビット            | [HL](L) | [HL]の下位4ビット           |
| B      | データレジスタB                | [IX]    | IXレジスタで指定されるメモリ       |
| BA     | BAペアレジスタ                | [IX+dd] | IXレジスタ+ddで指定されるメモリ    |
| H      | データレジスタH                | [IX+L]  | IXレジスタ+Lレジスタで指定されるメモリ |
| L      | データレジスタL                | [IY]    | IYレジスタで指定されるメモリ       |
| HL     | インデックスレジスタHL            | [IY+dd] | IYレジスタ+ddで指定されるメモリ    |
| IX     | インデックスレジスタIX            | [IY+L]  | IYレジスタ+Lレジスタで指定されるメモリ |
| IX(H)  | IXレジスタの上位8ビット           | [BR://] | BRレジスタと"//で指定されるメモリ   |
| IX(L)  | IXレジスタの下位8ビット           | [hh//]  | "hh//で指定されるメモリ        |
| IY     | インデックスレジスタIY            | [kk]    | "kk"で指定されるベクタ         |
| IY(H)  | IYレジスタの上位8ビット           | [SP]    | SPで指定されるスタック          |
| IY(L)  | IYレジスタの下位8ビット           | [SP+dd] | SP+ddで指定されるスタック       |
| SP     | スタックポインタSP              | フラグ関係   |                       |
| BR     | ベースレジスタBR               | Z       | ゼロフラグ                 |
| SC     | システムコンディションフラグSC        | C       | キャリーフラグ               |
| CC     | カスタマイズコンディションフラグCC      | V       | オーバーフローフラグ            |
| PC     | プログラムカウンタPC             | N       | ネガティブフラグ              |
| PC(H)  | PCの上位8ビット               | D       | デシマルフラグ               |
| PC(L)  | PCの下位8ビット               | U       | アンパックフラグ              |
| NB     | ニューコードバンクレジスタNB         | I0      | インタラプトフラグ0            |
| CB     | コードバンクレジスタCB            | I1      | インタラプトフラグ1            |
| EP     | エクスパンドページレジスタEP         | ↑       | フラグのセット/リセット          |
| XP     | IX用エクスパンドページレジスタXP      | -       | 変化なし                  |
| YP     | IY用エクスパンドページレジスタYP      | 0       | フラグのリセット              |
| IP     | XPおよびYPレジスタ             | F0      | カスタマイズコンディションフラグF0    |
| 即値データ  |                         | F1      | カスタマイズコンディションフラグF1    |
| nn     | 8ビット即値データ(符号なし)         | F2      | カスタマイズコンディションフラグF2    |
| hh     | 絶対アドレス上位8ビット設定データ(符号なし) | F3      | カスタマイズコンディションフラグF3    |
| ll     | 絶対アドレス下位8ビット設定データ(符号なし) | 演算、その他  |                       |
| pp     | ページ設定データ(符号なし)          | +       | 加算                    |
| bb     | バンク設定データ(符号なし)          | -       | 減算                    |
| dd     | 符号付き8ビットディスプレースメント      | *       | 乗算                    |
| rr     | 8ビット相対アドレス設定データ(符号付き)   | /       | 除算                    |
| kk     | ベクタアドレス設定データ(符号なし)      | ^       | 論理積                   |
| mmnn   | 16ビット即値データ(符号なし)        | ∨       | 論理和                   |
| hh ll  | 16ビット絶対アドレス設定データ(符号なし)  | ▽       | 排他的論理和                |
| qqrr   | 16ビット相対アドレス設定データ(符号付き)  | ★       | 10進演算/アンパック演算可能な命令    |

## 4.3.3 機能別命令一覧表 //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

表4.3.3.1(a) 機能別命令一覧表 (8ビット転送命令 1/3)

## 8ビット転送命令

| ニーモニック | コード       | オペレーション     | サイ<br>クル  | バイト | SC |    |   |   |   |   | 備 考 | ページ |     |
|--------|-----------|-------------|-----------|-----|----|----|---|---|---|---|-----|-----|-----|
|        |           |             |           |     | I1 | I0 | U | D | N | V | C   | Z   |     |
| LD     | A,A       | 40          | A←A       | 1   | 1  | —  | — | — | — | — | —   | —   | 101 |
|        | A,B       | 41          | A←B       | 1   | 1  | —  | — | — | — | — | —   | —   | 101 |
|        | A,L       | 42          | A←L       | 1   | 1  | —  | — | — | — | — | —   | —   | 101 |
|        | A,H       | 43          | A←H       | 1   | 1  | —  | — | — | — | — | —   | —   | 101 |
|        | A,BR      | CE,C0       | A←BR      | 2   | 2  | —  | — | — | — | — | —   | —   | 101 |
|        | A,SC      | CE,C1       | A←SC      | 2   | 2  | —  | — | — | — | — | —   | —   | 101 |
|        | A,#nn     | B0,nn       | A←nn      | 2   | 2  | —  | — | — | — | — | —   | —   | 108 |
|        | A,[BR:ll] | 44,ll       | A←[BR:ll] | 3   | 2  | —  | — | — | — | — | —   | —   | 111 |
|        | A,[hhll]  | CE,D0,ll,hh | A←[hhll]  | 5   | 4  | —  | — | — | — | — | —   | —   | 113 |
|        | A,[HL]    | 45          | A←[HL]    | 2   | 1  | —  | — | — | — | — | —   | —   | 113 |
|        | A,[IX]    | 46          | A←[IX]    | 2   | 1  | —  | — | — | — | — | —   | —   | 115 |
|        | A,[IY]    | 47          | A←[IY]    | 2   | 1  | —  | — | — | — | — | —   | —   | 116 |
|        | A,[IX+dd] | CE,40,dd    | A←[IX+dd] | 4   | 3  | —  | — | — | — | — | —   | —   | 118 |
|        | A,[IY+dd] | CE,41,dd    | A←[IY+dd] | 4   | 3  | —  | — | — | — | — | —   | —   | 119 |
|        | A,[IX+L]  | CE,42       | A←[IX+L]  | 4   | 2  | —  | — | — | — | — | —   | —   | 121 |
|        | A,[IY+L]  | CE,43       | A←[IY+L]  | 4   | 2  | —  | — | — | — | — | —   | —   | 122 |
| LD     | A,NB      | CE,C8       | A←NB      | 2   | 2  | —  | — | — | — | — | —   | —   | 102 |
|        | A,EP      | CE,C9       | A←EP      | 2   | 2  | —  | — | — | — | — | —   | —   | 102 |
|        | A,XP      | CE,CA       | A←XP      | 2   | 2  | —  | — | — | — | — | —   | —   | 102 |
|        | A,YP      | CE,CB       | A←YP      | 2   | 2  | —  | — | — | — | — | —   | —   | 102 |
|        | B,A       | 48          | B←A       | 1   | 1  | —  | — | — | — | — | —   | —   | 101 |
|        | B,B       | 49          | B←B       | 1   | 1  | —  | — | — | — | — | —   | —   | 101 |
|        | B,L       | 4A          | B←L       | 1   | 1  | —  | — | — | — | — | —   | —   | 101 |
|        | B,H       | 4B          | A←H       | 1   | 1  | —  | — | — | — | — | —   | —   | 101 |
|        | B,#nn     | B1,nn       | B←nn      | 2   | 2  | —  | — | — | — | — | —   | —   | 108 |
|        | B,[BR:ll] | 4C,ll       | B←[BR:ll] | 3   | 2  | —  | — | — | — | — | —   | —   | 111 |
|        | B,[hhll]  | CE,D1,ll,hh | B←[hhll]  | 5   | 4  | —  | — | — | — | — | —   | —   | 113 |
|        | B,[HL]    | 4D          | B←[HL]    | 2   | 1  | —  | — | — | — | — | —   | —   | 113 |
|        | B,[IX]    | 4E          | B←[IX]    | 2   | 1  | —  | — | — | — | — | —   | —   | 115 |
|        | B,[IY]    | 4F          | B←[IY]    | 2   | 1  | —  | — | — | — | — | —   | —   | 116 |
|        | B,[IX+dd] | CE,48,dd    | B←[IX+dd] | 4   | 3  | —  | — | — | — | — | —   | —   | 118 |
|        | B,[IY+dd] | CE,49,dd    | B←[IY+dd] | 4   | 3  | —  | — | — | — | — | —   | —   | 119 |
|        | B,[IX+L]  | CE,4A       | B←[IX+L]  | 4   | 2  | —  | — | — | — | — | —   | —   | 121 |
|        | B,[IY+L]  | CE,4B       | B←[IY+L]  | 4   | 2  | —  | — | — | — | — | —   | —   | 122 |
| LD     | L,A       | 50          | L←A       | 1   | 1  | —  | — | — | — | — | —   | —   | 101 |
|        | L,B       | 51          | L←B       | 1   | 1  | —  | — | — | — | — | —   | —   | 101 |
|        | L,L       | 52          | L←L       | 1   | 1  | —  | — | — | — | — | —   | —   | 101 |
|        | L,H       | 53          | L←H       | 1   | 1  | —  | — | — | — | — | —   | —   | 101 |
|        | L,#nn     | B2,nn       | L←nn      | 2   | 2  | —  | — | — | — | — | —   | —   | 108 |
|        | L,[BR:ll] | 54,ll       | L←[BR:ll] | 3   | 2  | —  | — | — | — | — | —   | —   | 111 |
|        | L,[hhll]  | CE,D2,ll,hh | L←[hhll]  | 5   | 4  | —  | — | — | — | — | —   | —   | 113 |
|        | L,[HL]    | 55          | L←[HL]    | 2   | 1  | —  | — | — | — | — | —   | —   | 113 |
|        | L,[IX]    | 56          | L←[IX]    | 2   | 1  | —  | — | — | — | — | —   | —   | 115 |
|        | L,[IY]    | 57          | L←[IY]    | 2   | 1  | —  | — | — | — | — | —   | —   | 116 |
|        | L,[IX+dd] | CE,50,dd    | L←[IX+dd] | 4   | 3  | —  | — | — | — | — | —   | —   | 118 |
|        | L,[IY+dd] | CE,51,dd    | L←[IY+dd] | 4   | 3  | —  | — | — | — | — | —   | —   | 119 |
|        | L,[IX+L]  | CE,52       | L←[IX+L]  | 4   | 2  | —  | — | — | — | — | —   | —   | 121 |
|        | L,[IY+L]  | CE,53       | L←[IY+L]  | 4   | 2  | —  | — | — | — | — | —   | —   | 122 |

- \* ニューコードバンクレジスタNBおよびエクスパンドページレジスタEP/XP/YPはMODEL2/3にのみ設定されています。したがって、MODEL0/1ではこれらのレジスタをアクセスする命令は使用できません。

表4.3.3.1(b) 機能別命令一覧表 (8ビット転送命令 2/3)

## 8ビット転送命令

| ニーモニック | コード          | オペレーション     | サイクル         | バイト | SC |    |   |   |   |   |   | 備考 | ページ |
|--------|--------------|-------------|--------------|-----|----|----|---|---|---|---|---|----|-----|
|        |              |             |              |     | I1 | I0 | U | D | N | V | C | Z  |     |
| LD     | H,A          | 58          | H←A          | 1   | 1  | —  | — | — | — | — | — | —  | 101 |
|        | H,B          | 59          | H←B          | 1   | 1  | —  | — | — | — | — | — | —  | 101 |
|        | H,L          | 5A          | H←L          | 1   | 1  | —  | — | — | — | — | — | —  | 101 |
|        | H,H          | 5B          | H←H          | 1   | 1  | —  | — | — | — | — | — | —  | 101 |
|        | H,#nn        | B3,nn       | H←nn         | 2   | 2  | —  | — | — | — | — | — | —  | 108 |
|        | H,[BR:ll]    | 5C,ll       | H←[BR:ll]    | 3   | 2  | —  | — | — | — | — | — | —  | 111 |
|        | H,[hh:ll]    | CE,D3,ll,hh | H←[hh:ll]    | 5   | 4  | —  | — | — | — | — | — | —  | 113 |
|        | H,[HL]       | 5D          | H←[HL]       | 2   | 1  | —  | — | — | — | — | — | —  | 113 |
|        | H,[IX]       | 5E          | H←[IX]       | 2   | 1  | —  | — | — | — | — | — | —  | 115 |
|        | H,[IY]       | 5F          | H←[IY]       | 2   | 1  | —  | — | — | — | — | — | —  | 116 |
|        | H,[IX+dd]    | CE,58,dd    | H←[IX+dd]    | 4   | 3  | —  | — | — | — | — | — | —  | 118 |
|        | H,[IY+dd]    | CE,59,dd    | H←[IY+dd]    | 4   | 3  | —  | — | — | — | — | — | —  | 119 |
|        | H,[IX+L]     | CE,5A       | H←[IX+L]     | 4   | 2  | —  | — | — | — | — | — | —  | 121 |
|        | H,[IY+L]     | CE,5B       | H←[IY+L]     | 4   | 2  | —  | — | — | — | — | — | —  | 122 |
| LD     | BR,A         | CE,C2       | BR←A         | 2   | 2  | —  | — | — | — | — | — | —  | 102 |
|        | BR,#hh       | B4,hh       | BR←hh        | 2   | 2  | —  | — | — | — | — | — | —  | 108 |
| LD     | SC,A         | CE,C3       | SC←A         | 3   | 2  | ↑  | ↑ | ↑ | ↑ | ↑ | ↑ | ↑  | 102 |
|        | SC,#nn       | 9F,nn       | SC←nn        | 3   | 2  | ↑  | ↑ | ↑ | ↑ | ↑ | ↑ | ↑  | 108 |
| LD     | [BR:ll],A    | 78,ll       | [BR:ll]←A    | 3   | 2  | —  | — | — | — | — | — | —  | 103 |
|        | [BR:ll],B    | 79,ll       | [BR:ll]←B    | 3   | 2  | —  | — | — | — | — | — | —  | 103 |
|        | [BR:ll],L    | 7A,ll       | [BR:ll]←L    | 3   | 2  | —  | — | — | — | — | — | —  | 103 |
|        | [BR:ll],H    | 7B,ll       | [BR:ll]←H    | 3   | 2  | —  | — | — | — | — | — | —  | 103 |
|        | [BR:ll],#nn  | DD,ll,nn    | [BR:ll]←nn   | 4   | 3  | —  | — | — | — | — | — | —  | 110 |
|        | [BR:ll],[HL] | 7D,ll       | [BR:ll]←[HL] | 4   | 2  | —  | — | — | — | — | — | —  | 114 |
|        | [BR:ll],[IX] | 7E,ll       | [BR:ll]←[IX] | 4   | 2  | —  | — | — | — | — | — | —  | 115 |
|        | [BR:ll],[IY] | 7F,ll       | [BR:ll]←[IY] | 4   | 2  | —  | — | — | — | — | — | —  | 117 |
|        | [hh:ll],A    | CE,D4,ll,hh | [hh:ll]←A    | 5   | 4  | —  | — | — | — | — | — | —  | 104 |
| LD     | [hh:ll],B    | CE,D5,ll,hh | [hh:ll]←B    | 5   | 4  | —  | — | — | — | — | — | —  | 104 |
|        | [hh:ll],L    | CE,D6,ll,hh | [hh:ll]←L    | 5   | 4  | —  | — | — | — | — | — | —  | 104 |
|        | [hh:ll],H    | CE,D7,ll,hh | [hh:ll]←H    | 5   | 4  | —  | — | — | — | — | — | —  | 104 |
|        | [HL],A       | 68          | [HL]←A       | 2   | 1  | —  | — | — | — | — | — | —  | 104 |
| LD     | [HL],B       | 69          | [HL]←B       | 2   | 1  | —  | — | — | — | — | — | —  | 104 |
|        | [HL],L       | 6A          | [HL]←L       | 2   | 1  | —  | — | — | — | — | — | —  | 104 |
|        | [HL],H       | 6B          | [HL]←H       | 2   | 1  | —  | — | — | — | — | — | —  | 104 |
|        | [HL],#nn     | B5,nn       | [HL]←nn      | 3   | 2  | —  | — | — | — | — | — | —  | 110 |
|        | [HL],[BR:ll] | 6C,ll       | [HL]←[BR:ll] | 4   | 2  | —  | — | — | — | — | — | —  | 112 |
|        | [HL],[HL]    | 6D          | [HL]←[HL]    | 3   | 1  | —  | — | — | — | — | — | —  | 114 |
|        | [HL],[IX]    | 6E          | [HL]←[IX]    | 3   | 1  | —  | — | — | — | — | — | —  | 115 |
|        | [HL],[IY]    | 6F          | [HL]←[IY]    | 3   | 1  | —  | — | — | — | — | — | —  | 117 |
|        | [HL],[IX+dd] | CE,60,dd    | [HL]←[IX+dd] | 5   | 3  | —  | — | — | — | — | — | —  | 118 |
|        | [HL],[IY+dd] | CE,61,dd    | [HL]←[IY+dd] | 5   | 3  | —  | — | — | — | — | — | —  | 120 |
|        | [HL],[IX+L]  | CE,62       | [HL]←[IX+L]  | 5   | 2  | —  | — | — | — | — | — | —  | 121 |
|        | [HL],[IY+L]  | CE,63       | [HL]←[IY+L]  | 5   | 2  | —  | — | — | — | — | — | —  | 123 |
|        | [IX],A       | 60          | [IX]←A       | 2   | 1  | —  | — | — | — | — | — | —  | 105 |
|        | [IX],B       | 61          | [IX]←B       | 2   | 1  | —  | — | — | — | — | — | —  | 105 |
|        | [IX],L       | 62          | [IX]←L       | 2   | 1  | —  | — | — | — | — | — | —  | 105 |
|        | [IX],H       | 63          | [IX]←H       | 2   | 1  | —  | — | — | — | — | — | —  | 105 |
|        | [IX],#nn     | B6,nn       | [IX]←nn      | 3   | 2  | —  | — | — | — | — | — | —  | 111 |

表4.3.3.1(c) 機能別命令一覧表 (8ビット転送命令 3/3)

## 8ビット転送命令

| ニーモニック | コード          | オペレーション  | サイクル            | バイト | SC |    |   |   |   |   | 備考 | ページ |     |
|--------|--------------|----------|-----------------|-----|----|----|---|---|---|---|----|-----|-----|
|        |              |          |                 |     | I1 | I0 | U | D | N | V | C  | Z   |     |
| LD     | [IX],[BR:ll] | 64,ll    | [IX]←[BR:ll]    | 4   | 2  | —  | — | — | — | — | —  | —   | 112 |
|        | [IX],[HL]    | 65       | [IX]←[HL]       | 3   | 1  | —  | — | — | — | — | —  | —   | 114 |
|        | [IX],[IX]    | 66       | [IX]←[IX]       | 3   | 1  | —  | — | — | — | — | —  | —   | 116 |
|        | [IX],[IY]    | 67       | [IX]←[IY]       | 3   | 1  | —  | — | — | — | — | —  | —   | 117 |
|        | [IX],[IX+dd] | CE,68,dd | [IX]←[IX+dd]    | 5   | 3  | —  | — | — | — | — | —  | —   | 119 |
|        | [IX],[IY+dd] | CE,69,dd | [IX]←[IY+dd]    | 5   | 3  | —  | — | — | — | — | —  | —   | 120 |
|        | [IX],[IX+L]  | CE,6A    | [IX]←[IX+L]     | 5   | 2  | —  | — | — | — | — | —  | —   | 122 |
|        | [IX],[IY+L]  | CE,6B    | [IX]←[IY+L]     | 5   | 2  | —  | — | — | — | — | —  | —   | 123 |
| LD     | [IY],A       | 70       | [IY]←A          | 2   | 1  | —  | — | — | — | — | —  | —   | 105 |
|        | [IY],B       | 71       | [IY]←B          | 2   | 1  | —  | — | — | — | — | —  | —   | 105 |
|        | [IY],L       | 72       | [IY]←L          | 2   | 1  | —  | — | — | — | — | —  | —   | 105 |
|        | [IY],H       | 73       | [IY]←H          | 2   | 1  | —  | — | — | — | — | —  | —   | 105 |
|        | [IY],#nn     | B7,nn    | [IY]←nn         | 3   | 2  | —  | — | — | — | — | —  | —   | 111 |
|        | [IY],[BR:ll] | 74,ll    | [IY]←[BR:ll]    | 4   | 2  | —  | — | — | — | — | —  | —   | 112 |
|        | [IY],[HL]    | 75       | [IY]←[HL]       | 3   | 1  | —  | — | — | — | — | —  | —   | 114 |
|        | [IY],[IX]    | 76       | [IY]←[IX]       | 3   | 1  | —  | — | — | — | — | —  | —   | 116 |
|        | [IY],[IY]    | 77       | [IY]←[IY]       | 3   | 1  | —  | — | — | — | — | —  | —   | 117 |
|        | [IY],[IX+dd] | CE,78,dd | [IY]←[IX+dd]    | 5   | 3  | —  | — | — | — | — | —  | —   | 119 |
|        | [IY],[IY+dd] | CE,79,dd | [IY]←[IY+dd]    | 5   | 3  | —  | — | — | — | — | —  | —   | 120 |
|        | [IY],[IX+L]  | CE,7A    | [IY]←[IX+L]     | 5   | 2  | —  | — | — | — | — | —  | —   | 122 |
|        | [IY],[IY+L]  | CE,7B    | [IY]←[IY+L]     | 5   | 2  | —  | — | — | — | — | —  | —   | 123 |
| LD     | [IX+dd],A    | CE,44,dd | [IX+dd]←A       | 4   | 3  | —  | — | — | — | — | —  | —   | 106 |
|        | [IX+dd],B    | CE,4C,dd | [IX+dd]←B       | 4   | 3  | —  | — | — | — | — | —  | —   | 106 |
|        | [IX+dd],L    | CE,54,dd | [IX+dd]←L       | 4   | 3  | —  | — | — | — | — | —  | —   | 106 |
|        | [IX+dd],H    | CE,5C,dd | [IX+dd]←H       | 4   | 3  | —  | — | — | — | — | —  | —   | 106 |
| LD     | [IY+dd],A    | CE,45,dd | [IY+dd]←A       | 4   | 3  | —  | — | — | — | — | —  | —   | 106 |
|        | [IY+dd],B    | CE,4D,dd | [IY+dd]←B       | 4   | 3  | —  | — | — | — | — | —  | —   | 106 |
|        | [IY+dd],L    | CE,55,dd | [IY+dd]←L       | 4   | 3  | —  | — | — | — | — | —  | —   | 106 |
|        | [IY+dd],H    | CE,5D,dd | [IY+dd]←H       | 4   | 3  | —  | — | — | — | — | —  | —   | 106 |
| LD     | [IX+L],A     | CE,46    | [IX+L]←A        | 4   | 2  | —  | — | — | — | — | —  | —   | 107 |
|        | [IX+L],B     | CE,4E    | [IX+L]←B        | 4   | 2  | —  | — | — | — | — | —  | —   | 107 |
|        | [IX+L],L     | CE,56    | [IX+L]←L        | 4   | 2  | —  | — | — | — | — | —  | —   | 107 |
|        | [IX+L],H     | CE,5E    | [IX+L]←H        | 4   | 2  | —  | — | — | — | — | —  | —   | 107 |
| LD     | [IY+L],A     | CE,47    | [IY+L]←A        | 4   | 2  | —  | — | — | — | — | —  | —   | 107 |
|        | [IY+L],B     | CE,4F    | [IY+L]←B        | 4   | 2  | —  | — | — | — | — | —  | —   | 107 |
|        | [IY+L],L     | CE,57    | [IY+L]←L        | 4   | 2  | —  | — | — | — | — | —  | —   | 107 |
|        | [IY+L],H     | CE,5F    | [IY+L]←H        | 4   | 2  | —  | — | — | — | — | —  | —   | 107 |
| LD     | NB,A         | CE,CC    | NB←A            | 3   | 2  | —  | — | — | — | — | —  | —   | 103 |
|        | NB,#bb       | CE,C4,bb | NB←bb           | 4   | 3  | —  | — | — | — | — | —  | —   | 109 |
| LD     | EP,A         | CE,CD    | EP←A            | 2   | 2  | —  | — | — | — | — | —  | —   | 103 |
|        | EP,#pp       | CE,C5,pp | EP←pp           | 3   | 3  | —  | — | — | — | — | —  | —   | 109 |
| LD     | XP,A         | CE,CE    | XP←A            | 2   | 2  | —  | — | — | — | — | —  | —   | 103 |
|        | XP,#pp       | CE,C6,pp | XP←pp           | 3   | 3  | —  | — | — | — | — | —  | —   | 109 |
| LD     | YP,A         | CE,CF    | YP←A            | 2   | 2  | —  | — | — | — | — | —  | —   | 103 |
|        | YP,#pp       | CE,C7,pp | YP←pp           | 3   | 3  | —  | — | — | — | — | —  | —   | 110 |
| EX     | A,B          | CC       | A↔B             | 2   | 1  | —  | — | — | — | — | —  | —   | 93  |
|        | A,[HL]       | CD       | A↔[HL]          | 3   | 1  | —  | — | — | — | — | —  | —   | 93  |
| SWAP   | A            | F6       | A(H)↔A(L)       | 2   | 1  | —  | — | — | — | — | —  | —   | 172 |
|        | [HL]         | F7       | [HL](H)↔[HL](L) | 3   | 1  | —  | — | — | — | — | —  | —   | 173 |

\* ニューコードバンクレジスタNBおよびエクスパンドページレジスタEP/XP/YPはMODEL2/3にのみ設定されています。したがって、MODEL0/1ではこれらのレジスタをアクセスする命令は使用できません。

表4.3.3.1(d) 機能別命令一覧表 (16ビット転送命令 1/2)

## 16ビット転送命令

| ニーモニック | コード        | オペレーション  | サイクル                           | バイト | SC |    |   |   |   |   |   | 備考 | ページ |     |
|--------|------------|----------|--------------------------------|-----|----|----|---|---|---|---|---|----|-----|-----|
|        |            |          |                                |     | I1 | I0 | U | D | N | V | C | Z  |     |     |
| LD     | BA,BA      | CF,E0    | BA←BA                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | BA,HL      | CF,E1    | BA←HL                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | BA,IX      | CF,E2    | BA←IX                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | BA,IY      | CF,E3    | BA←IY                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | BA,SP      | CF,F8    | BA←SP                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | BA,PC      | CF,F9    | BA←PC+2                        | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | BA,#mmnn   | C4,nn,mm | BA←mmnn                        | 3   | 3  | —  | — | — | — | — | — | —  |     | 129 |
|        | BA,[hh/l]  | B8,l,hh  | A←[hh/l], B←[hh/l+1]           | 5   | 3  | —  | — | — | — | — | — | —  |     | 130 |
|        | BA,[HL]    | CF,C0    | A←[HL], B←[HL+1]               | 5   | 2  | —  | — | — | — | — | — | —  |     | 131 |
|        | BA,[IX]    | CF,D0    | A←[IX], B←[IX+1]               | 5   | 2  | —  | — | — | — | — | — | —  |     | 132 |
|        | BA,[IY]    | CF,D8    | A←[IY], B←[IY+1]               | 5   | 2  | —  | — | — | — | — | — | —  |     | 132 |
|        | BA,[SP+dd] | CF,70,dd | A←[SP+dd], B←[SP+dd+1]         | 6   | 3  | —  | — | — | — | — | — | —  |     | 133 |
|        | HL,BA      | CF,E4    | HL←BA                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | HL,HL      | CF,E5    | HL←HL                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | HL,IX      | CF,E6    | HL←IX                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | HL,IY      | CF,E7    | HL←IY                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
| LD     | HL,SP      | CF,F4    | HL←SP                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 125 |
|        | HL,PC      | CF,F5    | HL←PC+2                        | 2   | 2  | —  | — | — | — | — | — | —  |     | 125 |
|        | HL,#mmnn   | C5,nn,mm | HL←mmnn                        | 3   | 3  | —  | — | — | — | — | — | —  |     | 129 |
|        | HL,[hh/l]  | B9,l,hh  | L←[hh/l], H←[hh/l+1]           | 5   | 3  | —  | — | — | — | — | — | —  |     | 130 |
|        | HL,[HL]    | CF,C1    | L←[HL], H←[HL+1]               | 5   | 2  | —  | — | — | — | — | — | —  |     | 131 |
|        | HL,[IX]    | CF,D1    | L←[IX], H←[IX+1]               | 5   | 2  | —  | — | — | — | — | — | —  |     | 132 |
|        | HL,[IY]    | CF,D9    | L←[IY], H←[IY+1]               | 5   | 2  | —  | — | — | — | — | — | —  |     | 132 |
|        | HL,[SP+dd] | CF,71,dd | L←[SP+dd], H←[SP+dd+1]         | 6   | 3  | —  | — | — | — | — | — | —  |     | 133 |
|        | IX,BA      | CF,E8    | IX←BA                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | IX,HL      | CF,E9    | IX←HL                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | IX,IX      | CF,EA    | IX←IX                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | IX,IY      | CF,EB    | IX←IY                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | IX,SP      | CF,FA    | IX←SP                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 125 |
|        | IX,#mmnn   | C6,nn,mm | IX←mmnn                        | 3   | 3  | —  | — | — | — | — | — | —  |     | 129 |
|        | IX,[hh/l]  | BA,l,hh  | IX(L)←[hh/l], IX(H)←[hh/l+1]   | 5   | 3  | —  | — | — | — | — | — | —  |     | 130 |
|        | IX,[HL]    | CF,C2    | IX(L)←[HL], IX(H)←[HL+1]       | 5   | 2  | —  | — | — | — | — | — | —  |     | 131 |
|        | IX,[IX]    | CF,D2    | IX(L)←[IX], IX(H)←[IX+1]       | 5   | 2  | —  | — | — | — | — | — | —  |     | 132 |
|        | IX,[IY]    | CF,DA    | IX(L)←[IY], IX(H)←[IY+1]       | 5   | 2  | —  | — | — | — | — | — | —  |     | 132 |
|        | IX,[SP+dd] | CF,72,dd | IX(L)←[SP+dd], IX(H)←[SP+dd+1] | 6   | 3  | —  | — | — | — | — | — | —  |     | 133 |
| LD     | IY,BA      | CF,EC    | IY←BA                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | IY,HL      | CF,ED    | IY←HL                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | IY,IX      | CF,EE    | IY←IX                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | IY,IY      | CF,EF    | IY←IY                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 124 |
|        | IY,SP      | CF,FE    | IY←SP                          | 2   | 2  | —  | — | — | — | — | — | —  |     | 125 |
|        | IY,#mmnn   | C7,nn,mm | IY←mmnn                        | 3   | 3  | —  | — | — | — | — | — | —  |     | 129 |
|        | IY,[hh/l]  | BB,l,hh  | IY(L)←[hh/l], IY(H)←[hh/l+1]   | 5   | 3  | —  | — | — | — | — | — | —  |     | 130 |
|        | IY,[HL]    | CF,C3    | IY(L)←[HL], IY(H)←[HL+1]       | 5   | 2  | —  | — | — | — | — | — | —  |     | 131 |
|        | IY,[IX]    | CF,D3    | IY(L)←[IX], IY(H)←[IX+1]       | 5   | 2  | —  | — | — | — | — | — | —  |     | 132 |
|        | IY,[IY]    | CF,DB    | IY(L)←[IY], IY(H)←[IY+1]       | 5   | 2  | —  | — | — | — | — | — | —  |     | 132 |
|        | IY,[SP+dd] | CF,73,dd | IY(L)←[SP+dd], IY(H)←[SP+dd+1] | 6   | 3  | —  | — | — | — | — | — | —  |     | 133 |

表4.3.3.1(e) 機能別命令一覧表 (16ビット転送命令 2/2)

## 16ビット転送命令

| ニーモニック | コード        | オペレーション     | サイ<br>クル                       | バイト | SC |    |   |   |   |   |   | 備 考 | ページ |
|--------|------------|-------------|--------------------------------|-----|----|----|---|---|---|---|---|-----|-----|
|        |            |             |                                |     | I1 | I0 | U | D | N | V | C | Z   |     |
| LD     | SP,BA      | CF,F0       | SP←BA                          | 2   | 2  | —  | — | — | — | — | — | —   | 126 |
|        | SP,[hh/l]  | CF,78,l, hh | SP(L)←[hh/l], SP(H)←[hh/l+1]   | 6   | 4  | —  | — | — | — | — | — | —   |     |
|        | SP,HL      | CF,F1       | SP←HL                          | 2   | 2  | —  | — | — | — | — | — | —   |     |
|        | SP,IX      | CF,F2       | SP←IX                          | 2   | 2  | —  | — | — | — | — | — | —   |     |
|        | SP,IY      | CF,F3       | SP←IY                          | 2   | 2  | —  | — | — | — | — | — | —   |     |
|        | SP,#mmnn   | CF,6E,nn,mm | SP←mmnn                        | 4   | 4  | —  | — | — | — | — | — | —   |     |
| LD     | [hh/l],BA  | BC,l, hh    | [hh/l]←A, [hh/l+1]←B           | 5   | 3  | —  | — | — | — | — | — | —   | 126 |
|        | [hh/l],HL  | BD,l, hh    | [hh/l]←L, [hh/l+1]←H           | 5   | 3  | —  | — | — | — | — | — | —   |     |
|        | [hh/l],IX  | BE,l, hh    | [hh/l]←IX(L), [hh/l+1]←IX(H)   | 5   | 3  | —  | — | — | — | — | — | —   |     |
|        | [hh/l],IY  | BF,l, hh    | [hh/l]←IY(L), [hh/l+1]←IY(H)   | 5   | 3  | —  | — | — | — | — | — | —   |     |
|        | [hh/l],SP  | CF,7C,l, hh | [hh/l]←SP(L), [hh/l+1]←SP(H)   | 6   | 4  | —  | — | — | — | — | — | —   |     |
| LD     | [HL],BA    | CF,C4       | [HL]←A, [HL+1]←B               | 5   | 2  | —  | — | — | — | — | — | —   | 127 |
|        | [HL],HL    | CF,C5       | [HL]←L, [HL+1]←H               | 5   | 2  | —  | — | — | — | — | — | —   |     |
|        | [HL],IX    | CF,C6       | [HL]←IX(L), [HL+1]←IX(H)       | 5   | 2  | —  | — | — | — | — | — | —   |     |
|        | [HL],IY    | CF,C7       | [HL]←IY(L), [HL+1]←IY(H)       | 5   | 2  | —  | — | — | — | — | — | —   |     |
| LD     | [IX],BA    | CF,D4       | [IX]←A, [IX+1]←B               | 5   | 2  | —  | — | — | — | — | — | —   | 128 |
|        | [IX],HL    | CF,D5       | [IX]←L, [IX+1]←H               | 5   | 2  | —  | — | — | — | — | — | —   |     |
|        | [IX],IX    | CF,D6       | [IX]←IX(L), [IX+1]←IX(H)       | 5   | 2  | —  | — | — | — | — | — | —   |     |
|        | [IX],IY    | CF,D7       | [IX]←IY(L), [IX+1]←IY(H)       | 5   | 2  | —  | — | — | — | — | — | —   |     |
| LD     | [IY],BA    | CF,DC       | [IY]←A, [IY+1]←B               | 5   | 2  | —  | — | — | — | — | — | —   | 128 |
|        | [IY],HL    | CF,DD       | [IY]←L, [IY+1]←H               | 5   | 2  | —  | — | — | — | — | — | —   |     |
|        | [IY],IX    | CF,DE       | [IY]←IX(L), [IY+1]←IX(H)       | 5   | 2  | —  | — | — | — | — | — | —   |     |
|        | [IY],IY    | CF,DF       | [IY]←IY(L), [IY+1]←IY(H)       | 5   | 2  | —  | — | — | — | — | — | —   |     |
| LD     | [SP+dd],BA | CF,74,dd    | [SP+dd]←A, [SP+dd+1]←B         | 6   | 3  | —  | — | — | — | — | — | —   | 129 |
|        | [SP+dd],HL | CF,75,dd    | [SP+dd]←L, [SP+dd+1]←H         | 6   | 3  | —  | — | — | — | — | — | —   |     |
|        | [SP+dd],IX | CF,76,dd    | [SP+dd]←IX(L), [SP+dd+1]←IX(H) | 6   | 3  | —  | — | — | — | — | — | —   |     |
|        | [SP+dd],IY | CF,77,dd    | [SP+dd]←IY(L), [SP+dd+1]←IY(H) | 6   | 3  | —  | — | — | — | — | — | —   |     |
| EX     | BA,HL      | C8          | BA←HL                          | 3   | 1  | —  | — | — | — | — | — | —   | 93  |
|        | BA,IX      | C9          | BA←IX                          | 3   | 1  | —  | — | — | — | — | — | —   |     |
|        | BA,IY      | CA          | BA←IY                          | 3   | 1  | —  | — | — | — | — | — | —   |     |
|        | BA,SP      | CB          | BA←SP                          | 3   | 1  | —  | — | — | — | — | — | —   |     |

表4.3.3.1(f) 機能別命令一覧表 (8ビット算術論理演算命令 1/4)

## 8ビット算術論理演算命令

| ニーモニック | コード       | オペレーション  | サイクル             | バイト | SC |    |   |   |   |   |   | 備考 | ページ |     |
|--------|-----------|----------|------------------|-----|----|----|---|---|---|---|---|----|-----|-----|
|        |           |          |                  |     | I1 | I0 | U | D | N | V | C | Z  |     |     |
| ADD    | A,A       | 00       | A←A+A            | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 60  |
|        | A,B       | 01       | A←A+B            | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 60  |
|        | A,#nn     | 02,nn    | A←A+nn           | 2   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 60  |
|        | A,[BR:ll] | 04,ll    | A←A+[BR:ll]      | 3   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 61  |
|        | A,[hhll]  | 05,ll,hh | A←A+[hhll]       | 4   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 61  |
|        | A,[HL]    | 03       | A←A+[HL]         | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 61  |
|        | A,[IX]    | 06       | A←A+[IX]         | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 62  |
|        | A,[IY]    | 07       | A←A+[IY]         | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 62  |
|        | A,[IX+dd] | CE,00,dd | A←A+[IX+dd]      | 4   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 62  |
|        | A,[IY+dd] | CE,01,dd | A←A+[IY+dd]      | 4   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 62  |
|        | A,[IX+L]  | CE,02    | A←A+[IX+L]       | 4   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 63  |
|        | A,[IY+L]  | CE,03    | A←A+[IY+L]       | 4   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 63  |
|        | [HL],A    | CE,04    | [HL]←[HL]+A      | 4   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 63  |
|        | [HL],#nn  | CE,05,nn | [HL]←[HL]+nn     | 5   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 63  |
|        | [HL],[IX] | CE,06    | [HL]←[HL]+[IX]   | 5   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 64  |
|        | [HL],[IY] | CE,07    | [HL]←[HL]+[IY]   | 5   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 64  |
| ADC    | A,A       | 08       | A←A+A+C          | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 55  |
|        | A,B       | 09       | A←A+B+C          | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 55  |
|        | A,#nn     | 0A,nn    | A←A+nn+C         | 2   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 55  |
|        | A,[BR:ll] | 0C,ll    | A←A+[BR:ll]+C    | 3   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 55  |
|        | A,[hhll]  | 0D,ll,hh | A←A+[hhll]+C     | 4   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 56  |
|        | A,[HL]    | 0B       | A←A+[HL]+C       | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 56  |
|        | A,[IX]    | 0E       | A←A+[IX]+C       | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 56  |
|        | A,[IY]    | 0F       | A←A+[IY]+C       | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 56  |
|        | A,[IX+dd] | CE,08,dd | A←A+[IX+dd]+C    | 4   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 57  |
|        | A,[IY+dd] | CE,09,dd | A←A+[IY+dd]+C    | 4   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 57  |
|        | A,[IX+L]  | CE,0A    | A←A+[IX+L]+C     | 4   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 57  |
|        | A,[IY+L]  | CE,0B    | A←A+[IY+L]+C     | 4   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 57  |
|        | [HL],A    | CE,0C    | [HL]←[HL]+A+C    | 4   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 58  |
|        | [HL],#nn  | CE,0D,nn | [HL]←[HL]+nn+C   | 5   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 58  |
|        | [HL],[IX] | CE,0E    | [HL]←[HL]+[IX]+C | 5   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 58  |
|        | [HL],[IY] | CE,0F    | [HL]←[HL]+[IY]+C | 5   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 58  |
| SUB    | A,A       | 10       | A←A-A            | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 165 |
|        | A,B       | 11       | A←A-B            | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 165 |
|        | A,#nn     | 12,nn    | A←A-nn           | 2   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 165 |
|        | A,[BR:ll] | 14,ll    | A←A-[BR:ll]      | 3   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 166 |
|        | A,[hhll]  | 15,ll,hh | A←A-[hhll]       | 4   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 166 |
|        | A,[HL]    | 13       | A←A-[HL]         | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 166 |
|        | A,[IX]    | 16       | A←A-[IX]         | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 167 |
|        | A,[IY]    | 17       | A←A-[IY]         | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 167 |
|        | A,[IX+dd] | CE,10,dd | A←A-[IX+dd]      | 4   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 167 |
|        | A,[IY+dd] | CE,11,dd | A←A-[IY+dd]      | 4   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 167 |
|        | A,[IX+L]  | CE,12    | A←A-[IX+L]       | 4   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 168 |
|        | A,[IY+L]  | CE,13    | A←A-[IY+L]       | 4   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 168 |
|        | [HL],A    | CE,14    | [HL]←[HL]-A      | 4   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 168 |
|        | [HL],#nn  | CE,15,nn | [HL]←[HL]-nn     | 5   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 168 |
|        | [HL],[IX] | CE,16    | [HL]←[HL]-[IX]   | 5   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 169 |
|        | [HL],[IY] | CE,17    | [HL]←[HL]-[IY]   | 5   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 169 |

表4.3.3.1(g) 機能別命令一覧表 (8ビット算術論理演算命令 2/4)

## 8ビット算術論理演算命令

| ニーモニック | コード         | オペレーション  | サイクル                | バイト | SC |    |   |   |   |   |   | 備考 | ページ |     |
|--------|-------------|----------|---------------------|-----|----|----|---|---|---|---|---|----|-----|-----|
|        |             |          |                     |     | I1 | I0 | U | D | N | V | C | Z  |     |     |
| SBC    | A,A         | 18       | A←A-A-C             | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 153 |
|        | A,B         | 19       | A←A-B-C             | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 153 |
|        | A,#nn       | 1A,nn    | A←A-nn-C            | 2   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 153 |
|        | A,[BR:ll]   | 1C,ll    | A←A-[BR:ll]-C       | 3   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 153 |
|        | A,[hhll]    | 1D,ll,hh | A←A-[hhll]-C        | 4   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 154 |
|        | A,[HL]      | 1B       | A←A-[HL]-C          | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 154 |
|        | A,[IX]      | 1E       | A←A-[IX]-C          | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 154 |
|        | A,[IY]      | 1F       | A←A-[IY]-C          | 2   | 1  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 154 |
|        | A,[IX+dd]   | CE,18,dd | A←A-[IX+dd]-C       | 4   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 155 |
|        | A,[IY+dd]   | CE,19,dd | A←A-[IY+dd]-C       | 4   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 155 |
|        | A,[IX+L]    | CE,1A    | A←A-[IX+L]-C        | 4   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 155 |
|        | A,[IY+L]    | CE,1B    | A←A-[IY+L]-C        | 4   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 155 |
|        | [HL],A      | CE,1C    | [HL]←[HL]-A-C       | 4   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 156 |
|        | [HL],#nn    | CE,1D,nn | [HL]←[HL]-nn-C      | 5   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 156 |
|        | [HL],[IX]   | CE,1E    | [HL]←[HL]-[IX]-C    | 5   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 156 |
|        | [HL],[IY]   | CE,1F    | [HL]←[HL]-[IY]-C    | 5   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 156 |
| AND    | A,A         | 20       | A←A^A               | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 67  |
|        | A,B         | 21       | A←A^B               | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 67  |
|        | A,#nn       | 22,nn    | A←A^nn              | 2   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 68  |
|        | A,[BR:ll]   | 24,ll    | A←A^-[BR:ll]        | 3   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 68  |
|        | A,[hhll]    | 25,ll,hh | A←A^-[hhll]         | 4   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 68  |
|        | A,[HL]      | 23       | A←A^-[HL]           | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 69  |
|        | A,[IX]      | 26       | A←A^-[IX]           | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 69  |
|        | A,[IY]      | 27       | A←A^-[IY]           | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 69  |
|        | A,[IX+dd]   | CE,20,dd | A←A^-[IX+dd]        | 4   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 69  |
|        | A,[IY+dd]   | CE,21,dd | A←A^-[IY+dd]        | 4   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 69  |
|        | A,[IX+L]    | CE,22    | A←A^-[IX+L]         | 4   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 70  |
|        | A,[IY+L]    | CE,23    | A←A^-[IY+L]         | 4   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 70  |
|        | B,#nn       | CE,B0,nn | B←B^nn              | 3   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 70  |
|        | L,#nn       | CE,B1,nn | L←L^nn              | 3   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 70  |
|        | H,#nn       | CE,B2,nn | H←H^nn              | 3   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 71  |
| SC     | SC,#nn      | 9C,nn    | SC←SC^nn            | 3   | 2  | ↓  | ↓ | ↓ | ↓ | ↓ | ↓ | ↓  | ↓   | 71  |
|        | [BR:ll],#nn | D8,ll,nn | [BR:ll]←-[BR:ll]^nn | 5   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 71  |
|        | [HL],A      | CE,24    | [HL]←-[HL]^A        | 4   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 72  |
|        | [HL],#nn    | CE,25,nn | [HL]←-[HL]^nn       | 5   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 72  |
|        | [HL],[IX]   | CE,26    | [HL]←-[HL]^-[IX]    | 5   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 72  |
|        | [HL],[IY]   | CE,27    | [HL]←-[HL]^-[IY]    | 5   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 72  |
|        | SC,nn       |          |                     |     |    |    |   |   |   |   |   |    |     |     |
| OR     | A,A         | 28       | A←A∨A               | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 135 |
|        | A,B         | 29       | A←A∨B               | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 135 |
|        | A,#nn       | 2A,nn    | A←A∨nn              | 2   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 135 |
|        | A,[BR:ll]   | 2C,ll    | A←A∨-[BR:ll]        | 3   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 136 |
|        | A,[hhll]    | 2D,ll,hh | A←A∨-[hhll]         | 4   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 136 |
|        | A,[HL]      | 2B       | A←A∨-[HL]           | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 136 |
|        | A,[IX]      | 2E       | A←A∨-[IX]           | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 137 |
|        | A,[IY]      | 2F       | A←A∨-[IY]           | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 137 |
|        | A,[IX+dd]   | CE,28,dd | A←A∨-[IX+dd]        | 4   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 137 |
|        | A,[IY+dd]   | CE,29,dd | A←A∨-[IY+dd]        | 4   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 137 |
| OR     | A,[IX+L]    | CE,2A    | A←A∨-[IX+L]         | 4   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 138 |

表4.3.3.1(h) 機能別命令一覧表 (8ビット算術論理演算命令 3/4)

## 8ビット算術論理演算命令

| 二ーモニック | コード         | オペレーション  | サイクル               | バイト | SC |    |   |   |   |   |   | 備考 | ページ |     |
|--------|-------------|----------|--------------------|-----|----|----|---|---|---|---|---|----|-----|-----|
|        |             |          |                    |     | I1 | I0 | U | D | N | V | C | Z  |     |     |
| OR     | A,[IY+L]    | CE,2B    | A←A∨[IY+L]         | 4   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 138 |
|        | B,#nn       | CE,B4,nn | B←B∨nn             | 3   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 138 |
|        | L,#nn       | CE,B5,nn | L←L∨nn             | 3   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 138 |
|        | H,#nn       | CE,B6,nn | H←H∨nn             | 3   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 139 |
|        | SC,#nn      | 9D,nn    | SC←SC∨nn           | 3   | 2  | ↑  | ↑ | ↑ | ↑ | ↑ | ↑ | ↑  | ↑   | 139 |
|        | [BR:ll],#nn | D9,ll,nn | [BR:ll]←[BR:ll]∨nn | 5   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 139 |
|        | [HL],A      | CE,2C    | [HL]←[HL]∨A        | 4   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 140 |
|        | [HL],#nn    | CE,2D,nn | [HL]←[HL]∨nn       | 5   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 140 |
|        | [HL],[IX]   | CE,2E    | [HL]←[HL]∨[IX]     | 5   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 140 |
|        | [HL],[IY]   | CE,2F    | [HL]←[HL]∨[IY]     | 5   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 140 |
|        | A,A         | 38       | A←A∨A              | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 173 |
| XOR    | A,B         | 39       | A←A∨B              | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 173 |
|        | A,#nn       | 3A,nn    | A←A∨nn             | 2   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 174 |
|        | A,[BR:ll]   | 3C,ll    | A←A∨[BR:ll]        | 3   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 174 |
|        | A,[hhll]    | 3D,ll,hh | A←A∨[hhll]         | 4   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 174 |
|        | A,[HL]      | 3B       | A←A∨[HL]           | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 175 |
|        | A,[IX]      | 3E       | A←A∨[IX]           | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 175 |
|        | A,[IY]      | 3F       | A←A∨[IY]           | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 175 |
|        | A,[IX+dd]   | CE,38,dd | A←A∨[IX+dd]        | 4   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 175 |
|        | A,[IY+dd]   | CE,39,dd | A←A∨[IY+dd]        | 4   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 175 |
|        | A,[IX+L]    | CE,3A    | A←A∨[IX+L]         | 4   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 176 |
|        | A,[IY+L]    | CE,3B    | A←A∨[IY+L]         | 4   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 176 |
|        | B,#nn       | CE,B8,nn | B←B∨nn             | 3   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 176 |
|        | L,#nn       | CE,B9,nn | L←L∨nn             | 3   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 176 |
|        | H,#nn       | CE,BA,nn | H←H∨nn             | 3   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 177 |
|        | SC,#nn      | 9E,nn    | SC←SC∨nn           | 3   | 2  | ↑  | ↑ | ↑ | ↑ | ↑ | ↑ | ↑  | ↑   | 177 |
|        | [BR:ll],#nn | DA,ll,nn | [BR:ll]←[BR:ll]∨nn | 5   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 177 |
|        | [HL],A      | CE,3C    | [HL]←[HL]∨A        | 4   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 178 |
|        | [HL],#nn    | CE,3D,nn | [HL]←[HL]∨nn       | 5   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 178 |
|        | [HL],[IX]   | CE,3E    | [HL]←[HL]∨[IX]     | 5   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 178 |
|        | [HL],[IY]   | CE,3F    | [HL]←[HL]∨[IY]     | 5   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 178 |
| CP     | A,A         | 30       | A-A                | 2   | 1  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 80  |
|        | A,B         | 31       | A-B                | 2   | 1  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 80  |
|        | A,#nn       | 32,nn    | A-nn               | 2   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 80  |
|        | A,[BR:ll]   | 34,ll    | A-[BR:ll]          | 3   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 80  |
|        | A,[hhll]    | 35,ll,hh | A-[hhll]           | 4   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 81  |
|        | A,[HL]      | 33       | A-[HL]             | 2   | 1  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 81  |
|        | A,[IX]      | 36       | A-[IX]             | 2   | 1  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 81  |
|        | A,[IY]      | 37       | A-[IY]             | 2   | 1  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 81  |
|        | A,[IX+dd]   | CE,30,dd | A-[IX+dd]          | 4   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 82  |
|        | A,[IY+dd]   | CE,31,dd | A-[IY+dd]          | 4   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 82  |
|        | A,[IX+L]    | CE,32    | A-[IX+L]           | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 82  |
|        | A,[IY+L]    | CE,33    | A-[IY+L]           | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 82  |
|        | B,#nn       | CE,BC,nn | B-nn               | 3   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 83  |
|        | L,#nn       | CE,BD,nn | L-nn               | 3   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 83  |
|        | H,#nn       | CE,BE,nn | H-nn               | 3   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 83  |
|        | BR,#hh      | CE,BF,hh | BR-hh              | 3   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 84  |
|        | [BR:ll],#nn | DB,ll,nn | [BR:ll]-nn         | 4   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 84  |

表4.3.3.1(i) 機能別命令一覧表 (8ビット算術論理演算命令 4/4)

## 8ビット算術論理演算命令

| ニーモニック | コード         | オペレーション  | サイクル                     | バイト | SC |    |   |   |   |   |   | 備考 | ページ |              |
|--------|-------------|----------|--------------------------|-----|----|----|---|---|---|---|---|----|-----|--------------|
|        |             |          |                          |     | I1 | I0 | U | D | N | V | C | Z  |     |              |
| CP     | [HL],A      | CE,34    | [HL]-A                   | 3   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 84           |
|        | [HL],#nn    | CE,35,nn | [HL]-nn                  | 4   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 85           |
|        | [HL],[IX]   | CE,36    | [HL]-[IX]                | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 85           |
|        | [HL],[IY]   | CE,37    | [HL]-[IY]                | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 85           |
| BIT    | A,B         | 94       | A&B                      | 2   | 1  | —  | — | — | — | ↑ | — | —  | ↑   | 73           |
|        | A,#nn       | 96,nn    | A&nn                     | 2   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 73           |
|        | B,#nn       | 97,nn    | B&nn                     | 2   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 73           |
|        | [BR:ll],#nn | DC,ll,nn | [BR:ll]&nn               | 4   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 74           |
|        | [HL],#nn    | 95,nn    | [HL]&nn                  | 3   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 74           |
| INC    | A           | 80       | A←A+1                    | 2   | 1  | —  | — | — | — | — | — | —  | ↑   | 94           |
|        | B           | 81       | B←B+1                    | 2   | 1  | —  | — | — | — | — | — | —  | ↑   | 94           |
|        | L           | 82       | L←L+1                    | 2   | 1  | —  | — | — | — | — | — | —  | ↑   | 94           |
|        | H           | 83       | H←H+1                    | 2   | 1  | —  | — | — | — | — | — | —  | ↑   | 94           |
|        | BR          | 84       | BR←BR+1                  | 2   | 1  | —  | — | — | — | — | — | —  | ↑   | 94           |
|        | [BR:ll]     | 85,ll    | [BR:ll]←[BR:ll]+1        | 4   | 2  | —  | — | — | — | — | — | —  | ↑   | 95           |
|        | [HL]        | 86       | [HL]←[HL]+1              | 3   | 1  | —  | — | — | — | — | — | —  | ↑   | 95           |
| DEC    | A           | 88       | A←A-1                    | 2   | 1  | —  | — | — | — | — | — | —  | ↑   | 90           |
|        | B           | 89       | B←B-1                    | 2   | 1  | —  | — | — | — | — | — | —  | ↑   | 90           |
|        | L           | 8A       | L←L-1                    | 2   | 1  | —  | — | — | — | — | — | —  | ↑   | 90           |
|        | H           | 8B       | H←H-1                    | 2   | 1  | —  | — | — | — | — | — | —  | ↑   | 90           |
|        | BR          | 8C       | BR←BR-1                  | 2   | 1  | —  | — | — | — | — | — | —  | ↑   | 90           |
|        | [BR:ll]     | 8D,ll    | [BR:ll]←[BR:ll]-1        | 4   | 2  | —  | — | — | — | — | — | —  | ↑   | 91           |
|        | [HL]        | 8E       | [HL]←[HL]-1              | 3   | 1  | —  | — | — | — | — | — | —  | ↑   | 91           |
| CPL    | A           | CE,A0    | A← $\bar{A}$             | 3   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 89           |
|        | B           | CE,A1    | B← $\bar{B}$             | 3   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 89           |
|        | [BR:ll]     | CE,A2,ll | [BR:ll]← $\bar{[BR:ll]}$ | 5   | 3  | —  | — | — | — | ↑ | — | —  | ↑   | 89           |
|        | [HL]        | CE,A3    | [HL]← $\bar{[HL]}$       | 4   | 2  | —  | — | — | — | ↑ | — | —  | ↑   | 90           |
| NEG    | A           | CE,A4    | A←-A                     | 3   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 134          |
|        | B           | CE,A5    | B←-B                     | 3   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 134          |
|        | [BR:ll]     | CE,A6,ll | [BR:ll]←-0-[BR:ll]       | 5   | 3  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 134          |
|        | [HL]        | CE,A7    | [HL]←-0-[HL]             | 4   | 2  | —  | — | ★ | ★ | ↑ | ↑ | ↑  | ↑   | 134          |
| MLT    |             | CE,D8    | HL←L*A                   | 12  | 2  | —  | — | — | — | ↑ | 0 | 0  | ↑   | MODEL1/3 133 |
| DIV    |             | CE,D9    | L←HL/A, H← <u>剰余</u>     | 13  | 2  | —  | — | — | — | ↑ | ↑ | 0  | ↑   | のみ 92        |

\* 乗除算命令はMODEL1/3にのみ設定されています。したがって、MODEL0/2ではこれらの命令を使用することはできません。

表4.3.3.1(j) 機能別命令一覧表 (16ビット算術演算命令 1/2)

## 16ビット算術演算命令

| ニーモニック | コード      | オペレーション     | サイクル         | バイト | SC |    |   |   |   |   |   | 備考 | ページ |     |
|--------|----------|-------------|--------------|-----|----|----|---|---|---|---|---|----|-----|-----|
|        |          |             |              |     | I1 | I0 | U | D | N | V | C | Z  |     |     |
| ADD    | BA,BA    | CF,00       | BA←BA+BA     | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 64  |
|        | BA,HL    | CF,01       | BA←BA+HL     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 64  |
|        | BA,IX    | CF,02       | BA←BA+IX     | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 64  |
|        | BA,IY    | CF,03       | BA←BA+IY     | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 64  |
|        | BA,#mmnn | C0,nn,mm    | BA←BA+mmnn   | 3   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 64  |
|        | HL,BA    | CF,20       | HL←HL+BA     | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 65  |
|        | HL,HL    | CF,21       | HL←HL+HL     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 65  |
|        | HL,IX    | CF,22       | HL←HL+IX     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 65  |
|        | HL,IY    | CF,23       | HL←HL+IY     | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 65  |
|        | HL,#mmnn | C1,nn,mm    | HL←HL+mmnn   | 3   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 65  |
|        | IX,BA    | CF,40       | IX←IX+BA     | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 65  |
|        | IX,HL    | CF,41       | IX←IX+HL     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 65  |
|        | IX,#mmnn | C2,nn,mm    | IX←IX+mmnn   | 3   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 66  |
|        | IY,BA    | CF,42       | IY←IY+BA     | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 66  |
|        | IY,HL    | CF,43       | IY←IY+HL     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 66  |
|        | IY,#mmnn | C3,nn,mm    | IY←IY+mmnn   | 3   | 3  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 66  |
|        | SP,BA    | CF,44       | SP←SP+BA     | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 67  |
|        | SP,HL    | CF,45       | SP←SP+HL     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 67  |
|        | SP,#mmnn | CF,68,nn,mm | SP←SP+mmnn   | 4   | 4  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 67  |
| ADC    | BA,BA    | CF,04       | BA←BA+BA+C   | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 59  |
|        | BA,HL    | CF,05       | BA←BA+HL+C   | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 59  |
|        | BA,IX    | CF,06       | BA←BA+IX+C   | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 59  |
|        | BA,IY    | CF,07       | BA←BA+IY+C   | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 59  |
|        | BA,#mmnn | CF,60,nn,mm | BA←BA+mmnn+C | 4   | 4  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 59  |
|        | HL,BA    | CF,24       | HL←HL+BA+C   | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 59  |
|        | HL,HL    | CF,25       | HL←HL+HL+C   | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 59  |
|        | HL,IX    | CF,26       | HL←HL+IX+C   | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 59  |
|        | HL,IY    | CF,27       | HL←HL+IY+C   | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 59  |
|        | HL,#mmnn | CF,61,nn,mm | HL←HL+mmnn+C | 4   | 4  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 60  |
| SUB    | BA,BA    | CF,08       | BA←BA-BA     | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 169 |
|        | BA,HL    | CF,09       | BA←BA-HL     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 169 |
|        | BA,IX    | CF,0A       | BA←BA-IX     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 169 |
|        | BA,IY    | CF,0B       | BA←BA-IY     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 169 |
|        | BA,#mmnn | D0,nn,mm    | BA←BA-mmnn   | 3   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 169 |
|        | HL,BA    | CF,28       | HL←HL-BA     | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 170 |
|        | HL,HL    | CF,29       | HL←HL-HL     | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 170 |
|        | HL,IX    | CF,2A       | HL←HL-IX     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 170 |
|        | HL,IY    | CF,2B       | HL←HL-IY     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 170 |
|        | HL,#mmnn | D1,nn,mm    | HL←HL-mmnn   | 3   | 3  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 170 |
|        | IX,BA    | CF,48       | IX←IX-BA     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 170 |
|        | IX,HL    | CF,49       | IX←IX-HL     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 170 |
|        | IX,#mmnn | D2,nn,mm    | IX←IX-mmnn   | 3   | 3  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 171 |
|        | IY,BA    | CF,4A       | IY←IY-BA     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 171 |
|        | IY,HL    | CF,4B       | IY←IY-HL     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 171 |
|        | IY,#mmnn | D3,nn,mm    | IY←IY-mmnn   | 3   | 3  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 171 |
|        | SP,BA    | CF,4C       | SP←SP-BA     | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 172 |
|        | SP,HL    | CF,4D       | SP←SP-HL     | 4   | 2  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 172 |
|        | SP,#mmnn | CF,6A,nn,mm | SP←SP-mmnn   | 4   | 4  | —  | — | — | — | ↓ | ↑ | ↑  | ↑   | 172 |

表4.3.3.1(k) 機能別命令一覧表 (16ビット算術演算命令 2/2)

## 16ビット算術演算命令

| ニーモニック | コード      | オペレーション     | サイクル         | バイト | SC |    |   |   |   |   |   | 備考 | ページ |     |
|--------|----------|-------------|--------------|-----|----|----|---|---|---|---|---|----|-----|-----|
|        |          |             |              |     | I1 | I0 | U | D | N | V | C | Z  |     |     |
| SBC    | BA,BA    | CF,0C       | BA←BA-BA-C   | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 157 |
|        | BA,HL    | CF,0D       | BA←BA-HL-C   | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 157 |
|        | BA,IX    | CF,0E       | BA←BA-IX-C   | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 157 |
|        | BA,IY    | CF,0F       | BA←BA-IY-C   | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 157 |
|        | BA,#mmnn | CF,62,nn,mm | BA←BA-mmnn-C | 4   | 4  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 157 |
|        | HL,BA    | CF,2C       | HL←HL-BA-C   | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 157 |
|        | HL,HL    | CF,2D       | HL←HL-HL-C   | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 157 |
|        | HL,IX    | CF,2E       | HL←HL-IX-C   | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 157 |
|        | HL,IY    | CF,2F       | HL←HL-IY-C   | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 157 |
|        | HL,#mmnn | CF,63,nn,mm | HL←HL-mmnn-C | 4   | 4  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 158 |
| CP     | BA,BA    | CF,18       | BA-BA        | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 86  |
|        | BA,HL    | CF,19       | BA-HL        | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 86  |
|        | BA,IX    | CF,1A       | BA-IX        | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 86  |
|        | BA,IY    | CF,1B       | BA-IY        | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 86  |
|        | BA,#mmnn | D4,nn,mm    | BA-mmnn      | 3   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 86  |
|        | HL,BA    | CF,38       | HL-BA        | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 87  |
|        | HL,HL    | CF,39       | HL-HL        | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 87  |
|        | HL,IX    | CF,3A       | HL-IX        | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 87  |
|        | HL,IY    | CF,3B       | HL-IY        | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 87  |
|        | HL,#mmnn | D5,nn,mm    | HL-mmnn      | 3   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 87  |
|        | IX,#mmnn | D6,nn,mm    | IX-mmnn      | 3   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 88  |
|        | IY,#mmnn | D7,nn,mm    | IY-mmnn      | 3   | 3  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 88  |
|        | SP,BA    | CF,5C       | SP-BA        | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 88  |
|        | SP,HL    | CF,5D       | SP-HL        | 4   | 2  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 88  |
|        | SP,#mmnn | CF,6C,nn,mm | SP-mmnn      | 4   | 4  | —  | — | — | — | ↑ | ↑ | ↑  | ↑   | 89  |
| INC    | BA       | 90          | BA←BA+1      | 2   | 1  | —  | — | — | — | — | — | ↑  |     | 95  |
|        | HL       | 91          | HL←HL+1      | 2   | 1  | —  | — | — | — | — | — | ↑  |     | 95  |
|        | IX       | 92          | IX←IX+1      | 2   | 1  | —  | — | — | — | — | — | ↑  |     | 95  |
|        | IY       | 93          | IY←IY+1      | 2   | 1  | —  | — | — | — | — | — | ↑  |     | 95  |
|        | SP       | 87          | SP←SP+1      | 2   | 1  | —  | — | — | — | — | — | ↑  |     | 96  |
| DEC    | BA       | 98          | BA←BA-1      | 2   | 1  | —  | — | — | — | — | — | ↑  |     | 91  |
|        | HL       | 99          | HL←HL-1      | 2   | 1  | —  | — | — | — | — | — | ↑  |     | 91  |
|        | IX       | 9A          | IX←IX-1      | 2   | 1  | —  | — | — | — | — | — | ↑  |     | 91  |
|        | IY       | 9B          | IY←IY-1      | 2   | 1  | —  | — | — | — | — | — | ↑  |     | 91  |
|        | SP       | 8F          | SP←SP-1      | 2   | 1  | —  | — | — | — | — | — | ↑  |     | 92  |

表4.3.3.1(l) 機能別命令一覧表 (演算補助命令)

## 演算補助命令

| ニーモニック | コード | オペレーション | サイクル                                                                                | バイト | SC |    |   |   |   |   |   | 備考 | ページ |     |
|--------|-----|---------|-------------------------------------------------------------------------------------|-----|----|----|---|---|---|---|---|----|-----|-----|
|        |     |         |                                                                                     |     | I1 | I0 | U | D | N | V | C | Z  |     |     |
| PACK   |     | DE      |  | 2   | 1  | —  | — | — | — | — | — | —  |     | 141 |
| UPCK   |     | DF      |  | 2   | 1  | —  | — | — | — | — | — | —  |     | 173 |
| SEP    |     | CE,A8   |  | 3   | 2  | —  | — | — | — | — | — | —  |     | 158 |

表4.3.3.1(m) 機能別命令一覧表(ローテート/シフト 1/2)

## ローテート/シフト命令

| ニーモニック | コード    | オペレーション  | サイクル | バイト | SC |    |   |   |   |   |   | 備考 | ページ |     |  |
|--------|--------|----------|------|-----|----|----|---|---|---|---|---|----|-----|-----|--|
|        |        |          |      |     | I1 | I0 | U | D | N | V | C | Z  |     |     |  |
| RL     | A      | CE,90    |      |     | 3  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 147 |  |
|        | B      | CE,91    |      |     | 3  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 147 |  |
|        | [BR:l] | CE,92,II |      |     | 5  | 3  | — | — | — | ↑ | — | ↑  | ↑   | 148 |  |
|        | [HL]   | CE,93    |      |     | 4  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 148 |  |
| RLC    | A      | CE,94    |      |     | 3  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 149 |  |
|        | B      | CE,95    |      |     | 3  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 149 |  |
|        | [BR:l] | CE,96,II |      |     | 5  | 3  | — | — | — | ↑ | — | ↑  | ↑   | 149 |  |
|        | [HL]   | CE,97    |      |     | 4  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 149 |  |
| RR     | A      | CE,98    |      |     | 3  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 150 |  |
|        | B      | CE,99    |      |     | 3  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 150 |  |
|        | [BR:l] | CE,9A,II |      |     | 5  | 3  | — | — | — | ↑ | — | ↑  | ↑   | 150 |  |
|        | [HL]   | CE,9B    |      |     | 4  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 151 |  |
| RRC    | A      | CE,9C    |      |     | 3  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 151 |  |
|        | B      | CE,9D    |      |     | 3  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 151 |  |
|        | [BR:l] | CE,9E,II |      |     | 5  | 3  | — | — | — | ↑ | — | ↑  | ↑   | 152 |  |
|        | [HL]   | CE,9F    |      |     | 4  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 152 |  |
| SLA    | A      | CE,80    |      |     | 3  | 2  | — | — | — | ↑ | ↑ | ↑  | ↑   | 159 |  |
|        | B      | CE,81    |      |     | 3  | 2  | — | — | — | ↑ | ↑ | ↑  | ↑   | 159 |  |
|        | [BR:l] | CE,82,II |      |     | 5  | 3  | — | — | — | ↑ | ↑ | ↑  | ↑   | 159 |  |
|        | [HL]   | CE,83    |      |     | 4  | 2  | — | — | — | ↑ | ↑ | ↑  | ↑   | 160 |  |
| SLL    | A      | CE,84    |      |     | 3  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 160 |  |
|        | B      | CE,85    |      |     | 3  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 160 |  |
|        | [BR:l] | CE,86,II |      |     | 5  | 3  | — | — | — | ↑ | — | ↑  | ↑   | 161 |  |
|        | [HL]   | CE,87    |      |     | 4  | 2  | — | — | — | ↑ | — | ↑  | ↑   | 161 |  |

表4.3.3.1(n) 機能別命令一覧表 (ローテート/シフト 2/2)

## ローテート/シフト命令

| ニーモニック | コード     | オペレーション  | サイ<br>クル                         | バイト | SC |    |   |   |   |   | 備 考 | ページ |   |     |  |
|--------|---------|----------|----------------------------------|-----|----|----|---|---|---|---|-----|-----|---|-----|--|
|        |         |          |                                  |     | I1 | I0 | U | D | N | V | C   |     |   |     |  |
| SRA    | A       | CE,88    | ►[7 6 5 4 3 2 1 0]►C<br>A        |     | 3  | 2  | — | — | — | ↑ | 0   | ↑   | ↑ | 162 |  |
|        | B       | CE,89    | ►[7 6 5 4 3 2 1 0]►C<br>B        |     | 3  | 2  | — | — | — | ↑ | 0   | ↑   | ↑ | 162 |  |
|        | [BR:ll] | CE,8A,ll | ►[7 6 5 4 3 2 1 0]►C<br>[BR:ll]  |     | 5  | 3  | — | — | — | ↑ | 0   | ↑   | ↑ | 163 |  |
|        | [HL]    | CE,8B    | ►[7 6 5 4 3 2 1 0]►C<br>[HL]     |     | 4  | 2  | — | — | — | ↑ | 0   | ↑   | ↑ | 163 |  |
| SRL    | A       | CE,8C    | 0►[7 6 5 4 3 2 1 0]►C<br>A       |     | 3  | 2  | — | — | — | 0 | —   | ↑   | ↑ | 164 |  |
|        | B       | CE,8D    | 0►[7 6 5 4 3 2 1 0]►C<br>B       |     | 3  | 2  | — | — | — | 0 | —   | ↑   | ↑ | 164 |  |
|        | [BR:ll] | CE,8E,ll | 0►[7 6 5 4 3 2 1 0]►C<br>[BR:ll] |     | 5  | 3  | — | — | — | 0 | —   | ↑   | ↑ | 164 |  |
|        | [HL]    | CE,8F    | 0►[7 6 5 4 3 2 1 0]►C<br>[HL]    |     | 4  | 2  | — | — | — | 0 | —   | ↑   | ↑ | 165 |  |

表4.3.3.1(o) 機能別命令一覧表 (スタック制御命令)

## スタック制御命令

| ニーモニック | コード | オペレーション | サイ<br>クル                            | バイト | SC |    |   |   |   |   | 備 考 | ページ |            |     |  |
|--------|-----|---------|-------------------------------------|-----|----|----|---|---|---|---|-----|-----|------------|-----|--|
|        |     |         |                                     |     | I1 | I0 | U | D | N | V | C   |     |            |     |  |
| PUSH   | A   | CF,B0   | [SP-1]←A, SP←SP-1                   |     | 3  | 2  | — | — | — | — | —   | —   | —          | 143 |  |
|        | B   | CF,B1   | [SP-1]←B, SP←SP-1                   |     | 3  | 2  | — | — | — | — | —   | —   | —          | 143 |  |
|        | L   | CF,B2   | [SP-1]←L, SP←SP-1                   |     | 3  | 2  | — | — | — | — | —   | —   | —          | 143 |  |
|        | H   | CF,B3   | [SP-1]←H, SP←SP-1                   |     | 3  | 2  | — | — | — | — | —   | —   | —          | 143 |  |
|        | BR  | A4      | [SP-1]←BR, SP←SP-1                  |     | 3  | 1  | — | — | — | — | —   | —   | —          | 144 |  |
|        | SC  | A7      | [SP-1]←SC, SP←SP-1                  |     | 3  | 1  | — | — | — | — | —   | —   | —          | 145 |  |
|        | BA  | A0      | [SP-1]←B, [SP-2]←A, SP←SP-2         |     | 4  | 1  | — | — | — | — | —   | —   | —          | 144 |  |
|        | HL  | A1      | [SP-1]←H, [SP-2]←L, SP←SP-2         |     | 4  | 1  | — | — | — | — | —   | —   | —          | 144 |  |
|        | IX  | A2      | [SP-1]←IX(H), [SP-2]←IX(L), SP←SP-2 |     | 4  | 1  | — | — | — | — | —   | —   | —          | 144 |  |
|        | IY  | A3      | [SP-1]←IY(H), [SP-2]←IY(L), SP←SP-2 |     | 4  | 1  | — | — | — | — | —   | —   | —          | 144 |  |
|        | EP  | A5      | [SP-1]←EP, SP←SP-1                  |     | 3  | 1  | — | — | — | — | —   | —   | MODEL2/3のみ | 144 |  |
|        | IP  | A6      | [SP-1]←XP, [SP-2]←YP, SP←SP-2       |     | 4  | 1  | — | — | — | — | —   | —   |            | 145 |  |
| PUSH   | ALL | CF,B8   | PUSH BA, HL, IX, IY, BR             |     | 12 | 2  | — | — | — | — | —   | —   | —          | 145 |  |
|        | ALE | CF,B9   | PUSH BA, HL, IX, IY, BR, EP, IP     |     | 15 | 2  | — | — | — | — | —   | —   | MODEL2/3のみ | 145 |  |
| POP    | A   | CF,B4   | A←[SP], SP←SP+1                     |     | 3  | 2  | — | — | — | — | —   | —   | —          | 141 |  |
|        | B   | CF,B5   | B←[SP], SP←SP+1                     |     | 3  | 2  | — | — | — | — | —   | —   | —          | 141 |  |
|        | L   | CF,B6   | L←[SP], SP←SP+1                     |     | 3  | 2  | — | — | — | — | —   | —   | —          | 141 |  |
|        | H   | CF,B7   | H←[SP], SP←SP+1                     |     | 3  | 2  | — | — | — | — | —   | —   | —          | 141 |  |
|        | BR  | AC      | BR←[SP], SP←SP+1                    |     | 2  | 1  | — | — | — | — | —   | —   | —          | 142 |  |
|        | SC  | AF      | SC←[SP], SP←SP+1                    |     | 2  | 1  | ↑ | ↑ | ↑ | ↑ | ↑   | ↑   | ↑          | 142 |  |
|        | BA  | A8      | A←[SP], B←[SP+1], SP←SP+2           |     | 3  | 1  | — | — | — | — | —   | —   | —          | 141 |  |
|        | HL  | A9      | L←[SP], H←[SP+1], SP←SP+2           |     | 3  | 1  | — | — | — | — | —   | —   | —          | 141 |  |
|        | IX  | AA      | IX(L)←[SP], IX(H)←[SP+1], SP←SP+2   |     | 3  | 1  | — | — | — | — | —   | —   | —          | 141 |  |
|        | IY  | AB      | IY(L)←[SP], IY(H)←[SP+1], SP←SP+2   |     | 3  | 1  | — | — | — | — | —   | —   | —          | 141 |  |
|        | EP  | AD      | EP←[SP], SP←SP+1                    |     | 2  | 1  | — | — | — | — | —   | —   | MODEL2/3のみ | 142 |  |
|        | IP  | AE      | YP←[SP], XP←[SP+1], SP←SP+2         |     | 3  | 1  | — | — | — | — | —   | —   |            | 142 |  |
| POP    | ALL | CF,BC   | POP BR, IY, IX, HL, BA              |     | 11 | 2  | — | — | — | — | —   | —   | —          | 143 |  |
|        | ALE | CF,BD   | POP IP, EP, BR, IY, IX, HL, BA      |     | 14 | 2  | — | — | — | — | —   | —   | MODEL2/3のみ | 143 |  |

\* エクスパンドページレジスタEP/XP/YPIはMODEL2/3にのみ設定されています。したがって、MODEL0/1ではこれらのレジスタをアクセスする命令は使用できません。

表4.3.3.1(p) 機能別命令一覧表 (分岐命令 1/4)

## 分岐命令

| ニーモニック | コード     | 分岐条件     | オペレーション   | サイクル                                                                                                                                                               | バイト | SC |     |     |     |     |     | ページ |     |
|--------|---------|----------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----|-----|-----|-----|-----|-----|-----|-----|
|        |         |          |           |                                                                                                                                                                    |     | I1 | I0  | U   | D   | N   | V   | Z   |     |
| JRS    | rr      | F1,rr    | 無条件       | MODEL0/1<br>PC←PC+rr+1                                                                                                                                             | 2   | 2  | --- | --- | --- | --- | --- | --- | 99  |
|        |         |          |           | MODEL2/3<br>PC←PC+rr+1, CB←NB                                                                                                                                      |     |    | --- | --- | --- | --- | --- | --- |     |
| JRS    | C,rr    | E4,rr    | C=1       | MODEL0/1<br>If Condition is true,<br>then PC←PC+rr+1<br>else PC←PC+2<br><br>MODEL2/3<br>If Condition is true,<br>then PC←PC+rr+1, CB←NB<br>else PC←PC+2, NB←CB     | 2   | 2  | --- | --- | --- | --- | --- | --- | 99  |
|        | NC,rr   | E5,rr    | C=0       |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | Z,rr    | E6,rr    | Z=1       |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | NZ,rr   | E7,rr    | Z=0       |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
| JRS    | LT,rr   | CE,E0,rr | [NVV]=1   | MODEL0/1<br>If Condition is true,<br>then PC←PC+rr+2<br>else PC←PC+3<br><br>MODEL2/3<br>If Condition is true,<br>then PC←PC+rr+2, CB←NB<br>else PC←PC+3, NB←CB     | 3   | 3  | --- | --- | --- | --- | --- | --- | 100 |
|        | LE,rr   | CE,E1,rr | Zv[NVV]=1 |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | GT,rr   | CE,E2,rr | Zv[NVV]=0 |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | GE,rr   | CE,E3,rr | [NVV]=0   |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | V,rr    | CE,E4,rr | V=1       |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | NV,rr   | CE,E5,rr | V=0       |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | P,rr    | CE,E6,rr | N=0       |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | M,rr    | CE,E7,rr | N=1       |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | F0,rr   | CE,E8,rr | F0=1      |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | F1,rr   | CE,E9,rr | F1=1      |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | F2,rr   | CE,EA,rr | F2=1      |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | F3,rr   | CE,EB,rr | F3=1      |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | NF0,rr  | CE,EC,rr | F0=0      |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | NF1,rr  | CE,ED,rr | F1=0      |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | NF2,rr  | CE,EE,rr | F2=0      |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | NF3,rr  | CE,EF,rr | F3=0      |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
| JRL    | qqrr    | F3,rr,qq | 無条件       | MODEL0/1<br>PC←PC+qqrr+2<br><br>MODEL2/3<br>PC←PC+qqrr+2, CB←NB                                                                                                    | 3   | 3  | --- | --- | --- | --- | --- | --- | 98  |
| JRL    | C,qqrr  | EC,rr,qq | C=1       |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
| JRL    | NC,qqrr | ED,rr,qq | C=0       | MODEL0/1<br>If Condition is true,<br>then PC←PC+qqrr+2<br>else PC←PC+3<br><br>MODEL2/3<br>If Condition is true,<br>then PC←PC+qqrr+2, CB←NB<br>else PC←PC+3, NB←CB | 3   | 3  | --- | --- | --- | --- | --- | --- | 98  |
|        | Z,qqrr  | EE,rr,qq | Z=1       |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
|        | NZ,qqrr | EF,rr,qq | Z=0       |                                                                                                                                                                    |     |    | --- | --- | --- | --- | --- | --- |     |
| DJR    | NZ,rr   | F5,rr    | B=0       | MODEL0/1<br>B←B-1, If B=0,<br>then PC←PC+rr+1<br>else PC←PC+2<br><br>MODEL2/3<br>B←B-1, If B=0,<br>then PC←PC+rr+1, CB←NB<br>else PC←PC+2, NB←CB                   | 4   | 2  | --- | --- | --- | --- | ↑   | --- | 92  |

表4.3.3.1(q) 機能別命令一覧表 (分歧命令 2/4)

## 分歧命令

表4.3.3.1(r) 機能別命令一覧表 (分岐命令 3/4)

## 分岐命令

| 二モニック | コード     | 分岐条件     | オペレーション | サイクル                                                                                                                           | バイト | SC |     |     |     |     |     | ページ |
|-------|---------|----------|---------|--------------------------------------------------------------------------------------------------------------------------------|-----|----|-----|-----|-----|-----|-----|-----|
|       |         |          |         |                                                                                                                                |     | I1 | I0  | U   | D   | N   | V   |     |
| CARL  | qqrr    | F2,rr,qq | 無条件     | <i>MODEL0/1</i><br>[SP-1]←PC(H), [SP-2]←PC(L),<br>SP←SP-2, PC←PC+qqrr+2                                                        | 5   | 3  | --- | --- | --- | --- | --- | 76  |
|       |         |          |         | <i>MODEL2/3 (Minimum mode)</i><br>[SP-1]←PC(H), [SP-2]←PC(L),<br>SP←SP-2, PC←PC+qqrr+2, CB←NB                                  |     |    | --- | --- | --- | --- | --- |     |
|       |         |          |         | <i>MODEL2/3 (Maximum mode)</i><br>[SP-1]←CB, [SP-2]←PC(H),<br>[SP-3]←PC(L), SP←SP-3,<br>PC←PC+qqrr+2, CB←NB                    |     |    | --- | --- | --- | --- | --- |     |
| CARL  | C,qqrr  | E8,rr,qq | C=1     | <i>MODEL0/1</i><br>If Condition is true<br>then [SP-1]←PC(H), [SP-2]←PC(L),<br>SP←SP-2, PC←PC+qqrr+2                           | 5   | 3  | --- | --- | --- | --- | --- | 76  |
|       | NC,qqrr | E9,rr,qq | C=0     | else PC←PC+3                                                                                                                   |     |    | --- | --- | --- | --- | --- |     |
|       | Z,qqrr  | EA,rr,qq | Z=1     | <i>MODEL2/3 (Minimum mode)</i><br>If Condition is true<br>then [SP-1]←PC(H), [SP-2]←PC(L),<br>SP←SP-2, PC←PC+qqrr+2,<br>CB←NB  | 5   | 3  | --- | --- | --- | --- | --- |     |
|       | NZ,qqrr | EB,rr,qq | Z=0     | else PC←PC+3, NB←CB                                                                                                            |     |    | --- | --- | --- | --- | --- |     |
| CALL  | [hhll]  | FB,ll,hh | 無条件     | <i>MODEL0/1</i><br>[SP-1]←PC(H), [SP-2]←PC(L),<br>SP←SP-2, PC(L)←[hhll],<br>PC(H)←[hhll+1]                                     | 7   | 3  | --- | --- | --- | --- | --- | 75  |
|       |         |          |         | <i>MODEL2/3 (Minimum mode)</i><br>[SP-1]←PC(H), [SP-2]←PC(L),<br>SP←SP-2, PC(L)←[hhll],<br>PC(H)←[hhll+1], CB←NB               |     |    | --- | --- | --- | --- | --- |     |
|       |         |          |         | <i>MODEL2/3 (Maximum mode)</i><br>[SP-1]←CB, [SP-2]←PC(H),<br>[SP-3]←PC(L), SP←SP-3,<br>PC(L)←[hhll], PC(H)←[hhll+1],<br>CB←NB | 8   | 8  | --- | --- | --- | --- | --- |     |

表4.3.3.1(s) 機能別命令一覧表(分岐命令 4/4)

## 分岐命令

| ニーモニック | コード  | オペレーション | サイクル                                                                                                                                                                                                                                                                                                                                                            | バイト | SC |              |   |   |   |   | 備考 | ページ |     |
|--------|------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----|--------------|---|---|---|---|----|-----|-----|
|        |      |         |                                                                                                                                                                                                                                                                                                                                                                 |     | I1 | I0           | U | D | N | V | C  |     |     |
| INT    | [kk] | FC,kk   | MODEL0/1<br>[SP-1]←PC(H), [SP-2]←PC(L),<br>[SP-3]←SC, SP←SP-3,<br>PC(L)←[00kk], PC(H)←[00kk+1]<br>MODEL2/3 (Minimum mode)<br>[SP-1]←PC(H), [SP-2]←PC(L),<br>[SP-3]←SC, SP←SP-3,<br>PC(L)←[00kk], PC(H)←[00kk+1],<br>CB←NB<br>MODEL2/3 (Maximum mode)<br>[SP-1]←CB, [SP-2]←PC(H),<br>[SP-3]←PC(L), [SP-4]←SC,<br>SP←SP-4, PC(L)←[00kk],<br>PC(H)←[00kk+1], CB←NB | 7   | 2  | -----        |   |   |   |   |    |     | 96  |
|        |      |         |                                                                                                                                                                                                                                                                                                                                                                 |     |    |              |   |   |   |   |    |     |     |
|        |      |         |                                                                                                                                                                                                                                                                                                                                                                 |     |    |              |   |   |   |   |    |     |     |
| RET    |      | F8      | MODEL0/1,MODEL2/3 (Minimum mode)<br>PC(L)←[SP], PC(H)←[SP+1],<br>SP←SP+2<br>MODEL2/3 (Maximum mode)<br>PC(L)←[SP], PC(H)←[SP+1],<br>CB←[SP+2], NB←CB, SP←SP+3                                                                                                                                                                                                   | 3   | 1  | -----        |   |   |   |   |    |     | 146 |
|        |      |         |                                                                                                                                                                                                                                                                                                                                                                 |     |    |              |   |   |   |   |    |     |     |
|        |      |         |                                                                                                                                                                                                                                                                                                                                                                 |     |    |              |   |   |   |   |    |     |     |
| RETE   |      | F9      | MODEL0/1,MODEL2/3 (Minimum mode)<br>SC←[SP], PC(L)←[SP+1],<br>PC(H)←[SP+2], SP←SP+3<br>MODEL2/3 (Maximum mode)<br>SC←[SP], PC(L)←[SP+1],<br>PC(H)←[SP+2], CB←[SP+3],<br>NB←CB, SP←SP+4                                                                                                                                                                          | 4   | 1  | ↑↑↑↑↑↑↑↑↑↑↑↑ |   |   |   |   |    |     | 146 |
|        |      |         |                                                                                                                                                                                                                                                                                                                                                                 |     |    |              |   |   |   |   |    |     |     |
| RETS   |      | FA      | MODEL0/1,MODEL2/3 (Minimum mode)<br>PC(L)←[SP], PC(H)←[SP+1],<br>SP←SP+2, PC←PC+2<br>MODEL2/3 (Maximum mode)<br>PC(L)←[SP], PC(H)←[SP+1],<br>CB←[SP+2], NB←CB, SP←SP+3,<br>PC←PC+2                                                                                                                                                                              | 5   | 1  | -----        |   |   |   |   |    |     | 147 |
|        |      |         |                                                                                                                                                                                                                                                                                                                                                                 |     |    |              |   |   |   |   |    |     |     |

表4.3.3.1(t) 機能別命令一覧表(システム制御命令)

## システム制御命令

| ニーモニック | コード | オペレーション | サイクル         | バイト | SC |       |       |       |       |       | 備考    | ページ |     |
|--------|-----|---------|--------------|-----|----|-------|-------|-------|-------|-------|-------|-----|-----|
|        |     |         |              |     | I1 | I0    | U     | D     | N     | V     | C     |     |     |
| NOP    |     | FF      | No Operation | 2   | 1  | ----- | ----- | ----- | ----- | ----- | ----- |     | 135 |
| HALT   |     | CE,AE   | HALT         | 3   | 2  | ----- | ----- | ----- | ----- | ----- | ----- |     | 94  |
| SLP    |     | CE,AF   | SLEEP        | 3   | 2  | ----- | ----- | ----- | ----- | ----- | ----- |     | 162 |

## 4.4 命令の詳細説明

ここでは各命令を個々に説明します。

なお、説明は以下のフォーマットにしたがって行います。



記号の意味は命令一覧表と同様です。☞ "4.3.2 記号の意味"

なお、複数のレジスタを一括して説明する際には以下の記号を使用します。

r..... データレジスタA/B、またはA/B/L/H

ir..... インデックスレジスタIX/IY

rp.... 16ビット(ペア)レジスタBA/ HL、または16ビットレジスタ(BA)/HL/IX/IY/(SP)

er.... ニューコードバンクレジスタNB、およびエクスパンドページレジスタEP/XP/YP

cc1 . 分岐条件C/NC/Z/NZ

cc2 . 分岐条件LT/LE/GT/GE/V/NV/P/M/F0/F1/F2/F3/NF0/NF1/NF2/NF3

マキシマムモードとミニマムモードでバスサイクル数の異なるものについてはサイクル数に(MAX)と(MIN)を付けて記載します。MINにはMODEL0/1も含まれます。

**ADC A, r** ////////////// Add with carry r reg. to A reg. ////////////// 2 cycle //**機能** A A + r + C

rレジスタ(A/B)の内容とキャリー(C)をAレジスタに加えます。

| コード | MSB             | LSB    | 08H, 09H |
|-----|-----------------|--------|----------|
|     | 0 0 0 0 1 0 0 r |        |          |
|     | r               | ニーモニック | コード      |
| A 0 | ADC A, A        | 08H    |          |
| B 1 | ADC A, B        | 09H    |          |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
| - - |    |    |   | ↑ | ↑ | ↑ | ↑ | ↑ |

**モード** Src: レジスタ直接

Dst: レジスタ直接

| 例           | 設定値 |   |     | 結果 |    |   |   |
|-------------|-----|---|-----|----|----|---|---|
|             | A   | B | C   | A  | SC |   |   |
| D=0, U=0の場合 |     |   |     |    |    |   |   |
| 18H         | 25H | 0 | 3DH | 0  | 0  | 0 | 0 |
| 18H         | 25H | 1 | 3EH | 0  | 0  | 0 | 0 |
| 30H         | D0H | 0 | 00H | 0  | 0  | 1 | 1 |
| 30H         | F0H | 0 | 20H | 0  | 0  | 1 | 0 |
| 30H         | 50H | 0 | 80H | 1  | 1  | 0 | 0 |
| D=1, U=0の場合 |     |   |     |    |    |   |   |
| 18          | 25  | 1 | 44  | 0  | 0  | 0 | 0 |
| D=1, U=1の場合 |     |   |     |    |    |   |   |
| 18          | 25  | 1 | 04  | 0  | 0  | 1 | 0 |

**ADC A, #nn** ////////////// Add with carry immediate data nn to A reg. ////////////// 2 cycle //**機能** A A + nn + C

8ビット即値データnnとキャリー(C)をAレジスタに加えます。

| コード | MSB             | LSB | 0AH |
|-----|-----------------|-----|-----|
|     | 0 0 0 0 1 0 1 0 |     |     |
|     | n n             |     | nn  |
| フラグ | I1              | I0  | U   |
| - - |                 |     |     |
|     | ↑               | ↑   | ↑   |
|     | ↑               | ↑   | ↑   |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例           | 設定値 |    |     | 結果 |    |   |   |
|-------------|-----|----|-----|----|----|---|---|
|             | A   | nn | C   | A  | SC |   |   |
| D=0, U=0の場合 |     |    |     |    |    |   |   |
| 18H         | 25H | 0  | 3DH | 0  | 0  | 0 | 0 |
| 18H         | 25H | 1  | 3EH | 0  | 0  | 0 | 0 |
| 30H         | D0H | 0  | 00H | 0  | 0  | 1 | 1 |
| 30H         | F0H | 0  | 20H | 0  | 0  | 1 | 0 |
| 30H         | 50H | 0  | 80H | 1  | 1  | 0 | 0 |
| D=1, U=0の場合 |     |    |     |    |    |   |   |
| 18          | 25  | 1  | 44  | 0  | 0  | 0 | 0 |
| D=1, U=1の場合 |     |    |     |    |    |   |   |
| 18          | 25  | 1  | 04  | 0  | 0  | 1 | 0 |

**ADC A, [BR:ll]** ////////////// Add with carry location [BR:ll] to A reg. ////////////// 3 cycle //**機能** A A + [BR:ll] + C

BRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されたデータメモリの内容とキャリー(C)をAレジスタに加えます。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB | 04H |
|-----|-----------------|-----|-----|
|     | 0 0 0 0 0 1 0 0 |     |     |
|     | l l             |     | ll  |
| フラグ | I1              | I0  | U   |
| - - |                 |     |     |
|     | ↑               | ↑   | ↑   |
|     | ↑               | ↑   | ↑   |

**モード** Src: 8ビット絶対

Dst: レジスタ直接

| 例           | 設定値 |         |     | 結果 |    |   |   |
|-------------|-----|---------|-----|----|----|---|---|
|             | A   | [BR:ll] | C   | A  | SC |   |   |
| D=0, U=0の場合 |     |         |     |    |    |   |   |
| 18H         | 25H | 0       | 3DH | 0  | 0  | 0 | 0 |
| 18H         | 25H | 1       | 3EH | 0  | 0  | 0 | 0 |
| 30H         | D0H | 0       | 00H | 0  | 0  | 1 | 1 |
| 30H         | F0H | 0       | 20H | 0  | 0  | 1 | 0 |
| 30H         | 50H | 0       | 80H | 1  | 1  | 0 | 0 |
| D=1, U=0の場合 |     |         |     |    |    |   |   |
| 18          | 25  | 1       | 44  | 0  | 0  | 0 | 0 |
| D=1, U=1の場合 |     |         |     |    |    |   |   |
| 18          | 25  | 1       | 04  | 0  | 0  | 1 | 0 |

**ADC A, [hhll]** ////////////// Add with carry location [hhll] to A reg. ////////////// 4 cycle //

機能 A A + [hhll] + C

16ビット絶対アドレスhhllでアドレス指定されたデータメモリの内容とキャリー(C)をAレジスタに加えます。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 0 0 0 0 1 1 0 1 | 0DH |
|     | l l             | ll  |
|     | h h             | hh  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  |   |   | ↑ | ↑ | ↑ | ↑ |

モード Src: 16ビット絶対

Dst: レジスタ直接

例

| A           | [hhll] | C | A   | 設定値 |   |   |   | 結果 |   |   |   |
|-------------|--------|---|-----|-----|---|---|---|----|---|---|---|
|             |        |   |     | SC  |   | N | V | C  | Z |   |   |
| D=0, U=0の場合 |        |   |     |     |   |   |   |    |   |   |   |
| 18H         | 25H    | 0 | 3DH | 0   | 0 | 0 | 0 | 0  | 0 | 0 | 0 |
| 18H         | 25H    | 1 | 3EH | 0   | 0 | 0 | 0 | 0  | 0 | 0 | 0 |
| 30H         | D0H    | 0 | 00H | 0   | 0 | 0 | 1 | 1  |   |   |   |
| 30H         | F0H    | 0 | 20H | 0   | 0 | 0 | 1 | 0  |   |   |   |
| 30H         | 50H    | 0 | 80H | 1   | 1 | 0 | 0 | 0  |   |   |   |
| D=1, U=0の場合 |        |   |     |     |   |   |   |    |   |   |   |
| 18          | 25     | 1 | 44  | 0   | 0 | 0 | 0 | 0  | 0 | 0 | 0 |
| D=1, U=1の場合 |        |   |     |     |   |   |   |    |   |   |   |
| 18          | 25     | 1 | 04  | 0   | 0 | 1 | 0 | 0  | 0 | 0 | 0 |

**ADC A, [HL]** ////////////// Add with carry location [HL] to A reg. ////////////// 2 cycle //

機能 A A + [HL] + C

HLレジスタでアドレス指定されたデータメモリの内容とキャリー(C)をAレジスタに加えます。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 0 0 0 0 1 0 1 1 | 0BH |
|     |                 |     |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  |   |   | ↑ | ↑ | ↑ | ↑ |

モード Src: レジスタ間接

Dst: レジスタ直接

例

| A           | [HL] | C | A   | 設定値 |   |   |   | 結果 |   |   |   |
|-------------|------|---|-----|-----|---|---|---|----|---|---|---|
|             |      |   |     | SC  |   | N | V | C  | Z |   |   |
| D=0, U=0の場合 |      |   |     |     |   |   |   |    |   |   |   |
| 18H         | 25H  | 0 | 3DH | 0   | 0 | 0 | 0 | 0  | 0 | 0 | 0 |
| 18H         | 25H  | 1 | 3EH | 0   | 0 | 0 | 0 | 0  | 0 | 0 | 0 |
| 30H         | D0H  | 0 | 00H | 0   | 0 | 0 | 1 | 1  |   |   |   |
| 30H         | F0H  | 0 | 20H | 0   | 0 | 0 | 1 | 0  |   |   |   |
| 30H         | 50H  | 0 | 80H | 1   | 1 | 0 | 0 | 0  |   |   |   |
| D=1, U=0の場合 |      |   |     |     |   |   |   |    |   |   |   |
| 18          | 25   | 1 | 44  | 0   | 0 | 0 | 0 | 0  | 0 | 0 | 0 |
| D=1, U=1の場合 |      |   |     |     |   |   |   |    |   |   |   |
| 18          | 25   | 1 | 04  | 0   | 0 | 1 | 0 | 0  | 0 | 0 | 0 |

**ADC A, [ir]** ////////////// Add with carry location [ir reg.] to A reg. ////////////// 2 cycle //

機能 A A + [ir] + C

irレジスタ(IX/IY)でアドレス指定されたデータメモリの内容とキャリー(C)をAレジスタに加えます。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB      |
|-----|------------------|----------|
|     | 0 0 0 0 1 1 1 ir | 0EH, 0FH |
|     |                  |          |

| ir   | ニーモニック      | コード |
|------|-------------|-----|
| IX 0 | ADC A, [IX] | 0EH |
| IY 1 | ADC A, [IY] | 0FH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  |   |   | ↑ | ↑ | ↑ | ↑ |

モード Src: レジスタ間接

Dst: レジスタ直接

例

| A           | [ir] | C | A   | 設定値 |   |   |   | 結果 |   |   |   |
|-------------|------|---|-----|-----|---|---|---|----|---|---|---|
|             |      |   |     | SC  |   | N | V | C  | Z |   |   |
| D=0, U=0の場合 |      |   |     |     |   |   |   |    |   |   |   |
| 18H         | 25H  | 0 | 3DH | 0   | 0 | 0 | 0 | 0  | 0 | 0 | 0 |
| 18H         | 25H  | 1 | 3EH | 0   | 0 | 0 | 0 | 0  | 0 | 0 | 0 |
| 30H         | D0H  | 0 | 00H | 0   | 0 | 0 | 1 | 1  |   |   |   |
| 30H         | F0H  | 0 | 20H | 0   | 0 | 0 | 1 | 0  |   |   |   |
| 30H         | 50H  | 0 | 80H | 1   | 1 | 0 | 0 | 0  |   |   |   |
| D=1, U=0の場合 |      |   |     |     |   |   |   |    |   |   |   |
| 18          | 25   | 1 | 44  | 0   | 0 | 0 | 0 | 0  | 0 | 0 | 0 |
| D=1, U=1の場合 |      |   |     |     |   |   |   |    |   |   |   |
| 18          | 25   | 1 | 04  | 0   | 0 | 1 | 0 | 0  | 0 | 0 | 0 |

**ADC A, [ir+dd]** ////////////////////////////////////////////////////////////////// Add with carry location [ir reg. + dd] to A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A A + [ir+dd] + C

irレジスタ(IX/IY)の内容とディスプレースメントddの和でアドレス指定されたデータメモリの内容とキャリー(C)をAレジスタに加えます。  
ddは符号付きデータとして扱われ、範囲は-128 ~ 127です。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB     |  |
|-----|------------------|---------|--|
|     | 1 1 0 0 1 1 1 0  | CEH     |  |
|     | 0 0 0 0 1 0 0 ir | 08H、09H |  |
|     | d d              | dd      |  |

| ir   | ニーモニック         | コード |
|------|----------------|-----|
| IX 0 | ADC A, [IX+dd] | 08H |
| IY 1 | ADC A, [IY+dd] | 09H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  |   | ↑ | ↑ | ↑ | ↑ | ↑ |

**モード** Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ直接

| 例           | 設定値 |         |     | 結果 |    |   |   |
|-------------|-----|---------|-----|----|----|---|---|
|             | A   | [ir+dd] | C   | A  | SC |   |   |
| D=0, U=0の場合 |     |         |     |    |    |   |   |
| 18H         | 25H | 0       | 3DH | 0  | 0  | 0 | 0 |
| 18H         | 25H | 1       | 3EH | 0  | 0  | 0 | 0 |
| 30H         | D0H | 0       | 00H | 0  | 0  | 1 | 1 |
| 30H         | F0H | 0       | 20H | 0  | 0  | 1 | 0 |
| 30H         | 50H | 0       | 80H | 1  | 1  | 0 | 0 |
| D=1, U=0の場合 |     |         |     |    |    |   |   |
| 18          | 25  | 1       | 44  | 0  | 0  | 0 | 0 |
| D=1, U=1の場合 |     |         |     |    |    |   |   |
| 18          | 25  | 1       | 04  | 0  | 0  | 1 | 0 |

**ADC A, [ir+L]** ////////////////////////////////////////////////////////////////// Add with carry location [ir reg. + L] to A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A A + [ir+L] + C

irレジスタ(IX/IY)の内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容とキャリー(C)をAレジスタに加えます。  
Lレジスタの内容は符号付きデータとして扱われ、範囲は-128 ~ 127です。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB     |     |
|-----|------------------|---------|-----|
|     | 1 1 0 0 1 1 1 0  | CEH     |     |
|     | 0 0 0 0 1 0 1 ir | 0AH、0BH |     |
|     | ir               | ニーモニック  | コード |

| IX | 0 | ADC A, [IX+L] | 0AH |
|----|---|---------------|-----|
| IY | 1 | ADC A, [IY+L] | 0BH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  |   | ↑ | ↑ | ↑ | ↑ | ↑ |

**モード** Src: インデックスレジスタ付きレジスタ間接

Dst: レジスタ直接

| 例           | 設定値 |        |     | 結果 |    |   |   |
|-------------|-----|--------|-----|----|----|---|---|
|             | A   | [ir+L] | C   | A  | SC |   |   |
| D=0, U=0の場合 |     |        |     |    |    |   |   |
| 18H         | 25H | 0      | 3DH | 0  | 0  | 0 | 0 |
| 18H         | 25H | 1      | 3EH | 0  | 0  | 0 | 0 |
| 30H         | D0H | 0      | 00H | 0  | 0  | 1 | 1 |
| 30H         | F0H | 0      | 20H | 0  | 0  | 1 | 0 |
| 30H         | 50H | 0      | 80H | 1  | 1  | 0 | 0 |
| D=1, U=0の場合 |     |        |     |    |    |   |   |
| 18          | 25  | 1      | 44  | 0  | 0  | 0 | 0 |
| D=1, U=1の場合 |     |        |     |    |    |   |   |
| 18          | 25  | 1      | 04  | 0  | 0  | 1 | 0 |

**ADC [HL], A** ////////////// Add with carry A reg. to location [HL] ////////////// 4 cycle //**機能** [HL] [HL] + A + C

Aレジスタの内容とキャリー(C)をHLレジスタでアドレス指定されたデータメモリに加えます。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 0 0 0 1 1 0 0 | 0CH |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  |    |   |   | ↑ | ↑ | ↑ | ↑ |

**モード** Src: レジスタ直接

Dst: レジスタ間接

**例**

| [HL]               | A   | C | 設定値  |    | 結果 |   |   |   |
|--------------------|-----|---|------|----|----|---|---|---|
|                    |     |   | [HL] | SC | N  | V | C | Z |
| <b>D=0, U=0の場合</b> |     |   |      |    |    |   |   |   |
| 18H                | 25H | 0 | 3DH  | 0  | 0  | 0 | 0 | 0 |
| 18H                | 25H | 1 | 3EH  | 0  | 0  | 0 | 0 | 0 |
| 30H                | D0H | 0 | 00H  | 0  | 0  | 1 | 1 |   |
| 30H                | F0H | 0 | 20H  | 0  | 0  | 1 | 0 |   |
| 30H                | 50H | 0 | 80H  | 1  | 1  | 0 | 0 |   |
| <b>D=1, U=0の場合</b> |     |   |      |    |    |   |   |   |
| 18                 | 25  | 1 | 44   | 0  | 0  | 0 | 0 | 0 |
| <b>D=1, U=1の場合</b> |     |   |      |    |    |   |   |   |
| 18                 | 25  | 1 | 04   | 0  | 0  | 1 | 0 |   |

**ADC [HL], #nn** ////////////// Add with carry immediate data nn to location [HL] ////////////// 5 cycle //**機能** [HL] [HL] + nn + C

8ビット即値データnnとキャリー(C)をHLレジスタでアドレス指定されたデータメモリに加えます。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 0 0 0 1 1 0 1 | 0DH |  |
|     | n n             | nn  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  |    |   |   | ↑ | ↑ | ↑ | ↑ |

**モード** Src: 即値データ

Dst: レジスタ間接

**例**

| [HL]               | nn  | C | 設定値  |    | 結果 |   |   |   |
|--------------------|-----|---|------|----|----|---|---|---|
|                    |     |   | [HL] | SC | N  | V | C | Z |
| <b>D=0, U=0の場合</b> |     |   |      |    |    |   |   |   |
| 18H                | 25H | 0 | 3DH  | 0  | 0  | 0 | 0 | 0 |
| 18H                | 25H | 1 | 3EH  | 0  | 0  | 0 | 0 | 0 |
| 30H                | D0H | 0 | 00H  | 0  | 0  | 1 | 1 |   |
| 30H                | F0H | 0 | 20H  | 0  | 0  | 1 | 0 |   |
| 30H                | 50H | 0 | 80H  | 1  | 1  | 0 | 0 |   |
| <b>D=1, U=0の場合</b> |     |   |      |    |    |   |   |   |
| 18                 | 25  | 1 | 44   | 0  | 0  | 0 | 0 | 0 |
| <b>D=1, U=1の場合</b> |     |   |      |    |    |   |   |   |
| 18                 | 25  | 1 | 04   | 0  | 0  | 1 | 0 |   |

**ADC [HL], [ir]** ////////////// Add with carry location [ir reg.] to location [HL] ////////////// 5 cycle //**機能** [HL] [HL] + [ir] + C

irレジスタ(IX/IY)でアドレス指定されたデータメモリの内容とキャリー(C)をHLレジスタでアドレス指定されるデータメモリに加えます。  
EPレジスタの内容がデータメモリ[HL]のページアドレス、XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリ[ir]のページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB      |     |
|-----|------------------|----------|-----|
|     | 1 1 0 0 1 1 1 0  | CEH      |     |
|     | 0 0 0 0 1 1 1 ir | 0EH, 0FH |     |
|     | ir               | 二-モニック   | コード |

| IX | 0 | ADC [HL], [IX] | 0EH |
|----|---|----------------|-----|
| IY | 1 | ADC [HL], [IY] | 0FH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  |    |   |   | ↑ | ↑ | ↑ | ↑ |

**モード** Src: レジスタ間接

Dst: レジスタ間接

**例**

| [HL]               | [ir] | C | 設定値  |    | 結果 |   |   |   |
|--------------------|------|---|------|----|----|---|---|---|
|                    |      |   | [HL] | SC | N  | V | C | Z |
| <b>D=0, U=0の場合</b> |      |   |      |    |    |   |   |   |
| 18H                | 25H  | 0 | 3DH  | 0  | 0  | 0 | 0 | 0 |
| 18H                | 25H  | 1 | 3EH  | 0  | 0  | 0 | 0 | 0 |
| 30H                | D0H  | 0 | 00H  | 0  | 0  | 1 | 1 |   |
| 30H                | F0H  | 0 | 20H  | 0  | 0  | 1 | 0 |   |
| 30H                | 50H  | 0 | 80H  | 1  | 1  | 0 | 0 |   |
| <b>D=1, U=0の場合</b> |      |   |      |    |    |   |   |   |
| 18                 | 25   | 1 | 44   | 0  | 0  | 0 | 0 | 0 |
| <b>D=1, U=1の場合</b> |      |   |      |    |    |   |   |   |
| 18                 | 25   | 1 | 04   | 0  | 0  | 1 | 0 |   |

**ADC BA, rp** // Add with carry rp reg. to BA reg. // 4 cycle //

機能 BA BA + rp + C

rpレジスタ(BA/HL/IX/IY)の内容とキャリー(C)を  
BAレジスタに加えます。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB       |  |
|-----|-----------------|-----------|--|
|     | 1 1 0 0 1 1 1 1 | CFH       |  |
|     | 0 0 0 0 0 1 rp  | 04H ~ 07H |  |

| rp    | ニーモニック     | コード |
|-------|------------|-----|
| BA 00 | ADC BA, BA | 04H |
| HL 01 | ADC BA, HL | 05H |
| IX 10 | ADC BA, IX | 06H |
| IY 11 | ADC BA, IY | 07H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

| BA    | rp    | C | 設定値   |    | 結果 |   |   |   |
|-------|-------|---|-------|----|----|---|---|---|
|       |       |   | BA    | SC |    |   |   |   |
|       |       |   |       |    | N  | V | C | Z |
| 1380H | 3546H | 0 | 48C6H | 0  | 0  | 0 | 0 | 0 |
| 1380H | 3546H | 1 | 48C7H | 0  | 0  | 0 | 0 | 0 |
| 1380H | EC80H | 0 | 0000H | 0  | 0  | 1 | 1 | 1 |
| 5218H | 4174H | 0 | 938CH | 1  | 1  | 0 | 0 | 0 |
| 5342H | C32AH | 1 | 166DH | 0  | 0  | 1 | 0 | 0 |

(rp BA)

**ADC BA, #mmnn** // Add with carry immediate data mmnn to BA reg. // 4 cycle //

機能 BA BA + mmnn + C

16ビット即値データmmnnとキャリー(C)をBAレジスタに加えます。

モード Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 1 | CFH |  |
|     | 0 1 1 0 0 0 0 0 | 60H |  |
|     | n n             | nn  |  |
|     | m m             | mm  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

| BA    | mmnn  | C | 設定値   |    | 結果 |   |   |   |
|-------|-------|---|-------|----|----|---|---|---|
|       |       |   | BA    | SC |    |   |   |   |
|       |       |   |       |    | N  | V | C | Z |
| 1380H | 3546H | 0 | 48C6H | 0  | 0  | 0 | 0 | 0 |
| 1380H | 3546H | 1 | 48C7H | 0  | 0  | 0 | 0 | 0 |
| 1380H | EC80H | 0 | 0000H | 0  | 0  | 1 | 1 | 1 |
| 5218H | 4174H | 0 | 938CH | 1  | 1  | 0 | 0 | 0 |
| 5342H | C32AH | 1 | 166DH | 0  | 0  | 1 | 0 | 0 |

**ADC HL, rp** // Add with carry rp reg. to HL reg. // 4 cycle //

機能 HL HL + rp + C

rpレジスタ(BA/HL/IX/IY)の内容とキャリー(C)を  
HLレジスタに加えます。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB       |  |
|-----|-----------------|-----------|--|
|     | 1 1 0 0 1 1 1 1 | CFH       |  |
|     | 0 0 1 0 0 1 rp  | 24H ~ 27H |  |

| rp    | ニーモニック     | コード |
|-------|------------|-----|
| BA 00 | ADC HL, BA | 24H |
| HL 01 | ADC HL, HL | 25H |
| IX 10 | ADC HL, IX | 26H |
| IY 11 | ADC HL, IY | 27H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

| HL    | rp    | C | 設定値   |    | 結果 |   |   |   |
|-------|-------|---|-------|----|----|---|---|---|
|       |       |   | HL    | SC |    |   |   |   |
|       |       |   |       |    | N  | V | C | Z |
| 1380H | 3546H | 0 | 48C6H | 0  | 0  | 0 | 0 | 0 |
| 1380H | 3546H | 1 | 48C7H | 0  | 0  | 0 | 0 | 0 |
| 1380H | EC80H | 0 | 0000H | 0  | 0  | 1 | 1 | 1 |
| 5218H | 4174H | 0 | 938CH | 1  | 1  | 0 | 0 | 0 |
| 5342H | C32AH | 1 | 166DH | 0  | 0  | 1 | 0 | 0 |

(rp HL)

**ADC HL, #mmnn** // Add with carry immediate data mmnn to HL reg. ////////////// 4 cycle //

**機能** HL HL + mmnn + C  
16ビット即値データmmnnとキャリー(C)をHLレジスタに加えます。

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 0 0 1 1 1 1 | CFH |
|     | 0 1 1 0 0 0 0 1 | 61H |
|     | n n             | nn  |
|     | m m             | mm  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**モード** Src: 即値データ  
Dst: レジスタ直接

| 例     | 設定値   |      |       | 結果 |    |   |   |   |
|-------|-------|------|-------|----|----|---|---|---|
|       | HL    | mmnn | C     | HL | SC |   |   |   |
|       |       |      |       |    | N  | V | C | Z |
| 1380H | 3546H | 0    | 48C6H | 0  | 0  | 0 | 0 | 0 |
| 1380H | 3546H | 1    | 48C7H | 0  | 0  | 0 | 0 | 0 |
| 1380H | EC80H | 0    | 0000H | 0  | 0  | 1 | 1 | 1 |
| 5218H | 4174H | 0    | 938CH | 1  | 1  | 0 | 0 | 0 |
| 5342H | C32AH | 1    | 166DH | 0  | 0  | 1 | 0 | 0 |

**ADD A, r** ////////////// Add r reg. to A reg. ////////////// 2 cycle //

**機能** A A + r  
rレジスタ(A/B)の内容をAレジスタに加えます。

| コード | MSB             | LSB      |
|-----|-----------------|----------|
|     | 0 0 0 0 0 0 0 r | 00H, 01H |
|     | r               | 二-モニック   |
|     | A 0             | ADD A, A |
|     | B 1             | ADD A, B |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**モード** Src: レジスタ直接  
Dst: レジスタ直接

| 例           | 設定値 |     |   | 結果 |   |   |   |
|-------------|-----|-----|---|----|---|---|---|
|             | A   | B   | A | SC |   |   |   |
|             |     |     |   | N  | V | C | Z |
| D=0, U=0の場合 |     |     |   |    |   |   |   |
| 18H         | 25H | 3DH | 0 | 0  | 0 | 0 | 0 |
| 30H         | D0H | 00H | 0 | 0  | 1 | 1 | 1 |
| 30H         | F0H | 20H | 0 | 0  | 1 | 0 | 0 |
| 30H         | 50H | 80H | 1 | 1  | 0 | 0 | 0 |
| D=1, U=0の場合 |     |     |   |    |   |   |   |
| 18          | 24  | 42  | 0 | 0  | 0 | 0 | 0 |
| D=1, U=1の場合 |     |     |   |    |   |   |   |
| 18          | 24  | 02  | 0 | 0  | 1 | 0 | 0 |

**ADD A, #nn** ////////////// Add immediate data nn to A reg. ////////////// 2 cycle //

**機能** A A + nn  
8ビット即値データnnをAレジスタに加えます。

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 0 0 0 0 0 0 1 0 | 02H |
|     | n n             | nn  |
|     | - -             | ↑↑  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**モード** Src: 即値データ  
Dst: レジスタ直接

| 例           | 設定値 |     |   | 結果 |   |   |   |
|-------------|-----|-----|---|----|---|---|---|
|             | A   | nn  | A | SC |   |   |   |
|             |     |     |   | N  | V | C | Z |
| D=0, U=0の場合 |     |     |   |    |   |   |   |
| 18H         | 25H | 3DH | 0 | 0  | 0 | 0 | 0 |
| 30H         | D0H | 00H | 0 | 0  | 1 | 1 | 1 |
| 30H         | F0H | 20H | 0 | 0  | 1 | 0 | 0 |
| 30H         | 50H | 80H | 1 | 1  | 0 | 0 | 0 |
| D=1, U=0の場合 |     |     |   |    |   |   |   |
| 18          | 24  | 42  | 0 | 0  | 0 | 0 | 0 |
| D=1, U=1の場合 |     |     |   |    |   |   |   |
| 18          | 24  | 02  | 0 | 0  | 1 | 0 | 0 |

**ADD A, [BR:ll]** ////////////////////////////////////////////////////////////////// Add location [BR:ll] to A reg. ////////////////////////////////////////////////////////////////// 3 cycle //**機能** A A + [BR:ll]

BRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されたデータメモリの内容をAレジスタに加えます。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

|            |     |     |     |
|------------|-----|-----|-----|
| <b>コード</b> | MSB | LSB | 04H |
|            |     | ll  |     |
|            |     | ll  |     |

|            |    |    |   |   |   |   |   |   |
|------------|----|----|---|---|---|---|---|---|
| <b>フラグ</b> | I1 | I0 | U | D | N | V | C | Z |
|            | -  | -  |   | ↓ | ↓ | ↓ | ↓ | ↓ |

**モード** Src: 8ビット絶対

Dst: レジスタ直接

| <b>例</b>           |         | <b>設定値</b> |    | <b>結果</b> |   |   |   |
|--------------------|---------|------------|----|-----------|---|---|---|
| A                  | [BR:ll] | A          | SC |           |   |   |   |
|                    |         |            | N  | V         | C | Z |   |
| <b>D=0, U=0の場合</b> |         |            |    |           |   |   |   |
| 18H                | 25H     | 3DH        | 0  | 0         | 0 | 0 | 0 |
| 30H                | D0H     | 00H        | 0  | 0         | 1 | 1 |   |
| 30H                | F0H     | 20H        | 0  | 0         | 1 | 0 |   |
| 30H                | 50H     | 80H        | 1  | 1         | 0 | 0 |   |
| <b>D=1, U=0の場合</b> |         |            |    |           |   |   |   |
| 18                 | 24      | 42         | 0  | 0         | 0 | 0 | 0 |
| <b>D=1, U=1の場合</b> |         |            |    |           |   |   |   |
| 18                 | 24      | 02         | 0  | 0         | 1 | 0 | 0 |

**ADD A, [hhll]** ////////////////////////////////////////////////////////////////// Add location [hhll] to A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A A + [hhll]

16ビット絶対アドレスhhllでアドレス指定されたデータメモリの内容をAレジスタに加えます。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

|            |     |     |     |
|------------|-----|-----|-----|
| <b>コード</b> | MSB | LSB | 05H |
|            |     | ll  |     |
|            |     | ll  |     |
|            |     | hh  |     |

|            |    |    |   |   |   |   |   |   |
|------------|----|----|---|---|---|---|---|---|
| <b>フラグ</b> | I1 | I0 | U | D | N | V | C | Z |
|            | -  | -  |   | ↓ | ↓ | ↓ | ↓ | ↓ |

**モード** Src: 16ビット絶対

Dst: レジスタ直接

| <b>例</b>           |        | <b>設定値</b> |    | <b>結果</b> |   |   |   |
|--------------------|--------|------------|----|-----------|---|---|---|
| A                  | [hhll] | A          | SC |           |   |   |   |
|                    |        |            | N  | V         | C | Z |   |
| <b>D=0, U=0の場合</b> |        |            |    |           |   |   |   |
| 18H                | 25H    | 3DH        | 0  | 0         | 0 | 0 | 0 |
| 30H                | D0H    | 00H        | 0  | 0         | 1 | 1 |   |
| 30H                | F0H    | 20H        | 0  | 0         | 1 | 0 |   |
| 30H                | 50H    | 80H        | 1  | 1         | 0 | 0 |   |
| <b>D=1, U=0の場合</b> |        |            |    |           |   |   |   |
| 18                 | 24     | 42         | 0  | 0         | 0 | 0 | 0 |
| <b>D=1, U=1の場合</b> |        |            |    |           |   |   |   |
| 18                 | 24     | 02         | 0  | 0         | 1 | 0 | 0 |

**ADD A, [HL]** ////////////////////////////////////////////////////////////////// Add location [HL] to A reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** A A + [HL]

HLレジスタでアドレス指定されたデータメモリの内容をAレジスタに加えます。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

|            |     |     |     |
|------------|-----|-----|-----|
| <b>コード</b> | MSB | LSB | 03H |
|            |     | ll  |     |

|            |    |    |   |   |   |   |   |   |
|------------|----|----|---|---|---|---|---|---|
| <b>フラグ</b> | I1 | I0 | U | D | N | V | C | Z |
|            | -  | -  |   | ↓ | ↓ | ↓ | ↓ | ↓ |

**モード** Src: レジスタ間接

Dst: レジスタ直接

| <b>例</b>           |      | <b>設定値</b> |    | <b>結果</b> |   |   |   |
|--------------------|------|------------|----|-----------|---|---|---|
| A                  | [HL] | A          | SC |           |   |   |   |
|                    |      |            | N  | V         | C | Z |   |
| <b>D=0, U=0の場合</b> |      |            |    |           |   |   |   |
| 18H                | 25H  | 3DH        | 0  | 0         | 0 | 0 | 0 |
| 30H                | D0H  | 00H        | 0  | 0         | 1 | 1 |   |
| 30H                | F0H  | 20H        | 0  | 0         | 1 | 0 |   |
| 30H                | 50H  | 80H        | 1  | 1         | 0 | 0 |   |
| <b>D=1, U=0の場合</b> |      |            |    |           |   |   |   |
| 18                 | 24   | 42         | 0  | 0         | 0 | 0 | 0 |
| <b>D=1, U=1の場合</b> |      |            |    |           |   |   |   |
| 18                 | 24   | 02         | 0  | 0         | 1 | 0 | 0 |

**ADD A, [ir]** ////////////////////////////////////////////////////////////////// Add location [ir reg.] to A reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** A A + [ir]

irレジスタ(IX/IY)でアドレス指定されたデータメモリの内容をAレジスタに加えます。

XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります (MODEL2/3)。

**コード** MSB LSB  

|   |   |   |   |   |   |   |    |          |
|---|---|---|---|---|---|---|----|----------|
| 0 | 0 | 0 | 0 | 0 | 1 | 1 | ir | 06H, 07H |
|---|---|---|---|---|---|---|----|----------|

| ir   | ニーモニック      | コード |
|------|-------------|-----|
| IX 0 | ADD A, [IX] | 06H |
| IY 1 | ADD A, [IY] | 07H |

**フラグ** I1 I0 U D N V C Z  

|   |   |  |  |   |   |   |   |   |
|---|---|--|--|---|---|---|---|---|
| - | - |  |  | ↑ | ↑ | ↑ | ↑ | ↑ |
|---|---|--|--|---|---|---|---|---|

**モード** Src: レジスタ間接

Dst: レジスタ直接

| 例           |      | 設定値 |    | 結果 |   |   |  |
|-------------|------|-----|----|----|---|---|--|
| A           | [ir] | A   | SC |    |   |   |  |
|             |      |     | N  | V  | C | Z |  |
| D=0, U=0の場合 |      |     |    |    |   |   |  |
| 18H         | 25H  | 3DH | 0  | 0  | 0 | 0 |  |
| 30H         | D0H  | 00H | 0  | 0  | 1 | 1 |  |
| 30H         | F0H  | 20H | 0  | 0  | 1 | 0 |  |
| 30H         | 50H  | 80H | 1  | 1  | 0 | 0 |  |
| D=1, U=0の場合 |      |     |    |    |   |   |  |
| 18          | 24   | 42  | 0  | 0  | 0 | 0 |  |
| D=1, U=1の場合 |      |     |    |    |   |   |  |
| 18          | 24   | 02  | 0  | 0  | 1 | 0 |  |

**ADD A, [ir+dd]** ////////////////////////////////////////////////////////////////// Add location [ir reg. + dd] to A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A A + [ir+dd]

irレジスタ(IX/IY)の内容とディスプレースメント ddの和でアドレス指定されたデータメモリの内容をAレジスタに加えます。

ddは符号付きデータとして扱われ、範囲は-128 ~ 127です。

XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります (MODEL2/3)。

**コード** MSB LSB  

|     |   |   |   |    |   |   |    |          |
|-----|---|---|---|----|---|---|----|----------|
| 1   | 1 | 0 | 0 | 1  | 1 | 1 | 0  | CEH      |
| 0   | 0 | 0 | 0 | 0  | 0 | 0 | ir | 00H, 01H |
| d d |   |   |   | dd |   |   |    |          |

| ir   | ニーモニック         | コード |
|------|----------------|-----|
| IX 0 | ADD A, [IX+dd] | 00H |
| IY 1 | ADD A, [IY+dd] | 01H |

**フラグ** I1 I0 U D N V C Z  

|   |   |  |  |   |   |   |   |   |
|---|---|--|--|---|---|---|---|---|
| - | - |  |  | ↑ | ↑ | ↑ | ↑ | ↑ |
|---|---|--|--|---|---|---|---|---|

**モード** Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ直接

| 例           |         | 設定値 |    | 結果 |   |   |  |
|-------------|---------|-----|----|----|---|---|--|
| A           | [ir+dd] | A   | SC |    |   |   |  |
|             |         |     | N  | V  | C | Z |  |
| D=0, U=0の場合 |         |     |    |    |   |   |  |
| 18H         | 25H     | 3DH | 0  | 0  | 0 | 0 |  |
| 30H         | D0H     | 00H | 0  | 0  | 1 | 1 |  |
| 30H         | F0H     | 20H | 0  | 0  | 1 | 0 |  |
| 30H         | 50H     | 80H | 1  | 1  | 0 | 0 |  |
| D=1, U=0の場合 |         |     |    |    |   |   |  |
| 18          | 24      | 42  | 0  | 0  | 0 | 0 |  |
| D=1, U=1の場合 |         |     |    |    |   |   |  |
| 18          | 24      | 02  | 0  | 0  | 1 | 0 |  |

**ADD A, [ir+L]** ////////////// Add location [ir reg. + L] to A reg. ////////////// 4 cycle //**機能** A A + [ir+L]

irレジスタ(IX/IY)の内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容をAレジスタに加えます。  
 Lレジスタの内容は符号付きデータとして扱われ、範囲は-128~127です。  
 XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB           |     |
|-----|------------------|---------------|-----|
|     | 1 1 0 0 1 1 1 0  | CEH           |     |
|     | 0 0 0 0 0 0 1 ir | 02H, 03H      |     |
|     | ir               | ニーモニック        | コード |
| IX  | 0                | ADD A, [IX+L] | 02H |
| IY  | 1                | ADD A, [IY+L] | 03H |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  |   | ↑ | ↑ | ↑ | ↑ | ↑ |

**モード** Src: インデックスレジスタ付きレジスタ間接

Dst: レジスタ直接

| 例           |        | 設定値 |    | 結果 |   |   |  |
|-------------|--------|-----|----|----|---|---|--|
| A           | [ir+L] | A   | SC |    |   |   |  |
|             |        |     | N  | V  | C | Z |  |
| D=0, U=0の場合 |        |     |    |    |   |   |  |
| 18H         | 25H    | 3DH | 0  | 0  | 0 | 0 |  |
| 30H         | D0H    | 00H | 0  | 0  | 1 | 1 |  |
| 30H         | F0H    | 20H | 0  | 0  | 1 | 0 |  |
| 30H         | 50H    | 80H | 1  | 1  | 0 | 0 |  |
| D=1, U=0の場合 |        |     |    |    |   |   |  |
| 18          | 24     | 42  | 0  | 0  | 0 | 0 |  |
| D=1, U=1の場合 |        |     |    |    |   |   |  |
| 18          | 24     | 02  | 0  | 0  | 1 | 0 |  |

**ADD [HL], A** ////////////// Add A reg. to location [HL] ////////////// 4 cycle //**機能** [HL] [HL] + A

Aレジスタの内容をHLレジスタでアドレス指定されたデータメモリに加えます。  
 EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |   |
|-----|-----------------|-----|---|
|     | 1 1 0 0 1 1 1 0 | CEH |   |
|     | 0 0 0 0 0 1 0 0 | 04H |   |
|     | I1              | I0  | U |
|     | -               | -   |   |
|     | D               | N   | V |
|     | ↑               | ↑   | ↑ |
|     | C               | Z   |   |
|     | ↑               | ↑   | ↑ |

**モード** Src: レジスタ直接

Dst: レジスタ間接

| 例           |     | 設定値  |    | 結果 |   |   |  |
|-------------|-----|------|----|----|---|---|--|
| [HL]        | A   | [HL] | SC |    |   |   |  |
|             |     |      | N  | V  | C | Z |  |
| D=0, U=0の場合 |     |      |    |    |   |   |  |
| 18H         | 25H | 3DH  | 0  | 0  | 0 | 0 |  |
| 30H         | D0H | 00H  | 0  | 0  | 1 | 1 |  |
| 30H         | F0H | 20H  | 0  | 0  | 1 | 0 |  |
| 30H         | 50H | 80H  | 1  | 1  | 0 | 0 |  |
| D=1, U=0の場合 |     |      |    |    |   |   |  |
| 18          | 24  | 42   | 0  | 0  | 0 | 0 |  |
| D=1, U=1の場合 |     |      |    |    |   |   |  |
| 18          | 24  | 02   | 0  | 0  | 1 | 0 |  |

**ADD [HL], #nn** ////////////// Add immediate data nn to location [HL] ////////////// 5 cycle //**機能** [HL] [HL] + nn

8ビット即値データnnをHLレジスタでアドレス指定されたデータメモリに加えます。  
 EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |   |
|-----|-----------------|-----|---|
|     | 1 1 0 0 1 1 1 0 | CEH |   |
|     | 0 0 0 0 0 1 0 1 | 05H |   |
|     | n n             | nn  |   |
|     | -               | -   |   |
|     | D               | N   | V |
|     | ↑               | ↑   | ↑ |
|     | C               | Z   |   |
|     | ↑               | ↑   | ↑ |

**モード** Src: 即値データ

Dst: レジスタ間接

| 例           |     | 設定値  |    | 結果 |   |   |  |
|-------------|-----|------|----|----|---|---|--|
| [HL]        | nn  | [HL] | SC |    |   |   |  |
|             |     |      | N  | V  | C | Z |  |
| D=0, U=0の場合 |     |      |    |    |   |   |  |
| 18H         | 25H | 3DH  | 0  | 0  | 0 | 0 |  |
| 30H         | D0H | 00H  | 0  | 0  | 1 | 1 |  |
| 30H         | F0H | 20H  | 0  | 0  | 1 | 0 |  |
| 30H         | 50H | 80H  | 1  | 1  | 0 | 0 |  |
| D=1, U=0の場合 |     |      |    |    |   |   |  |
| 18          | 24  | 42   | 0  | 0  | 0 | 0 |  |
| D=1, U=1の場合 |     |      |    |    |   |   |  |
| 18          | 24  | 02   | 0  | 0  | 1 | 0 |  |

**ADD [HL], [ir]** // Add location [ir reg.] to location [HL] // 5 cycle //

機能 [HL] [HL] + [ir]

irレジスタ(IX/IY)でアドレス指定されたデータメモリの内容をHLレジスタでアドレス指定されるデータメモリに加えます。

EPレジスタの内容がデータメモリ[HL]のページアドレス、XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリ[ir]のページアドレスになります(MODEL2/3)。

| コード  | MSB              | LSB      |   |   |   |   |   |   |
|------|------------------|----------|---|---|---|---|---|---|
|      | 1 1 0 0 1 1 1 0  | CEH      |   |   |   |   |   |   |
|      | 0 0 0 0 0 1 1 ir | 06H, 07H |   |   |   |   |   |   |
| ir   | ニーモニック           | コード      |   |   |   |   |   |   |
| IX 0 | ADD [HL], [IX]   | 06H      |   |   |   |   |   |   |
| IY 1 | ADD [HL], [IY]   | 07H      |   |   |   |   |   |   |
| フラグ  | I1               | I0       | U | D | N | V | C | Z |
|      | -                | -        |   | ↑ | ↑ | ↑ | ↑ | ↑ |

モード Src: レジスタ間接

Dst: レジスタ間接

| 例           | 設定値  |      | 結果   |    |   |   |   |
|-------------|------|------|------|----|---|---|---|
|             | [HL] | [ir] | [HL] | SC |   |   |   |
|             |      |      | N    | V  | C | Z |   |
| D=0, U=0の場合 |      |      |      |    |   |   |   |
| 18H         | 25H  | 3DH  | 0    | 0  | 0 | 0 | 0 |
| 30H         | D0H  | 00H  | 0    | 0  | 1 | 1 |   |
| 30H         | F0H  | 20H  | 0    | 0  | 1 | 0 |   |
| 30H         | 50H  | 80H  | 1    | 1  | 0 | 0 |   |
| D=1, U=0の場合 |      |      |      |    |   |   |   |
| 18          | 24   | 42   | 0    | 0  | 0 | 0 | 0 |
| D=1, U=1の場合 |      |      |      |    |   |   |   |
| 18          | 24   | 02   | 0    | 0  | 1 | 0 |   |

**ADD BA, rp** // Add rp reg. to BA reg. // 4 cycle //

機能 BA BA + rp

rpレジスタ(BA/HL/IX/IY)の内容をBAレジスタに加えます。

| コード   | MSB             | LSB       |   |   |   |   |   |   |
|-------|-----------------|-----------|---|---|---|---|---|---|
|       | 1 1 0 0 1 1 1 1 | CFH       |   |   |   |   |   |   |
|       | 0 0 0 0 0 0 rp  | 00H ~ 03H |   |   |   |   |   |   |
| rp    | ニーモニック          | コード       |   |   |   |   |   |   |
| BA 00 | ADD BA, BA      | 00H       |   |   |   |   |   |   |
| HL 01 | ADD BA, HL      | 01H       |   |   |   |   |   |   |
| IX 10 | ADD BA, IX      | 02H       |   |   |   |   |   |   |
| IY 11 | ADD BA, IY      | 03H       |   |   |   |   |   |   |
| フラグ   | I1              | I0        | U | D | N | V | C | Z |
|       | -               | -         | - | ↑ | ↑ | ↑ | ↑ | ↑ |

モード Src: レジスタ直接

Dst: レジスタ直接

| 例     | 設定値   |       | 結果 |    |   |   |  |
|-------|-------|-------|----|----|---|---|--|
|       | BA    | rp    | BA | SC |   |   |  |
|       |       |       | N  | V  | C | Z |  |
| 1380H | 3546H | 48C6H | 0  | 0  | 0 | 0 |  |
| 1380H | EC80H | 0000H | 0  | 0  | 1 | 1 |  |
| 5218H | 4174H | 938CH | 1  | 1  | 0 | 0 |  |
| 5342H | C32AH | 166CH | 0  | 0  | 1 | 0 |  |

(rp BA)

**ADD BA, #mmnn** // Add immediate data mmnn to BA reg. // 3 cycle //

機能 BA BA + mmnn

16ビット即値データmmnnをBAレジスタに加えます。

モード Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB |   |   |   |   |   |   |
|-----|-----------------|-----|---|---|---|---|---|---|
|     | 1 1 0 0 0 0 0 0 | C0H |   |   |   |   |   |   |
|     | n n             | nn  |   |   |   |   |   |   |
|     | m m             | mm  |   |   |   |   |   |   |
| フラグ | I1              | I0  | U | D | N | V | C | Z |
|     | -               | -   | - | ↑ | ↑ | ↑ | ↑ | ↑ |

| 例     | 設定値   |       | 結果 |    |   |   |  |
|-------|-------|-------|----|----|---|---|--|
|       | BA    | mmnn  | BA | SC |   |   |  |
|       |       |       | N  | V  | C | Z |  |
| 1380H | 3546H | 48C6H | 0  | 0  | 0 | 0 |  |
| 1380H | EC80H | 0000H | 0  | 0  | 1 | 1 |  |
| 5218H | 4174H | 938CH | 1  | 1  | 0 | 0 |  |
| 5342H | C32AH | 166CH | 0  | 0  | 1 | 0 |  |

**ADD HL, rp** ////////////// Add rp reg. to HL reg. ////////////// 4 cycle //

機能 HL HL + rp

rpレジスタ(BA/HL/IX/IY)の内容をHLレジスタに加えます。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード           |    |            |     |  |  |  |  | MSB | LSB       |  |
|---------------|----|------------|-----|--|--|--|--|-----|-----------|--|
|               |    |            |     |  |  |  |  |     | CFH       |  |
|               |    |            |     |  |  |  |  |     | 20H ~ 23H |  |
| rp ニーモニック コード |    |            |     |  |  |  |  |     |           |  |
| BA            | 00 | ADD HL, BA | 20H |  |  |  |  |     |           |  |
| HL            | 01 | ADD HL, HL | 21H |  |  |  |  |     |           |  |
| IX            | 10 | ADD HL, IX | 22H |  |  |  |  |     |           |  |
| IY            | 11 | ADD HL, IY | 23H |  |  |  |  |     |           |  |

| フラグ |   |   |   |   |   |   |   | I1 | I0 | U | D | N | V | C | Z |
|-----|---|---|---|---|---|---|---|----|----|---|---|---|---|---|---|
| -   | - | - | - | ↑ | ↑ | ↑ | ↑ | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

| 例     | 設定値   |       | 結果 |    |   |   |
|-------|-------|-------|----|----|---|---|
|       | HL    | rp    | HL | SC |   |   |
|       |       |       |    | N  | V | C |
| 1380H | 3546H | 48C6H | 0  | 0  | 0 | 0 |
| 1380H | EC80H | 0000H | 0  | 0  | 1 | 1 |
| 5218H | 4174H | 938CH | 1  | 1  | 0 | 0 |
| 5342H | C32AH | 166CH | 0  | 0  | 1 | 0 |

(rp HL)

**ADD HL, #mmnn** // Add immediate data mmnn to HL reg. ////////////// 3 cycle //

機能 HL HL + mmnn

16ビット即値データmmnnをHLレジスタに加えます。

モード Src: 即値データ

Dst: レジスタ直接

| コード |  |  |  |  |  |  |  | MSB | LSB |  |
|-----|--|--|--|--|--|--|--|-----|-----|--|
|     |  |  |  |  |  |  |  |     | C1H |  |
|     |  |  |  |  |  |  |  |     | nn  |  |
|     |  |  |  |  |  |  |  |     | mm  |  |

| フラグ |   |   |   |   |   |   |   | I1 | I0 | U | D | N | V | C | Z |
|-----|---|---|---|---|---|---|---|----|----|---|---|---|---|---|---|
| -   | - | - | - | ↑ | ↑ | ↑ | ↑ | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

| 例     | 設定値   |       | 結果 |    |   |   |
|-------|-------|-------|----|----|---|---|
|       | HL    | mmnn  | HL | SC |   |   |
|       |       |       |    | N  | V | C |
| 1380H | 3546H | 48C6H | 0  | 0  | 0 | 0 |
| 1380H | EC80H | 0000H | 0  | 0  | 1 | 1 |
| 5218H | 4174H | 938CH | 1  | 1  | 0 | 0 |
| 5342H | C32AH | 166CH | 0  | 0  | 1 | 0 |

**ADD IX, rp** ////////////// Add rp reg. to IX reg. ////////////// 4 cycle //

機能 IX IX + rp

rpレジスタ(BA/HL)の内容をIXレジスタに加えます。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード |   |            |     |  |  |  |  | MSB | LSB      |  |
|-----|---|------------|-----|--|--|--|--|-----|----------|--|
|     |   |            |     |  |  |  |  |     | CFH      |  |
|     |   |            |     |  |  |  |  |     | 40H, 41H |  |
|     |   |            |     |  |  |  |  |     |          |  |
| BA  | 0 | ADD IX, BA | 40H |  |  |  |  |     |          |  |
| HL  | 1 | ADD IX, HL | 41H |  |  |  |  |     |          |  |

| フラグ |   |   |   |   |   |   |   | I1 | I0 | U | D | N | V | C | Z |
|-----|---|---|---|---|---|---|---|----|----|---|---|---|---|---|---|
| -   | - | - | - | ↑ | ↑ | ↑ | ↑ | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

| 例     | 設定値   |       | 結果 |    |   |   |
|-------|-------|-------|----|----|---|---|
|       | IX    | rp    | IX | SC |   |   |
|       |       |       |    | N  | V | C |
| 1380H | 3546H | 48C6H | 0  | 0  | 0 | 0 |
| 1380H | EC80H | 0000H | 0  | 0  | 1 | 1 |
| 5218H | 4174H | 938CH | 1  | 1  | 0 | 0 |
| 5342H | C32AH | 166CH | 0  | 0  | 1 | 0 |

**ADD IX, #mmnn** //// Add immediate data mmnn to IX reg. //// 3 cycle //

機能 IX IX + mmnn

16ビット即値データmmnnをIXレジスタに加えます。

モード Src: 即値データ

Dst: レジスタ直接

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 0 0 0 0 1 0   | C2H |  |
|     | n n               | nn  |  |
|     | m m               | mm  |  |
| フラグ | I1 I0 U D N V C Z |     |  |
|     | - - - - ↑ ↑ ↑ ↑   |     |  |

| 例     | 設定値   |       | 結果 |    |   |   |
|-------|-------|-------|----|----|---|---|
|       | IX    | mmnn  | IX | SC |   |   |
|       |       |       |    | N  | V | C |
| 1380H | 3546H | 48C6H | 0  | 0  | 0 | 0 |
| 1380H | EC80H | 0000H | 0  | 0  | 1 | 1 |
| 5218H | 4174H | 938CH | 1  | 1  | 0 | 0 |
| 5342H | C32AH | 166CH | 0  | 0  | 1 | 0 |

**ADD IY, rp** //// Add rp reg. to IY reg. //// 4 cycle //

機能 IY IY + rp

rpレジスタ(BA/HL)の内容をIYレジスタに加えます。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB               | LSB      |  |
|-----|-------------------|----------|--|
|     | 1 1 0 0 1 1 1 1   | CFH      |  |
|     | 0 1 0 0 0 0 1 rp  | 42H, 43H |  |
|     | rp ニーモニック コード     |          |  |
|     | BA 0 ADD IY, BA   | 42H      |  |
|     | HL 1 ADD IY, HL   | 43H      |  |
| フラグ | I1 I0 U D N V C Z |          |  |
|     | - - - - ↑ ↑ ↑ ↑   |          |  |

| 例     | 設定値   |       | 結果 |    |   |   |
|-------|-------|-------|----|----|---|---|
|       | IY    | rp    | IY | SC |   |   |
|       |       |       |    | N  | V | C |
| 1380H | 3546H | 48C6H | 0  | 0  | 0 | 0 |
| 1380H | EC80H | 0000H | 0  | 0  | 1 | 1 |
| 5218H | 4174H | 938CH | 1  | 1  | 0 | 0 |
| 5342H | C32AH | 166CH | 0  | 0  | 1 | 0 |

**ADD IY, #mmnn** //// Add immediate data mmnn to IY reg. //// 3 cycle //

機能 IY IY + mmnn

16ビット即値データmmnnをIYレジスタに加えます。

モード Src: 即値データ

Dst: レジスタ直接

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 0 0 0 0 1 1   | C3H |  |
|     | n n               | nn  |  |
|     | m m               | mm  |  |
| フラグ | I1 I0 U D N V C Z |     |  |
|     | - - - - ↑ ↑ ↑ ↑   |     |  |

| 例     | 設定値   |       | 結果 |    |   |   |
|-------|-------|-------|----|----|---|---|
|       | IY    | mmnn  | IY | SC |   |   |
|       |       |       |    | N  | V | C |
| 1380H | 3546H | 48C6H | 0  | 0  | 0 | 0 |
| 1380H | EC80H | 0000H | 0  | 0  | 1 | 1 |
| 5218H | 4174H | 938CH | 1  | 1  | 0 | 0 |
| 5342H | C32AH | 166CH | 0  | 0  | 1 | 0 |

**ADD SP, rp** /////////////// Add rp reg. to SP /////////////// 4 cycle //

機能 SP SP + rp

rpレジスタ(BA/HL)の内容をスタックポインタ  
(SP)に加えます。

| コード | MSB              | LSB        |     |
|-----|------------------|------------|-----|
|     | 1 1 0 0 1 1 1 1  | CFH        |     |
|     | 0 1 0 0 0 1 0 rp | 44H, 45H   |     |
|     | rp               | ニーモニック     | コード |
| BA  | 0                | ADD SP, BA | 44H |
| HL  | 1                | ADD SP, HL | 45H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: レジスタ直接

Dst: レジスタ直接

| 例     | 設定値   |       | 結果 |    |   |   |
|-------|-------|-------|----|----|---|---|
|       | SP    | rp    | SP | SC |   |   |
|       |       |       |    | N  | V | C |
| 1380H | 3546H | 48C6H | 0  | 0  | 0 | 0 |
| 1380H | EC80H | 0000H | 0  | 0  | 1 | 1 |
| 5218H | 4174H | 938CH | 1  | 1  | 0 | 0 |
| 5342H | C32AH | 166CH | 0  | 0  | 1 | 0 |

**ADD SP, #mmnn** /////////////// Add immediate data mmnn to SP /////////////// 4 cycle //

機能 SP SP + mmnn

16ビット即値データmmnnをスタックポインタ  
(SP)に加えます。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 1 | CFH |  |
|     | 0 1 1 0 1 0 0 0 | 68H |  |
|     | n n             | nn  |  |
|     | m m             | mm  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: 即値データ

Dst: レジスタ直接

| 例     | 設定値   |       | 結果 |    |   |   |
|-------|-------|-------|----|----|---|---|
|       | SP    | mmnn  | SP | SC |   |   |
|       |       |       |    | N  | V | C |
| 1380H | 3546H | 48C6H | 0  | 0  | 0 | 0 |
| 1380H | EC80H | 0000H | 0  | 0  | 1 | 1 |
| 5218H | 4174H | 938CH | 1  | 1  | 0 | 0 |
| 5342H | C32AH | 166CH | 0  | 0  | 1 | 0 |

**AND A, r** /////////////// Logical AND of r reg. and A reg. /////////////// 2 cycle //機能 A A  $\wedge$  rrレジスタ(A/B)の内容とAレジスタの内容との論  
理積をとり、結果をAレジスタにストアします。

| コード | MSB             | LSB      |     |
|-----|-----------------|----------|-----|
|     | 0 0 1 0 0 0 0 r | 20H, 21H |     |
|     | r               | ニーモニック   | コード |
| A   | 0               | AND A, A | 20H |
| B   | 1               | AND A, B | 21H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

モード Src: レジスタ直接

Dst: レジスタ直接

| 例   | 設定値 |     | 結果 |    |   |   |
|-----|-----|-----|----|----|---|---|
|     | A   | B   | A  | SC |   |   |
|     |     |     |    | N  | V | C |
| 3BH | 61H | 21H | 0  | —  | — | 0 |
| 5AH | A5H | 00H | 0  | —  | — | 1 |
| D6H | 93H | 92H | 1  | —  | — | 0 |

**AND A, #nn** ////////////////////////////////////////////////////////////////// Logical AND of immediate data nn and A reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** A A  $\wedge$  nn

8ビット即値データnnとAレジスタの内容との論理積をとり、結果をAレジスタにストアします。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 0 1 0 0 0 1 0 | 22H |  |
|     | n n             |     |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |   |   |   |
|---|-----|-----|-----|----|---|---|---|
|   | A   | nn  | A   | SC |   |   |   |
|   |     |     |     | N  | V | C | Z |
|   | 3BH | 61H | 21H | 0  | — | — | 0 |
|   | 5AH | A5H | 00H | 0  | — | — | 1 |
|   | D6H | 93H | 92H | 1  | — | — | 0 |

**AND A, [BR:ll]** ////////////////////////////////////////////////////////////////// Logical AND of location [BR:ll] and A reg. ////////////////////////////////////////////////////////////////// 3 cycle //**機能** A A  $\wedge$  [BR:ll]

BRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されるデータメモリの内容とAレジスタの内容との論理積をとり、結果をAレジスタにストアします。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 0 1 0 0 1 0 0 | 24H |  |
|     | l l             |     |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: 8ビット絶対

Dst: レジスタ直接

| 例 | 設定値 |         | 結果  |    |   |   |   |
|---|-----|---------|-----|----|---|---|---|
|   | A   | [BR:ll] | A   | SC |   |   |   |
|   |     |         |     | N  | V | C | Z |
|   | 3BH | 61H     | 21H | 0  | — | — | 0 |
|   | 5AH | A5H     | 00H | 0  | — | — | 1 |
|   | D6H | 93H     | 92H | 1  | — | — | 0 |

**AND A, [hhll]** ////////////////////////////////////////////////////////////////// Logical AND of location [hhll] and A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A A  $\wedge$  [hhll]

16ビット絶対アドレスhh//でアドレス指定されたデータメモリの内容とAレジスタの内容との論理積をとり、結果をAレジスタにストアします。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 0 1 0 0 1 0 1 | 25H |  |
|     | l l             |     |  |
|     | h h             |     |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: 16ビット絶対

Dst: レジスタ直接

| 例 | 設定値 |        | 結果  |    |   |   |   |
|---|-----|--------|-----|----|---|---|---|
|   | A   | [hhll] | A   | SC |   |   |   |
|   |     |        |     | N  | V | C | Z |
|   | 3BH | 61H    | 21H | 0  | — | — | 0 |
|   | 5AH | A5H    | 00H | 0  | — | — | 1 |
|   | D6H | 93H    | 92H | 1  | — | — | 0 |

**AND A, [HL]** ////////////////////////////////////////////////////////////////// Logical AND of location [HL] and A reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** A A  $\wedge$  [HL]

HLレジスタでアドレス指定されたデータメモリの内容とAレジスタの内容との論理積をとり、結果をAレジスタにストアします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 0 1 0 0 0 1 1 | 23H |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: レジスタ間接

Dst: レジスタ直接

| 例   |      | 設定値 |    | 結果 |   |   |  |
|-----|------|-----|----|----|---|---|--|
| A   | [HL] | A   | SC |    |   |   |  |
|     |      |     | N  | V  | C | Z |  |
| 3BH | 61H  | 21H | 0  | —  | — | 0 |  |
| 5AH | A5H  | 00H | 0  | —  | — | 1 |  |
| D6H | 93H  | 92H | 1  | —  | — | 0 |  |

**AND A, [ir]** ////////////////////////////////////////////////////////////////// Logical AND of location [ir reg.] and A reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** A A  $\wedge$  [ir]

irレジスタ(IX/IY)でアドレス指定されたデータメモリの内容とAレジスタの内容との論理積をとり、結果をAレジスタにストアします。

XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB      |  |
|-----|------------------|----------|--|
|     | 0 0 1 0 0 1 1 ir | 26H, 27H |  |

| ir   | ニーモニック      | コード |
|------|-------------|-----|
| IX 0 | AND A, [IX] | 26H |
| IY 1 | AND A, [IY] | 27H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: レジスタ間接

Dst: レジスタ直接

| 例   |      | 設定値 |    | 結果 |   |   |  |
|-----|------|-----|----|----|---|---|--|
| A   | [ir] | A   | SC |    |   |   |  |
|     |      |     | N  | V  | C | Z |  |
| 3BH | 61H  | 21H | 0  | —  | — | 0 |  |
| 5AH | A5H  | 00H | 0  | —  | — | 1 |  |
| D6H | 93H  | 92H | 1  | —  | — | 0 |  |

**AND A, [ir+dd]** ////////////////////////////////////////////////////////////////// Logical AND of location [ir reg. + dd] and A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A A  $\wedge$  [ir+dd]

irレジスタ(IX/IY)の内容とディスプレースメントddの和でアドレス指定されたデータメモリの内容とAレジスタの内容との論理積をとり、結果をAレジスタにストアします。ddは符号付きデータとして扱われ、範囲は-128~127です。

XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB      |  |
|-----|------------------|----------|--|
|     | 1 1 0 0 1 1 1 0  | CEH      |  |
|     | 0 0 1 0 0 0 0 ir | 20H, 21H |  |

dd

| ir   | ニーモニック         | コード |
|------|----------------|-----|
| IX 0 | AND A, [IX+dd] | 20H |
| IY 1 | AND A, [IY+dd] | 21H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ直接

| 例   |         | 設定値 |    | 結果 |   |   |  |
|-----|---------|-----|----|----|---|---|--|
| A   | [ir+dd] | A   | SC |    |   |   |  |
|     |         |     | N  | V  | C | Z |  |
| 3BH | 61H     | 21H | 0  | —  | — | 0 |  |
| 5AH | A5H     | 00H | 0  | —  | — | 1 |  |
| D6H | 93H     | 92H | 1  | —  | — | 0 |  |

**AND A, [ir+L]** ////////////////////////////////////////////////////////////////// Logical AND of location [ir reg. + L] and A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A A  $\wedge$  [ir+L]

irレジスタ(IX/IY)の内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容とAレジスタの内容との論理積をとり、結果をAレジスタにストアします。  
 Lレジスタの内容は符号付きデータとして扱われ、範囲は-128 ~ 127です。  
 XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: インデックスレジスタ付きレジスタ間接  
 Dst: レジスタ直接

| A   | [ir+L] | A   | 設定値 |   |   |   | 結果      |   |   |   |
|-----|--------|-----|-----|---|---|---|---------|---|---|---|
|     |        |     | SC  |   |   |   | N V C Z |   |   |   |
|     |        |     | N   | V | C | Z | N       | V | C | Z |
| 3BH | 61H    | 21H | 0   | — | — | 0 |         |   |   |   |
| 5AH | A5H    | 00H | 0   | — | — | 1 |         |   |   |   |
| D6H | 93H    | 92H | 1   | — | — | 0 |         |   |   |   |

| コード | MSB              | LSB           |     |
|-----|------------------|---------------|-----|
|     | 1 1 0 0 1 1 1 0  | CEH           |     |
|     | 0 0 1 0 0 0 1 ir | 22H, 23H      |     |
|     | ir               | ニーモニック        | コード |
|     | IX 0             | AND A, [IX+L] | 22H |
|     | IY 1             | AND A, [IY+L] | 23H |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**AND B, #nn** ////////////////////////////////////////////////////////////////// Logical AND of immediate data nn and B reg. ////////////////////////////////////////////////////////////////// 3 cycle //**機能** B B  $\wedge$  nn

8ビット即値データnnとBレジスタの内容との論理積をとり、結果をBレジスタにストアします。

**モード** Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 0 1 1 0 0 0 0 | B0H |  |
|     | n n             | nn  |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

| B   | nn  | B   | 設定値 |   |   |   | 結果      |   |   |   |
|-----|-----|-----|-----|---|---|---|---------|---|---|---|
|     |     |     | SC  |   |   |   | N V C Z |   |   |   |
|     |     |     | N   | V | C | Z | N       | V | C | Z |
| 3BH | 61H | 21H | 0   | — | — | 0 |         |   |   |   |
| 5AH | A5H | 00H | 0   | — | — | 1 |         |   |   |   |
| D6H | 93H | 92H | 1   | — | — | 0 |         |   |   |   |

**AND L, #nn** ////////////////////////////////////////////////////////////////// Logical AND of immediate data nn and L reg. ////////////////////////////////////////////////////////////////// 3 cycle //**機能** L L  $\wedge$  nn

8ビット即値データnnとLレジスタの内容との論理積をとり、結果をLレジスタにストアします。

**モード** Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 0 1 1 0 0 0 1 | B1H |  |
|     | n n             | nn  |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

| L   | nn  | L   | 設定値 |   |   |   | 結果      |   |   |   |
|-----|-----|-----|-----|---|---|---|---------|---|---|---|
|     |     |     | SC  |   |   |   | N V C Z |   |   |   |
|     |     |     | N   | V | C | Z | N       | V | C | Z |
| 3BH | 61H | 21H | 0   | — | — | 0 |         |   |   |   |
| 5AH | A5H | 00H | 0   | — | — | 1 |         |   |   |   |
| D6H | 93H | 92H | 1   | — | — | 0 |         |   |   |   |

**AND H, #nn** ////////////// Logical AND of immediate data nn and H reg. ////////////// 3 cycle //**機能** H H  $\wedge$  nn

8ビット即値データnnとHレジスタの内容との論理積をとり、結果をHレジスタにストアします。

| コード | MSB | LSB |     |
|-----|-----|-----|-----|
|     |     |     | CEH |
|     |     |     | B2H |
|     |     |     | nn  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例   |     | 設定値 |    | 結果 |   |   |  |
|-----|-----|-----|----|----|---|---|--|
| H   | nn  | H   | SC |    |   |   |  |
|     |     |     | N  | V  | C | Z |  |
| 3BH | 61H | 21H | 0  | —  | — | 0 |  |
| 5AH | A5H | 00H | 0  | —  | — | 1 |  |
| D6H | 93H | 92H | 1  | —  | — | 0 |  |

**AND SC, #nn** ////////////// Logical AND of immediate data nn and SC ////////////// 3 cycle //**機能** SC SC  $\wedge$  nn

8ビット即値データnnとシステムコンディションフラグ(SC)の内容との論理積をとり、結果をシステムコンディションフラグ(SC)にセットします。

| コード | MSB | LSB |     |
|-----|-----|-----|-----|
|     |     |     | 9CH |
|     |     |     | nn  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | ↓  | ↓  | ↓ | ↓ | ↓ | ↓ | ↓ | ↓ |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例   |     | 設定値 |    | 結果 |   |   |   |   |
|-----|-----|-----|----|----|---|---|---|---|
| SC  | nn  | SC  | SC |    |   |   |   |   |
|     |     |     | I1 | I0 | U | D | N | Z |
| 3BH | 61H | 21H | 0  | 0  | 1 | 0 | 0 | 0 |
| 5AH | A5H | 00H | 0  | 0  | 0 | 0 | 0 | 0 |
| D6H | 93H | 92H | 1  | 0  | 0 | 1 | 0 | 0 |

**AND [BR:ll], #nn** // Logical AND of immediate data nn and location [BR:ll] ////////////// 5 cycle //**機能** [BR:ll] [BR:ll]  $\wedge$  nn

8ビット即値データnnとBRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されるデータメモリの内容との論理積をとり、結果をそのアドレスにストアします。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB | LSB |     |
|-----|-----|-----|-----|
|     |     |     | D8H |
|     |     |     | ll  |
|     |     |     | nn  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: 即値データ

Dst: 8ビット絶対

| 例       |     | 設定値     |    | 結果 |   |   |  |
|---------|-----|---------|----|----|---|---|--|
| [BR:ll] | nn  | [BR:ll] | SC |    |   |   |  |
|         |     |         | N  | V  | C | Z |  |
| 3BH     | 61H | 21H     | 0  | —  | — | 0 |  |
| 5AH     | A5H | 00H     | 0  | —  | — | 1 |  |
| D6H     | 93H | 92H     | 1  | —  | — | 0 |  |

**AND [HL], A** // Logical AND of A reg. and location [HL] // 4 cycle //**機能** [HL] [HL]  $\wedge$  A

Aレジスタの内容とHLレジスタでアドレス指定されたデータメモリの内容との論理積をとり、結果をそのアドレスにストアします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 0 1 0 0 1 0 0 | 24H |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: レジスタ直接

Dst: レジスタ間接

| 例 | 設定値  |     | 結果   |    |   |   |   |
|---|------|-----|------|----|---|---|---|
|   | [HL] | A   | [HL] | SC |   |   |   |
|   |      |     |      | N  | V | C | Z |
|   | 3BH  | 61H | 21H  | 0  | — | — | 0 |
|   | 5AH  | A5H | 00H  | 0  | — | — | 1 |
|   | D6H  | 93H | 92H  | 1  | — | — | 0 |

**AND [HL], #nn** // Logical AND of immediate data nn and location [HL] // 5 cycle //**機能** [HL] [HL]  $\wedge$  nn

8ビット即値データnnとHLレジスタでアドレス指定されたデータメモリの内容との論理積をとり、結果をそのアドレスにストアします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 0 1 0 0 1 0 1 | 25H |  |
|     | n n             | nn  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: 即値データ

Dst: レジスタ間接

| 例 | 設定値  |     | 結果   |    |   |   |   |
|---|------|-----|------|----|---|---|---|
|   | [HL] | nn  | [HL] | SC |   |   |   |
|   |      |     |      | N  | V | C | Z |
|   | 3BH  | 61H | 21H  | 0  | — | — | 0 |
|   | 5AH  | A5H | 00H  | 0  | — | — | 1 |
|   | D6H  | 93H | 92H  | 1  | — | — | 0 |

**AND [HL], [ir]** // Logical AND of location [ir reg.] and location [HL] // 5 cycle //**機能** [HL] [HL]  $\wedge$  [ir]

irレジスタ(IX/IY)とHLレジスタでそれぞれアドレス指定されたデータメモリの内容の論理積をとり、結果をデータメモリ[HL]にストアします。

EPレジスタの内容がデータメモリ[HL]のページアドレス、XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリ[ir]のページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |          |
|-----|-----------------|-----|----------|
|     | 1 1 0 0 1 1 1 0 | CEH |          |
|     | 0 0 1 0 0 1 1 1 | ir  | 26H, 27H |

| ir | ニーモニック | コード            |
|----|--------|----------------|
| IX | 0      | AND [HL], [IX] |
| IY | 1      | AND [HL], [IY] |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: レジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |      | 結果   |    |   |   |   |
|---|------|------|------|----|---|---|---|
|   | [HL] | [ir] | [HL] | SC |   |   |   |
|   |      |      |      | N  | V | C | Z |
|   | 3BH  | 61H  | 21H  | 0  | — | — | 0 |
|   | 5AH  | A5H  | 00H  | 0  | — | — | 1 |
|   | D6H  | 93H  | 92H  | 1  | — | — | 0 |

**BIT A, B** ////////////////////////////////////////////////////////////////// Test bit of A reg. with B reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** A  $\wedge$  B

Bレジスタの内容とAレジスタの内容との論理積をとり、Aレジスタのビットをチェックします。その結果によりフラグ(N/Z)が変更されますが、レジスタの内容は変更されません。

**コード** MSB LSB  

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

 94H

**フラグ** I1 I0 U D N V C Z  

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| - | - | - | - | ↑ | - | - | ↑ |
|---|---|---|---|---|---|---|---|

**モード** Src: レジスタ直接

Dst: レジスタ直接

**例**

| A   | B   | A   | SC |   |   |   |
|-----|-----|-----|----|---|---|---|
|     |     |     | N  | V | C | Z |
| 3BH | 61H | 3BH | 0  | — | — | 0 |
| 5AH | A5H | 5AH | 0  | — | — | 1 |
| D6H | 93H | D6H | 1  | — | — | 0 |

**BIT A, #nn** ////////////////////////////////////////////////////////////////// Test bit of A reg. with immediate data nn ////////////////////////////////////////////////////////////////// 2 cycle //**機能** A  $\wedge$  nn

8ビット即値データnnとAレジスタの内容との論理積をとり、Aレジスタのビットをチェックします。その結果によりフラグ(N/Z)が変更されますが、レジスタの内容は変更されません。

**コード** MSB LSB  

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

 96H  

|   |   |  |  |
|---|---|--|--|
| n | n |  |  |
|---|---|--|--|

 nn

**フラグ** I1 I0 U D N V C Z  

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| - | - | - | - | ↑ | - | - | ↑ |
|---|---|---|---|---|---|---|---|

**モード** Src: 即値データ

Dst: レジスタ直接

**例**

| A   | nn  | A   | SC |   |   |   |
|-----|-----|-----|----|---|---|---|
|     |     |     | N  | V | C | Z |
| 3BH | 61H | 3BH | 0  | — | — | 0 |
| 5AH | A5H | 5AH | 0  | — | — | 1 |
| D6H | 93H | D6H | 1  | — | — | 0 |

**BIT B, #nn** ////////////////////////////////////////////////////////////////// Test bit of B reg. with immediate data nn ////////////////////////////////////////////////////////////////// 2 cycle //**機能** B  $\wedge$  nn

8ビット即値データnnとBレジスタの内容との論理積をとり、Bレジスタのビットをチェックします。その結果によりフラグ(N/Z)が変更されますが、レジスタの内容は変更されません。

**コード** MSB LSB  

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

 97H  

|   |   |  |  |
|---|---|--|--|
| n | n |  |  |
|---|---|--|--|

 nn

**フラグ** I1 I0 U D N V C Z  

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| - | - | - | - | ↑ | - | - | ↑ |
|---|---|---|---|---|---|---|---|

**モード** Src: 即値データ

Dst: レジスタ直接

**例**

| B   | nn  | B   | SC |   |   |   |
|-----|-----|-----|----|---|---|---|
|     |     |     | N  | V | C | Z |
| 3BH | 61H | 3BH | 0  | — | — | 0 |
| 5AH | A5H | 5AH | 0  | — | — | 1 |
| D6H | 93H | D6H | 1  | — | — | 0 |

**BIT [BR:ll], #nn** // Test bit of location [BR:ll] with immediate data nn ////////////// 4 cycle //**機能** [BR:ll]  $\wedge$  nn

8ビット即値データnnとBRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されるデータメモリの内容との論理積をとり、そのメモリのビットをチェックします。その結果によりフラグ(N/Z)が変更されますが、メモリの内容は変更されません。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: 即値データ

Dst: 8ビット絶対

| 例 | 設定値     |     | 結果      |    |   |   |   |
|---|---------|-----|---------|----|---|---|---|
|   | [BR:ll] | nn  | [BR:ll] | SC |   |   |   |
|   |         |     |         | N  | V | C |   |
|   | 3BH     | 61H | 3BH     | 0  | — | — | 0 |
|   | 5AH     | A5H | 5AH     | 0  | — | — | 1 |
|   | D6H     | 93H | D6H     | 1  | — | — | 0 |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 1 1 1 0 0 | DCH |  |
|     | l l             | ll  |  |
|     | n n             | nn  |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**BIT [HL], #nn** ////////////// Test bit of location [HL] with immediate data nn ////////////// 3 cycle //**機能** [HL]  $\wedge$  nn

8ビット即値データnnとHLレジスタでアドレス指定されるデータメモリの内容との論理積をとり、そのメモリのビットをチェックします。その結果によりフラグ(N/Z)が変更されますが、メモリの内容は変更されません。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: 即値データ

Dst: レジスタ間接

| 例 | 設定値  |     | 結果   |    |   |   |   |
|---|------|-----|------|----|---|---|---|
|   | [HL] | nn  | [HL] | SC |   |   |   |
|   |      |     |      | N  | V | C |   |
|   | 3BH  | 61H | 3BH  | 0  | — | — | 0 |
|   | 5AH  | A5H | 5AH  | 0  | — | — | 1 |
|   | D6H  | 93H | D6H  | 1  | — | — | 0 |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 0 0 1 0 1 0 1 | 95H |  |
|     | n n             | nn  |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**CALL [hhll]** // Call subroutine at location [hhll] // 7(MIN)/8(MAX) cycle //

## 機能

MODEL0/1  
 [SP-1] PC(H), [SP-2] PC(L), SP SP-2,  
 PC(L) [hhll], PC(H) [hhll+1]  
 MODEL2/3(ミニマムモード)  
 [SP-1] PC(H), [SP-2] PC(L), SP SP-2,  
 PC(L) [hhll], PC(H) [hhll+1], CB NB  
 MODEL2/3(マキシマムモード)  
 [SP-1] CB, [SP-2] PC(H), [SP-3] PC(L),  
 SP SP-3, PC(L) [hhll], PC(H) [hhll+1],  
 CB NB

本命令の先頭アドレス+3の値をリターンアドレスとしてスタックに退避後、サブルーチンを無条件にコールします。分岐先アドレス(サブルーチンの先頭アドレス)としては、16ビット絶対アドレスhhllで指定されたデータメモリの内容が下位バイト、その次のアドレスの内容が上位バイトとなります。

MODEL2/3のマキシマムモードでは、リターンアドレスの退避時に現在選択されているバンクアドレス(CBの内容)の退避も行われます。また、MODEL2/3では、分岐時にNBに設定されているバンクアドレスがCBにロードされ、バンクの変更も行われます。

EPレジスタの内容がデータメモリのページアドレスになります。

| コード             | MSB | LSB |
|-----------------|-----|-----|
| 1 1 1 1 1 0 1 1 |     | FBH |
| l l             |     | ll  |
| h h             |     | hh  |

| フラグ             | I1 | I0 | U | D | N | V | C | Z |
|-----------------|----|----|---|---|---|---|---|---|
| - - - - - - - - |    |    |   |   |   |   |   |   |

## モード 16ビット間接

例 MODEL2/3においてNB=02Hの場合、物理アドレス9000H番地にあるCALL [2000H]命令を実行。

|     | NB  | CB  | PC(論理アドレス) | EP  | M(032000H) | SP    |
|-----|-----|-----|------------|-----|------------|-------|
| 実行前 | 02H | 01H | 9000H      | 03H | ABCDH      | 0000H |
| 実行後 | 02H | 02H | ABCDH      | 03H | ABCDH      | FFF0H |

上記の例では物理アドレス012BCDHへ分岐します。MODEL0/1ではEPがないためM(2000H)の内容がPCに転送され、M(2000H)の内容がABCDHであればNB, CBもないため物理アドレスABCDHへ分岐します。

## 実行後のスタック内容

(1) MODEL2/3(マキシマムモード) (2) MODEL2/3(ミニマムモード)  
 MODEL0/1

|          |             |         |             |
|----------|-------------|---------|-------------|
| 00FFFFDH | 03H (PC(L)) | 00FFFEH | 03H (PC(L)) |
| 00FFFEH  | 90H (PC(H)) | 00FFFFH | 90H (PC(H)) |

**CARL qqrr** // Call subroutine at relative location qqrr // 5(MIN)/6(MAX) cycle //**機能** MODEL0/1

[SP-1] PC(H), [SP-2] PC(L), SP SP-2,  
PC PC+qqrr+2

MODEL2/3(ミニマムモード)

[SP-1] PC(H), [SP-2] PC(L), SP SP-2,  
PC PC+qqrr+2, CB NB

MODEL2/3(マキシマムモード)

[SP-1] CB, [SP-2] PC(H), [SP-3] PC(L),  
SP SP-3, PC PC+qqrr+2, CB NB

本命令の先頭アドレス+3の値をリターンアドレスとしてスタックに退避後、サブルーチンを無条件にコールします。分岐先(サブルーチンの先頭アドレス)は、本命令の先頭アドレス+2に符号付き16ビット相対アドレスqqrr(-32768 ~ 32767)を加算したアドレスになります。

MODEL2/3のマキシマムモードでは、リターンアドレスの退避時に現在選択されているバンクアドレス(CBの内容)の退避も行われます。また、MODEL2/3では、分岐時にNBに設定されているバンクアドレスがCBにロードされ、バンクの変更も行われます。

**CARL cc1, qqrr** // Call subroutine at relative location qqrr if condition cc1 is true //**機能** MODEL0/1

If cc1 is true then CARL qqrr  
else PC PC+3

MODEL2/3

If cc1 is true then CARL qqrr  
else PC PC+3, NB CB

条件cc1が成立している場合に"CARL qqrr"命令を実行し、条件不成立の場合は次の命令を実行します。

☞ "CARL qqrr"命令

MODEL2/3では、分岐先バンクを指定するNBの内容が条件不成立の場合に現在のバンクアドレス(CBの内容)に戻されます。

条件cc1は以下の4種類です。

| cc1 | 条件                     |
|-----|------------------------|
| C   | Carry (キャリーフラグC=1)     |
| NC  | Non Carry (キャリーフラグC=0) |
| Z   | Zero (ゼロフラグZ=1)        |
| NZ  | Non Zero (ゼロフラグZ=0)    |

バスサイクルはミニマムモード/マキシマムモード、条件成立/不成立により以下のようになります。

| モード   | 条件  | バスサイクル  |
|-------|-----|---------|
| ミニマム  | 成立  | 5 cycle |
| ミニマム  | 不成立 | 3 cycle |
| マキシマム | 成立  | 6 cycle |
| マキシマム | 不成立 | 3 cycle |

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 1 1 0 0 1 0 | F2H |
|     | rr              | rr  |
|     | qq              | qq  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

モード 符号付き16ビットPC相対

例 MODEL2/3においてNB=02Hの場合、物理アドレス9000H番地にあるCARL \$+2000H命令を実行。

|     | NB  | CB  | PC(論理アドレス)      | SP     |
|-----|-----|-----|-----------------|--------|
| 実行前 | 02H | 01H | 9000H           | 0000H  |
|     |     |     | 9002H+(2000H-2) |        |
| 実行後 | 02H | 02H | B000H           | FFFDFH |

上記の例では物理アドレス013000Hへ分岐します。  
MODEL0/1ではNB, CBがないため物理アドレスB000Hへ分岐します。

実行後のスタック内容

(1) MODEL2/3(マキシマムモード) (2) MODEL2/3(ミニマムモード)

| 00FFFFDH | 03H (PC(L)) |
|----------|-------------|
| 00FFFEH  | 90H (PC(H)) |
| 00FFFFH  | 01H (CB)    |

  

| 00FFFEH | 03H (PC(L)) |
|---------|-------------|
| 00FFFFH | 90H (PC(H)) |

| コード | MSB             | LSB       |
|-----|-----------------|-----------|
|     | 1 1 1 0 1 0 cc1 | E8H ~ EBH |
|     | rr              | rr        |
|     | qq              | qq        |

| cc1   | ニーモニック       | コード |
|-------|--------------|-----|
| C 00  | CARL C,qqrr  | E8H |
| NC 01 | CARL NC,qqrr | E9H |
| Z 10  | CARL Z,qqrr  | EAH |
| NZ 11 | CARL NZ,qqrr | EBH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

モード 符号付き16ビットPC相対

例 条件成立時はCARL qqrr命令と同じ動作をします。条件不成立時、物理アドレス9000H番地のCARL cc1, qqrrの動作は下記のとおりです。スタックは行いません。

|     | NB  | CB  | PC(論理アドレス) | SP    |
|-----|-----|-----|------------|-------|
| 実行前 | 02H | 01H | 9000H      | 0000H |
|     |     |     | 9003H      | 0000H |

MODEL0/1ではNB, CBはありません。

**CARS rr** // Call subroutine at relative location rr // 4(MIN)/5(MAX) cycle //**機能** MODEL0/1

[SP-1] PC(H), [SP-2] PC(L), SP SP-2,  
PC PC+rr+1

## MODEL2/3(ミニマムモード)

[SP-1] PC(H), [SP-2] PC(L), SP SP-2,  
PC PC+rr+1, CB NB

## MODEL2/3(マキシマムモード)

[SP-1] CB, [SP-2] PC(H), [SP-3] PC(L),  
SP SP-3, PC PC+rr+1, CB NB

本命令の先頭アドレス+2の値をリターンアドレスとしてスタックに退避後、サブルーチンを無条件にコールします。分岐先(サブルーチンの先頭アドレス)は、本命令の先頭アドレス+1に符号付き8ビット相対アドレスrr(-128~127)を加算したアドレスになります。

MODEL2/3のマキシマムモードでは、リターンアドレスの退避時に現在選択されているバンクアドレス(CBの内容)の退避も行われます。また、MODEL2/3では、分岐時にNBに設定されているバンクアドレスがCBにロードされ、バンクの変更も行われます。

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 1 1 0 0 0 0 | F0H |
|     | r r             | rr  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**モード** 符号付き8ビットPC相対

**例** MODEL2/3においてNB=02Hの場合、物理アドレス9000H番地にあるCARS \$+20H命令を実行。

|     | NB  | CB  | PC(論理アドレス)    | SP    |
|-----|-----|-----|---------------|-------|
| 実行前 | 02H | 01H | 9000H         | 0000H |
|     |     |     | 9001H+(20H-1) |       |
| 実行後 | 02H | 02H | 9020H         | FFFDH |

上記の例では物理アドレス011020Hへ分岐します。MODEL0/1ではNB, CBがないため物理アドレス9020Hへ分岐します。

## 実行後のスタック内容

(1) MODEL2/3(マキシマムモード) (2) MODEL2/3(ミニマムモード)

|         |             |         |             |
|---------|-------------|---------|-------------|
| 00FFFDH | 02H (PC(L)) | 00FFFEH | 02H (PC(L)) |
| 00FFFEH | 90H (PC(H)) | 00FFFFH | 90H (PC(H)) |
| 00FFFFH | 01H (CB)    |         |             |

**CARS cc1, rr** // Call subroutine at relative location rr if condition cc1 is true //**機能** MODEL0/1

If cc1 is true then CARS rr  
else PC PC+2

## MODEL2/3

If cc1 is true then CARS rr  
else PC PC+2, NB CB

条件cc1が成立している場合に"CARS rr"命令を実行し、条件不成立の場合は次の命令を実行します。

☞ "CARS rr"命令

MODEL2/3のマキシマムモードでは、分岐先バンクを指定するNBの内容が条件不成立の場合に現在のバンクアドレス(CBの内容)に戻されます。

条件cc1は以下の4種類です。

| cc1 | 条件                     |
|-----|------------------------|
| C   | Carry (キャリーフラグC=1)     |
| NC  | Non Carry (キャリーフラグC=0) |
| Z   | Zero (ゼロフラグZ=1)        |
| NZ  | Non Zero (ゼロフラグZ=0)    |

バスサイクルはミニマムモード/マキシマムモード、条件成立/不成立により以下のようにになります。

| モード   | 条件  | バスサイクル  |
|-------|-----|---------|
| ミニマム  | 成立  | 4 cycle |
| ミニマム  | 不成立 | 2 cycle |
| マキシマム | 成立  | 5 cycle |
| マキシマム | 不成立 | 2 cycle |

| コード | MSB             | LSB       |
|-----|-----------------|-----------|
|     | 1 1 1 0 0 0 cc1 | E0H ~ E3H |
|     | r r             | rr        |

| cc1   | ニーモニック     | コード |
|-------|------------|-----|
| C 00  | CARS C,rr  | E0H |
| NC 01 | CARS NC,rr | E1H |
| Z 10  | CARS Z,rr  | E2H |
| NZ 11 | CARS NZ,rr | E3H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**モード** 符号付き8ビットPC相対

**例** 条件成立時はCARS rr命令と同じ動作をします。条件不成立時、物理アドレス9000H番地のCARS cc1, rrの動作は下記のとおりです。スタックは行いません。

|     | NB  | CB  | PC(論理アドレス)    | SP    |
|-----|-----|-----|---------------|-------|
| 実行前 | 02H | 01H | 9000H         | 0000H |
|     |     |     | 9001H+(cc1-1) |       |
| 実行後 | 01H | 01H | 9002H         | 0000H |

MODEL0/1ではNB, CBはありません。

**CARS cc2, rr** ////////////// Call subroutine at relative location rr if condition cc2 is true //////////////**機能** MODEL0/1

If cc2 is true

then [SP-1] PC(H), [SP-2] PC(L),  
 SP SP-2, PC PC+rr+2  
 else PC PC+3

MODEL2/3(ミニマムモード)

If cc2 is true

then [SP-1] PC(H), [SP-2] PC(L),  
 SP SP-2, PC PC+rr+2,  
 CB NB

else PC PC+3, NB CB

MODEL2/3(マキシマムモード)

If cc2 is true

then [SP-1] CB, [SP-2] PC(H),  
 [SP-3] PC(L), SP SP-3,  
 PC PC+rr+2, CB NB

else PC PC+3, NB CB

条件cc2が成立している場合に本命令の先頭アドレス+3の値をリターンアドレスとしてスタックに退避後、サブルーチンをコールします。分岐先(サブルーチンの先頭アドレス)は、本命令の先頭アドレス+2に符号付き8ビット相対アドレスrr(-128~127)を加算したアドレスになります。

条件不成立の場合は次の命令を実行します。

MODEL2/3のマキシマムモードでは、リターンアドレスの退避時に現在選択されているバンクアドレス(CBの内容)の退避も行われます。また、MODEL2/3では、分岐時にNBに設定されているバンクアドレスがCBにロードされ、バンクの変更も行われます。

条件不成立の場合には、NBの内容が現在のバンクアドレス(CBの内容)に戻されます。

条件cc2は以下の16種類です。

| cc2 | 条件                                           |
|-----|----------------------------------------------|
| LT  | Less Than ( $[N \forall V] = 1$ )            |
| LE  | Less or Equal ( $Z \vee [N \forall V] = 1$ ) |
| GT  | Greater Than ( $Z \vee [N \forall V] = 0$ )  |
| GE  | Greater or Equal ( $[N \forall V] = 0$ )     |
| V   | Overflow ( $V = 1$ )                         |
| NV  | Non Overflow ( $V = 0$ )                     |
| P   | Plus ( $N = 0$ )                             |
| M   | Minus ( $N = 1$ )                            |
| F0  | F0 is set ( $F0 = 1$ )                       |
| F1  | F1 is set ( $F1 = 1$ )                       |
| F2  | F2 is set ( $F2 = 1$ )                       |
| F3  | F3 is set ( $F3 = 1$ )                       |
| NF0 | F0 is reset ( $F0 = 0$ )                     |
| NF1 | F1 is reset ( $F1 = 0$ )                     |
| NF2 | F2 is reset ( $F2 = 0$ )                     |
| NF3 | F3 is reset ( $F3 = 0$ )                     |

バスサイクルはミニマムモード/マキシマムモード、条件成立/不成立により以下のようになります。

| モード   | 条件  | バスサイクル  |
|-------|-----|---------|
| ミニマム  | 成立  | 5 cycle |
| ミニマム  | 不成立 | 3 cycle |
| マキシマム | 成立  | 6 cycle |
| マキシマム | 不成立 | 3 cycle |

| コード | MSB     | LSB       |
|-----|---------|-----------|
|     | 1 1 0 0 | 1 1 1 0   |
|     | CEH     |           |
|     | 1 1 1 1 | cc2       |
|     |         | F0H ~ FFH |
|     | r r     | rr        |

| cc2      | ニーモニック      | コード |
|----------|-------------|-----|
| LT 0000  | CARS LT,rr  | F0H |
| LE 0001  | CARS LE,rr  | F1H |
| GT 0010  | CARS GT,rr  | F2H |
| GE 0011  | CARS GE,rr  | F3H |
| V 0100   | CARS V,rr   | F4H |
| NV 0101  | CARS NV,rr  | F5H |
| P 0110   | CARS P,rr   | F6H |
| M 0111   | CARS M,rr   | F7H |
| F0 1000  | CARS F0,rr  | F8H |
| F1 1001  | CARS F1,rr  | F9H |
| F2 1010  | CARS F2,rr  | FAH |
| F3 1011  | CARS F3,rr  | FBH |
| NF0 1100 | CARS NF0,rr | FCH |
| NF1 1101 | CARS NF1,rr | FDH |
| NF2 1110 | CARS NF2,rr | FEH |
| NF3 1111 | CARS NF3,rr | FFH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

モード 符号付き8ビットPC相対

**例** MODEL2/3においてNB=02Hの場合、条件成立時の物理アドレス9000H番地にあるCARS cc2, \$+20Hの動作は下記のとおりです。

|     | NB  | CB  | PC(論理アドレス)    | SP    |
|-----|-----|-----|---------------|-------|
| 実行前 | 02H | 01H | 9000H         | 0000H |
|     |     |     | 9002H+(20H-2) |       |
| 実行後 | 02H | 02H | 9020H         | FFFDH |

上記の例では物理アドレス011020Hへ分岐します。  
MODEL0/1ではNB, CBがないため物理アドレス9020Hへ分岐します。

条件不成立時、物理アドレス9000H番地のCARS cc2, \$+20Hの動作は下記のとおりです。スタックは行いません。

|     | NB  | CB  | PC(論理アドレス) | SP    |
|-----|-----|-----|------------|-------|
| 実行前 | 02H | 01H | 9000H      | 0000H |
|     |     |     | 9003H      | 0000H |
| 実行後 | 01H | 01H | 9003H      | 0000H |

MODEL0/1ではNB, CBはありません。

#### 実行後のスタック内容

(1) MODEL2/3(マキシマムモード) (2) MODEL2/3(ミニマムモード)  
MODEL0/1

|          |             |
|----------|-------------|
| 00FFFFDH | 03H (PC(L)) |
| 00FFFEH  | 90H (PC(H)) |
| 00FFFFH  | 01H (CB)    |

  

|         |             |
|---------|-------------|
| 00FFFEH | 03H (PC(L)) |
| 00FFFFH | 90H (PC(H)) |

**CP A, r** /////////////////////////////////////////////////////////////////// Compare r reg. with A reg. /////////////////////////////////////////////////////////////////// 2 cycle //

機能 A - r

Aレジスタの内容からrレジスタ(A/B)の内容を減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。Aレジスタの内容は変更されません。

| コード | MSB             | LSB     |          |
|-----|-----------------|---------|----------|
|     | 0 0 1 1 0 0 0 r |         | 30H, 31H |
|     | r               | ニーモニック  | コード      |
| A   | 0               | CP A, A | 30H      |
| B   | 1               | CP A, B | 31H      |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: レジスタ直接

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |   |   |   |
|---|-----|-----|-----|----|---|---|---|
|   | A   | B   | A   | SC |   |   |   |
|   |     |     |     | N  | V | C | Z |
|   | 74H | 2AH | 74H | 0  | 0 | 0 | 0 |
|   | 1DH | 1DH | 1DH | 0  | 0 | 0 | 1 |
|   | 3CH | 59H | 3CH | 1  | 0 | 1 | 0 |
|   | C3H | 62H | C3H | 0  | 1 | 0 | 0 |

**CP A, #nn** /////////////////////////////////////////////////////////////////// Compare immediate data nn with A reg. /////////////////////////////////////////////////////////////////// 2 cycle //

機能 A - nn

Aレジスタの内容から8ビット即値データnnを減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。Aレジスタの内容は変更されません。

| コード | MSB             | LSB |     |
|-----|-----------------|-----|-----|
|     | 0 0 1 1 0 0 1 0 |     | 32H |
|     | n n             |     | nn  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |   |   |   |
|---|-----|-----|-----|----|---|---|---|
|   | A   | nn  | A   | SC |   |   |   |
|   |     |     |     | N  | V | C | Z |
|   | 74H | 2AH | 74H | 0  | 0 | 0 | 0 |
|   | 1DH | 1DH | 1DH | 0  | 0 | 0 | 1 |
|   | 3CH | 59H | 3CH | 1  | 0 | 1 | 0 |
|   | C3H | 62H | C3H | 0  | 1 | 0 | 0 |

**CP A, [BR:lI]** /////////////////////////////////////////////////////////////////// Compare location [BR:lI] with A reg. /////////////////////////////////////////////////////////////////// 3 cycle //

機能 A - [BR:lI]

Aレジスタの内容からBRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されるデータメモリの内容を減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。Aレジスタの内容は変更されません。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |     |
|-----|-----------------|-----|-----|
|     | 0 0 1 1 0 1 0 0 |     | 34H |
|     | l l             |     | ll  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: 8ビット絶対

Dst: レジスタ直接

| 例 | 設定値 |         | 結果  |    |   |   |   |
|---|-----|---------|-----|----|---|---|---|
|   | A   | [BR:lI] | A   | SC |   |   |   |
|   |     |         |     | N  | V | C | Z |
|   | 74H | 2AH     | 74H | 0  | 0 | 0 | 0 |
|   | 1DH | 1DH     | 1DH | 0  | 0 | 0 | 1 |
|   | 3CH | 59H     | 3CH | 1  | 0 | 1 | 0 |
|   | C3H | 62H     | C3H | 0  | 1 | 0 | 0 |

**CP A, [hhll]** ////////////////////////////////////////////////////////////////// Compare location [hhll] with A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A - [hhll]

Aレジスタの内容から16ビット絶対アドレスhhllでアドレス指定されたデータメモリの内容を減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。Aレジスタの内容は変更されません。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 0 1 1 0 1 0 1 | 35H |  |
|     | l l             | ll  |  |
|     | h h             | hh  |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**モード** Src: 16ビット絶対

Dst: レジスタ直接

| A   | [hhll] | A   | 設定値 |   |   |   | 結果 |  |  |  |
|-----|--------|-----|-----|---|---|---|----|--|--|--|
|     |        |     | SC  |   |   |   |    |  |  |  |
|     |        |     | N   | V | C | Z |    |  |  |  |
| 74H | 2AH    | 74H | 0   | 0 | 0 | 0 |    |  |  |  |
| 1DH | 1DH    | 1DH | 0   | 0 | 0 | 1 |    |  |  |  |
| 3CH | 59H    | 3CH | 1   | 0 | 1 | 0 |    |  |  |  |
| C3H | 62H    | C3H | 0   | 1 | 0 | 0 |    |  |  |  |

**CP A, [HL]** ////////////////////////////////////////////////////////////////// Compare location [HL] with A reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** A - [HL]

Aレジスタの内容からHLレジスタでアドレス指定されたデータメモリの内容を減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。Aレジスタの内容は変更されません。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 0 1 1 0 0 1 1 | 33H |  |
|     | h h             | hh  |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**モード** Src: レジスタ間接

Dst: レジスタ直接

| A   | [HL] | A   | 設定値 |   |   |   | 結果 |  |  |  |
|-----|------|-----|-----|---|---|---|----|--|--|--|
|     |      |     | SC  |   |   |   |    |  |  |  |
|     |      |     | N   | V | C | Z |    |  |  |  |
| 74H | 2AH  | 74H | 0   | 0 | 0 | 0 |    |  |  |  |
| 1DH | 1DH  | 1DH | 0   | 0 | 0 | 1 |    |  |  |  |
| 3CH | 59H  | 3CH | 1   | 0 | 1 | 0 |    |  |  |  |
| C3H | 62H  | C3H | 0   | 1 | 0 | 0 |    |  |  |  |

**CP A, [ir]** ////////////////////////////////////////////////////////////////// Compare location [ir reg.] with A reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** A - [ir]

Aレジスタの内容からirレジスタ(IX/IY)でアドレス指定されたデータメモリの内容を減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。Aレジスタの内容は変更されません。XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB      |  |
|-----|------------------|----------|--|
|     | 0 0 1 1 0 1 1 ir | 36H, 37H |  |

| ir   | ニーモニック     | コード |
|------|------------|-----|
| IX 0 | CP A, [IX] | 36H |
| IY 1 | CP A, [IY] | 37H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**モード** Src: レジスタ間接

Dst: レジスタ直接

| A   | [ir] | A   | 設定値 |   |   |   | 結果 |  |  |  |
|-----|------|-----|-----|---|---|---|----|--|--|--|
|     |      |     | SC  |   |   |   |    |  |  |  |
|     |      |     | N   | V | C | Z |    |  |  |  |
| 74H | 2AH  | 74H | 0   | 0 | 0 | 0 |    |  |  |  |
| 1DH | 1DH  | 1DH | 0   | 0 | 0 | 1 |    |  |  |  |
| 3CH | 59H  | 3CH | 1   | 0 | 1 | 0 |    |  |  |  |
| C3H | 62H  | C3H | 0   | 1 | 0 | 0 |    |  |  |  |

**CP A, [ir+dd]** ////////////////////////////////////////////////////////////////// Compare location [ir reg. + dd] with A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A - [ir+dd]

Aレジスタの内容から、irレジスタ(IX/IY)の内容とディスプレースメントddの和でアドレス指定されたデータメモリの内容を減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。Aレジスタの内容は変更されません。  
ddは符号付きデータとして扱われ、範囲は-128～127です。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ直接

| 例 | 設定値 |         | 結果  |    |   |   |   |
|---|-----|---------|-----|----|---|---|---|
|   | A   | [ir+dd] | A   | SC |   |   |   |
|   |     |         |     | N  | V | C | Z |
|   | 74H | 2AH     | 74H | 0  | 0 | 0 | 0 |
|   | 1DH | 1DH     | 1DH | 0  | 0 | 0 | 1 |
|   | 3CH | 59H     | 3CH | 1  | 0 | 1 | 0 |
|   | C3H | 62H     | C3H | 0  | 1 | 0 | 0 |

| コード | MSB              | LSB           |     |
|-----|------------------|---------------|-----|
|     | 1 1 0 0 1 1 1 0  | CEH           |     |
|     | 0 0 1 1 0 0 0 ir | 30H、31H       |     |
|     | d d              | dd            |     |
|     | ir               | ニーモニック        | コード |
| IX  | 0                | CP A, [IX+dd] | 30H |
| IY  | 1                | CP A, [IY+dd] | 31H |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**CP A, [ir+L]** ////////////////////////////////////////////////////////////////// Compare location [ir reg. + L] and A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A - [ir+L]

Aレジスタの内容から、irレジスタ(IX/IY)の内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容を減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。Aレジスタの内容は変更されません。  
Lレジスタの内容は符号付きデータとして扱われ、範囲は-128～127です。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: インデックスレジスタ付きレジスタ間接

Dst: レジスタ直接

| 例 | 設定値 |        | 結果  |    |   |   |   |
|---|-----|--------|-----|----|---|---|---|
|   | A   | [ir+L] | A   | SC |   |   |   |
|   |     |        |     | N  | V | C | Z |
|   | 74H | 2AH    | 74H | 0  | 0 | 0 | 0 |
|   | 1DH | 1DH    | 1DH | 0  | 0 | 0 | 1 |
|   | 3CH | 59H    | 3CH | 1  | 0 | 1 | 0 |
|   | C3H | 62H    | C3H | 0  | 1 | 0 | 0 |

| コード | MSB              | LSB          |     |
|-----|------------------|--------------|-----|
|     | 1 1 0 0 1 1 1 0  | CEH          |     |
|     | 0 0 1 1 0 0 1 ir | 32H、33H      |     |
|     | d d              | dd           |     |
|     | ir               | ニーモニック       | コード |
| IX  | 0                | CP A, [IX+L] | 32H |
| IY  | 1                | CP A, [IY+L] | 33H |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**CP B, #nn** /////////////////////////////////////////////////////////////////// Compare immediate data nn with B reg. /////////////////////////////////////////////////////////////////// 3 cycle //**機能** B - nn

Bレジスタの内容から、8ビット即値データnnを減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。Bレジスタの内容は変更されません。

| コード | MSB | LSB |  |
|-----|-----|-----|--|
|     |     | CEH |  |
|     |     | BCH |  |
|     |     | nn  |  |
| フラグ |     |     |  |
|     |     |     |  |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |   |   |   |
|---|-----|-----|-----|----|---|---|---|
|   | B   | nn  | B   | SC |   |   |   |
|   |     |     |     | N  | V | C | Z |
|   | 74H | 2AH | 74H | 0  | 0 | 0 | 0 |
|   | 1DH | 1DH | 1DH | 0  | 0 | 0 | 1 |
|   | 3CH | 59H | 3CH | 1  | 0 | 1 | 0 |
|   | C3H | 62H | C3H | 0  | 1 | 0 | 0 |

**CP L, #nn** /////////////////////////////////////////////////////////////////// Compare immediate data nn with L reg. /////////////////////////////////////////////////////////////////// 3 cycle //**機能** L - nn

Lレジスタの内容から、8ビット即値データnnを減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。Lレジスタの内容は変更されません。

| コード | MSB | LSB |  |
|-----|-----|-----|--|
|     |     | CEH |  |
|     |     | BDH |  |
|     |     | nn  |  |
| フラグ |     |     |  |
|     |     |     |  |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |   |   |   |
|---|-----|-----|-----|----|---|---|---|
|   | L   | nn  | L   | SC |   |   |   |
|   |     |     |     | N  | V | C | Z |
|   | 74H | 2AH | 74H | 0  | 0 | 0 | 0 |
|   | 1DH | 1DH | 1DH | 0  | 0 | 0 | 1 |
|   | 3CH | 59H | 3CH | 1  | 0 | 1 | 0 |
|   | C3H | 62H | C3H | 0  | 1 | 0 | 0 |

**CP H, #nn** /////////////////////////////////////////////////////////////////// Compare immediate data nn with H reg. /////////////////////////////////////////////////////////////////// 3 cycle //**機能** H - nn

Hレジスタの内容から、8ビット即値データnnを減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。Hレジスタの内容は変更されません。

| コード | MSB | LSB |  |
|-----|-----|-----|--|
|     |     | CEH |  |
|     |     | BEH |  |
|     |     | nn  |  |
| フラグ |     |     |  |
|     |     |     |  |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |   |   |   |
|---|-----|-----|-----|----|---|---|---|
|   | H   | nn  | H   | SC |   |   |   |
|   |     |     |     | N  | V | C | Z |
|   | 74H | 2AH | 74H | 0  | 0 | 0 | 0 |
|   | 1DH | 1DH | 1DH | 0  | 0 | 0 | 1 |
|   | 3CH | 59H | 3CH | 1  | 0 | 1 | 0 |
|   | C3H | 62H | C3H | 0  | 1 | 0 | 0 |

**CP BR, #hh** ////////////////////////////////////////////////////////////////// Compare immediate data hh with BR reg. ////////////////////////////////////////////////////////////////// 3 cycle //

機能 BR - hh

BRレジスタの内容から、8ビット即値データhhを減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。BRレジスタの内容は変更されません。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 0 1 1 1 1 1 1 | BFH |  |

h h hh

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |   |   |   |
|---|-----|-----|-----|----|---|---|---|
|   | BR  | hh  | BR  | SC |   |   |   |
|   |     |     |     | N  | V | C | Z |
|   | 74H | 2AH | 74H | 0  | 0 | 0 | 0 |
|   | 1DH | 1DH | 1DH | 0  | 0 | 0 | 1 |
|   | 3CH | 59H | 3CH | 1  | 0 | 1 | 0 |
|   | C3H | 62H | C3H | 0  | 1 | 0 | 0 |

**CP [BR:l], #nn** ////////////////////////////////////////////////////////////////// Compare immediate data nn with location [BR:l] ////////////////////////////////////////////////////////////////// 4 cycle //

機能 [BR:l] - nn

BRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されるデータメモリの内容から8ビット即値データnnを減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。データメモリの内容は変更されません。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 1 1 0 1 1 | DBH |  |
|     | l l             | ll  |  |
|     | n n             | nn  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: 即値データ

Dst: 8ビット絶対

| 例 | 設定値    |     | 結果     |    |   |   |   |
|---|--------|-----|--------|----|---|---|---|
|   | [BR:l] | nn  | [BR:l] | SC |   |   |   |
|   |        |     |        | N  | V | C | Z |
|   | 74H    | 2AH | 74H    | 0  | 0 | 0 | 0 |
|   | 1DH    | 1DH | 1DH    | 0  | 0 | 0 | 1 |
|   | 3CH    | 59H | 3CH    | 1  | 0 | 1 | 0 |
|   | C3H    | 62H | C3H    | 0  | 1 | 0 | 0 |

**CP [HL], A** ////////////////////////////////////////////////////////////////// Compare A reg. with location [HL] ////////////////////////////////////////////////////////////////// 3 cycle //

機能 [HL] - A

HLレジスタでアドレス指定されたデータメモリの内容からAレジスタの内容を減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。データメモリの内容は変更されません。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 0 1 1 0 1 0 0 | 34H |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: レジスタ直接

Dst: レジスタ間接

| 例 | 設定値  |     | 結果   |    |   |   |   |
|---|------|-----|------|----|---|---|---|
|   | [HL] | A   | [HL] | SC |   |   |   |
|   |      |     |      | N  | V | C | Z |
|   | 74H  | 2AH | 74H  | 0  | 0 | 0 | 0 |
|   | 1DH  | 1DH | 1DH  | 0  | 0 | 0 | 1 |
|   | 3CH  | 59H | 3CH  | 1  | 0 | 1 | 0 |
|   | C3H  | 62H | C3H  | 0  | 1 | 0 | 0 |

**CP [HL], #nn** /////////////////////////////////////////////////////////////////// Compare immediate data nn with location [HL] /////////////////////////////////////////////////////////////////// 4 cycle //**機能** [HL] - nn

HLレジスタでアドレス指定されたデータメモリの内容から8ビット即値データnnを減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。データメモリの内容は変更されません。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 0 1 1 0 1 0 1 | 35H |  |
|     | n n             | nn  |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**モード** Src: 即値データ

Dst: レジスタ間接

| 例 | 設定値  |     | 結果   |    |   |   |   |
|---|------|-----|------|----|---|---|---|
|   | [HL] | nn  | [HL] | SC |   |   |   |
|   |      |     |      | N  | V | C | Z |
|   | 74H  | 2AH | 74H  | 0  | 0 | 0 | 0 |
|   | 1DH  | 1DH | 1DH  | 0  | 0 | 0 | 1 |
|   | 3CH  | 59H | 3CH  | 1  | 0 | 1 | 0 |
|   | C3H  | 62H | C3H  | 0  | 1 | 0 | 0 |

**CP [HL], [ir]** /////////////////////////////////////////////////////////////////// Compare location [ir reg.] with location [HL] /////////////////////////////////////////////////////////////////// 4 cycle //**機能** [HL] - [ir]

HLレジスタでアドレス指定されたデータメモリの内容からirレジスタ(IX/IY)でアドレス指定されるデータメモリの内容を減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。データメモリの内容は変更されません。EPレジスタの内容がデータメモリ[HL]のページアドレス、XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリ[ir]のページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB      |     |
|-----|------------------|----------|-----|
|     | 1 1 0 0 1 1 1 0  | CEH      |     |
|     | 0 0 1 1 0 1 1 ir | 36H, 37H |     |
|     | ir               | ニーモニック   | コード |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**モード** Src: レジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |      | 結果   |    |   |   |   |
|---|------|------|------|----|---|---|---|
|   | [HL] | [ir] | [HL] | SC |   |   |   |
|   |      |      |      | N  | V | C | Z |
|   | 74H  | 2AH  | 74H  | 0  | 0 | 0 | 0 |
|   | 1DH  | 1DH  | 1DH  | 0  | 0 | 0 | 1 |
|   | 3CH  | 59H  | 3CH  | 1  | 0 | 1 | 0 |
|   | C3H  | 62H  | C3H  | 0  | 1 | 0 | 0 |

**CP BA, rp** /////////////////////////////////////////////////////////////////// Compare rp reg. with BA reg. /////////////////////////////////////////////////////////////////// 4 cycle //**機能** BA - rp

BAレジスタの内容からrpレジスタ(BA/HL/IX/IY)の内容を減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。BAレジスタの内容は変更されません。

| コード | MSB             | LSB       |  |
|-----|-----------------|-----------|--|
|     | 1 1 0 0 1 1 1 1 | CFH       |  |
|     | 0 0 0 1 1 0 rp  | 18H ~ 1BH |  |

| rp    | ニーモニック    | コード |
|-------|-----------|-----|
| BA 00 | CP BA, BA | 18H |
| HL 01 | CP BA, HL | 19H |
| IX 10 | CP BA, IX | 1AH |
| IY 11 | CP BA, IY | 1BH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**モード** Src: レジスタ直接

Dst: レジスタ直接

| 例 | 設定値   |       | 結果    |    |   |   |   |
|---|-------|-------|-------|----|---|---|---|
|   | BA    | rp    | BA    | SC |   |   |   |
|   |       |       |       | N  | V | C | Z |
|   | 3F71H | 145AH | 3F71H | 0  | 0 | 0 | 0 |
|   | 53D1H | 53D1H | 53D1H | 0  | 0 | 0 | 1 |
|   | A291H | 632EH | A291H | 0  | 1 | 0 | 0 |
|   | 2862H | 4C25H | 2862H | 1  | 0 | 1 | 0 |

(rp BA)

**CP BA, #mmnn** /////////////////////////////////////////////////////////////////// Compare immediate data mmnn with BA reg. /////////////////////////////////////////////////////////////////// 3 cycle //**機能** BA - mmnn

BAレジスタの内容から16ビット即値データmmnnを減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。BAレジスタの内容は変更されません。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 1 0 1 0 0 | D4H |  |
|     | n n             | nn  |  |
|     | m m             | mm  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↓ | ↑ | ↑ |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値   |       | 結果    |    |   |   |   |
|---|-------|-------|-------|----|---|---|---|
|   | BA    | mmnn  | BA    | SC |   |   |   |
|   |       |       |       | N  | V | C | Z |
|   | 3F71H | 145AH | 3F71H | 0  | 0 | 0 | 0 |
|   | 53D1H | 53D1H | 53D1H | 0  | 0 | 0 | 1 |
|   | A291H | 632EH | A291H | 0  | 1 | 0 | 0 |
|   | 2862H | 4C25H | 2862H | 1  | 0 | 1 | 0 |

**CP HL, rp** /////////////////////////////////////////////////////////////////// Compare rp reg. with HL reg. /////////////////////////////////////////////////////////////////// 4 cycle //

機能 HL - rp

HLレジスタの内容からrpレジスタ(BA/HL/IX/IY)の内容を減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。HLレジスタの内容は変更されません。

| コード | MSB             | LSB | CFH | 38H ~ 3BH |
|-----|-----------------|-----|-----|-----------|
|     | 1 1 0 0 1 1 1 1 |     |     |           |
|     | 0 0 1 1 1 0 rp  |     |     |           |

モード Src: レジスタ直接

Dst: レジスタ直接

例

| HL    | rp    | HL    | 設定値 |   |   |   | 結果 |   |   |   |
|-------|-------|-------|-----|---|---|---|----|---|---|---|
|       |       |       | SC  |   |   |   | N  | V | C | Z |
| 3F71H | 145AH | 3F71H | 0   | 0 | 0 | 0 | 0  | 0 | 0 | 0 |
| 53D1H | 53D1H | 53D1H | 0   | 0 | 0 | 1 | 0  | 0 | 0 | 1 |
| A291H | 632EH | A291H | 0   | 1 | 0 | 0 | 0  | 1 | 0 | 0 |
| 2862H | 4C25H | 2862H | 1   | 0 | 1 | 0 | 1  | 0 | 1 | 0 |

(rp HL)

| rp    | ニーモニック    | コード |
|-------|-----------|-----|
| BA 00 | CP HL, BA | 38H |
| HL 01 | CP HL, HL | 39H |
| IX 10 | CP HL, IX | 3AH |
| IY 11 | CP HL, IY | 3BH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**CP HL, #mmnn** /////////////////////////////////////////////////////////////////// Compare immediate data mmnn with HL reg. /////////////////////////////////////////////////////////////////// 3 cycle //

機能 HL - mmnn

HLレジスタの内容から16ビット即値データmmnnを減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。HLレジスタの内容は変更されません。

| コード | MSB             | LSB | D5H |
|-----|-----------------|-----|-----|
|     | 1 1 0 1 0 1 0 1 |     |     |
|     | n n             |     | nn  |
|     | m m             |     | mm  |

モード Src: 即値データ

Dst: レジスタ直接

例

| HL    | mmnn  | HL    | 設定値 |   |   |   | 結果 |   |   |   |
|-------|-------|-------|-----|---|---|---|----|---|---|---|
|       |       |       | SC  |   |   |   | N  | V | C | Z |
| 3F71H | 145AH | 3F71H | 0   | 0 | 0 | 0 | 0  | 0 | 0 | 0 |
| 53D1H | 53D1H | 53D1H | 0   | 0 | 0 | 1 | 0  | 0 | 0 | 1 |
| A291H | 632EH | A291H | 0   | 1 | 0 | 0 | 0  | 1 | 0 | 0 |
| 2862H | 4C25H | 2862H | 1   | 0 | 1 | 0 | 1  | 0 | 1 | 0 |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↓ | ↑ | ↑ | ↑ |

**CP IX, #mmnn** ////////////// Compare immediate data mmnn with IX reg. ////////////// 3 cycle //

機能 IX - mmnn

IXレジスタの内容から16ビット即値データmmnnを減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。IXレジスタの内容は変更されません。

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 0 1 0 1 1 1 0 | D6H |  |
|     | n n               | nn  |  |
|     | m m               | mm  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: 即値データ

Dst: レジスタ直接

例

| IX    | mmnn  | IX    | 設定値 |   |   |   | 結果 |   |   |   |
|-------|-------|-------|-----|---|---|---|----|---|---|---|
|       |       |       | SC  |   |   |   | N  | V | C | Z |
| 3F71H | 145AH | 3F71H | 0   | 0 | 0 | 0 |    |   |   |   |
| 53D1H | 53D1H | 53D1H | 0   | 0 | 0 | 1 |    |   |   |   |
| A291H | 632EH | A291H | 0   | 1 | 0 | 0 |    |   |   |   |
| 2862H | 4C25H | 2862H | 1   | 0 | 1 | 0 |    |   |   |   |

**CP IY, #mmnn** ////////////// Compare immediate data mmnn with IY reg. ////////////// 3 cycle //

機能 IY - mmnn

IYレジスタの内容から16ビット即値データmmnnを減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。IYレジスタの内容は変更されません。

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 0 1 0 1 1 1 1 | D7H |  |
|     | n n               | nn  |  |
|     | m m               | mm  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: 即値データ

Dst: レジスタ直接

例

| IY    | mmnn  | IY    | 設定値 |   |   |   | 結果 |   |   |   |
|-------|-------|-------|-----|---|---|---|----|---|---|---|
|       |       |       | SC  |   |   |   | N  | V | C | Z |
| 3F71H | 145AH | 3F71H | 0   | 0 | 0 | 0 |    |   |   |   |
| 53D1H | 53D1H | 53D1H | 0   | 0 | 0 | 1 |    |   |   |   |
| A291H | 632EH | A291H | 0   | 1 | 0 | 0 |    |   |   |   |
| 2862H | 4C25H | 2862H | 1   | 0 | 1 | 0 |    |   |   |   |

**CP SP, rp** ////////////// Compare rp reg. with SP ////////////// 4 cycle //

機能 SP - rp

スタックポインタ(SP)の内容からrpレジスタ(BA/HL)の内容を減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。SPの内容は変更されません。

| コード | MSB              | LSB      |  |
|-----|------------------|----------|--|
|     | 1 1 0 0 1 1 1 1  | CFH      |  |
|     | 0 1 0 1 1 1 0 rp | 5CH, 5DH |  |

| rp | ニーモニック | コード       |
|----|--------|-----------|
| BA | 0      | CP SP, BA |
| HL | 1      | CP SP, HL |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: レジスタ直接

Dst: レジスタ直接

例

| SP    | rp    | SP    | 設定値 |   |   |   | 結果 |   |   |   |
|-------|-------|-------|-----|---|---|---|----|---|---|---|
|       |       |       | SC  |   |   |   | N  | V | C | Z |
| 3F71H | 145AH | 3F71H | 0   | 0 | 0 | 0 |    |   |   |   |
| 53D1H | 53D1H | 53D1H | 0   | 0 | 0 | 1 |    |   |   |   |
| A291H | 632EH | A291H | 0   | 1 | 0 | 0 |    |   |   |   |
| 2862H | 4C25H | 2862H | 1   | 0 | 1 | 0 |    |   |   |   |

**CP SP, #mmnn** ////////////////////////////////////////////////////////////////// Compare immediate data mmnn with SP ////////////////////////////////////////////////////////////////// 4 cycle //**機能** SP - mmnn

スタックポインタ(SP)の内容から16ビット即値データmmnnを減じ、その結果によりフラグ(N/V/C/Z)の内容を変更します。SPの内容は変更されません。

| コード | MSB | LSB |     |
|-----|-----|-----|-----|
|     |     |     | CFH |
|     |     |     | 6CH |
|     |     |     | nn  |
|     |     |     | mm  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例     | 設定値   |       | 結果 |    |   |   |
|-------|-------|-------|----|----|---|---|
|       | SP    | mmnn  | SP | SC |   |   |
|       |       |       |    | N  | V | C |
| 3F71H | 145AH | 3F71H | 0  | 0  | 0 | 0 |
| 53D1H | 53D1H | 53D1H | 0  | 0  | 0 | 1 |
| A291H | 632EH | A291H | 0  | 1  | 0 | 0 |
| 2862H | 4C25H | 2862H | 1  | 0  | 1 | 0 |

**CPL r** ////////////////////////////////////////////////////////////////// Complement r reg. ////////////////////////////////////////////////////////////////// 3 cycle //**機能** r - r

レジスタ(A/B)の各ビットを反転し、1の補数を作成します。

| コード | MSB | LSB |          |
|-----|-----|-----|----------|
|     |     |     | CEH      |
|     |     |     | A0H, A1H |

  

| フラグ | r | ニーモニック | コード |
|-----|---|--------|-----|
| A   | 0 | CPL A  | A0H |
| B   | 1 | CPL B  | A1H |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
| -   | -  | -  | - | ↑ | - | - | ↑ |   |

**モード** レジスタ直接

| 例        | 設定値      |   | 結果 |   |   |   |
|----------|----------|---|----|---|---|---|
|          | r        | r | SC |   |   |   |
|          |          |   | N  | V | C | Z |
| 11111111 | 00000000 | 0 | —  | — | 1 |   |
| 10100101 | 01011010 | 1 | —  | — | 0 |   |

**CPL [BR:l]** ////////////////////////////////////////////////////////////////// Complement location [BR:l] ////////////////////////////////////////////////////////////////// 5 cycle //**機能** [BR:l] - [BR:l]

BRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されるデータメモリの各ビットを反転し、1の補数を作成します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB | LSB |     |
|-----|-----|-----|-----|
|     |     |     | CEH |
|     |     |     | A2H |
|     |     |     | ll  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
| -   | -  | -  | - | ↑ | - | - | ↑ |   |

**モード** 8ビット絶対

| 例        | 設定値      |        | 結果 |   |   |   |
|----------|----------|--------|----|---|---|---|
|          | [BR:l]   | [BR:l] | SC |   |   |   |
|          |          |        | N  | V | C | Z |
| 11111111 | 00000000 | 0      | —  | — | 1 |   |
| 10100101 | 01011010 | 1      | —  | — | 0 |   |

**CPL [HL]** ////////////////////////////////////////////////////////////////// Complement location [HL] ////////////////////////////////////////////////////////////////// 4 cycle //

機能 [HL] [HL]

HLレジスタでアドレス指定されたデータメモリの各ビットを反転し、1の補数を作成します。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 0 1 0 0 0 1 1 | A3H |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

モード レジスタ間接

| 例 | 設定値      |          | 結果 |   |   |   |
|---|----------|----------|----|---|---|---|
|   | [HL]     | [HL]     | SC |   |   |   |
|   |          |          | N  | V | C | Z |
|   | 11111111 | 00000000 | 0  | — | — | 1 |
|   | 10100101 | 01011010 | 1  | — | — | 0 |

**DEC r** ////////////////////////////////////////////////////////////////// Decrement r reg. ////////////////////////////////////////////////////////////////// 2 cycle //

機能 r r - 1

レジスタ(A/B/L/H)の内容をデクリメント(-1)します。

| コード | MSB           | LSB       |     |
|-----|---------------|-----------|-----|
|     | 1 0 0 0 1 0 r | 88H ~ 8BH |     |
|     | コード           |           |     |
| A   | 00            | DEC A     | 88H |
| B   | 01            | DEC B     | 89H |
| L   | 10            | DEC L     | 8AH |
| H   | 11            | DEC H     | 8BH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | ↑ |

モード レジスタ直接

| 例 | 設定値 |     | 結果 |   |   |   |
|---|-----|-----|----|---|---|---|
|   | r   | r   | SC |   |   |   |
|   |     |     | N  | V | C | Z |
|   | 63H | 62H | —  | — | — | 0 |
|   | 01H | 00H | —  | — | — | 1 |

**DEC BR** ////////////////////////////////////////////////////////////////// Decrement BR reg. ////////////////////////////////////////////////////////////////// 2 cycle //

機能 BR BR - 1

BRレジスタの内容をデクリメント(-1)します。

| コード | MSB             | LSB |   |
|-----|-----------------|-----|---|
|     | 1 0 0 0 1 1 0 0 | 8CH |   |
|     | コード             |     |   |
|     | -               | -   | ↑ |

モード レジスタ直接

| 例 | 設定値 |     | 結果 |   |   |   |
|---|-----|-----|----|---|---|---|
|   | BR  | BR  | SC |   |   |   |
|   |     |     | N  | V | C | Z |
|   | 63H | 62H | —  | — | — | 0 |
|   | 01H | 00H | —  | — | — | 1 |

**DEC [BR:ll]** ////////////////////////////////////////////////////////////////// Decrement location [BR:ll] ////////////////////////////////////////////////////////////////// 4 cycle //

機能 [BR:ll] [BR:ll] - 1

BRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されるデータメモリの内容をデクリメント(-1)します。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード 8ビット絶対

| 例       | 設定値     | 結果 |   |   |   |
|---------|---------|----|---|---|---|
|         |         | SC |   |   |   |
| [BR:ll] | [BR:ll] | N  | V | C | Z |
| 63H     | 62H     | —  | — | — | 0 |
| 01H     | 00H     | —  | — | — | 1 |

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 0 0 0 1 1 0 1 | 8DH |

l l ll

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | ↑ |

**DEC [HL]** ////////////////////////////////////////////////////////////////// Decrement location [HL] ////////////////////////////////////////////////////////////////// 3 cycle //

機能 [HL] [HL] - 1

HLレジスタでアドレス指定されたデータメモリの内容をデクリメント(-1)します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード レジスタ間接

| 例    | 設定値  | 結果 |   |   |   |
|------|------|----|---|---|---|
|      |      | SC |   |   |   |
| [HL] | [HL] | N  | V | C | Z |
| 63H  | 62H  | —  | — | — | 0 |
| 01H  | 00H  | —  | — | — | 1 |

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 0 0 0 1 1 1 0 | 8EH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | ↑ |

**DEC rp** ////////////////////////////////////////////////////////////////// Decrement rp reg. ////////////////////////////////////////////////////////////////// 2 cycle //

機能 rp rp - 1

rpレジスタ(BA/HL/IX/IY)の内容をデクリメント(-1)します。

モード レジスタ直接

| 例     | 設定値   | 結果 |   |   |   |
|-------|-------|----|---|---|---|
|       |       | SC |   |   |   |
| rp    | rp    | N  | V | C | Z |
| 4285H | 4284H | —  | — | — | 0 |
| 0001H | 0000H | —  | — | — | 1 |

| コード | MSB            | LSB       |
|-----|----------------|-----------|
|     | 1 0 0 1 1 0 rp | 98H ~ 9BH |

| rp    | ニーモニック | コード |
|-------|--------|-----|
| BA 00 | DEC BA | 98H |
| HL 01 | DEC HL | 99H |
| IX 10 | DEC IX | 9AH |
| IY 11 | DEC IY | 9BH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | ↑ |

**DEC SP** ////////////////////////////////////////////////////////////////// Decrement SP ////////////////////////////////////////////////////////////////// 2 cycle //

機能 SP SP - 1

スタックポインタ(SP)の内容をデクリメント(-1)します。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 0 0 0 1 1 1 1 | 8FH |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | ↑ |

モード レジスタ直接

例

| SP    | SP    | 結果 |   |   |   |
|-------|-------|----|---|---|---|
|       |       | SC |   |   |   |
| N     | V     | C  | Z |   |   |
| 4285H | 4284H | —  | — | — | 0 |
| 0001H | 0000H | —  | — | — | 1 |

**DIV** ////////////////////////////////////////////////////////////////// Divide HL reg. by A reg. ////////////////////////////////////////////////////////////////// 13 cycle //

機能 L HL/A H 剰余

HLレジスタの内容をAレジスタの内容で除算し、商をLレジスタに、剰余をHレジスタにストアします。

除数'0'で除算を行うと、ゼロ除算例外処理が発生します。

除数'0'以外で除算を行い、商が8ビットを越えた場合はVフラグが'1'にセットされ、被除数(HLレジスタの内容)は保存されます。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |

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

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | 0 | ↑ |

注意 MODEL0/2では本命令が使用できません。

モード インプライド(レジスタ直接)

例

| HL    | A   | 設定値 |     | 結果 |   |   |   |   |   |
|-------|-----|-----|-----|----|---|---|---|---|---|
|       |     | L   | H   | SC |   | N | V | C | Z |
| 1A16H | 64H | 42H | 4EH | 0  | 0 | 0 | 0 | 0 | 0 |
| 332CH | 64H | 83H | 00H | 1  | 0 | 0 | 0 | 0 | 0 |
| 0000H | 58H | 00H | 00H | 0  | 0 | 0 | 0 | 1 | 1 |
| 0301H | 02H | 01H | 03H | 1  | 1 | 0 | 0 | 0 | 0 |

**DJR NZ, rr** ////////////////////////////////////////////////////////////////// Decrement B reg. & Jump relative if B reg. is not zero ////////////////////////////////////////////////////////////////// 4 cycle //

機能 MODEL0/1

B B - 1,

If B ≠ 0 then JRS rr  
else PC PC + 2

MODEL2/3

B B - 1,

If B ≠ 0 then JRS rr  
else PC PC + 2, NB CB

Bレジスタをデクリメント(-1)し、その結果、Bレジスタが'0'以外の場合に分岐命令"JRS rr"を実行します。Bレジスタが'0'になった場合には次の命令を実行します。

☞ "JRS rr"命令

MODEL2/3では、分岐時にNBに設定されているバンクアドレスがCBにロードされ、バンクの変更も行われます。分岐せずに次の命令に移行する際にはNBの内容を現在のバンクアドレス(CBの内容)に戻します。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 1 1 0 1 0 1 | F5H |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | ↑ |

モード 符号付き8ビットPC相対

例

MODEL2/3においてNB=02H, B=05Hの場合、条件成立時の物理アドレス9000H番地にあるDJR NZ, \$-05Hの動作は下記のとおりです。

|     | NB  | CB  | PC(論理アドレス)       | B   |
|-----|-----|-----|------------------|-----|
| 実行前 | 02H | 01H | 9000H            | 05H |
|     |     |     | 9001H+(FFFFBH-1) |     |
| 実行後 | 02H | 02H | 8FFBH            | 04H |

上記の例では物理アドレス010FFBHへ分岐します。MODEL0/1ではNB, CBがないため物理アドレス8FFBHへ分岐します。

条件不成立時(B=01H)、物理アドレス9000H番地のDJR NZ, \$-05Hの動作は下記のとおりです。

|     | NB  | CB  | PC(論理アドレス) | B   |
|-----|-----|-----|------------|-----|
| 実行前 | 01H | 02H | 9000H      | 01H |
|     |     |     |            |     |
| 実行後 | 02H | 02H | 9002H      | 00H |

MODEL0/1ではNB, CBはありません。

**EX A, B** // Exchange A reg. and B reg. // 2 cycle //

機能 A ↔ B

AレジスタとBレジスタの内容を交換します。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB | CCH |   |   |   |   |   |
|-----|-----------------|-----|-----|---|---|---|---|---|
|     | 1 1 0 0 1 1 0 0 |     |     |   |   |   |   |   |
| フラグ | I1              | I0  | U   | D | N | V | C | Z |
|     | -               | -   | -   | - | - | - | - | - |

| 例 | 設定値 |     | 結果  |     |    |   |   |
|---|-----|-----|-----|-----|----|---|---|
|   | A   | B   | A   | B   | SC |   |   |
|   |     |     |     |     | N  | V | C |
|   | 82H | 49H | 49H | 82H | -  | - | - |

**EX A, [HL]** // Exchange A reg. and location [HL] // 3 cycle //

機能 A ↔ [HL]

AレジスタとHLレジスタでアドレス指定された  
データメモリの内容を交換します。  
EPレジスタの内容がデータメモリのページアドレ  
スになります(MODEL2/3)。

モード Src: レジスタ間接

Dst: レジスタ直接

| コード | MSB             | LSB | CDH |   |   |   |   |   |
|-----|-----------------|-----|-----|---|---|---|---|---|
|     | 1 1 0 0 1 1 0 1 |     |     |   |   |   |   |   |
| フラグ | I1              | I0  | U   | D | N | V | C | Z |
|     | -               | -   | -   | - | - | - | - | - |

| 例 | 設定値 |      | 結果  |      |    |   |   |
|---|-----|------|-----|------|----|---|---|
|   | A   | [HL] | A   | [HL] | SC |   |   |
|   |     |      |     |      | N  | V | C |
|   | 82H | 49H  | 49H | 82H  | -  | - | - |

**EX BA, rp** // Exchange BA reg. and rp reg. // 3 cycle //

機能 BA ↔ rp

BAレジスタとrpレジスタ(HL/IX/IY/SP)の内容を  
交換します。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB            | LSB       | C8H ~ CBH |
|-----|----------------|-----------|-----------|
|     | 1 1 0 0 1 0 rp |           |           |
| rp  | ニーモニック         | コード       |           |
| HL  | 00             | EX BA, HL | C8H       |
| IX  | 01             | EX BA, IX | C9H       |
| IY  | 10             | EX BA, IY | CAH       |
| SP  | 11             | EX BA, SP | CBH       |
| フラグ | I1             | I0        | U         |
|     | -              | -         | -         |

| 例 | 設定値   |       | 結果    |       |    |   |   |
|---|-------|-------|-------|-------|----|---|---|
|   | BA    | rp    | BA    | rp    | SC |   |   |
|   |       |       |       |       | N  | V | C |
|   | 35D6H | C284H | C284H | 35D6H | -  | - | - |

**HALT** ////////////////////////////////////////////////////////////////// Set CPU to HALT mode ////////////////////////////////////////////////////////////////// 3 cycle //**機能** HALT

CPUをHALT状態にします。

HALT状態ではCPUが動作を停止し、消費電力を低減できます。発振回路などの周辺回路は動作します。

HALT状態からは割り込みにより通常のプログラム実行状態に戻ります。

☞ "3.7.1 HALT状態"

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |

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

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**INC r** ////////////////////////////////////////////////////////////////// Increment r reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** r r + 1

rレジスタ(A/B/L/H)の内容をインクリメント(+1)します。

| コード | MSB           | LSB       |  |
|-----|---------------|-----------|--|
|     | 1 0 0 0 0 0 r | 80H ~ 83H |  |

**モード** レジスタ直接

| 例 | 設定値 | 結果  |   |   |   |   |
|---|-----|-----|---|---|---|---|
|   |     | SC  |   |   |   |   |
|   | r   | r   | N | V | C | Z |
|   | 52H | 53H | — | — | — | 0 |
|   | FFH | 00H | — | — | — | 1 |

| r    | ニーモニック | コード |
|------|--------|-----|
| A 00 | INC A  | 80H |
| B 01 | INC B  | 81H |
| L 10 | INC L  | 82H |
| H 11 | INC H  | 83H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | ↑ |

**INC BR** ////////////////////////////////////////////////////////////////// Increment BR reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** BR BR + 1

BRレジスタの内容をインクリメント(+1)します。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 0 0 0 0 1 0 0 | 84H |  |

**モード** レジスタ直接

| 例 | 設定値 | 結果  |   |   |   |   |
|---|-----|-----|---|---|---|---|
|   |     | SC  |   |   |   |   |
|   | BR  | BR  | N | V | C | Z |
|   | 52H | 53H | — | — | — | 0 |
|   | FFH | 00H | — | — | — | 1 |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | ↑ |

**INC [BR:ll]** ////////////////////////////////////////////////////////////////// Increment location [BR:ll] ////////////////////////////////////////////////////////////////// 4 cycle //

機能 [BR:ll] [BR:ll] + 1

BRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されるデータメモリの内容をインクリメント(+1)します。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード 8ビット絶対

| 例       | 設定値     | 結果 |   |   |   |
|---------|---------|----|---|---|---|
|         |         | SC |   |   |   |
| [BR:ll] | [BR:ll] | N  | V | C | Z |
| 52H     | 53H     | —  | — | — | 0 |
| FFH     | 00H     | —  | — | — | 1 |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 0 0 0 0 1 0 1 | 85H |  |
|     | l l             | ll  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | ↑ |

**INC [HL]** ////////////////////////////////////////////////////////////////// Increment location [HL] ////////////////////////////////////////////////////////////////// 3 cycle //

機能 [HL] [HL] + 1

HLレジスタでアドレス指定されたデータメモリの内容をインクリメント(+1)します。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード レジスタ間接

| 例    | 設定値  | 結果 |   |   |   |
|------|------|----|---|---|---|
|      |      | SC |   |   |   |
| [HL] | [HL] | N  | V | C | Z |
| 52H  | 53H  | —  | — | — | 0 |
| FFH  | 00H  | —  | — | — | 1 |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 0 0 0 0 1 1 0 | 86H |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | ↑ |

**INC rp** ////////////////////////////////////////////////////////////////// Increment rp reg. ////////////////////////////////////////////////////////////////// 2 cycle //

機能 rp rp + 1

rpレジスタ(BA/HL/IX/IY)の内容をインクリメント(+1)します。

モード レジスタ直接

| 例     | 設定値   | 結果 |   |   |   |
|-------|-------|----|---|---|---|
|       |       | SC |   |   |   |
| rp    | rp    | N  | V | C | Z |
| 3259H | 325AH | —  | — | — | 0 |
| FFFFH | 0000H | —  | — | — | 1 |

| コード | MSB            | LSB       |  |
|-----|----------------|-----------|--|
|     | 1 0 0 1 0 0 rp | 90H ~ 93H |  |

| rp    | ニーモニック | コード |
|-------|--------|-----|
| BA 00 | INC BA | 90H |
| HL 01 | INC HL | 91H |
| IX 10 | INC IX | 92H |
| IY 11 | INC IY | 93H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | ↑ |

**INC SP** // Increment SP // 2 cycle //

機能 SP SP + 1

スタックポインタ(SP)の内容をインクリメント(+1)します。

コード MSB LSB  
 1 0 0 0 0 1 1 1 87H

フラグ I1 I0 U D N V C Z  
 - - - - - - - ↑

モード レジスタ直接

例

| SP    | SP    | SC |   |   |   | Z |
|-------|-------|----|---|---|---|---|
|       |       | N  | V | C |   |   |
| 3259H | 325AH | —  | — | — | 0 |   |
| FFFFH | 0000H | —  | — | — | 1 |   |

**INT [kk]** // Software Interrupt // 7(MIN)/8(MAX) cycle //

機能 MODEL0/1

[SP-1] PC(H), [SP-2] PC(L),  
 [SP-3] SC, SP SP-3, PC(L) [00kk],  
 PC(H) [00kk+1]

MODEL2/3(ミニマムモード)

[SP-1] PC(H), [SP-2] PC(L),  
 [SP-3] SC, SP SP-3, PC(L) [00kk],  
 PC(H) [00kk+1], CB NB

MODEL2/3(マキシマムモード)

[SP-1] CB, [SP-2] PC(H),  
 [SP-3] PC(L), [SP-4] SC, SP SP-4,  
 PC(L) [00kk], PC(H) [00kk+1], CB NB

本命令の先頭アドレス+2の値とシステムコンディションコード(SC)をスタックに退避後、プログラムメモリの00kk番地をベクタアドレスとするソフトウェア割り込みルーチンを実行します。

MODEL2/3のマキシマムモードでは、リターンアドレスの退避時に現在選択されているバンクアドレス(CBの内容)の退避も行われます。また、MODEL2/3では、分岐時にNBに設定されているバンクアドレスがCBにロードされ、バンクの変更も行われます。

ベクタ領域は0ページに固定です。

注意 "INT [kk]"命令により実行される割り込みルーチンからのリターンにはSCの内容も復帰させる"RETE"命令を使用してください。

コード MSB LSB

1 1 1 1 1 1 0 0 FCH  
 k k kk

フラグ I1 I0 U D N V C Z  
 - - - - - - - -

モード 8ビット間接

例 MODEL2/3においてNB=02Hの場合、物理アドレス9000H番地にあるINT [20H]命令を実行。

|     | NB  | CB  | PC(論理アドレス) | EP  | M(000020H) | SP    |
|-----|-----|-----|------------|-----|------------|-------|
| 実行前 | 02H | 01H | 9000H      | 03H | ABCDH      | 0000H |
|     |     |     |            |     |            |       |
| 実行後 | 02H | 02H | ABCDH      | 03H | ABCDH      | FFFCH |

EPは無視されベクタ領域(000000H ~ 0000FFH)が指定されます。

上記の例では物理アドレス012BCDHへ分岐します。MODEL0/1ではNB, CBがないため物理アドレスABCDHへ分岐します。

実行後のスタック内容

(1) MODEL2/3(マキシマムモード) (2) MODEL2/3(ミニマムモード)  
 MODEL0/1

|         |             |
|---------|-------------|
| 00FFFFH | SCの内容       |
| 00FFFDH | 02H (PC(L)) |
| 00FFFEH | 90H (PC(H)) |
| 00FFFFH | 01H (CB)    |

|         |             |
|---------|-------------|
| 00FFFFH | SCの内容       |
| 00FFFDH | 02H (PC(L)) |
| 00FFFEH | 90H (PC(H)) |
| 00FFFFH | 01H (CB)    |

**JP HL** ////////////////////////////////////////////////////////////////// Indirect Jump using HL reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** MODEL0/1

PC HL

MODEL2/3

PC HL, CB NB

HLレジスタの内容をプログラムカウンタ(PC)にロードして無条件に分岐します。  
MODEL2/3では、分岐時にNBに設定されているバンクアドレスがCBにロードされ、バンクの変更も行われます。

**モード** レジスタ直接

**例** MODEL2/3においてNB=02H, HL=8765Hの場合、物理アドレス9000H番地にあるJP HLの動作は下記のとおりです。

|     | NB  | CB  | PC(論理アドレス) | HL    |
|-----|-----|-----|------------|-------|
| 実行前 | 02H | 01H | 9000H      | 8765H |
|     |     |     | ↓          | ↓     |
| 実行後 | 02H | 02H | 8765H      | 8765H |

上記の例では物理アドレス010765Hへ分岐します。  
MODEL0/1ではNB, CBがないため物理アドレス8765Hへ分岐します。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 1 1 0 1 0 0 | F4H |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**JP [kk]** ////////////////////////////////////////////////////////////////// Indirect Jump using vector ////////////////////////////////////////////////////////////////// 4 cycle //**機能** MODEL0/1

PC(L) [00kk], PC(H) [00kk+1]

MODEL2/3

CB NB, PC(L) [00kk], PC(H) [00kk+1]

8ビット間接アドレスkkで示される、プログラムメモリの00kk ~ 00kk+1番地に書き込まれているベクタをプログラムカウンタ(PC)にロードして無条件に分岐します。

MODEL2/3では、分岐時にNBに設定されているバンクアドレスがCBにロードされ、バンクの変更も行われます。

ベクタ領域は0ページに固定です。

**モード** 8ビット間接

**例** MODEL2/3においてNB=02Hの場合、物理アドレス9000H番地にあるJP [20H]命令を実行。

|     | NB  | CB  | PC(論理アドレス) | EP  | M(0000020H) |
|-----|-----|-----|------------|-----|-------------|
| 実行前 | 02H | 01H | 9000H      | 03H | ABCDH       |
|     |     |     | ↓          | ↓   |             |
| 実行後 | 02H | 02H | ABCDH      | 03H | ABCDH       |

EPは無視されベクタ領域(000000H ~ 0000FFH)が指定されます。

上記の例では物理アドレス012BCDHへ分岐します。  
MODEL0/1ではNB, CBがないため物理アドレスABCDHへ分岐します。

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 1 1 1 1 1 0 1 | FDH |  |

k k

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**JRL qqrr** /////////////////////////////////////////////////////////////////// Jump to relative location qqrr /////////////////////////////////////////////////////////////////// 3 cycle //**機能** MODEL0/1

PC PC + qqrr + 2

## MODEL2/3

PC PC + qqrr + 2, CB NB

16ビット相対アドレスqqrr(-32768 ~ 32767)を本命令の先頭アドレス+2からのオフセットとしてプログラムカウンタ(PC)に加え、そのアドレスに無条件に分岐します。

MODEL2/3では、分岐時にNBに設定されているバンクアドレスがCBにロードされ、バンクの変更も行われます。

**モード** 符号付き16ビットPC相対

**例** MODEL2/3においてNB=02Hの場合、物理アドレス9000H番地にあるJRL \$+2000H命令を実行。

|     | NB  | CB  | PC(論理アドレス)      |
|-----|-----|-----|-----------------|
| 実行前 | 02H | 01H | 9000H           |
|     | ↓   |     | 9002H+(2000H-2) |
| 実行後 | 02H | 02H | B000H           |

上記の例では物理アドレス01300Hへ分岐します。MODEL0/1ではNB, CBがないため物理アドレスB000Hへ分岐します。

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 1 1 0 0 1 1 | F3H |
|     | rr              |     |
|     | qq              |     |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**JRL cc1, qqrr** /////////////////////////////////////////////////////////////////// Jump to relative location qqrr if condition cc1 is true /////////////////////////////////////////////////////////////////// 3 cycle //**機能** MODEL0/1

If cc1 is true then JRL qqrr  
else PC PC + 3

## MODEL2/3

If cc1 is true then JRL qqrr  
else PC PC + 3, NB CB

条件cc1が成立している場合に"JRL qqrr"命令を実行し、条件不成立の場合は次の命令を実行します。

☞ "JRL qqrr"命令

MODEL2/3では、分岐先バンクを指定するNBの内容が条件不成立の場合に現在のバンクアドレス(CBの内容)に戻されます。

条件cc1は以下の4種類です。

| cc1 | 条件                     |
|-----|------------------------|
| C   | Carry (キャリーフラグC=1)     |
| NC  | Non Carry (キャリーフラグC=0) |
| Z   | Zero (ゼロフラグZ=1)        |
| NZ  | Non Zero (ゼロフラグZ=0)    |

| コード | MSB             | LSB       |
|-----|-----------------|-----------|
|     | 1 1 1 0 1 1 cc1 | ECH ~ EFH |
|     | rr              |           |
|     | qq              |           |

| cc1   | ニーモニック      | コード |
|-------|-------------|-----|
| C 00  | JRL C,qqrr  | ECH |
| NC 01 | JRL NC,qqrr | EDH |
| Z 10  | JRL Z,qqrr  | EEH |
| NZ 11 | JRL NZ,qqrr | EFH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**モード** 符号付き16ビットPC相対

**例** 条件成立時はJRL qqrr命令と同じ動作をします。条件不成立時、物理アドレス9000H番地のJRL cc1, qqrrの動作は下記のとおりです。

|     | NB  | CB  | PC(論理アドレス) |
|-----|-----|-----|------------|
| 実行前 | 02H | 01H | 9000H      |
|     | ↓   |     |            |
| 実行後 | 01H | 01H | 9003H      |

MODEL0/1ではNB, CBはありません。

**JRS rr** /////////////////////////////////////////////////////////////////// Jump to relative location rr /////////////////////////////////////////////////////////////////// 2 cycle //**機能** MODEL0/1

PC PC + rr + 1

MODEL2/3

PC PC + rr + 1, CB NB

8ビット相対アドレスrr(-128 ~ 127)を本命令の先頭アドレス+1からのオフセットとしてプログラムカウンタ(PC)に加え、そのアドレスに無条件に分岐します。

MODEL2/3では、分岐時にNBに設定されているバンクアドレスがCBにロードされ、バンクの変更も行われます。

**モード** 符号付き8ビットPC相対**例** MODEL2/3においてNB=02Hの場合、物理アドレス9000H番地にあるJRS \$+20H命令を実行。

|     | NB  | CB  | PC(論理アドレス)    |
|-----|-----|-----|---------------|
| 実行前 | 02H | 01H | 9000H         |
|     |     | ↓   | 9001H+(20H-1) |
| 実行後 | 02H | 02H | 9020H         |

上記の例では物理アドレス011020Hへ分岐します。MODEL0/1ではNB, CBがないため物理アドレス9020Hへ分岐します。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 1 1 0 0 0 1 | F1H |  |
|     | rr              |     |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**JRS cc1, rr** /////////////////////////////////////////////////////////////////// Jump to relative location rr if condition cc1 is true /////////////////////////////////////////////////////////////////// 2 cycle //**機能** MODEL0/1

If cc1 is true then JRS rr

else PC PC + 2

MODEL2/3

If cc1 is true then JRS rr

else PC PC + 2, NB CB

条件cc1が成立している場合に"JRS rr"命令を実行し、条件不成立の場合は次の命令を実行します。

☞ "JRS rr"命令

MODEL2/3では、分岐先バンクを指定するNBの内容が条件不成立の場合に現在のバンクアドレス(CBの内容)に戻されます。

条件cc1は以下の4種類です。

| cc1 | 条件                     |
|-----|------------------------|
| C   | Carry (キャリーフラグC=1)     |
| NC  | Non Carry (キャリーフラグC=0) |
| Z   | Zero (ゼロフラグZ=1)        |
| NZ  | Non Zero (ゼロフラグZ=0)    |

| コード | MSB             | LSB       |  |
|-----|-----------------|-----------|--|
|     | 1 1 1 0 0 1 cc1 | E4H ~ E7H |  |
|     | rr              |           |  |

| cc1   | ニーモニック    | コード |
|-------|-----------|-----|
| C 00  | JRS C,rr  | E4H |
| NC 01 | JRS NC,rr | E5H |
| Z 10  | JRS Z,rr  | E6H |
| NZ 11 | JRS NZ,rr | E7H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**モード** 符号付き8ビットPC相対**例** 条件成立時はJRS rr命令と同じ動作をします。条件不成立時、物理アドレス9000H番地のJRS cc1, rrの動作は下記のとおりです。

|     | NB  | CB  | PC(論理アドレス) |
|-----|-----|-----|------------|
| 実行前 | 02H | 01H | 9000H      |
|     |     | ↓   |            |
| 実行後 | 01H | 01H | 9002H      |

MODEL0/1ではNB, CBはありません。

**JRS cc2, rr** /////////////// Jump to relative location rr if condition cc2 is true /////////////// 3 cycle //

## 機能 MODEL0/1

If cc2 is true then PC PC + rr + 2  
else PC PC + 3

MODEL2/3

If cc2 is true then PC PC + rr + 2, CB NB  
else PC PC + 3, NB CB

条件cc2が成立している場合、8ビット相対アドレスrr(-128~127)を本命令の先頭アドレス+2からのオフセットとしてプログラムカウンタ(PC)に加え、そのアドレスに分岐します。条件不成立の場合は次の命令を実行します。

MODEL2/3では、分岐時にNBに設定されているバンクアドレスがCBにロードされ、バンクの変更も行われます。

また、条件不成立の場合には分岐先バンクを指定するNBの内容が現在のバンクアドレス(CBの内容)に戻されます。

条件cc2は以下の16種類です。

| cc2 | 条件                                        |
|-----|-------------------------------------------|
| LT  | Less Than ( $[N \vee V] = 1$ )            |
| LE  | Less or Equal ( $Z \vee [N \vee V] = 1$ ) |
| GT  | Greater Than ( $Z \vee [N \vee V] = 0$ )  |
| GE  | Greater or Equal ( $[N \vee V] = 0$ )     |
| V   | Overflow ( $V = 1$ )                      |
| NV  | Non Overflow ( $V = 0$ )                  |
| P   | Plus ( $N = 0$ )                          |
| M   | Minus ( $N = 1$ )                         |
| F0  | F0 is set ( $F0 = 1$ )                    |
| F1  | F1 is set ( $F1 = 1$ )                    |
| F2  | F2 is set ( $F2 = 1$ )                    |
| F3  | F3 is set ( $F3 = 1$ )                    |
| NF0 | F0 is reset ( $F0 = 0$ )                  |
| NF1 | F1 is reset ( $F1 = 0$ )                  |
| NF2 | F2 is reset ( $F2 = 0$ )                  |
| NF3 | F3 is reset ( $F3 = 0$ )                  |

| コード             | MSB | LSB       |
|-----------------|-----|-----------|
| 1 1 0 0 1 1 1 0 | CEH |           |
| 1 1 1 0         | cc2 | E0H ~ EFH |
| r r             |     | rr        |

| cc2      | ニーモニック     | コード |
|----------|------------|-----|
| LT 0000  | JRS LT,rr  | E0H |
| LE 0001  | JRS LE,rr  | E1H |
| GT 0010  | JRS GT,rr  | E2H |
| GE 0011  | JRS GE,rr  | E3H |
| V 0100   | JRS V,rr   | E4H |
| NV 0101  | JRS NV,rr  | E5H |
| P 0110   | JRS P,rr   | E6H |
| M 0111   | JRS M,rr   | E7H |
| F0 1000  | JRS F0,rr  | E8H |
| F1 1001  | JRS F1,rr  | E9H |
| F2 1010  | JRS F2,rr  | EAH |
| F3 1011  | JRS F3,rr  | EBH |
| NF0 1100 | JRS NF0,rr | ECH |
| NF1 1101 | JRS NF1,rr | EDH |
| NF2 1110 | JRS NF2,rr | EEH |
| NF3 1111 | JRS NF3,rr | EFH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

## モード 符号付き8ビットPC相対

例 MODEL2/3においてNB=02Hの場合、条件成立時の物理アドレス9000H番地にあるJRS cc2, \$+20Hの動作は下記のとおりです。

|     | NB  | CB  | PC(論理アドレス)    |
|-----|-----|-----|---------------|
| 実行前 | 02H | 01H | 9000H         |
|     |     | ↓   | 9002H+(20H-2) |
| 実行後 | 02H | 02H | 9020H         |

上記の例では物理アドレス011020Hへ分岐します。MODEL0/1ではNB, CBがないため物理アドレス9020Hへ分岐します。

条件不成立時、物理アドレス9000H番地のJRS cc2, rrの動作は下記のとおりです。

|     | NB  | CB  | PC(論理アドレス) |
|-----|-----|-----|------------|
| 実行前 | 02H | 01H | 9000H      |
|     |     | ↓   |            |
| 実行後 | 01H | 01H | 9003H      |

MODEL0/1ではNB, CBはありません。

**LD r, r' /////////////// Load r' reg. into r reg. /////////////// 1 cycle //**

機能 r r'

r'レジスタ(A/B/L/H)の内容をrレジスタ(A/B/L/H)にロードします。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB   | LSB     |
|-----|-------|---------|
|     | 0 1 0 | r' 0 r' |

| r' \ r | A<br>(0,0) | B<br>(0,1) | L<br>(1,0) | H<br>(1,1) |
|--------|------------|------------|------------|------------|
| A(0,0) | 40H        | 41H        | 42H        | 43H        |
| B(0,1) | 48H        | 49H        | 4AH        | 4BH        |
| L(1,0) | 50H        | 51H        | 52H        | 53H        |
| H(1,1) | 58H        | 59H        | 5AH        | 5BH        |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

| 例 | 設定値 |     | 結果  |     |    |   |   |   |
|---|-----|-----|-----|-----|----|---|---|---|
|   | r   | r'  | r   | r'  | SC |   |   |   |
|   |     |     |     |     | N  | V | C | Z |
|   | 5AH | 42H | 42H | 42H | —  | — | — | — |

(r r')

**LD A, BR /////////////// Load BR reg. into A reg. /////////////// 2 cycle //**

機能 A BR

BRレジスタの内容をAレジスタにロードします。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 1 0 0 0 0 0 0 | C0H |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

| 例 | 設定値 |     | 結果  |     |    |   |   |   |
|---|-----|-----|-----|-----|----|---|---|---|
|   | A   | BR  | A   | BR  | SC |   |   |   |
|   |     |     |     |     | N  | V | C | Z |
|   | 5AH | 42H | 42H | 42H | —  | — | — | — |

**LD A, SC /////////////// Load SC into A reg. /////////////// 2 cycle //**

機能 A SC

システムコンディションフラグ(SC)の内容をAレジスタにロードします。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 1 0 0 0 0 0 1 | C1H |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

| 例 | 設定値 |     | 結果  |     |    |   |   |   |
|---|-----|-----|-----|-----|----|---|---|---|
|   | A   | SC  | A   | SC  | SC |   |   |   |
|   |     |     |     |     | N  | V | C | Z |
|   | 5AH | 42H | 42H | 42H | —  | — | — | — |

**LD A, er** // Load er reg. into A reg. // 2 cycle //

機能 A er

erレジスタ(NB/EP/XP/YP)の内容をAレジスタにロードします。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB       |  |
|-----|-----------------|-----------|--|
|     | 1 1 0 0 1 1 1 0 | CEH       |  |
|     | 1 1 0 0 1 0 er  | C8H ~ CBH |  |

| er    | ニーモニック   | コード |
|-------|----------|-----|
| NB 00 | LD A, NB | C8H |
| EP 01 | LD A, EP | C9H |
| XP 10 | LD A, XP | CAH |
| YP 11 | LD A, YP | CBH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

注意 MODEL0/1では本命令が使用できません。

| 例 | 設定値 |     | 結果  |     |    |   |   |
|---|-----|-----|-----|-----|----|---|---|
|   | A   | er  | A   | er  | SC |   |   |
|   |     |     |     |     | N  | V | C |
|   | 5AH | 42H | 42H | 42H | —  | — | — |

**LD BR, A** // Load A reg. into BR reg. // 2 cycle //

機能 BR A

Aレジスタの内容をBRレジスタにロードします。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 1 0 0 0 0 1 0 | C2H |  |

| 例 | 設定値 |     | 結果  |     |    |   |   |
|---|-----|-----|-----|-----|----|---|---|
|   | BR  | A   | BR  | A   | SC |   |   |
|   |     |     |     |     | N  | V | C |
|   | 5AH | 42H | 42H | 42H | —  | — | — |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD SC, A** // Load A reg. into SC // 3 cycle //

機能 SC A

Aレジスタの内容をシステムコンディションフラグ(SC)にロードします。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 1 0 0 0 0 1 1 | C3H |  |

| 例 | 設定値 |     |     |     | 結果 |    |   |   |
|---|-----|-----|-----|-----|----|----|---|---|
|   | SC  | A   | SC  | A   | SC |    |   |   |
|   |     |     |     |     | I1 | I0 | U | D |
|   | 5AH | 42H | 42H | 42H | 0  | 1  | 0 | 0 |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | ↑  | ↑  | ↑ | ↑ | ↑ | ↑ | ↑ | ↑ |

**LD er, A** /////////////// Load A reg. into er reg. /////////////// 2 or 3 cycle //**機能** er A

Aレジスタの内容をerレジスタ(NB/EP/XP/YP)にロードします。

**モード** Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB |           |
|-----|-----------------|-----|-----------|
|     | 1 1 0 0 1 1 1 0 |     | CEH       |
|     | 1 1 0 0 1 1 er  |     | CCH ~ CFH |

| 例 | 設定値 |     | 結果  |     |    |   |   |
|---|-----|-----|-----|-----|----|---|---|
|   | er  | A   | er  | A   | SC |   |   |
|   |     |     |     |     | N  | V | C |
|   | 5AH | 42H | 42H | 42H | —  | — | — |

| er    | ニーモニック   | コード |
|-------|----------|-----|
| NB 00 | LD NB, A | CCH |
| EP 01 | LD EP, A | CDH |
| XP 10 | LD XP, A | CEH |
| YP 11 | LD YP, A | CFH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | — |

**注意** MODEL0/1では本命令が使用できません。**LD [BR:ll], r** /////////////// Load r reg. into location [BR:ll] /////////////// 3 cycle //**機能** [BR:ll] r

rレジスタ(A/B/L/H)の内容をBRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されるデータメモリにロードします。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: レジスタ直接

Dst: 8ビット絶対

| コード | MSB           | LSB |           |
|-----|---------------|-----|-----------|
|     | 0 1 1 1 1 0 r |     | 78H ~ 7BH |
|     | l l           |     | ll        |

| 例 | 設定値     |     | 結果      |     |    |   |   |
|---|---------|-----|---------|-----|----|---|---|
|   | [BR:ll] | r   | [BR:ll] | r   | SC |   |   |
|   |         |     |         |     | N  | V | C |
|   | 5AH     | 42H | 42H     | 42H | —  | — | — |

| r    | ニーモニック        | コード |
|------|---------------|-----|
| A 00 | LD [BR:ll], A | 78H |
| B 01 | LD [BR:ll], B | 79H |
| L 10 | LD [BR:ll], L | 7AH |
| H 11 | LD [BR:ll], H | 7BH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | — |

**LD [hhll], r** // Load r reg. into location [hhll] // 5 cycle //**機能** [hhll] r

rレジスタ(A/B/L/H)の内容を16ビット絶対アドレスhhllでアドレス指定されるデータメモリにロードします。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: レジスタ直接

Dst: 16ビット絶対

**例**

| [hhll] | r   | 設定値    |     | 結果 |   |   |   |
|--------|-----|--------|-----|----|---|---|---|
|        |     | [hhll] | r   | SC |   |   |   |
| N      | V   | C      | Z   |    |   |   |   |
| 5AH    | 42H | 42H    | 42H | —  | — | — | — |

**コード**

| MSB     | LSB       |
|---------|-----------|
| 1 1 0 0 | 1 1 1 0   |
| CEH     |           |
| 1 1 0 1 | 0 1 r     |
|         | D4H ~ D7H |
| l l     | ll        |
| h h     | hh        |

| r    | ニーモニック       | コード |
|------|--------------|-----|
| A 00 | LD [hhll], A | D4H |
| B 01 | LD [hhll], B | D5H |
| L 10 | LD [hhll], L | D6H |
| H 11 | LD [hhll], H | D7H |

**フラグ**

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| -  | -  | - | - | - | - | - | - |

**LD [HL], r** // Load r reg. into location [HL] // 2 cycle //**機能** [HL] r

rレジスタ(A/B/L/H)の内容をHLレジスタでアドレス指定されるデータメモリにロードします。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: レジスタ直接

Dst: レジスタ間接

**例**

| [HL] | r   | 設定値  |     | 結果 |   |   |   |
|------|-----|------|-----|----|---|---|---|
|      |     | [HL] | r   | SC |   |   |   |
| N    | V   | C    | Z   |    |   |   |   |
| 5AH  | 42H | 42H  | 42H | —  | — | — | — |

**コード**

| MSB     | LSB       |
|---------|-----------|
| 0 1 1 0 | 1 0 r     |
|         | 68H ~ 6BH |

| r    | ニーモニック     | コード |
|------|------------|-----|
| A 00 | LD [HL], A | 68H |
| B 01 | LD [HL], B | 69H |
| L 10 | LD [HL], L | 6AH |
| H 11 | LD [HL], H | 6BH |

**フラグ**

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| -  | -  | - | - | - | - | - | - |

**LD [IX], r** ////////////////////////////////////////////////////////////////// Load r reg. into location [IX] ////////////////////////////////////////////////////////////////// 2 cycle //

機能 [IX] r

rレジスタ(A/B/L/H)の内容をIXレジスタでアドレス指定されるデータメモリにロードします。

XPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: レジスタ直接

Dst: レジスタ間接

例

| [IX] | r   | 設定値  |     | 結果 |   |   |   |
|------|-----|------|-----|----|---|---|---|
|      |     | [IX] | r   | SC |   | N | V |
| 5AH  | 42H | 42H  | 42H | —  | — | — | — |

コード

| MSB         | LSB |
|-------------|-----|
| 0 1 1 0 0 0 | r   |

60H~63H

| r    | ニーモニック     | コード |
|------|------------|-----|
| A 00 | LD [IX], A | 60H |
| B 01 | LD [IX], B | 61H |
| L 10 | LD [IX], L | 62H |
| H 11 | LD [IX], H | 63H |

フラグ

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| -  | -  | - | - | - | - | - | - |

**LD [IY], r** ////////////////////////////////////////////////////////////////// Load r reg. into location [IY] ////////////////////////////////////////////////////////////////// 2 cycle //

機能 [IY] r

rレジスタ(A/B/L/H)の内容をIYレジスタでアドレス指定されるデータメモリにロードします。

YPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: レジスタ直接

Dst: レジスタ間接

例

| [IY] | r   | 設定値  |     | 結果 |   |   |   |
|------|-----|------|-----|----|---|---|---|
|      |     | [IY] | r   | SC |   | N | V |
| 5AH  | 42H | 42H  | 42H | —  | — | — | — |

コード

| MSB         | LSB |
|-------------|-----|
| 0 1 1 1 0 0 | r   |

70H~73H

| r    | ニーモニック     | コード |
|------|------------|-----|
| A 00 | LD [IY], A | 70H |
| B 01 | LD [IY], B | 71H |
| L 10 | LD [IY], L | 72H |
| H 11 | LD [IY], H | 73H |

フラグ

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| -  | -  | - | - | - | - | - | - |

**LD [IX+dd], r** ////////////////////////////////////////////////////////////////// Load r reg. into location [IX + dd] ////////////////////////////////////////////////////////////////// 4 cycle //**機能** [IX+dd] r

レジスタ(A/B/L/H)の内容をIXレジスタの内容とディスプレースメントddの和でアドレス指定されたデータメモリにロードします。  
ddは符号付きデータとして扱われ、範囲は-128 ~ 127です。  
XPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: レジスタ直接

Dst: ディスプレースメント付きレジスタ間接

| 例 | 設定値     |     | 結果      |     |    |   |   |
|---|---------|-----|---------|-----|----|---|---|
|   | [IX+dd] | r   | [IX+dd] | r   | SC |   |   |
|   |         |     |         |     | N  | V | C |
|   | 5AH     | 42H | 42H     | 42H | —  | — | — |

| コード  | MSB             | LSB                |  |
|------|-----------------|--------------------|--|
|      | 1 1 0 0 1 1 1 0 | CEH                |  |
|      | 0 1 0 r 1 0 0   | 44H, 4CH, 54H, 5CH |  |
|      | d d             | dd                 |  |
| r    | ニーモニック          | コード                |  |
| A 00 | LD [IX+dd], A   | 44H                |  |
| B 01 | LD [IX+dd], B   | 4CH                |  |
| L 10 | LD [IX+dd], L   | 54H                |  |
| H 11 | LD [IX+dd], H   | 5CH                |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD [IY+dd], r** ////////////////////////////////////////////////////////////////// Load r reg. into location [IY + dd] ////////////////////////////////////////////////////////////////// 4 cycle //**機能** [IY+dd] r

レジスタ(A/B/L/H)の内容をIYレジスタの内容とディスプレースメントddの和でアドレス指定されたデータメモリにロードします。  
ddは符号付きデータとして扱われ、範囲は-128 ~ 127です。  
YPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: レジスタ直接

Dst: ディスプレースメント付きレジスタ間接

| 例 | 設定値     |     | 結果      |     |    |   |   |
|---|---------|-----|---------|-----|----|---|---|
|   | [IY+dd] | r   | [IY+dd] | r   | SC |   |   |
|   |         |     |         |     | N  | V | C |
|   | 5AH     | 42H | 42H     | 42H | —  | — | — |

| コード  | MSB             | LSB                |  |
|------|-----------------|--------------------|--|
|      | 1 1 0 0 1 1 1 0 | CEH                |  |
|      | 0 1 0 r 1 0 1   | 45H, 4DH, 55H, 5DH |  |
|      | d d             | dd                 |  |
| r    | ニーモニック          | コード                |  |
| A 00 | LD [IY+dd], A   | 45H                |  |
| B 01 | LD [IY+dd], B   | 4DH                |  |
| L 10 | LD [IY+dd], L   | 55H                |  |
| H 11 | LD [IY+dd], H   | 5DH                |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD [IX+L], r** ////////////// Load r reg. into location [IX + L] ////////////// 4 cycle //**機能** [IX+L] r

rレジスタ(A/B/L/H)の内容をIXレジスタの内容と  
Lレジスタの内容の和でアドレス指定されたデー  
タメモリにロードします。

Lレジスタの内容は符号付きデータとして扱わ  
れ、範囲は-128 ~ 127です。

XPレジスタの内容がデータメモリのページアド  
レスになります(MODEL2/3)。

**モード** Src: レジスタ直接

Dst: インデックスレジスタ付きレジスタ間接

**例**

| [IX+L] | r   | 設定値    |     | 結果 |   |   |   |
|--------|-----|--------|-----|----|---|---|---|
|        |     | [IX+L] | r   | SC |   | N | V |
| 5AH    | 42H | 42H    | 42H | —  | — | — | — |

| コード | MSB             | LSB                |  |
|-----|-----------------|--------------------|--|
|     | 1 1 0 0 1 1 1 0 | CEH                |  |
|     | 0 1 0 r 1 1 1 0 | 46H, 4EH, 56H, 5EH |  |

| r    | ニーモニック       | コード |
|------|--------------|-----|
| A 00 | LD [IX+L], A | 46H |
| B 01 | LD [IX+L], B | 4EH |
| L 10 | LD [IX+L], L | 56H |
| H 11 | LD [IX+L], H | 5EH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD [IY+L], r** ////////////// Load r reg. into location [IY + L] ////////////// 4 cycle //**機能** [IY+L] r

rレジスタ(A/B/L/H)の内容をIYレジスタの内容と  
Lレジスタの内容の和でアドレス指定されたデー  
タメモリにロードします。

Lレジスタの内容は符号付きデータとして扱わ  
れ、範囲は-128 ~ 127です。

YPレジスタの内容がデータメモリのページアド  
レスになります(MODEL2/3)。

**モード** Src: レジスタ直接

Dst: インデックスレジスタ付きレジスタ間接

| [IY+L] | r   | 設定値    |     | 結果 |   |   |   |
|--------|-----|--------|-----|----|---|---|---|
|        |     | [IY+L] | r   | SC |   | N | V |
| 5AH    | 42H | 42H    | 42H | —  | — | — | — |

| コード | MSB             | LSB                |  |
|-----|-----------------|--------------------|--|
|     | 1 1 0 0 1 1 1 0 | CEH                |  |
|     | 0 1 0 r 1 1 1 1 | 47H, 4FH, 57H, 5FH |  |

| r    | ニーモニック       | コード |
|------|--------------|-----|
| A 00 | LD [IY+L], A | 47H |
| B 01 | LD [IY+L], B | 4FH |
| L 10 | LD [IY+L], L | 57H |
| H 11 | LD [IY+L], H | 5FH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD r, #nn** ////////////// Load immediate data nn into r reg. ////////////// 2 cycle //

機能 r nn

8ビット即値データnnをrレジスタ(A/B/L/H)にロードします。

モード Src: 即値データ

Dst: レジスタ直接

| コード | MSB           | LSB |           |
|-----|---------------|-----|-----------|
|     | 1 0 1 1 0 0 r |     | B0H ~ B3H |
|     | n n           |     |           |

| r    | ニーモニック    | コード |
|------|-----------|-----|
| A 00 | LD A, #nn | B0H |
| B 01 | LD B, #nn | B1H |
| L 10 | LD L, #nn | B2H |
| H 11 | LD H, #nn | B3H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

| 例 | 設定値 |     | 結果  |     |    |   |   |
|---|-----|-----|-----|-----|----|---|---|
|   | r   | nn  | r   | nn  | SC |   |   |
|   |     |     |     |     | N  | V | C |
|   | 5AH | 42H | 42H | 42H | —  | — | — |

**LD BR, #hh** ////////////// Load immediate data hh into BR reg. ////////////// 2 cycle //

機能 BR hh

8ビット即値データhhをBRレジスタにロードします。

モード Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB |     |
|-----|-----------------|-----|-----|
|     | 1 0 1 1 0 1 0 0 |     | B4H |
|     | h h             |     |     |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

| 例 | 設定値 |     | 結果  |     |    |   |   |
|---|-----|-----|-----|-----|----|---|---|
|   | BR  | hh  | BR  | hh  | SC |   |   |
|   |     |     |     |     | N  | V | C |
|   | 5AH | 42H | 42H | 42H | —  | — | — |

**LD SC, #nn** ////////////// Load immediate data nn into SC ////////////// 3 cycle //

機能 SC nn

8ビット即値データnnをシステムコンディションフラグ(SC)にセットします。

モード Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB |     |
|-----|-----------------|-----|-----|
|     | 1 0 0 1 1 1 1 1 |     | 9FH |
|     | n n             |     |     |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | ↑  | ↑  | ↑ | ↑ | ↑ | ↑ | ↑ | ↑ |

| 例 | 設定値 |     | 結果  |     |    |    |   |   |   |   |   |   |
|---|-----|-----|-----|-----|----|----|---|---|---|---|---|---|
|   | SC  | nn  | SC  | nn  | SC |    |   |   |   |   |   |   |
|   |     |     |     |     | I1 | I0 | U | D | N | V | C | Z |
|   | 5AH | 42H | 42H | 42H | 0  | 1  | 0 | 0 | 0 | 0 | 1 | 0 |

**LD NB, #bb** ////////////// Load immediate data bb into NB reg. ////////////// 4 cycle //

機能 NB bb

8ビット即値データbbをニューコードバンクレジスタ(NB)にロードします。

モード Src: 即値データ

Dst: レジスタ直接

| コード | MSB                                                                               | LSB |   |   |   |   |   |   |
|-----|-----------------------------------------------------------------------------------|-----|---|---|---|---|---|---|
|     |  | CEH |   |   |   |   |   |   |
|     |  | C4H |   |   |   |   |   |   |
|     |  | bb  |   |   |   |   |   |   |
| フラグ | I1                                                                                | I0  | U | D | N | V | C | Z |
|     | -                                                                                 | -   | - | - | - | - | - | - |

| 例 | 設定値 |     | 結果  |     |    |   |   |   |
|---|-----|-----|-----|-----|----|---|---|---|
|   | NB  | bb  | NB  | bb  | SC |   |   |   |
|   |     |     |     |     | N  | V | C | Z |
|   | 5AH | 42H | 42H | 42H | —  | — | — | — |

注意 MODEL0/1では本命令が使用できません。

**LD EP, #pp** ////////////// Load immediate data pp into EP reg. ////////////// 3 cycle //

機能 EP pp

8ビット即値データppをエクスパンドページレジスタ(EP)にロードします。

モード Src: 即値データ

Dst: レジスタ直接

| コード | MSB                                                                                 | LSB |   |   |   |   |   |   |
|-----|-------------------------------------------------------------------------------------|-----|---|---|---|---|---|---|
|     |    | CEH |   |   |   |   |   |   |
|     |    | C5H |   |   |   |   |   |   |
|     |  | pp  |   |   |   |   |   |   |
| フラグ | I1                                                                                  | I0  | U | D | N | V | C | Z |
|     | -                                                                                   | -   | - | - | - | - | - | - |

| 例 | 設定値 |     | 結果  |     |    |   |   |   |
|---|-----|-----|-----|-----|----|---|---|---|
|   | EP  | pp  | EP  | pp  | SC |   |   |   |
|   |     |     |     |     | N  | V | C | Z |
|   | 5AH | 42H | 42H | 42H | —  | — | — | — |

注意 MODEL0/1では本命令が使用できません。

**LD XP, #pp** ////////////// Load immediate data pp into XP reg. ////////////// 3 cycle //

機能 XP pp

8ビット即値データppをIX用エクスパンドページレジスタ(XP)にロードします。

モード Src: 即値データ

Dst: レジスタ直接

| コード | MSB                                                                                 | LSB |   |   |   |   |   |   |
|-----|-------------------------------------------------------------------------------------|-----|---|---|---|---|---|---|
|     |  | CEH |   |   |   |   |   |   |
|     |  | C6H |   |   |   |   |   |   |
|     |  | pp  |   |   |   |   |   |   |
| フラグ | I1                                                                                  | I0  | U | D | N | V | C | Z |
|     | -                                                                                   | -   | - | - | - | - | - | - |

| 例 | 設定値 |     | 結果  |     |    |   |   |   |
|---|-----|-----|-----|-----|----|---|---|---|
|   | XP  | pp  | XP  | pp  | SC |   |   |   |
|   |     |     |     |     | N  | V | C | Z |
|   | 5AH | 42H | 42H | 42H | —  | — | — | — |

注意 MODEL0/1では本命令が使用できません。

**LD YP, #pp** ////////////// Load immediate data pp into YP reg. ////////////// 3 cycle //

**機能** YP pp  
8ビット即値データppをYP用エクスパンドページレジスタ(YP)にロードします。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 1 0 0 0 1 1 1 | C7H |  |
|     | p p             | pp  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**モード** Src: 即値データ  
Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |     |    |   |
|---|-----|-----|-----|-----|----|---|
|   | YP  | pp  | YP  | pp  | SC |   |
|   |     |     |     |     | N  | V |
|   | 5AH | 42H | 42H | 42H | —  | — |

**注 意** MODEL0/1では本命令が使用できません。

**LD [BR:l], #nn** ////////////// Load immediate data nn into location [BR:l] ////////////// 4 cycle //

**機能** [BR:l] nn  
8ビット即値データnnをBRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されるデータメモリにロードします。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 1 1 1 0 1 | DDH |  |
|     | l l             | ll  |  |
|     | n n             | nn  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**モード** Src: 即値データ  
Dst: 8ビット絶対

| 例 | 設定値    |     | 結果     |     |    |   |
|---|--------|-----|--------|-----|----|---|
|   | [BR:l] | nn  | [BR:l] | nn  | SC |   |
|   |        |     |        |     | N  | V |
|   | 5AH    | 42H | 42H    | 42H | —  | — |

**LD [HL], #nn** ////////////// Load immediate data nn into location [HL] ////////////// 3 cycle //

**機能** [HL] nn  
8ビット即値データnnをHLレジスタでアドレス指定されるデータメモリにロードします。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 0 1 1 0 1 0 1 | B5H |  |
|     | n n             | nn  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**モード** Src: 即値データ

Dst: レジスタ間接

| 例 | 設定値  |     | 結果   |     |    |   |
|---|------|-----|------|-----|----|---|
|   | [HL] | nn  | [HL] | nn  | SC |   |
|   |      |     |      |     | N  | V |
|   | 5AH  | 42H | 42H  | 42H | —  | — |

**LD [ir], #nn** ////////////// Load immediate data nn into location [ir reg.] ////////////// 3 cycle //**機能** [ir] nn

8ビット即値データnnをirレジスタ(IX/IY)でアドレス指定されるデータメモリにロードします。

XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります (MODEL2/3)。

**モード** Src: 即値データ

Dst: レジスタ間接

**例**

| [ir] | nn  | 設定値  |     | 結果 |   |   |   |
|------|-----|------|-----|----|---|---|---|
|      |     | [ir] | nn  | SC |   | N | V |
| 5AH  | 42H | 42H  | 42H | —  | — | — | — |

| コード | MSB              | LSB      |
|-----|------------------|----------|
|     | 1 0 1 1 0 1 1 ir | B6H, B7H |

nn

| ir   | ニーモニック       | コード |
|------|--------------|-----|
| IX 0 | LD [IX], #nn | B6H |
| IY 1 | LD [IY], #nn | B7H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD r, [BR:ll]** ////////////// Load location [BR:ll] into r reg. ////////////// 3 cycle //**機能** r [BR:ll]

BRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されるデータメモリの内容をrレジスタ(A/B/L/H)にロードします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: 8ビット絶対

Dst: レジスタ直接

**例**

| r   | [BR:ll] | 設定値 |         | 結果 |   |   |   |
|-----|---------|-----|---------|----|---|---|---|
|     |         | r   | [BR:ll] | SC |   | N | V |
| 5AH | 42H     | 42H | 42H     | —  | — | — | — |

| コード | MSB           | LSB                |
|-----|---------------|--------------------|
|     | 0 1 0 r 1 0 0 | 44H, 4CH, 54H, 5CH |

ll

| r    | ニーモニック        | コード |
|------|---------------|-----|
| A 00 | LD A, [BR:ll] | 44H |
| B 01 | LD B, [BR:ll] | 4CH |
| L 10 | LD L, [BR:ll] | 54H |
| H 11 | LD H, [BR:ll] | 5CH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD [HL], [BR:ll]** // Load location [BR:ll] into location [HL] // 4 cycle //

機能 [HL] [BR:ll]

BRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されるデータメモリの内容をHLレジスタでアドレス指定されるデータメモリにロードします。  
EPレジスタの内容がデータメモリ双方のページアドレスになります(MODEL2/3)。

モード Src: 8ビット絶対

Dst: レジスタ間接

| 例 | 設定値  |         | 結果   |         |    |   |   |
|---|------|---------|------|---------|----|---|---|
|   | [HL] | [BR:ll] | [HL] | [BR:ll] | SC |   |   |
|   |      |         |      |         | N  | V | C |
|   | 5AH  | 42H     | 42H  | 42H     | —  | — | — |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 1 1 0 1 1 0 0 | 6CH |  |
|     | l l             | ll  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | — |

**LD [ir], [BR:ll]** // Load location [BR:ll] into location [ir reg.] // 4 cycle //

機能 [ir] [BR:ll]

BRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されるデータメモリの内容をirレジスタ(IX/IY)でアドレス指定されるデータメモリにロードします。  
EPレジスタの内容がデータメモリ[BR:ll]のページアドレス、XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリ[ir]のページアドレスになります(MODEL2/3)。

モード Src: 8ビット絶対

Dst: レジスタ間接

| 例 | 設定値  |         | 結果   |         |    |   |   |
|---|------|---------|------|---------|----|---|---|
|   | [ir] | [BR:ll] | [ir] | [BR:ll] | SC |   |   |
|   |      |         |      |         | N  | V | C |
|   | 5AH  | 42H     | 42H  | 42H     | —  | — | — |

| コード | MSB              | LSB     |  |
|-----|------------------|---------|--|
|     | 0 1 1 ir 0 1 0 0 | 64H、74H |  |
|     | l l              | ll      |  |

| ir   | ニーモニック           | コード |
|------|------------------|-----|
| IX 0 | LD [IX], [BR:ll] | 64H |
| IY 1 | LD [IY], [BR:ll] | 74H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | — |

**LD r, [hhll]** ////////////////////////////////////////////////////////////////// Load location [hhll] into r reg. ////////////////////////////////////////////////////////////////// 5 cycle //

機能 r [hhll]

16ビット絶対アドレスhhllでアドレス指定されたデータメモリの内容をrレジスタ(A/B/L/H)にロードします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: 16ビット絶対

Dst: レジスタ直接

| 例 | 設定値 |        | 結果  |        |    |   |   |
|---|-----|--------|-----|--------|----|---|---|
|   | r   | [hhll] | r   | [hhll] | SC |   |   |
|   |     |        |     | N      | V  | C | Z |
|   | 5AH | 42H    | 42H | 42H    | —  | — | — |

| コード | MSB             | LSB       |  |
|-----|-----------------|-----------|--|
|     | 1 1 0 0 1 1 1 0 | CEH       |  |
|     | 1 1 0 1 0 0 r   | D0H ~ D3H |  |
|     | l l             | ll        |  |
|     | h h             | hh        |  |

| r    | ニーモニック       | コード |
|------|--------------|-----|
| A 00 | LD A, [hhll] | D0H |
| B 01 | LD B, [hhll] | D1H |
| L 10 | LD L, [hhll] | D2H |
| H 11 | LD H, [hhll] | D3H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD r, [HL]** ////////////////////////////////////////////////////////////////// Load location [HL] into r reg. ////////////////////////////////////////////////////////////////// 2 cycle //

機能 r [HL]

HLレジスタでアドレス指定されたデータメモリの内容をrレジスタ(A/B/L/H)にロードします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: レジスタ間接

Dst: レジスタ直接

| 例 | 設定値 |      | 結果  |      |    |   |   |
|---|-----|------|-----|------|----|---|---|
|   | r   | [HL] | r   | [HL] | SC |   |   |
|   |     |      |     | N    | V  | C | Z |
|   | 5AH | 42H  | 42H | 42H  | —  | — | — |

| コード | MSB           | LSB                |  |
|-----|---------------|--------------------|--|
|     | 0 1 0 r 1 0 1 | 45H, 4DH, 55H, 5DH |  |

| r    | ニーモニック     | コード |
|------|------------|-----|
| A 00 | LD A, [HL] | 45H |
| B 01 | LD B, [HL] | 4DH |
| L 10 | LD L, [HL] | 55H |
| H 11 | LD H, [HL] | 5DH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD [BR:ll], [HL]** // Load location [HL] into location [BR:ll] // 4 cycle //**機能** [BR:ll] [HL]

HLレジスタでアドレス指定されたデータメモリの内容をBRレジスタの内容を上位バイト、8ビット絶対アドレスを下位バイトとしてアドレス指定されるデータメモリにロードします。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: レジスタ間接

Dst: 8ビット絶対

| 例 | 設定値     |      | 結果      |      |    |   |   |   |
|---|---------|------|---------|------|----|---|---|---|
|   | [BR:ll] | [HL] | [BR:ll] | [HL] | SC |   |   |   |
|   | 5AH     | 42H  | 42H     | 42H  | —  | — | — | — |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 1 1 1 1 1 0 1 | 7DH |  |
|     | l l             | ll  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | — |

**LD [HL], [HL]** // Load location [HL] into location [HL] // 3 cycle //**機能** [HL] [HL]

HLレジスタでアドレス指定されたデータメモリの内容を同じアドレスにロードします。結果的には3サイクルを消費するのみとなります。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: レジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |      | 結果 |   |   |   |
|---|------|------|----|---|---|---|
|   | [HL] | [HL] | SC |   |   |   |
|   | 42H  | 42H  | —  | — | — | — |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 1 1 0 1 1 0 1 | 6DH |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | — |

**LD [ir], [HL]** // Load location [HL] into location [ir reg.] // 3 cycle //**機能** [ir] [HL]

HLレジスタでアドレス指定されたデータメモリの内容をirレジスタ(IX/IY)でアドレス指定されるデータメモリにロードします。  
EPレジスタの内容がデータメモリ[HL]のページアドレス、XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリ[ir]のページアドレスになります(MODEL2/3)。

**モード** Src: レジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |      | 結果   |      |    |   |   |   |
|---|------|------|------|------|----|---|---|---|
|   | [ir] | [HL] | [ir] | [HL] | SC |   |   |   |
|   | 5AH  | 42H  | 42H  | 42H  | —  | — | — | — |

| コード | MSB              | LSB      |  |
|-----|------------------|----------|--|
|     | 0 1 1 ir 0 1 0 1 | 65H, 75H |  |

| ir   | ニーモニック        | コード |
|------|---------------|-----|
| IX 0 | LD [IX], [HL] | 65H |
| IY 1 | LD [IY], [HL] | 75H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | — |

**LD r, [IX]** // Load location [IX] into r reg. // 2 cycle //**機能** r [IX]

IXレジスタでアドレス指定されたデータメモリの内容をrレジスタ(A/B/L/H)にロードします。

XPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: レジスタ間接

Dst: レジスタ直接

**例**

| r   | [IX] | 設定値 |      | 結果 |   |   |   |
|-----|------|-----|------|----|---|---|---|
|     |      | r   | [IX] | SC |   | N | V |
| 5AH | 42H  | 42H | 42H  | —  | — | — | — |

**コード**

MSB

LSB

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

46H, 4EH, 56H, 5EH

| r    | ニーモニック     | コード |
|------|------------|-----|
| A 00 | LD A, [IX] | 46H |
| B 01 | LD B, [IX] | 4EH |
| L 10 | LD L, [IX] | 56H |
| H 11 | LD H, [IX] | 5EH |

**フラグ**

|    |    |   |   |   |   |   |   |
|----|----|---|---|---|---|---|---|
| I1 | I0 | U | D | N | V | C | Z |
| -  | -  | - | - | - | - | - | - |

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

**LD [BR:l], [IX]** // Load location [IX] into location [BR:l] // 4 cycle //**機能** [BR:l] [IX]

IXレジスタでアドレス指定されたデータメモリの内容をBRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されるデータメモリにロードします。

EPレジスタの内容がデータメモリ[BR:l]のページアドレス、XPレジスタ内容がデータメモリ[IX]のページアドレスになります(MODEL2/3)。

**モード** Src: レジスタ間接

Dst: 8ビット絶対

**例**

| [BR:l] | [IX] | 設定値    |      | 結果 |   |   |   |
|--------|------|--------|------|----|---|---|---|
|        |      | [BR:l] | [IX] | SC |   | N | V |
| 5AH    | 42H  | 42H    | 42H  | —  | — | — | — |

**コード**

MSB

LSB

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

7EH

|  |  |  |   |   |  |  |  |
|--|--|--|---|---|--|--|--|
|  |  |  | l | l |  |  |  |
|--|--|--|---|---|--|--|--|

l

**フラグ**

|    |    |   |   |   |   |   |   |
|----|----|---|---|---|---|---|---|
| I1 | I0 | U | D | N | V | C | Z |
| -  | -  | - | - | - | - | - | - |

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

**LD [HL], [IX]** // Load location [IX] into location [HL] // 3 cycle //**機能** [HL] [IX]

IXレジスタでアドレス指定されたデータメモリの内容をHLレジスタでアドレス指定されるデータメモリにロードします。

EPレジスタの内容がデータメモリ[HL]のページアドレス、XPレジスタ内容がデータメモリ[IX]のページアドレスになります(MODEL2/3)。

**モード** Src: レジスタ間接

Dst: レジスタ間接

**例**

| [HL] | [IX] | 設定値  |      | 結果 |   |   |   |
|------|------|------|------|----|---|---|---|
|      |      | [HL] | [IX] | SC |   | N | V |
| 5AH  | 42H  | 42H  | 42H  | —  | — | — | — |

**コード**

MSB

LSB

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

6EH

**フラグ**

|    |    |   |   |   |   |   |   |
|----|----|---|---|---|---|---|---|
| I1 | I0 | U | D | N | V | C | Z |
| -  | -  | - | - | - | - | - | - |

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

**LD [ir], [IX]** /////////////// Load location [IX] into location [ir reg.] /////////////// 3 cycle //

機能 [ir] [IX]

IXレジスタでアドレス指定されたデータメモリの内容をirレジスタ(IX/IY)でアドレス指定されるデータメモリにロードします。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: レジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |      | 結果   |      |    |   |   |   |
|---|------|------|------|------|----|---|---|---|
|   | [IY] | [IX] | [IY] | [IX] | SC |   |   |   |
|   |      |      |      |      | N  | V | C | Z |
|   | 5AH  | 42H  | 42H  | 42H  | —  | — | — | — |

コード MSB

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

LSB

66H、76H

| ir   | ニーモニック        | コード |
|------|---------------|-----|
| IX 0 | LD [IX], [IX] | 66H |
| IY 1 | LD [IY], [IX] | 76H |

フラグ

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| -  | -  | - | - | - | - | - | - |

**LD r, [IY]** /////////////// Load location [IY] into r reg. /////////////// 2 cycle //

機能 r [IY]

IYレジスタでアドレス指定されたデータメモリの内容をrレジスタ(A/B/L/H)にロードします。  
YPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: レジスタ間接

Dst: レジスタ直接

| 例 | 設定値 |      | 結果  |      |    |   |   |   |
|---|-----|------|-----|------|----|---|---|---|
|   | r   | [IY] | r   | [IY] | SC |   |   |   |
|   |     |      |     |      | N  | V | C | Z |
|   | 5AH | 42H  | 42H | 42H  | —  | — | — | — |

コード MSB

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

LSB

47H, 4FH, 57H, 5FH

| r    | ニーモニック     | コード |
|------|------------|-----|
| A 00 | LD A, [IY] | 47H |
| B 01 | LD B, [IY] | 4FH |
| L 10 | LD L, [IY] | 57H |
| H 11 | LD H, [IY] | 5FH |

フラグ

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| -  | -  | - | - | - | - | - | - |

**LD [BR:ll], [IY]** // Load location [IY] into location [BR:ll] // 4 cycle //

機能 [BR:ll] [IY]

IYレジスタでアドレス指定されたデータメモリの内容をBRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されるデータメモリにロードします。  
EPレジスタの内容がデータメモリ[BR:ll]のページアドレス、YPレジスタ内容がデータメモリ[IY]のページアドレスになります(MODEL2/3)。

モード Src: レジスタ間接

Dst: 8ビット絶対

例

| [BR:ll] | [IY] | [BR:ll] | [IY] | 結果 |   |   |   |
|---------|------|---------|------|----|---|---|---|
|         |      |         |      | SC |   |   |   |
|         |      | N       | V    | C  | Z |   |   |
| 5AH     | 42H  | 42H     | 42H  | —  | — | — | — |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 1 1 1 1 1 1 1 | 7FH |  |
|     | l l             | ll  |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | — |

**LD [HL], [IY]** // Load location [IY] into location [HL] // 3 cycle //

機能 [HL] [IY]

IYレジスタでアドレス指定されたデータメモリの内容をHLレジスタでアドレス指定されるデータメモリにロードします。  
EPレジスタの内容がデータメモリ[HL]のページアドレス、YPレジスタ内容がデータメモリ[IY]のページアドレスになります(MODEL2/3)。

モード Src: レジスタ間接

Dst: レジスタ間接

例

| [HL] | [IY] | [HL] | [IY] | 結果 |   |   |   |
|------|------|------|------|----|---|---|---|
|      |      |      |      | SC |   |   |   |
|      |      | N    | V    | C  | Z |   |   |
| 5AH  | 42H  | 42H  | 42H  | —  | — | — | — |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 1 1 0 1 1 1 1 | 6FH |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | — |

**LD [ir], [IY]** // Load location [IY] into location [ir reg.] // 3 cycle //

機能 [ir] [IY]

Irレジスタでアドレス指定されたデータメモリの内容をIrレジスタ(IX/IY)でアドレス指定されるデータメモリにロードします。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: レジスタ間接

Dst: レジスタ間接

例

| [IX] | [IY] | [IX] | [IY] | 結果 |   |   |   |
|------|------|------|------|----|---|---|---|
|      |      |      |      | SC |   |   |   |
|      |      | N    | V    | C  | Z |   |   |
| 5AH  | 42H  | 42H  | 42H  | —  | — | — | — |

| コード | MSB              | LSB      |  |
|-----|------------------|----------|--|
|     | 0 1 1 ir 0 1 1 1 | 67H, 77H |  |

  

| ir | ニーモニック | コード           |
|----|--------|---------------|
| IX | 0      | LD [IX], [IY] |
| IY | 1      | LD [IY], [IY] |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | — |

**LD r, [IX+dd]** // Load location [IX + dd] into r reg. // 4 cycle //**機能** r [IX+dd]

IXレジスタの内容とディスプレースメントddの和でアドレス指定されたデータメモリの内容をrレジスタ(A/B/L/H)にロードします。  
ddは符号付きデータとして扱われ、範囲は-128~127です。  
XPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ直接

| 例 | 設定値 |         | 結果  |         |    |   |   |   |   |
|---|-----|---------|-----|---------|----|---|---|---|---|
|   | r   | [IX+dd] | r   | [IX+dd] | SC | N | V | C | Z |
|   | 5AH | 42H     | 42H | 42H     | —  | — | — | — | — |

| コード  | MSB             | LSB                |   |   |   |   |   |   |   |
|------|-----------------|--------------------|---|---|---|---|---|---|---|
|      | 1 1 0 0 1 1 1 0 | CEH                |   |   |   |   |   |   |   |
|      | 0 1 0 r 0 0 0   | 40H, 48H, 50H, 58H |   |   |   |   |   |   |   |
|      | d d             | dd                 |   |   |   |   |   |   |   |
| r    | ニーモニック          | コード                |   |   |   |   |   |   |   |
| A 00 | LD A, [IX+dd]   | 40H                |   |   |   |   |   |   |   |
| B 01 | LD B, [IX+dd]   | 48H                |   |   |   |   |   |   |   |
| L 10 | LD L, [IX+dd]   | 50H                |   |   |   |   |   |   |   |
| H 11 | LD H, [IX+dd]   | 58H                |   |   |   |   |   |   |   |
| フラグ  | I1              | I0                 | U | D | N | V | C | Z |   |
|      | -               | -                  | - | - | - | - | - | - | - |

**LD [HL], [IX+dd]** // Load location [IX + dd] into location [HL] // 5 cycle //**機能** [HL] [IX+dd]

IXレジスタの内容とディスプレースメントddの和でアドレス指定されたデータメモリの内容をHLレジスタでアドレス指定されるデータメモリにロードします。  
ddは符号付きデータとして扱われ、範囲は-128~127です。  
EPレジスタの内容がデータメモリ[HL]のページアドレス、XPレジスタ内容がデータメモリ[IX+dd]のページアドレスになります(MODEL2/3)。

**モード** Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |         | 結果   |         |    |   |   |   |   |
|---|------|---------|------|---------|----|---|---|---|---|
|   | [HL] | [IX+dd] | [HL] | [IX+dd] | SC | N | V | C | Z |
|   | 5AH  | 42H     | 42H  | 42H     | —  | — | — | — | — |

| コード | MSB             | LSB |   |
|-----|-----------------|-----|---|
|     | 1 1 0 0 1 1 1 0 | CEH |   |
|     | 0 1 1 0 0 0 0 0 | 60H |   |
|     | d d             | dd  |   |
| フラグ | I1              | I0  | U |
|     | -               | -   | - |

**LD [ir], [IX+dd]** // Load location [IX + dd] into location [ir reg.] // 5 cycle //**機能** [ir] [IX+dd]

IXレジスタの内容とディスプレースメントddの和でアドレス指定されたデータメモリの内容をirレジスタ(IX/IY)でアドレス指定されるデータメモリにロードします。  
ddは符号付きデータとして扱われ、範囲は-128 ~ 127です。

XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |         | 結果   |         |    |   |   |
|---|------|---------|------|---------|----|---|---|
|   | [ir] | [IX+dd] | [ir] | [IX+dd] | SC |   |   |
|   |      |         |      |         | N  | V | C |
|   | 5AH  | 42H     | 42H  | 42H     | —  | — | — |

| コード  | MSB              |     |   |    |    |   |   |   | LSB     |  |  |  |  |  |
|------|------------------|-----|---|----|----|---|---|---|---------|--|--|--|--|--|
|      | 1                | 1   | 0 | 0  | 1  | 1 | 1 | 0 | CEH     |  |  |  |  |  |
|      | 0                | 1   | 1 | ir | 1  | 0 | 0 | 0 | 68H、78H |  |  |  |  |  |
|      | d d              |     |   |    | dd |   |   |   |         |  |  |  |  |  |
|      |                  |     |   |    |    |   |   |   |         |  |  |  |  |  |
| ir   | ニーモニック           | コード |   |    |    |   |   |   |         |  |  |  |  |  |
| IX 0 | LD [IX], [IX+dd] | 68H |   |    |    |   |   |   |         |  |  |  |  |  |
| IY 1 | LD [IY], [IX+dd] | 78H |   |    |    |   |   |   |         |  |  |  |  |  |
| フラグ  | I1               | I0  | U | D  | N  | V | C | Z |         |  |  |  |  |  |
|      | -                | -   | - | -  | -  | - | - | - | -       |  |  |  |  |  |

**LD r, [IY+dd]** // Load location [IY + dd] into r reg. // 4 cycle //**機能** r [IY+dd]

IYレジスタの内容とディスプレースメントddの和でアドレス指定されたデータメモリの内容をrレジスタ(A/B/L/H)にロードします。  
ddは符号付きデータとして扱われ、範囲は-128 ~ 127です。  
YPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ直接

| 例 | 設定値 |         | 結果  |         |    |   |   |
|---|-----|---------|-----|---------|----|---|---|
|   | r   | [IY+dd] | r   | [IY+dd] | SC |   |   |
|   |     |         |     | N       | V  | C | Z |
|   | 5AH | 42H     | 42H | 42H     | —  | — | — |

| コード  | MSB           |     |   |   |    |   |   |   | LSB             |  |  |  |  |  |
|------|---------------|-----|---|---|----|---|---|---|-----------------|--|--|--|--|--|
|      | 1             | 1   | 0 | 0 | 1  | 1 | 1 | 0 | CEH             |  |  |  |  |  |
|      | 0             | 1   | 0 | r | 0  | 0 | 1 |   | 41H、49H、51H、59H |  |  |  |  |  |
|      | d d           |     |   |   | dd |   |   |   |                 |  |  |  |  |  |
|      |               |     |   |   |    |   |   |   |                 |  |  |  |  |  |
| r    | ニーモニック        | コード |   |   |    |   |   |   |                 |  |  |  |  |  |
| A 00 | LD A, [IY+dd] | 41H |   |   |    |   |   |   |                 |  |  |  |  |  |
| B 01 | LD B, [IY+dd] | 49H |   |   |    |   |   |   |                 |  |  |  |  |  |
| L 10 | LD L, [IY+dd] | 51H |   |   |    |   |   |   |                 |  |  |  |  |  |
| H 11 | LD H, [IY+dd] | 59H |   |   |    |   |   |   |                 |  |  |  |  |  |
| フラグ  | I1            | I0  | U | D | N  | V | C | Z |                 |  |  |  |  |  |
|      | -             | -   | - | - | -  | - | - | - | -               |  |  |  |  |  |

**LD [HL], [IY+dd]** // Load location [IY + dd] into location [HL] // 5 cycle //**機能** [HL] [IY+dd]

IYレジスタの内容とディスプレースメントddの和でアドレス指定されたデータメモリの内容をHLレジスタでアドレス指定されるデータメモリにロードします。  
ddは符号付きデータとして扱われ、範囲は-128 ~ 127です。

EPレジスタの内容がデータメモリ[HL]のページアドレス、YPレジスタ内容がデータメモリ[IY+dd]のページアドレスになります(MODEL2/3)。

**モード** Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |         | 結果   |         |     |         |
|---|------|---------|------|---------|-----|---------|
|   | [HL] | [IY+dd] | [HL] | [IY+dd] | SC  |         |
|   |      | 5AH     | 42H  | 42H     | 42H | N V C Z |
|   |      | —       | —    | —       | —   | —       |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 1 1 0 0 0 0 1 | 61H |  |
|     | d d             | dd  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD [ir], [IY+dd]** // Load location [IY + dd] into location [ir reg.] // 5 cycle //**機能** [ir] [IY+dd]

IYレジスタの内容とディスプレースメントddの和でアドレス指定されたデータメモリの内容をirレジスタ(IX/IY)でアドレス指定されるデータメモリにロードします。  
ddは符号付きデータとして扱われ、範囲は-128 ~ 127です。

XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |         | 結果   |         |     |         |
|---|------|---------|------|---------|-----|---------|
|   | [ir] | [IY+dd] | [ir] | [IY+dd] | SC  |         |
|   |      | 5AH     | 42H  | 42H     | 42H | N V C Z |
|   |      | —       | —    | —       | —   | —       |

| コード | MSB              | LSB      |  |
|-----|------------------|----------|--|
|     | 1 1 0 0 1 1 1 0  | CEH      |  |
|     | 0 1 1 ir 1 0 0 1 | 69H, 79H |  |
|     | d d              | dd       |  |

|    | ir | 二-モニック           | コード |
|----|----|------------------|-----|
| IX | 0  | LD [IX], [IY+dd] | 69H |
| IY | 1  | LD [IY], [IY+dd] | 79H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD r, [IX+L]** // Load location [IX + L] into r reg. // 4 cycle //**機能** r [IX+L]

IXレジスタの内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容をrレジスタ(A/B/L/H)にロードします。

Lレジスタの内容は符号付きデータとして扱われ、範囲は-128~127です。

XPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: インデックスレジスタ付きレジスタ間接

Dst: レジスタ直接

| 例 | 設定値 |        | 結果  |        |    |   |   |   |
|---|-----|--------|-----|--------|----|---|---|---|
|   | r   | [IX+L] | r   | [IX+L] | SC |   |   |   |
|   |     |        |     |        | N  | V | C | Z |
|   | 5AH | 42H    | 42H | 42H    | —  | — | — | — |

| コード | MSB             | LSB                |  |
|-----|-----------------|--------------------|--|
|     | 1 1 0 0 1 1 1 0 | CEH                |  |
|     | 0 1 0 r 0 1 0   | 42H, 4AH, 52H, 5AH |  |

| r    | ニーモニック       | コード |
|------|--------------|-----|
| A 00 | LD A, [IX+L] | 42H |
| B 01 | LD B, [IX+L] | 4AH |
| L 10 | LD L, [IX+L] | 52H |
| H 11 | LD H, [IX+L] | 5AH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD [HL], [IX+L]** // Load location [IX + L] into location [HL] // 5 cycle //**機能** [HL] [IX+L]

IXレジスタの内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容をHLレジスタでアドレス指定されるデータメモリにロードします。

Lレジスタの内容は符号付きデータとして扱われ、範囲は-128~127です。

EPレジスタの内容がデータメモリ[HL]のページアドレス、XPレジスタ内容がデータメモリ[IX+L]のページアドレスになります(MODEL2/3)。

**モード** Src: インデックスレジスタ付きレジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |        | 結果   |        |    |   |   |   |
|---|------|--------|------|--------|----|---|---|---|
|   | [HL] | [IX+L] | [HL] | [IX+L] | SC |   |   |   |
|   |      |        |      |        | N  | V | C | Z |
|   | 5AH  | 42H    | 42H  | 42H    | —  | — | — | — |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 1 1 0 0 0 1 0 | 62H |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD [ir], [IX+L]** // Load location [IX + L] into location [ir reg.] // 5 cycle //**機能** [ir] [IX+L]

IXレジスタの内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容をirレジスタ(IX/IY)でアドレス指定されるデータメモリにロードします。  
Lレジスタの内容は符号付きデータとして扱われ、範囲は-128 ~ 127です。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: インデックスレジスタ付きレジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |        | 結果   |        |    |   |   |   |
|---|------|--------|------|--------|----|---|---|---|
|   | [ir] | [IX+L] | [ir] | [IX+L] | SC |   |   |   |
|   |      |        |      |        | N  | V | C | Z |
|   | 5AH  | 42H    | 42H  | 42H    | —  | — | — | — |

| コード | MSB              | LSB             |
|-----|------------------|-----------------|
|     | 1 1 0 0 1 1 1 0  | CEH             |
|     | 0 1 1 ir 1 0 1 0 | 6AH、7AH         |
|     |                  |                 |
| r   | ニーモニック           | コード             |
| IX  | 0                | LD [IX], [IX+L] |
| IY  | 1                | LD [IY], [IX+L] |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD r, [IY+L]** // Load location [IY + L] into r reg. // 4 cycle //**機能** r [IY+L]

IYレジスタの内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容をrレジスタ(A/B/L/H)にロードします。  
Lレジスタの内容は符号付きデータとして扱われ、範囲は-128 ~ 127です。  
YPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: インデックスレジスタ付きレジスタ間接

Dst: レジスタ直接

| 例 | 設定値 |        | 結果  |        |    |   |   |
|---|-----|--------|-----|--------|----|---|---|
|   | r   | [IY+L] | r   | [IY+L] | SC |   |   |
|   |     |        |     | N      | V  | C | Z |
|   | 5AH | 42H    | 42H | 42H    | —  | — | — |

| コード | MSB             | LSB             |
|-----|-----------------|-----------------|
|     | 1 1 0 0 1 1 1 0 | CEH             |
|     | 0 1 0 r 0 1 1   | 43H、4BH、53H、5BH |
|     |                 |                 |
| r   | ニーモニック          | コード             |
| A   | 00              | LD A, [IY+L]    |
| B   | 01              | LD B, [IY+L]    |
| L   | 10              | LD L, [IY+L]    |
| H   | 11              | LD H, [IY+L]    |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD [HL], [IY+L]** // Load location [IY + L] into location [HL] // 5 cycle //**機能** [HL] [IY+L]

IYレジスタの内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容をHLレジスタでアドレス指定されるデータメモリにロードします。  
 Lレジスタの内容は符号付きデータとして扱われ、範囲は-128 ~ 127です。  
 EPレジスタの内容がデータメモリ[HL]のページアドレス、YPレジスタ内容がデータメモリ[IY+L]のページアドレスになります(MODEL2/3)。

**モード** Src: インデックスレジスタ付きレジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |        | 結果   |        |    |   |   |
|---|------|--------|------|--------|----|---|---|
|   | [HL] | [IY+L] | [HL] | [IY+L] | SC |   |   |
|   |      |        |      |        | N  | V | C |
|   | 5AH  | 42H    | 42H  | 42H    | —  | — | — |

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 0 0 1 1 1 0 | CEH |
|     | 0 1 1 0 0 0 1 1 | 63H |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD [ir], [IY+L]** // Load location [IY + L] into location [ir reg.] // 5 cycle //**機能** [ir] [IY+L]

IYレジスタの内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容をirレジスタ(IX/IY)でアドレス指定されるデータメモリにロードします。  
 Lレジスタの内容は符号付きデータとして扱われ、範囲は-128 ~ 127です。  
 XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: インデックスレジスタ付きレジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |        | 結果   |        |    |   |   |
|---|------|--------|------|--------|----|---|---|
|   | [ir] | [IY+L] | [ir] | [IY+L] | SC |   |   |
|   |      |        |      |        | N  | V | C |
|   | 5AH  | 42H    | 42H  | 42H    | —  | — | — |

| コード | MSB              | LSB      |
|-----|------------------|----------|
|     | 1 1 0 0 1 1 1 0  | CEH      |
|     | 0 1 1 ir 1 0 1 1 | 6BH, 7BH |

  

| ir   | ニーモニック          | コード |
|------|-----------------|-----|
| IX 0 | LD [IX], [IY+L] | 6BH |
| IY 1 | LD [IY], [IY+L] | 7BH |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD rp, rp'** ////////////// Load rp' reg. into rp reg. ////////////// 2 cycle //

**機能** rp rp'  
rp'レジスタ(BA/HL/IX/IY)の内容をrpレジスタ  
(BA/HL/IX/IY)にロードします。

**モード** Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 0 0 1 1 1 1 | CFH |
|     | 1 1 1 0 rp rp'  |     |

| rp' rp  | BA (0,0) | HL (0,1) | IX (1,0) | IY (1,1) |
|---------|----------|----------|----------|----------|
| BA(0,0) | E0H      | E1H      | E2H      | E3H      |
| HL(0,1) | E4H      | E5H      | E6H      | E7H      |
| IX(1,0) | E8H      | E9H      | EAH      | EBH      |
| IY(1,1) | ECH      | EDH      | EEH      | EFH      |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

| 例 | 設定値   |       | 結果    |       |    |   |   |
|---|-------|-------|-------|-------|----|---|---|
|   | rp    | rp'   | rp    | rp'   | SC |   |   |
|   |       |       |       |       | N  | V | C |
|   | 3521H | E964H | E964H | E964H | —  | — | — |

(rp rp')

**LD BA, PC** ////////////// Load PC into BA reg. ////////////// 2 cycle //

**機能** BA PC + 2  
プログラムカウンタ(PC)の内容をBAレジスタに  
ロードします。ロード値は本命令の先頭アドレス  
+2となります。

**モード** Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 0 0 1 1 1 1 | CFH |
|     | 1 1 1 1 1 0 0 1 | F9H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

| 例 | 設定値   |       | 結果    |       |    |   |   |
|---|-------|-------|-------|-------|----|---|---|
|   | BA    | PC    | BA    | PC    | SC |   |   |
|   |       |       |       |       | N  | V | C |
|   | 3521H | E964H | E964H | E964H | —  | — | — |

**LD BA, SP** ////////////// Load SP into BA reg. ////////////// 2 cycle //

**機能** BA SP  
スタックポインタ(SP)の内容をBAレジスタにロードします。

**モード** Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 0 0 1 1 1 1 | CFH |
|     | 1 1 1 1 1 0 0 0 | F8H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

| 例 | 設定値   |       | 結果    |       |    |   |   |
|---|-------|-------|-------|-------|----|---|---|
|   | BA    | SP    | BA    | SP    | SC |   |   |
|   |       |       |       |       | N  | V | C |
|   | 3521H | E964H | E964H | E964H | —  | — | — |

**LD HL, PC** /////////////// Load PC into HL reg. /////////////// 2 cycle //

機能 HL PC + 2

プログラムカウンタ(PC)の内容をHLレジスタにロードします。ロード値は本命令の先頭アドレス+2となります。

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 0 0 1 1 1 1   | CFH |  |
|     | 1 1 1 1 0 1 0 1   | F5H |  |
| フラグ | I1 I0 U D N V C Z |     |  |
|     | - - - - - - - -   |     |  |

モード Src: レジスタ直接

Dst: レジスタ直接

| 例 | 設定値   |       | 結果    |       |    |   |   |
|---|-------|-------|-------|-------|----|---|---|
|   | HL    | PC    | HL    | PC    | SC |   |   |
|   |       |       |       |       | N  | V | C |
|   | 3521H | E964H | E964H | E964H | —  | — | — |

**LD HL, SP** /////////////// Load SP into HL reg. /////////////// 2 cycle //

機能 HL SP

スタックポインタ(SP)の内容をHLレジスタにロードします。

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 0 0 1 1 1 1   | CFH |  |
|     | 1 1 1 1 0 1 0 0   | F4H |  |
| フラグ | I1 I0 U D N V C Z |     |  |
|     | - - - - - - - -   |     |  |

モード Src: レジスタ直接

Dst: レジスタ直接

| 例 | 設定値   |       | 結果    |       |    |   |   |
|---|-------|-------|-------|-------|----|---|---|
|   | HL    | SP    | HL    | SP    | SC |   |   |
|   |       |       |       |       | N  | V | C |
|   | 3521H | E964H | E964H | E964H | —  | — | — |

**LD IX, SP** /////////////// Load SP into IX reg. /////////////// 2 cycle //

機能 IX SP

スタックポインタ(SP)の内容をIXレジスタにロードします。

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 0 0 1 1 1 1   | CFH |  |
|     | 1 1 1 1 1 0 1 0   | FAH |  |
| フラグ | I1 I0 U D N V C Z |     |  |
|     | - - - - - - - -   |     |  |

モード Src: レジスタ直接

Dst: レジスタ直接

| 例 | 設定値   |       | 結果    |       |    |   |   |
|---|-------|-------|-------|-------|----|---|---|
|   | IX    | SP    | IX    | SP    | SC |   |   |
|   |       |       |       |       | N  | V | C |
|   | 3521H | E964H | E964H | E964H | —  | — | — |

**LD IY, SP** /////////////// Load SP into IY reg. /////////////// 2 cycle //

機能 IY SP

スタックポインタ(SP)の内容をIYレジスタにロードします。

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 0 0 1 1 1 1   | CFH |  |
|     | 1 1 1 1 1 1 1 0   | FEH |  |
| フラグ | I1 I0 U D N V C Z |     |  |
|     | - - - - - - - -   |     |  |

モード Src: レジスタ直接

Dst: レジスタ直接

| 例 | 設定値   |       | 結果    |       |    |   |   |
|---|-------|-------|-------|-------|----|---|---|
|   | IY    | SP    | IY    | SP    | SC |   |   |
|   |       |       |       |       | N  | V | C |
|   | 3521H | E964H | E964H | E964H | —  | — | — |

**LD SP, rp** ////////////////////////////////////////////////////////////////// Load rp reg. into SP ////////////////////////////////////////////////////////////////// 2 cycle //

機能 SP rp

rpレジスタ(BA/HL/IX/IY)の内容をスタックポインタ(SP)にロードします。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB | CFH       |
|-----|-----------------|-----|-----------|
|     | 1 1 0 0 1 1 1 1 |     |           |
|     | 1 1 1 1 0 0 rp  |     | F0H ~ F3H |

| 例 | 設定値   |       | 結果    |       |    |   |
|---|-------|-------|-------|-------|----|---|
|   | SP    | rp    | SP    | rp    | SC |   |
|   |       |       |       |       | N  | V |
|   | 3521H | E964H | E964H | E964H | —  | — |

| rp    | ニーモニック    | コード |
|-------|-----------|-----|
| BA 00 | LD SP, BA | F0H |
| HL 01 | LD SP, HL | F1H |
| IX 10 | LD SP, IX | F2H |
| IY 11 | LD SP, IY | F3H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD [hhll], rp** ////////////////////////////////////////////////////////////////// Load rp reg. into location [hhll] ////////////////////////////////////////////////////////////////// 5 cycle //

機能 [hhll] rp(L), [hhll+1] rp(H)

rpレジスタ(BA/HL/IX/IY)の下位バイトをデータメモリのアドレスhhllに、上位バイトをその次のアドレスhhll+1にストアします。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: レジスタ直接

Dst: 16ビット絶対

| 例 | 設定値   |        | 結果       |       |    |   |
|---|-------|--------|----------|-------|----|---|
|   | rp    | [hhll] | [hhll+1] | rp    | SC |   |
|   |       |        |          |       | N  | V |
|   | E964H | 64H    | E9H      | E964H | —  | — |

| コード | MSB            | LSB | BCH ~ BFH |
|-----|----------------|-----|-----------|
|     | 1 0 1 1 1 1 rp |     |           |
|     | l l            |     | ll        |
|     | h h            |     | hh        |

| rp    | ニーモニック        | コード |
|-------|---------------|-----|
| BA 00 | LD [hhll], BA | BCH |
| HL 01 | LD [hhll], HL | BDH |
| IX 10 | LD [hhll], IX | BEH |
| IY 11 | LD [hhll], IY | BFH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD [hhll], SP** ////////////////////////////////////////////////////////////////// Load SP into location [hhll] ////////////////////////////////////////////////////////////////// 6 cycle //

機能 [hhll] SP(L), [hhll+1] SP(H)

スタックポインタ(SP)の下位バイトをデータメモリのアドレスhhllに、上位バイトをその次のアドレスhhll+1にストアします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: レジスタ直接

Dst: 16ビット絶対

| 例 | 設定値   |        | 結果       |       |    |   |   |   |
|---|-------|--------|----------|-------|----|---|---|---|
|   | SP    | [hhll] | [hhll+1] | SP    | SC |   |   |   |
|   |       |        |          |       | N  | V | C | Z |
|   | E964H | 64H    | E9H      | E964H | —  | — | — | — |

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 0 0 1 1 1 1 | CFH |
|     | 0 1 1 1 1 1 0 0 | 7CH |
|     | l l             | ll  |
|     | h h             | hh  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | — |

**LD [HL], rp** ////////////////////////////////////////////////////////////////// Load rp reg. into location [HL] ////////////////////////////////////////////////////////////////// 5 cycle //

機能 [HL] rp(L), [HL+1] rp(H)

rpレジスタ(BA/HL/IX/IY)の下位バイトをHLレジスタの内容で指定されたデータメモリのアドレスに、上位バイトをその次のアドレスにストアします。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: レジスタ直接

Dst: レジスタ間接

| 例 | 設定値   |      | 結果     |       |    |   |   |   |
|---|-------|------|--------|-------|----|---|---|---|
|   | rp    | [HL] | [HL+1] | rp    | SC |   |   |   |
|   |       |      |        |       | N  | V | C | Z |
|   | E964H | 64H  | E9H    | E964H | —  | — | — | — |

| コード | MSB             | LSB       |
|-----|-----------------|-----------|
|     | 1 1 0 0 1 1 1 1 | CFH       |
|     | 1 1 0 0 0 1 rp  | C4H ~ C7H |

| rp    | ニーモニック      | コード |
|-------|-------------|-----|
| BA 00 | LD [HL], BA | C4H |
| HL 01 | LD [HL], HL | C5H |
| IX 10 | LD [HL], IX | C6H |
| IY 11 | LD [HL], IY | C7H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | —  | —  | — | — | — | — | — | — |

**LD [IX], rp** ////////////////////////////////////////////////////////////////// Load rp reg. into location [IX] ////////////////////////////////////////////////////////////////// 5 cycle //

機能 [IX] rp(L), [IX+1] rp(H)

rpレジスタ(BA/HL/IX/IY)の下位バイトをIXレジスタの内容で指定されたデータメモリのアドレスに、上位バイトをその次のアドレスにストアします。XPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: レジスタ直接

Dst: レジスタ間接

| 例 | 設定値   |      | 結果     |       |    |   |   |
|---|-------|------|--------|-------|----|---|---|
|   | rp    | [IX] | [IX+1] | rp    | SC |   |   |
|   |       |      |        |       | N  | V | C |
|   | E964H | 64H  | E9H    | E964H | —  | — | — |

| コード   | MSB         | LSB     |           |   |   |   |   |   |
|-------|-------------|---------|-----------|---|---|---|---|---|
|       | 1 1 0 0     | 1 1 1 1 | CFH       |   |   |   |   |   |
|       | 1 1 0 1     | 0 1 rp  | D4H ~ D7H |   |   |   |   |   |
| rp    | ニーモニック      | コード     |           |   |   |   |   |   |
| BA 00 | LD [IX], BA | D4H     |           |   |   |   |   |   |
| HL 01 | LD [IX], HL | D5H     |           |   |   |   |   |   |
| IX 10 | LD [IX], IX | D6H     |           |   |   |   |   |   |
| IY 11 | LD [IX], IY | D7H     |           |   |   |   |   |   |
| フラグ   | I1          | I0      | U         | D | N | V | C | Z |
|       | -           | -       | -         | - | - | - | - | - |

**LD [IY], rp** ////////////////////////////////////////////////////////////////// Load rp reg. into location [IY] ////////////////////////////////////////////////////////////////// 5 cycle //

機能 [IY] rp(L), [IY+1] rp(H)

rpレジスタ(BA/HL/IX/IY)の下位バイトをIYレジスタの内容で指定されたデータメモリのアドレスに、上位バイトをその次のアドレスにストアします。YPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: レジスタ直接

Dst: レジスタ間接

| 例 | 設定値   |      | 結果     |       |    |   |   |
|---|-------|------|--------|-------|----|---|---|
|   | rp    | [IY] | [IY+1] | rp    | SC |   |   |
|   |       |      |        |       | N  | V | C |
|   | E964H | 64H  | E9H    | E964H | —  | — | — |

| コード   | MSB         | LSB      |           |   |   |   |   |   |
|-------|-------------|----------|-----------|---|---|---|---|---|
|       | 1 1 0 0     | 1 1 1 1  | CFH       |   |   |   |   |   |
|       | 1 1 0 1     | 1 1 1 rp | DCH ~ DFH |   |   |   |   |   |
| rp    | ニーモニック      | コード      |           |   |   |   |   |   |
| BA 00 | LD [IY], BA | DCH      |           |   |   |   |   |   |
| HL 01 | LD [IY], HL | DDH      |           |   |   |   |   |   |
| IX 10 | LD [IY], IX | DEH      |           |   |   |   |   |   |
| IY 11 | LD [IY], IY | DFH      |           |   |   |   |   |   |
| フラグ   | I1          | I0       | U         | D | N | V | C | Z |
|       | -           | -        | -         | - | - | - | - | - |

**LD [SP+dd], rp** // Load rp reg. into location [SP + dd] // 6 cycle //

**機能** [SP+dd] rp(L), [SP+dd+1] rp(H)  
 rpレジスタ(BA/HL/IX/IY)の下位バイトをSPの内容とディスプレースメントddの和で指定されたデータメモリのアドレスに、上位バイトをその次のアドレスにストアします。  
 ddは符号付きデータとして扱われ、範囲は-128 ~ 127です。

**モード** Src: レジスタ直接  
 Dst: ディスプレースメント付きレジスタ間接

| 例 | 設定値   |         | 結果        |       |    |   |   |   |
|---|-------|---------|-----------|-------|----|---|---|---|
|   | rp    | [SP+dd] | [SP+dd+1] | rp    | SC |   |   |   |
|   |       |         |           |       | N  | V | C | Z |
|   | E964H | 64H     | E9H       | E964H | —  | — | — | — |

| コード | MSB             | LSB       |  |
|-----|-----------------|-----------|--|
|     | 1 1 0 0 1 1 1 1 | CFH       |  |
|     | 0 1 1 1 0 1 rp  | 74H ~ 77H |  |
|     | d d             | dd        |  |

| rp    | ニーモニック         | コード |
|-------|----------------|-----|
| BA 00 | LD [SP+dd], BA | 74H |
| HL 01 | LD [SP+dd], HL | 75H |
| IX 10 | LD [SP+dd], IX | 76H |
| IY 11 | LD [SP+dd], IY | 77H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD rp, #mmnn** // Load immediate data mmnn into rp reg. // 3 cycle //

**機能** rp mmnn  
 16ビット即値データmmnnをrpレジスタ(BA/HL/IX/IY)にロードします。

**モード** Src: 即値データ

Dst: レジスタ直接

| コード | MSB            | LSB       |  |
|-----|----------------|-----------|--|
|     | 1 1 0 0 0 1 rp | C4H ~ C7H |  |
|     | n n            | nn        |  |
|     | m m            | mm        |  |

| 例 | 設定値   |       | 結果    |       |    |   |   |   |
|---|-------|-------|-------|-------|----|---|---|---|
|   | rp    | mmnn  | rp    | mmnn  | SC |   |   |   |
|   |       |       |       |       | N  | V | C | Z |
|   | 3521H | E964H | E964H | E964H | —  | — | — | — |

| rp    | ニーモニック       | コード |
|-------|--------------|-----|
| BA 00 | LD BA, #mmnn | C4H |
| HL 01 | LD HL, #mmnn | C5H |
| IX 10 | LD IX, #mmnn | C6H |
| IY 11 | LD IY, #mmnn | C7H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD SP, #mmnn** ////////////////////////////////////////////////////////////////// Load immediate data mmnn into SP ////////////////////////////////////////////////////////////////// 4 cycle //

機能 SP mmnn

16ビット即値データmmnnをスタックポインタ  
(SP)にロードします。

モード Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB | CFH |
|-----|-----------------|-----|-----|
|     | 1 1 0 0 1 1 1 1 |     |     |
|     | 0 1 1 0 1 1 1 0 |     | 6EH |
|     | n n             |     | nn  |
|     | m m             |     | mm  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

| 例 | 設定値   |       | 結果    |       |    |   |   |
|---|-------|-------|-------|-------|----|---|---|
|   | SP    | mmnn  | SP    | mmnn  | SC |   |   |
|   |       |       |       |       | N  | V | C |
|   | 3521H | E964H | E964H | E964H | —  | — | — |

**LD rp, [hhll]** ////////////////////////////////////////////////////////////////// Load location [hhll] into rp reg. ////////////////////////////////////////////////////////////////// 5 cycle //

機能 rp(l) [hhll], rp(H) [hhll+1]

16ビット絶対アドレスhhllでアドレス指定された  
データメモリの内容を下位バイト、その次のアド  
レスの内容を上位バイトとしてrpレジスタ(BA/  
HL/IX/IY)にロードします。  
EPレジスタの内容がデータメモリのページアドレ  
スになります(MODEL2/3)。

モード Src: 16ビット絶対

Dst: レジスタ直接

| 例 | 設定値   |        |          | 結果    |    |   |   |
|---|-------|--------|----------|-------|----|---|---|
|   | rp    | [hhll] | [hhll+1] | rp    | SC |   |   |
|   |       |        |          |       | N  | V | C |
|   | 3521H | 64H    | E9H      | E964H | —  | — | — |

| コード | MSB         | LSB | rp | B8H ~ BBH |
|-----|-------------|-----|----|-----------|
|     | 1 0 1 1 1 0 |     |    |           |
|     | l l         |     |    | ll        |
|     | h h         |     |    | hh        |

| rp    | ニーモニック        | コード |
|-------|---------------|-----|
| BA 00 | LD BA, [hhll] | B8H |
| HL 01 | LD HL, [hhll] | B9H |
| IX 10 | LD IX, [hhll] | BAH |
| IY 11 | LD IY, [hhll] | BBH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**LD SP, [hhll]** ////////////////////////////////////////////////////////////////// Load location [hhll] into SP ////////////////////////////////////////////////////////////////// 6 cycle //**機能** SP(L) [hhll], SP(H) [hhll+1]

16ビット絶対アドレスhhllでアドレス指定されたデータメモリの内容を下位バイト、その次のアドレスの内容を上位バイトとしてスタックポインタ(SP)にロードします。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: 16ビット絶対

Dst: レジスタ直接

例

| SP    | 設定値    |          | SP    | 結果 |   |   |   |   |
|-------|--------|----------|-------|----|---|---|---|---|
|       | [hhll] | [hhll+1] |       | SC |   | N | V | C |
| 3521H | 64H    | E9H      | E964H | —  | — | — | — | — |

**コード**

| MSB             | LSB |
|-----------------|-----|
| 1 1 0 0 1 1 1 1 | CFH |
| 0 1 1 1 1 0 0 0 | 78H |
| l l             | ll  |
| h h             | hh  |

**フラグ**

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| —  | —  | — | — | — | — | — | — |

**LD rp, [HL]** ////////////////////////////////////////////////////////////////// Load location [HL] into rp reg. ////////////////////////////////////////////////////////////////// 5 cycle //**機能** rp(L) [HL], rp(H) [HL+1]

HLレジスタでアドレス指定されたデータメモリの内容を下位バイト、その次のアドレスの内容を上位バイトとしてrpレジスタ(BA/HL/IX/IY)にロードします。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: レジスタ間接

Dst: レジスタ直接

例

| rp    | 設定値  |        | rp    | 結果 |   |   |   |   |
|-------|------|--------|-------|----|---|---|---|---|
|       | [HL] | [HL+1] |       | SC |   | N | V | C |
| 3521H | 64H  | E9H    | E964H | —  | — | — | — | — |

**コード**

| MSB              | LSB       |
|------------------|-----------|
| 1 1 0 0 1 1 1 1  | CFH       |
| 1 1 0 0 0 0 0 rp | C0H ~ C3H |

| rp    | ニーモニック      | コード |
|-------|-------------|-----|
| BA 00 | LD BA, [HL] | C0H |
| HL 01 | LD HL, [HL] | C1H |
| IX 10 | LD IX, [HL] | C2H |
| IY 11 | LD IY, [HL] | C3H |

**フラグ**

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| —  | —  | — | — | — | — | — | — |

**LD rp, [IX]** ////////////////////////////////////////////////////////////////// Load location [IX] into rp reg. ////////////////////////////////////////////////////////////////// 5 cycle //

機能 rp(L) [IX], rp(H) [IX+1]

IXレジスタでアドレス指定されたデータメモリの内容を下位バイト、その次のアドレスの内容を上位バイトとしてrpレジスタ(BA/HL/IX/IY)にロードします。  
XPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: レジスタ間接

Dst: レジスタ直接

例

| rp    | 設定値  |        | rp    | 結果 |   |   |   |   |
|-------|------|--------|-------|----|---|---|---|---|
|       | [IX] | [IX+1] |       | SC |   | N | V | C |
| 3521H | 64H  | E9H    | E964H | —  | — | — | — | — |

コード

| MSB |   |   |   |   |   |    |   | LSB       |
|-----|---|---|---|---|---|----|---|-----------|
| 1   | 1 | 0 | 0 | 1 | 1 | 1  | 1 | CFH       |
| 1   | 1 | 0 | 1 | 0 | 0 | rp |   | D0H ~ D3H |

| rp    | ニーモニック      | コード |
|-------|-------------|-----|
| BA 00 | LD BA, [IX] | D0H |
| HL 01 | LD HL, [IX] | D1H |
| IX 10 | LD IX, [IX] | D2H |
| IY 11 | LD IY, [IX] | D3H |

フラグ

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| -  | -  | - | - | - | - | - | - |

**LD rp, [IY]** ////////////////////////////////////////////////////////////////// Load location [IY] into rp reg. ////////////////////////////////////////////////////////////////// 5 cycle //

機能 rp(L) [IY], rp(H) [IY+1]

IYレジスタでアドレス指定されたデータメモリの内容を下位バイト、その次のアドレスの内容を上位バイトとしてrpレジスタ(BA/HL/IX/IY)にロードします。  
YPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

モード Src: レジスタ間接

Dst: レジスタ直接

例

| rp    | 設定値  |        | rp    | 結果 |   |   |   |   |
|-------|------|--------|-------|----|---|---|---|---|
|       | [IY] | [IY+1] |       | SC |   | N | V | C |
| 3521H | 64H  | E9H    | E964H | —  | — | — | — | — |

コード

| MSB |   |   |   |   |   |    |   | LSB       |
|-----|---|---|---|---|---|----|---|-----------|
| 1   | 1 | 0 | 0 | 1 | 1 | 1  | 1 | CFH       |
| 1   | 1 | 0 | 1 | 1 | 0 | rp |   | D8H ~ DBH |

| rp    | ニーモニック      | コード |
|-------|-------------|-----|
| BA 00 | LD BA, [IY] | D8H |
| HL 01 | LD HL, [IY] | D9H |
| IX 10 | LD IX, [IY] | DAH |
| IY 11 | LD IY, [IY] | DBH |

フラグ

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| -  | -  | - | - | - | - | - | - |

**LD rp, [SP+dd]** // Load location [SP + dd] into rp reg. // 6 cycle //**機能** rp(L) [SP+dd], rp(H) [SP+dd+1]

スタックポインタ(SP)の内容とディスプレースメントddの和でアドレス指定されたデータメモリの内容を下位バイト、その次のアドレスの内容を上位バイトとしてrpレジスタ(BA/HL/IX/IY)にロードします。  
ddは符号付きデータとして扱われ、範囲は-128 ~ 127です。

**モード** Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ直接

例

| rp    | 設定値     |           | rp    | 結果 |   |   |   |   |
|-------|---------|-----------|-------|----|---|---|---|---|
|       | [SP+dd] | [SP+dd+1] |       | SC |   | N | V | C |
| 3521H | 64H     | E9H       | E964H | —  | — | — | — | — |

コード

| MSB |   |   |   |   |   |    |   | LSB       |
|-----|---|---|---|---|---|----|---|-----------|
| 1   | 1 | 0 | 0 | 1 | 1 | 1  | 1 | CFH       |
| 0   | 1 | 1 | 1 | 0 | 0 | rp | — | 70H ~ 73H |
| —   | — | d | d | — | — | —  | — | dd        |

| rp | ニーモニック            | コード |
|----|-------------------|-----|
| BA | 00 LD BA, [SP+dd] | 70H |
| HL | 01 LD HL, [SP+dd] | 71H |
| IX | 10 LD IX, [SP+dd] | 72H |
| IY | 11 LD IY, [SP+dd] | 73H |

フラグ

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| —  | —  | — | — | — | — | — | — |

**MLT**

Multiply // 12 cycle //

**機能** HL L \* A

Lレジスタの内容とAレジスタの内容の乗算を行い、結果をHLレジスタにストアします。

**モード** インプライド (レジスタ直接)

コード

| MSB |   |   |   |   |   |   |   | LSB |
|-----|---|---|---|---|---|---|---|-----|
| 1   | 1 | 0 | 0 | 1 | 1 | 1 | 0 | CEH |
| 1   | 1 | 0 | 1 | 1 | 0 | 0 | 0 | D8H |

フラグ

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| —  | —  | — | — | ↑ | 0 | 0 | ↑ |

注意 MODE0/2では本命令が使用できません。

例

| L   | A   | HL    | 設定値 |   |   |   | 結果 |   |  |  |
|-----|-----|-------|-----|---|---|---|----|---|--|--|
|     |     |       | SC  |   | N | V | C  | Z |  |  |
| 00H | 64H | 0000H | 0   | 0 | 0 | 1 |    |   |  |  |
| 64H | 58H | 2260H | 0   | 0 | 0 | 0 |    |   |  |  |
| A5H | 93H | 5EBFH | 0   | 0 | 0 | 0 |    |   |  |  |
| C8H | A5H | 80E8H | 1   | 0 | 0 | 0 |    |   |  |  |

**NEG r** ////////////////////////////////////////////////////////////////// Negate r reg. ////////////////////////////////////////////////////////////////// 3 cycle //**機能** r 0 - r

rレジスタ(A/B)の内容を0から減算(2の補数を作成)し、結果をrレジスタにストアします。

| コード             |    |    |   |   |   |   |   | MSB      | LSB |  |
|-----------------|----|----|---|---|---|---|---|----------|-----|--|
| 1 1 0 0 1 1 1 0 |    |    |   |   |   |   |   | CEH      |     |  |
| 1 0 1 0 0 1 0 r |    |    |   |   |   |   |   | A4H, A5H |     |  |
| r ニーモニック コード    |    |    |   |   |   |   |   |          |     |  |
| A 0 NEG A A4H   |    |    |   |   |   |   |   |          |     |  |
| B 1 NEG B A5H   |    |    |   |   |   |   |   |          |     |  |
| フラグ             | I1 | I0 | U | D | N | V | C | Z        |     |  |
| - - - - - - - - | ↑  | ↑  | ↑ | ↑ | ↑ | ↑ | ↑ |          |     |  |

**モード** レジスタ直接**例**

| 設定値         |     | 結果 |   |   |   |   |   |
|-------------|-----|----|---|---|---|---|---|
|             |     | SC |   |   |   |   |   |
|             |     | r  | r | N | V | C | Z |
| D=0, U=0の場合 |     |    |   |   |   |   |   |
| 57H         | A9H | 1  | 0 | 1 | 0 |   |   |
| 00H         | 00H | 0  | 0 | 0 | 1 |   |   |
| 2BH         | D5H | 1  | 0 | 1 | 0 |   |   |
| 80H         | 80H | 1  | 1 | 1 | 0 |   |   |
| D=1, U=0の場合 |     |    |   |   |   |   |   |
| 57          | 43  | 0  | 0 | 1 | 0 |   |   |
| D=1, U=1の場合 |     |    |   |   |   |   |   |
| 57          | 03  | 0  | 0 | 1 | 0 |   |   |

**NEG [BR:l]** ////////////////////////////////////////////////////////////////// Negate location [BR:l] ////////////////////////////////////////////////////////////////// 5 cycle //**機能** [BR:l] 0 - [BR:l]

BRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されるデータメモリの内容を0から減算(2の補数を作成)し、結果をそのアドレスにストアします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード             |    |    |   |   |   |   |   | MSB | LSB |  |
|-----------------|----|----|---|---|---|---|---|-----|-----|--|
| 1 1 0 0 1 1 1 0 |    |    |   |   |   |   |   | CEH |     |  |
| 1 0 1 0 0 1 1 0 |    |    |   |   |   |   |   | A6H |     |  |
| l l             |    |    |   |   |   |   |   | ll  |     |  |
| フラグ             | I1 | I0 | U | D | N | V | C | Z   |     |  |
| - - - - - - - - | ↑  | ↑  | ↑ | ↑ | ↑ | ↑ | ↑ |     |     |  |

**モード** 8ビット絶対**例**

| 設定値         |     | 結果     |   |   |   |   |
|-------------|-----|--------|---|---|---|---|
| [BR:l]      |     | SC     |   |   |   |   |
| [BR:l]      |     | [BR:l] | N | V | C | Z |
| D=0, U=0の場合 |     |        |   |   |   |   |
| 57H         | A9H | 1      | 0 | 1 | 0 |   |
| 00H         | 00H | 0      | 0 | 0 | 1 |   |
| 2BH         | D5H | 1      | 0 | 1 | 0 |   |
| 80H         | 80H | 1      | 1 | 1 | 0 |   |
| D=1, U=0の場合 |     |        |   |   |   |   |
| 57          | 43  | 0      | 0 | 1 | 0 |   |
| D=1, U=1の場合 |     |        |   |   |   |   |
| 57          | 03  | 0      | 0 | 1 | 0 |   |

**NEG [HL]** ////////////////////////////////////////////////////////////////// Negate location [HL] ////////////////////////////////////////////////////////////////// 4 cycle //**機能** [HL] 0 - [HL]

HLレジスタでアドレス指定されたデータメモリの内容を0から減算(2の補数を作成)し、結果をそのアドレスにストアします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード             |    |    |   |   |   |   |   | MSB | LSB |  |
|-----------------|----|----|---|---|---|---|---|-----|-----|--|
| 1 1 0 0 1 1 1 0 |    |    |   |   |   |   |   | CEH |     |  |
| 1 0 1 0 0 1 1 1 |    |    |   |   |   |   |   | A7H |     |  |
| l l             |    |    |   |   |   |   |   | ll  |     |  |
| フラグ             | I1 | I0 | U | D | N | V | C | Z   |     |  |
| - - - - - - - - | ↑  | ↑  | ↑ | ↑ | ↑ | ↑ | ↑ |     |     |  |

**モード** レジスタ間接**例**

| 設定値         |     | 結果   |   |   |   |   |
|-------------|-----|------|---|---|---|---|
| [HL]        |     | SC   |   |   |   |   |
| [HL]        |     | [HL] | N | V | C | Z |
| D=0, U=0の場合 |     |      |   |   |   |   |
| 57H         | A9H | 1    | 0 | 1 | 0 |   |
| 00H         | 00H | 0    | 0 | 0 | 1 |   |
| 2BH         | D5H | 1    | 0 | 1 | 0 |   |
| 80H         | 80H | 1    | 1 | 1 | 0 |   |
| D=1, U=0の場合 |     |      |   |   |   |   |
| 57          | 43  | 0    | 0 | 1 | 0 |   |
| D=1, U=1の場合 |     |      |   |   |   |   |
| 57          | 03  | 0    | 0 | 1 | 0 |   |

**NOP** /////////////////////////////////////////////////////////////////// No Operation /////////////////////////////////////////////////////////////////// 2 cycle //**機能** No Operation

他に影響を与える動作は行わずに2サイクルを費  
やします。プログラムカウンタ(PC)はインクリメ  
ント(+1)されます。

| コード | MSB               | LSB |   |   |   |   |   |   |
|-----|-------------------|-----|---|---|---|---|---|---|
|     | 1 1 1 1 1 1 1 1 1 | FFH |   |   |   |   |   |   |
| フラグ | I1                | I0  | U | D | N | V | C | Z |
|     | -                 | -   | - | - | - | - | - | - |

**OR A, r** /////////////////////////////////////////////////////////////////// Logical OR of r reg. and A reg. /////////////////////////////////////////////////////////////////// 2 cycle //**機能** A A  $\vee$  r

rレジスタ(A/B)の内容とAレジスタの内容との論  
理和をとり、結果をAレジスタにストアします。

| コード | MSB             | LSB      |   |   |   |   |   |   |
|-----|-----------------|----------|---|---|---|---|---|---|
|     | 0 0 1 0 1 0 0 r | 28H, 29H |   |   |   |   |   |   |
| フラグ | I1              | I0       | U | D | N | V | C | Z |
|     | -               | -        | - | - | ↑ | - | - | ↑ |

**モード** Src: レジスタ直接

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |   |   |   |
|---|-----|-----|-----|----|---|---|---|
|   | A   | B   | A   | SC |   |   |   |
|   |     |     |     | N  | V | C | Z |
|   | 32H | 6CH | 7EH | 0  | — | — | 0 |
|   | 86H | 41H | C7H | 1  | — | — | 0 |

**OR A, #nn** /////////////////////////////////////////////////////////////////// Logical OR of immediate data nn and A reg. /////////////////////////////////////////////////////////////////// 2 cycle //**機能** A A  $\vee$  nn

8ビット即値データnnとAレジスタの内容との論  
理和をとり、結果をAレジスタにストアします。

| コード | MSB                 | LSB |   |   |   |   |   |   |
|-----|---------------------|-----|---|---|---|---|---|---|
|     | 0 0 1 0 1 0 1 0 1 0 | 2AH |   |   |   |   |   |   |
| フラグ | I1                  | I0  | U | D | N | V | C | Z |
|     | -                   | -   | - | - | ↑ | - | - | ↑ |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |   |   |   |
|---|-----|-----|-----|----|---|---|---|
|   | A   | nn  | A   | SC |   |   |   |
|   |     |     |     | N  | V | C | Z |
|   | 32H | 6CH | 7EH | 0  | — | — | 0 |
|   | 86H | 41H | C7H | 1  | — | — | 0 |

**OR A, [BR:l]** ////////////////////////////////////////////////////////////////// Logical OR of location [BR:l] and A reg. ////////////////////////////////////////////////////////////////// 3 cycle //**機能** A A  $\vee$  [BR:l]

BRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されるデータメモリの内容とAレジスタの内容との論理和をとり、結果をAレジスタにストアします。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: 8ビット絶対

Dst: レジスタ直接

| 例 | 設定値 |        | 結果  |    |   |   |   |
|---|-----|--------|-----|----|---|---|---|
|   | A   | [BR:l] | A   | SC |   |   |   |
|   |     |        |     | N  | V | C | Z |
|   | 32H | 6CH    | 7EH | 0  | — | — | 0 |
|   | 86H | 41H    | C7H | 1  | — | — | 0 |

**コード** MSB LSB
 

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

 2CH

l l

**フラグ** I1 I0 U D N V C Z
 

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| - | - | - | - | ↑ | - | - | ↑ |
|---|---|---|---|---|---|---|---|

**OR A, [hhll]** ////////////////////////////////////////////////////////////////// Logical OR of location [hhll] and A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A A  $\vee$  [hhll]

16ビット絶対アドレスhhllでアドレス指定されたデータメモリの内容とAレジスタの内容との論理和をとり、結果をAレジスタにストアします。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: 16ビット絶対

Dst: レジスタ直接

| 例 | 設定値 |        | 結果  |    |   |   |   |
|---|-----|--------|-----|----|---|---|---|
|   | A   | [hhll] | A   | SC |   |   |   |
|   |     |        |     | N  | V | C | Z |
|   | 32H | 6CH    | 7EH | 0  | — | — | 0 |
|   | 86H | 41H    | C7H | 1  | — | — | 0 |

**コード** MSB LSB
 

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

 2DH

l l

hh

**フラグ** I1 I0 U D N V C Z
 

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| - | - | - | - | ↑ | - | - | ↑ |
|---|---|---|---|---|---|---|---|

**OR A, [HL]** ////////////////////////////////////////////////////////////////// Logical OR of location [HL] and A reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** A A  $\vee$  [HL]

HLレジスタでアドレス指定されたデータメモリの内容とAレジスタの内容との論理和をとり、結果をAレジスタにストアします。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: レジスタ間接

Dst: レジスタ直接

| 例 | 設定値 |      | 結果  |    |   |   |   |
|---|-----|------|-----|----|---|---|---|
|   | A   | [HL] | A   | SC |   |   |   |
|   |     |      | N   | V  | C | Z |   |
|   | 32H | 6CH  | 7EH | 0  | — | — | 0 |
|   | 86H | 41H  | C7H | 1  | — | — | 0 |

**コード** MSB LSB
 

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

 2BH

l l

**フラグ** I1 I0 U D N V C Z
 

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| - | - | - | - | ↑ | - | - | ↑ |
|---|---|---|---|---|---|---|---|

**OR A, [ir]** ////////////////////////////////////////////////////////////////// Logical OR of location [ir reg.] and A reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** A A  $\vee$  [ir]

irレジスタ(IX/IY)でアドレス指定されたデータメモリの内容とAレジスタの内容との論理和をとり、結果をAレジスタにストアします。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります (MODEL2/3)。

**モード** Src: レジスタ間接

Dst: レジスタ直接

| 例 | 設定値 |      | 結果  |    |   |   |
|---|-----|------|-----|----|---|---|
|   | A   | [ir] | A   | SC |   |   |
|   |     |      |     | N  | V | C |
|   | 32H | 6CH  | 7EH | 0  | — | — |
|   | 86H | 41H  | C7H | 1  | — | — |
|   |     |      |     |    |   | 0 |

**コード** MSB LSB

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

2EH、2FH

| ir   | ニーモニック     | コード |
|------|------------|-----|
| IX 0 | OR A, [IX] | 2EH |
| IY 1 | OR A, [IY] | 2FH |

**フラグ**

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| -  | -  | - | - | ↑ | - | - | ↑ |

**OR A, [ir+dd]** ////////////////////////////////////////////////////////////////// Logical OR of location [ir reg. + dd] and A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A A  $\vee$  [ir+dd]

irレジスタ(IX/IY)の内容とディスプレースメントddの和でアドレス指定されたデータメモリの内容とAレジスタの内容との論理和をとり、結果をAレジスタにストアします。  
ddは符号付きデータとして扱われ、範囲は-128 ~ 127です。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります (MODEL2/3)。

**モード** Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ直接

| 例 | 設定値 |         | 結果  |    |   |   |
|---|-----|---------|-----|----|---|---|
|   | A   | [ir+dd] | A   | SC |   |   |
|   |     |         |     | N  | V | C |
|   | 32H | 6CH     | 7EH | 0  | — | — |
|   | 86H | 41H     | C7H | 1  | — | — |
|   |     |         |     |    |   | 0 |

**コード** MSB

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

CEH

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

28H、29H

|  |  |   |   |  |  |  |  |
|--|--|---|---|--|--|--|--|
|  |  | d | d |  |  |  |  |
|--|--|---|---|--|--|--|--|

dd

| ir   | ニーモニック        | コード |
|------|---------------|-----|
| IX 0 | OR A, [IX+dd] | 28H |
| IY 1 | OR A, [IY+dd] | 29H |

**フラグ**

| I1 | I0 | U | D | N | V | C | Z |
|----|----|---|---|---|---|---|---|
| -  | -  | - | - | ↑ | - | - | ↑ |

**OR A, [ir+L]** ////////////////////////////////////////////////////////////////// Logical OR of location [ir reg. + L] and A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A = A  $\vee$  [ir+L]

irレジスタ(IX/IY)の内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容とAレジスタの内容との論理和をとり、結果をAレジスタにストアします。  
 Lレジスタの内容は符号付きデータとして扱われ、範囲は-128 ~ 127です。  
 XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: インデックスレジスタ付きレジスタ間接  
 Dst: レジスタ直接

| 例 | 設定値 |        | 結果  |    |   |   |   |
|---|-----|--------|-----|----|---|---|---|
|   | A   | [ir+L] | A   | SC |   |   |   |
|   |     |        |     | N  | V | C |   |
|   | 32H | 6CH    | 7EH | 0  | — | — | 0 |
|   | 86H | 41H    | C7H | 1  | — | — | 0 |

| コード | MSB              | LSB          |     |
|-----|------------------|--------------|-----|
|     | 1 1 0 0 1 1 1 0  | CEH          |     |
|     | 0 0 1 0 1 0 1 ir | 2AH, 2BH     |     |
|     | ir               | ニーモニック       | コード |
| IX  | 0                | OR A, [IX+L] | 2AH |
| IY  | 1                | OR A, [IY+L] | 2BH |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**OR B, #nn** ////////////////////////////////////////////////////////////////// Logical OR of immediate data nn and B reg. ////////////////////////////////////////////////////////////////// 3 cycle //**機能** B = B  $\vee$  nn

8ビット即値データnnとBレジスタの内容との論理和をとり、結果をBレジスタにストアします。

**モード** Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 0 1 1 0 1 0 0 | B4H |  |
|     | n n             | nn  |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

| 例 | 設定値 |     | 結果  |    |   |   |   |
|---|-----|-----|-----|----|---|---|---|
|   | B   | nn  | B   | SC |   |   |   |
|   |     |     |     | N  | V | C |   |
|   | 32H | 6CH | 7EH | 0  | — | — | 0 |
|   | 86H | 41H | C7H | 1  | — | — | 0 |

**OR L, #nn** ////////////////////////////////////////////////////////////////// Logical OR of immediate data nn and L reg. ////////////////////////////////////////////////////////////////// 3 cycle //**機能** L = L  $\vee$  nn

8ビット即値データnnとLレジスタの内容との論理和をとり、結果をLレジスタにストアします。

**モード** Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 0 1 1 0 1 0 1 | B5H |  |
|     | n n             | nn  |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

| 例 | 設定値 |     | 結果  |    |   |   |   |
|---|-----|-----|-----|----|---|---|---|
|   | L   | nn  | L   | SC |   |   |   |
|   |     |     |     | N  | V | C |   |
|   | 32H | 6CH | 7EH | 0  | — | — | 0 |
|   | 86H | 41H | C7H | 1  | — | — | 0 |

**OR H, #nn** /////////////// Logical OR of immediate data nn and H reg. /////////////// 3 cycle //**機能** H H  $\vee$  nn

8ビット即値データnnとHレジスタの内容との論理和をとり、結果をHレジスタにストアします。

| コード | MSB             | LSB |     |
|-----|-----------------|-----|-----|
|     | 1 1 0 0 1 1 1 0 |     | CEH |
|     | 1 0 1 1 0 1 1 0 |     | B6H |

nn

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |   |   |   |
|---|-----|-----|-----|----|---|---|---|
|   | H   | nn  | H   | SC |   |   |   |
|   |     |     |     | N  | V | C | Z |
|   | 32H | 6CH | 7EH | 0  | — | — | 0 |
|   | 86H | 41H | C7H | 1  | — | — | 0 |

**OR SC, #nn** /////////////// Logical OR of immediate data nn and SC /////////////// 3 cycle //**機能** SC SC  $\vee$  nn

8ビット即値データnnとシステムコンディションフラグ(SC)の内容との論理和をとり、結果をシステムコンディションフラグ(SC)にセットします。

| コード | MSB             | LSB |     |
|-----|-----------------|-----|-----|
|     | 1 0 0 1 1 1 0 1 |     | 9DH |

nn

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | ↑  | ↑  | ↑ | ↑ | ↑ | ↑ | ↑ | ↑ |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |    |   |   |   |   |
|---|-----|-----|-----|----|----|---|---|---|---|
|   | SC  | nn  | SC  | SC |    |   |   |   |   |
|   |     |     |     | I1 | I0 | U | D | N | V |
|   | 32H | 6CH | 7EH | 0  | 1  | 1 | 1 | 1 | 1 |
|   | 86H | 41H | C7H | 1  | 1  | 0 | 0 | 0 | 1 |

**OR [BR:l], #nn** // Logical OR of immediate data nn and location [BR:l] /////////////// 5 cycle //**機能** [BR:l] [BR:l]  $\vee$  nn

8ビット即値データnnとBRレジスタの内容を上位バイト、8ビット絶対アドレスlを下位バイトとしてアドレス指定されるデータメモリの内容との論理和をとり、結果をそのアドレスにストアします。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |     |
|-----|-----------------|-----|-----|
|     | 1 1 0 1 1 0 0 1 |     | D9H |

l l

nn

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: 即値データ

Dst: 8ビット絶対

| 例 | 設定値    |     | 結果     |    |   |   |   |  |  |
|---|--------|-----|--------|----|---|---|---|--|--|
|   | [BR:l] | nn  | [BR:l] | SC |   |   |   |  |  |
|   |        |     |        | N  | V | C | Z |  |  |
|   | 32H    | 6CH | 7EH    | 0  | — | — | 0 |  |  |
|   | 86H    | 41H | C7H    | 1  | — | — | 0 |  |  |

**OR [HL], A** ////////////////////////////////////////////////////////////////// Logical OR of A reg. and location [HL] ////////////////////////////////////////////////////////////////// 4 cycle //**機能** [HL]  $\vee$  A

Aレジスタの内容とHLレジスタでアドレス指定されたデータメモリの内容との論理和をとり、結果をそのアドレスにストアします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 0 1 0 1 1 0 0 | 2CH |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: レジスタ直接

Dst: レジスタ間接

| 例 | 設定値  |     | 結果   |    |   |   |   |
|---|------|-----|------|----|---|---|---|
|   | [HL] | A   | [HL] | SC |   |   |   |
|   |      |     |      | N  | V | C | Z |
|   | 32H  | 6CH | 7EH  | 0  | — | — | 0 |
|   | 86H  | 41H | C7H  | 1  | — | — | 0 |

**OR [HL], #nn** ////////////////////////////////////////////////////////////////// Logical OR of immediate data nn and location [HL] ////////////////////////////////////////////////////////////////// 5 cycle //**機能** [HL]  $\vee$  nn

8ビット即値データnnとHLレジスタでアドレス指定されたデータメモリの内容との論理和をとり、結果をそのアドレスにストアします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 0 1 0 1 1 0 1 | 2DH |  |
|     | n n             | nn  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: 即値データ

Dst: レジスタ間接

| 例 | 設定値  |     | 結果   |    |   |   |   |
|---|------|-----|------|----|---|---|---|
|   | [HL] | nn  | [HL] | SC |   |   |   |
|   |      |     |      | N  | V | C | Z |
|   | 32H  | 6CH | 7EH  | 0  | — | — | 0 |
|   | 86H  | 41H | C7H  | 1  | — | — | 0 |

**OR [HL], [ir]** ////////////////////////////////////////////////////////////////// Logical OR of location [ir reg.] and location [HL] ////////////////////////////////////////////////////////////////// 5 cycle //**機能** [HL]  $\vee$  [ir]

irレジスタ(IX/IY)とHLレジスタでそれぞれアドレス指定されたデータメモリの内容の論理和をとり、結果をデータメモリ[HL]にストアします。

EPレジスタの内容がデータメモリ[HL]のページアドレス、XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリ[ir]のページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB      |  |
|-----|------------------|----------|--|
|     | 1 1 0 0 1 1 1 0  | CEH      |  |
|     | 0 0 1 0 1 1 1 ir | 2EH, 2FH |  |

| ir | ニーモニック | コード           |
|----|--------|---------------|
| IX | 0      | OR [HL], [IX] |
| IY | 1      | OR [HL], [IY] |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: レジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |      | 結果   |    |   |   |   |
|---|------|------|------|----|---|---|---|
|   | [HL] | [ir] | [HL] | SC |   |   |   |
|   |      |      |      | N  | V | C | Z |
|   | 32H  | 6CH  | 7EH  | 0  | — | — | 0 |
|   | 86H  | 41H  | C7H  | 1  | — | — | 0 |

**PACK** ////////////////////////////////////////////////////////////////// Pack BA reg. to A reg. ////////////////////////////////////////////////////////////////// 2 cycle //

機能 **B A**  
 $\begin{array}{|c|c|} \hline * & m \\ \hline m & n \\ \hline \end{array} \rightarrow \begin{array}{|c|} \hline m \\ \hline n \\ \hline \end{array}$

BAレジスタの内容をパックし、Aレジスタにストアします。Aレジスタの上位4ビットがBレジスタの下位4ビットの内容に置き換えられます。

モード インプライド(レジスタ直接)

| 例 | 設定値   |     | 結果  |    |   |   |
|---|-------|-----|-----|----|---|---|
|   | BA    | A   | B   | SC |   |   |
|   |       |     |     | N  | V | C |
|   | 38C4H | 84H | 38H | —  | — | — |

コード MSB LSB  
 $\begin{array}{|c|c|c|c|c|c|c|c|c|c|} \hline 1 & 1 & 0 & 1 & 1 & 1 & 1 & 1 & 0 \\ \hline \end{array} \text{ DEH}$

フラグ **I1 I0 U D N V C Z**  
 $\begin{array}{|c|c|c|c|c|c|c|c|c|c|} \hline - & - & - & - & - & - & - & - & - \\ \hline \end{array}$

**POP r** ////////////////////////////////////////////////////////////////// Pop top of stack into r reg. ////////////////////////////////////////////////////////////////// 3 cycle //

機能 **r [SP], SP SP + 1**

スタックポインタ(SP)が示すアドレスの内容をレジスタ(A/B/L/H)にロードし、SPをインクリメント(+1)します。

モード レジスタ直接

例 POP Aを実行。

|     | A   | SP    | Stack       |
|-----|-----|-------|-------------|
| 実行前 | 82H | FFFFH | 5AH 00FFFFH |
| 実行後 | 5AH | 0000H |             |

コード MSB LSB  
 $\begin{array}{|c|c|c|c|c|c|c|c|c|c|} \hline 1 & 1 & 0 & 0 & 1 & 1 & 1 & 1 & 1 \\ \hline \end{array} \text{ CFH}$   
 $\begin{array}{|c|c|c|c|c|c|c|c|c|c|} \hline 1 & 0 & 1 & 1 & 0 & 1 & r \\ \hline \end{array} \text{ B4H} \sim \text{B7H}$

| r    | ニーモニック | コード |
|------|--------|-----|
| A 00 | POP A  | B4H |
| B 01 | POP B  | B5H |
| L 10 | POP L  | B6H |
| H 11 | POP H  | B7H |

フラグ **I1 I0 U D N V C Z**  
 $\begin{array}{|c|c|c|c|c|c|c|c|c|c|} \hline - & - & - & - & - & - & - & - & - \\ \hline \end{array}$

**POP rp** ////////////////////////////////////////////////////////////////// Pop top of stack into rp reg. ////////////////////////////////////////////////////////////////// 3 cycle //

機能 **rp(L) [SP], rp(H) [SP+1], SP SP + 2**

スタックポインタ(SP)が示すアドレスからの2バイトの内容をrpレジスタ(BA/HL/IX/IY)の下位バイト、上位バイトの順にロードし、SPに2を加算します。

モード レジスタ直接

例 POP BAを実行。

|     | B   | A   | SP    | Stack       |
|-----|-----|-----|-------|-------------|
| 実行前 | 67H | 05H | FFFFH | 5AH 00FFFFH |
| 実行後 | 23H | 5AH | 0000H | 23H 00FFFFH |

コード MSB LSB  
 $\begin{array}{|c|c|c|c|c|c|c|c|c|c|} \hline 1 & 0 & 1 & 0 & 1 & 0 & rp \\ \hline \end{array} \text{ A8H} \sim \text{ABH}$

| rp    | ニーモニック | コード |
|-------|--------|-----|
| BA 00 | POP BA | A8H |
| HL 01 | POP HL | A9H |
| IX 10 | POP IX | AAH |
| IY 11 | POP IY | ABH |

フラグ **I1 I0 U D N V C Z**  
 $\begin{array}{|c|c|c|c|c|c|c|c|c|c|} \hline - & - & - & - & - & - & - & - & - \\ \hline \end{array}$

**POP BR** /////////////// Pop top of stack into BR reg. /////////////// 2 cycle //

機能 BR [SP], SP SP + 1

スタックポインタ(SP)が示すアドレスの内容をBRレジスタにロードし、SPをインクリメント(+1)します。

コード MSB LSB  
1 0 1 0 1 1 0 0 ACHフラグ I1 I0 U D N V C Z  
- - - - - - - -

モード レジスタ直接

例

|     | BR  | SP    |
|-----|-----|-------|
| 実行前 | 82H | FFFFH |
| 実行後 | 5AH | 0000H |

**POP EP** /////////////// Pop top of stack into EP reg. /////////////// 2 cycle //

機能 EP [SP], SP SP + 1

スタックポインタ(SP)が示すアドレスの内容をEPレジスタにロードし、SPをインクリメント(+1)します。

コード MSB LSB  
1 0 1 0 1 1 0 1 ADHフラグ I1 I0 U D N V C Z  
- - - - - - - -

モード レジスタ直接

例

|     | EP  | SP    |
|-----|-----|-------|
| 実行前 | 82H | FFFFH |
| 実行後 | 5AH | 0000H |



注意 MODEL0/1では本命令が使用できません。

**POP IP** /////////////// Pop top of stack into IP reg. /////////////// 3 cycle //

機能 YP [SP], XP [SP+1], SP SP + 2

スタックポインタ(SP)が示すアドレスからの2バイトの内容をYPレジスタ、XPレジスタの順にロードし、SPに2を加算します。

コード MSB LSB  
1 0 1 0 1 1 1 0 AEHフラグ I1 I0 U D N V C Z  
- - - - - - - -

モード レジスタ直接

例 POP IPを実行。

|     | XP  | YP  | SP    |
|-----|-----|-----|-------|
| 実行前 | 67H | 05H | FFFEH |
| 実行後 | 23H | 5AH | 0000H |



注意 MODEL0/1では本命令が使用できません。

**POP SC** /////////////// Pop top of stack into SC /////////////// 2 cycle //

機能 SC [SP], SP SP + 1

スタックポインタ(SP)が示すアドレスの内容をシステムコンディションフラグ(SC)にセットし、SPをインクリメント(+1)します。

コード MSB LSB  
1 0 1 0 1 1 1 1 AFHフラグ I1 I0 U D N V C Z  
↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓

モード レジスタ直接

例

|     | SC  | SP    |
|-----|-----|-------|
| 実行前 | 82H | FFFFH |
| 実行後 | 5AH | 0000H |



**POP ALE** /////////////// Pop all registers including expand registers /////////////// 14 cycle //**機能** POP IP, EP, BR, IY, IX, HL, BA

スタックポインタ(SP)が示すアドレスからの内容をIP(YP/XP)、EP、BR、IY、IX、HL、BAレジスタの順にポップします。"PUSH ALE"命令で一括して退避させたレジスタの内容を一度に復帰できます。SPにはポップしたバイト数分の12が加算されます。MODEL2/3で使用するレジスタを復帰します。

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 0 0 1 1 1 1   | CFH |  |
|     | 1 0 1 1 1 1 0 1   | BDH |  |
| フラグ | I1 I0 U D N V C Z |     |  |
|     | ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓   |     |  |

**モード** インプライド(レジスタ直接)

**例** SP=FFF4Hの場合、POP ALEを実行すると、下図のようにスタックの内容が各レジスタに戻されSP=0000Hとなります。

|         |       |         |       |
|---------|-------|---------|-------|
| 00FFF9H | IY(H) | 00FFF4H | YP    |
| 00FFF8H | IY(L) | 00FFF5H | XP    |
| 00FFF7H | BR    | 00FFF6H | EP    |
| 00FFF6H | HL    | 00FFF7H | BR    |
| 00FFF5H | A     | 00FFF8H | IY(L) |
| 00FFF4H | B     | 00FFF9H | IY(H) |

**注意** MODEL0/1では本命令が使用できません。**POP ALL** /////////////// Pop all registers /////////////// 11 cycle //**機能** POP BR, IY, IX, HL, BA

スタックポインタ(SP)が示すアドレスからの内容をBR、IY、IX、HL、BAレジスタの順にポップします。"PUSH ALL"命令で一括して退避させたレジスタの内容を一度に復帰できます。SPにはポップしたバイト数分の9が加算されます。MODEL0/1で使用するレジスタを復帰します。

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 0 0 1 1 1 1   | CFH |  |
|     | 1 0 1 1 1 1 0 0   | BCH |  |
| フラグ | I1 I0 U D N V C Z |     |  |
|     | ↓ ↓ ↓ ↓ ↓ ↓ ↓ ↓   |     |  |

**モード** インプライド(レジスタ直接)

**例** SP=FFF7Hの場合、POP ALLを実行すると、下図のようにスタックの内容が各レジスタに戻されSP=0000Hとなります。

|         |       |         |       |
|---------|-------|---------|-------|
| 00FFF9H | IY(H) | 00FFF7H | BR    |
| 00FFF8H | IY(L) | 00FFF8H | IY(L) |
| 00FFF7H | IX(H) | 00FFF9H | IY(H) |
| 00FFF6H | IX(L) | 00FFF7H | BR    |
| 00FFF5H | HL    | 00FFF8H | IY(L) |
| 00FFF4H | BA    | 00FFF9H | IY(H) |

**PUSH r** /////////////// Push r reg. onto stack /////////////// 3 cycle //**機能** [SP-1] r, SP SP - 1

rレジスタ(A/B/L/H)の内容をスタックポインタ(SP)から1を減算した内容で示されるアドレスにストアします。SPはデクリメント(-1)されます。

| コード | MSB             | LSB       |  |
|-----|-----------------|-----------|--|
|     | 1 1 0 0 1 1 1 1 | CFH       |  |
|     | 1 0 1 1 1 0 0 r | B0H ~ B3H |  |

**モード** レジスタ直接**例** PUSH Aを実行。

|     | A   | SP    |  |
|-----|-----|-------|--|
| 実行前 | 5AH | 0000H |  |
|     |     | ↓     |  |
| 実行後 | 5AH | FFFFH |  |

Stack

5AH (A) 00FFFFH

| r    | ニーモニック | コード |
|------|--------|-----|
| A 00 | PUSH A | B0H |
| B 01 | PUSH B | B1H |
| L 10 | PUSH L | B2H |
| H 11 | PUSH H | B3H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**PUSH rp** // Push rp reg. onto stack // 4 cycle //

**機能** [SP-1] rp(H), [SP-2] rp(L), SP SP - 2  
 rpレジスタ(BA/HL/IX/IY)の内容を上位バイト、下位バイトの順にスタックポインタ(SP)から1を減算した内容で示されるアドレスと、さらにひとつ前のアドレスにストアします。  
 SPからは2が減算されます。

**コード** MSB LSB  
 1 0 1 0 0 0 rp A0H ~ A3H

| rp    | ニーモニック  | コード |
|-------|---------|-----|
| BA 00 | PUSH BA | A0H |
| HL 01 | PUSH HL | A1H |
| IX 10 | PUSH IX | A2H |
| IY 11 | PUSH IY | A3H |

**フラグ** I1 I0 U D N V C Z  
 - - - - - - - - -

**モード** レジスタ直接

**例** PUSH BAを実行。

|     | BA    | SP    |                                    |
|-----|-------|-------|------------------------------------|
| 実行前 | 235AH | 0000H |                                    |
|     |       |       | Stack                              |
| 実行後 | 235AH | FFFEH | 5AH (A) 00FFFFH<br>23H (B) 00FFFFH |

**PUSH BR** // Push BR reg. onto stack // 3 cycle //

**機能** [SP-1] BR, SP SP - 1  
 BRレジスタの内容をスタックポインタ(SP)から1を減算した内容で示されるアドレスにストアします。SPはデクリメント(-1)されます。

**コード** MSB LSB  
 1 0 1 0 0 1 0 0 A4H

**フラグ** I1 I0 U D N V C Z  
 - - - - - - - - -

**モード** レジスタ直接

**例**

|     | BR  | SP    |                  |
|-----|-----|-------|------------------|
| 実行前 | 5AH | 0000H |                  |
|     |     |       | Stack            |
| 実行後 | 5AH | FFFFH | 5AH (BR) 00FFFFH |

**PUSH EP** // Push EP reg. onto stack // 3 cycle //

**機能** [SP-1] EP, SP SP - 1  
 EPレジスタの内容をスタックポインタ(SP)から1を減算した内容で示されるアドレスにストアします。SPはデクリメント(-1)されます。

**コード** MSB LSB  
 1 0 1 0 0 1 0 1 A5H

**フラグ** I1 I0 U D N V C Z  
 - - - - - - - - -

**モード** レジスタ直接

**例**

|     | EP  | SP    |                  |
|-----|-----|-------|------------------|
| 実行前 | 5AH | 0000H |                  |
|     |     |       | Stack            |
| 実行後 | 5AH | FFFFH | 5AH (EP) 00FFFFH |

**注意** MODEL0/1では本命令が使用できません。

**PUSH IP** // Push IP reg. onto stack // 4 cycle //**機能** [SP-1] XP, [SP-2] YP, SP SP - 2

YPレジスタ、XPレジスタの内容をそれぞれスタックポインタ(SP)から1を減算した内容で示されるアドレスと、さらにひとつ前のアドレスにストアします。SPからは2が減算されます。

**コード** MSB LSB  

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

 A6H

**フラグ** I1 I0 U D N V C Z  

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

**モード** レジスタ直接**例** PUSH IPを実行。

|     | XP  | YP  | SP     |                                      |
|-----|-----|-----|--------|--------------------------------------|
| 実行前 | 23H | 5AH | 0000H  |                                      |
|     |     |     |        | Stack                                |
| 実行後 | 23H | 5AH | FFFFEH | 5AH (YP) 00FFFFH<br>23H (XP) 00FFFFH |

**注意** MODEL0/1では本命令が使用できません。**PUSH SC** // Push SC onto stack // 3 cycle //**機能** [SP-1] SC, SP SP - 1

システムコンディションフラグ(SC)の内容をスタックポインタ(SP)から1を減算した内容で示されるアドレスにストアします。SPはデクリメント(-1)されます。

**コード** MSB LSB  

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

 A7H

**フラグ** I1 I0 U D N V C Z  

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

**モード** レジスタ直接**例**

|     | SC  | SP    |                  |
|-----|-----|-------|------------------|
| 実行前 | 5AH | 0000H |                  |
|     |     |       | Stack            |
| 実行後 | 5AH | FFFFH | 5AH (SC) 00FFFFH |

**PUSH ALE** // Push all registers including expand registers // 15 cycle //**機能** PUSH BA, HL, IX, IY, BR, EP, IP

BA、HL、IX、IY、BR、EP、IP(XP/YP)の順にレジスタの内容をスタックポインタ(SP)が示すアドレスから下位のアドレスに向けてプッシュします。SPはプッシュしたバイト数分の12が減算されます。

MODEL2/3で使用するレジスタを退避します。

**コード** MSB LSB  

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

 CFH  

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

 B9H

**フラグ** I1 I0 U D N V C Z  

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

**モード** インプライド(レジスタ直接)**例** SP=0000Hの場合、PUSH ALEを実行すると、下図のようにレジスタがスタックされSP=FFF4Hとなります。

|         |       |         |       |
|---------|-------|---------|-------|
| 00FFFAH | IX(L) | 00FFF4H | YP    |
| 00FFFBH | IX(H) | 00FFF5H | XP    |
| 00FFFCB | L     | 00FFF6H | EP    |
| 00FFFDH | H     | 00FFF7H | BR    |
| 00FFFEH | A     | 00FFF8H | IY(L) |
| 00FFFFH | B     | 00FFF9H | IY(H) |

**注意** MODEL0/1では本命令が使用できません。**PUSH ALL** // Push all registers // 12 cycle //**機能** PUSH BA, HL, IX, IY, BR

BA、HL、IX、IY、BRの順にレジスタの内容をスタックポインタ(SP)が示すアドレスから下位のアドレスに向けてプッシュします。SPはプッシュしたバイト数分の9が減算されます。

MODEL0/1で使用するレジスタを退避します。

**コード** MSB LSB  

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

 CFH  

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

 B8H

**フラグ** I1 I0 U D N V C Z  

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

**モード** インプライド(レジスタ直接)**例** SP=0000Hの場合、PUSH ALLを実行すると、下図のようにレジスタがスタックされSP=FFF7Hとなります。

|         |   |         |       |
|---------|---|---------|-------|
| 00FFFCB | L | 00FFF7H | BR    |
| 00FFFDH | H | 00FFF8H | IY(L) |
| 00FFFEH | A | 00FFF9H | IY(H) |
| 00FFFFH | B | 00FFFAH | IX(L) |
|         |   | 00FFFBH | IX(H) |

**RET** ////////////////////////////////////////////////////////////////// Return from subroutine ////////////////////////////////////////////////////////////////// 3(MIN)/4(MAX) cycle //

**機能** MODEL0/1, MODEL2/3(ミニマムモード)  
 PC(L) [SP], PC(H) [SP+1], SP SP + 2  
 MODEL2/3(マキシマムモード)  
 PC(L) [SP], PC(H) [SP+1], CB [SP+2],  
 NB CB, SP SP + 3

スタックポインタ(SP)で示されるアドレスからの2バイトをプログラムカウンタ(PC)の下位バイト、上位バイトの順にロードして、サブルーチンからリターンします。

MODEL2/3のマキシマムモードでは、続く1バイトをパンクアドレスとしてCBにロードし、呼び出し元のパンクに戻します。同時に、そのパンクアドレスをNBにも再設定します。

SPは復帰させたバイト数分(ミニマムモード: 2バイト、マキシマムモード: 3バイト)だけ加算されます。

**例** MODEL2/3マキシマムモードにおいて物理アドレス013100H番地にあるRET命令を実行。

|     | NB  | CB  | PC(論理アドレス) | SP    | Stack                                                        |
|-----|-----|-----|------------|-------|--------------------------------------------------------------|
| 実行前 | 02H | 02H | B100H      | FFFDH | 03H(PC(L)) 00FFFFDH<br>90H(PC(H)) 00FFFEH<br>01H(CB) 00FFFFH |
| 実行後 | 01H | 01H | 9003H      | 0000H |                                                              |

上記の例では物理アドレス009003Hへ復帰します。  
 MODEL2/3ミニマムモードでは、CBがスタックされていませんのでCB, NBは変化しません。  
 MODEL0/1ではCB, NBはありません。

**注意** 例外処理ルーチンからのリターンには次の"RETE"命令を使用してください。

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 1 1 1 0 0 0 | F8H |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**RETE** ////////////////////////////////////////////////////////////////// Return from exception processing routine ////////////////////////////////////////////////////////////////// 4(MIN)/5(MAX) cycle //

**機能** MODEL0/1, MODEL2/3(ミニマムモード)  
 SC [SP], PC(L) [SP+1], PC(H) [SP+2],  
 SP SP + 3  
 MODEL2/3(マキシマムモード)  
 SC [SP], PC(L) [SP+1], PC(H) [SP+2],  
 CB [SP+3], NB CB, SP SP + 4

スタックポインタ(SP)で示されるアドレスからの3バイトをシステムコンディションフラグ(SC)、プログラムカウンタ(PC)の下位バイト、上位バイトの順にロードして、例外処理ルーチンからリターンします。

MODEL2/3のマキシマムモードでは、続く1バイトをパンクアドレスとしてCBにロードし、割り込み発生時のパンクに戻します。同時に、そのパンクアドレスをNBにも再設定します。

SPは復帰させたバイト数分(ミニマムモード: 3バイト、マキシマムモード: 4バイト)だけ加算されます。

**例** MODEL2/3マキシマムモードにおいて物理アドレス013100H番地にあるRETE命令を実行。

|     | NB  | CB  | PC(論理アドレス) | SP    | SC  | Stack                                                                            |
|-----|-----|-----|------------|-------|-----|----------------------------------------------------------------------------------|
| 実行前 | 02H | 02H | B100H      | FFFCH | 91H | 54H(SC) 00FFFFCH<br>03H(PC(L)) 00FFFFDH<br>90H(PC(H)) 00FFFEH<br>01H(CB) 00FFFFH |
| 実行後 | 01H | 01H | 9003H      | 0000H | 54H |                                                                                  |

上記の例では物理アドレス009003Hへ復帰します。  
 MODEL2/3ミニマムモードでは、CBがスタックされていませんのでCB, NBは変化しません。  
 MODEL0/1ではCB, NBはありません。

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 1 1 1 0 0 1 | F9H |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | ↑  | ↑  | ↑ | ↑ | ↑ | ↑ | ↑ | ↑ |

**RETS** ////////////////////////////////////////////////////////////////// Return from subroutine then skip 2 byte ////////////////////////////////////////////////////////////////// 5(MIN)/6(MAX) cycle //

**機能** MODEL0/1, MODEL2/3(ミニマムモード)  
 PC(L) [SP], PC(H) [SP+1], SP SP + 2,  
 PC PC + 2  
 MODEL2/3(マキシマムモード)  
 PC(L) [SP], PC(H) [SP+1], CB [SP+2],  
 NB CB, SP SP + 3, PC PC + 2  
 "RET"命令を実行後、リターンしたアドレスの2  
 バイト命令をスキップします。

| コード | MSB             | LSB |   |   |   |   |   |   |
|-----|-----------------|-----|---|---|---|---|---|---|
|     | 1 1 1 1 1 0 1 0 | FAH |   |   |   |   |   |   |
| フラグ | I1              | I0  | U | D | N | V | C | Z |
|     | -               | -   | - | - | - | - | - | - |

**例** MODEL2/3マキシマムモードにおいて物理アドレス013100H番地にあるRET命令を実行。

|     | NB  | CB  | PC(論理アドレス) | SP     |
|-----|-----|-----|------------|--------|
| 実行前 | 02H | 02H | B100H      | FFFFDH |
|     |     |     | +2         |        |
| 実行後 | 01H | 01H | 9005H      | 0000H  |

Stack  
 03H(PC(L)) 00FFFFDH  
 90H(PC(H)) 00FFFFEH  
 01H(CB) 00FFFFH

上記の例では物理アドレス009005Hへ復帰します。  
 MODEL2/3ミニマムモードでは、CBがスタック  
 されていませんのでCB, NBは変化しません。  
 MODEL0/1ではCB, NBはありません。

**RL r** ////////////////////////////////////////////////////////////////// Rotate left r reg. with carry ////////////////////////////////////////////////////////////////// 3 cycle //

**機能** [C ← 7 6 5 4 3 2 1 0] ← r  
 rレジスタ(A/B)の内容をキャリー(C)を含めて1  
 ビット分左に回転させます。キャリー(C)の内容  
 がレジスタのビット0に、レジスタのビット7は  
 キャリー(C)に移動します。

| コード | MSB             | LSB        |
|-----|-----------------|------------|
|     | 1 1 0 0 1 1 1 0 | CEH        |
|     | 1 0 0 1 0 0 0 0 | r 90H, 91H |

**モード** レジスタ直接

| 例   | 設定値 |     | 結果 |    |   |   |
|-----|-----|-----|----|----|---|---|
|     | r   | C   | r  | SC |   |   |
|     |     |     |    | N  | V | C |
| 83H | 0   | 06H | 0  | —  | 1 | 0 |
| 4CH | 0   | 98H | 1  | —  | 0 | 0 |
| A2H | 1   | 45H | 0  | —  | 1 | 0 |

| r | ニーモニック | コード  |
|---|--------|------|
| A | 0      | RL A |
| B | 1      | RL B |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | ↑ | ↑ |

**RL [BR:ll]** /////////////// Rotate left location [BR:ll] with carry /////////////// 5 cycle //

機能 [C ← 7|6|5|4|3|2|1|0 ← [BR:ll]

モード 8ビット絶対

BRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されたデータメモリの内容をキャリー(C)を含めて1ビット分左に回転させます。キャリー(C)の内容がデータのビット0に、データのビット7はキャリー(C)に移動します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 0 0 1 1 1 0 | CEH |
|     | 1 0 0 1 0 0 1 0 | 92H |
|     | l l             | ll  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | ↑ | ↑ |

| 例 | 設定値     |   | 結果  |   |   |   |   |
|---|---------|---|-----|---|---|---|---|
|   | [BR:ll] | C | SC  |   |   |   |   |
|   |         |   | N   | V | C | Z |   |
|   | 83H     | 0 | 06H | 0 | — | 1 | 0 |
|   | 4CH     | 0 | 98H | 1 | — | 0 | 0 |
|   | A2H     | 1 | 45H | 0 | — | 1 | 0 |

**RL [HL]** /////////////// Rotate left location [HL] with carry /////////////// 4 cycle //

機能 [C ← 7|6|5|4|3|2|1|0 ← [HL]

モード レジスタ間接

HLレジスタで指定されたデータメモリの内容をキャリー(C)を含めて1ビット分左に回転させます。キャリー(C)の内容がデータのビット0に、データのビット7はキャリー(C)に移動します。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 0 0 1 1 1 0 | CEH |
|     | 1 0 0 1 0 0 1 1 | 93H |
|     | l l             | ll  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | ↑ | ↑ |

| 例 | 設定値  |   | 結果  |   |   |   |   |
|---|------|---|-----|---|---|---|---|
|   | [HL] | C | SC  |   |   |   |   |
|   |      |   | N   | V | C | Z |   |
|   | 83H  | 0 | 06H | 0 | — | 1 | 0 |
|   | 4CH  | 0 | 98H | 1 | — | 0 | 0 |
|   | A2H  | 1 | 45H | 0 | — | 1 | 0 |

**RLC r** /////////////// Rotate left r reg. circular /////////////// 3 cycle //

機能 C←[7 6 5 4 3 2 1 0]← r

モード レジスタ直接

rレジスタ(A/B)の内容を1ビット分左に回転させます。レジスタのビット7がビット0およびキャリー(C)に移動します。

| コード | MSB               | LSB      |  |
|-----|-------------------|----------|--|
|     | [1 1 0 0 1 1 1 0] | CEH      |  |
|     | [1 0 0 1 0 1 0 r] | 94H, 95H |  |

| r | ニーモニック  | コード |
|---|---------|-----|
| A | 0 RLC A | 94H |
| B | 1 RLC B | 95H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | ↑ | ↑ |

| 例   |   | 設定値 |    | 結果 |   |   |  |
|-----|---|-----|----|----|---|---|--|
| r   | C | r   | SC |    |   |   |  |
|     |   |     | N  | V  | C | Z |  |
| E3H | 0 | C7H | 1  | —  | 1 | 0 |  |
| 3BH | 1 | 76H | 0  | —  | 0 | 0 |  |

**RLC [BR:ll]** /////////////// Rotate left location [BR:ll] circular /////////////// 5 cycle //

機能 C←[7 6 5 4 3 2 1 0]← [BR:ll]

モード 8ビット絶対

BRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されたデータメモリの内容を1ビット分左に回転させます。データのビット7がビット0およびキャリー(C)に移動します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | [1 1 0 0 1 1 1 0] | CEH |  |
|     | [1 0 0 1 0 1 1 0] | 96H |  |
|     | [l l]             | ll  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | ↑ | ↑ |

| 例       |   | 設定値     |    | 結果 |   |   |  |
|---------|---|---------|----|----|---|---|--|
| [BR:ll] | C | [BR:ll] | SC |    |   |   |  |
|         |   |         | N  | V  | C | Z |  |
| E3H     | 0 | C7H     | 1  | —  | 1 | 0 |  |
| 3BH     | 1 | 76H     | 0  | —  | 0 | 0 |  |

**RLC [HL]** /////////////// Rotate left location [HL] circular /////////////// 4 cycle //

機能 C←[7 6 5 4 3 2 1 0]← [HL]

モード レジスタ間接

HLレジスタで指定されたデータメモリの内容を1ビット分左に回転させます。データのビット7がビット0およびキャリー(C)に移動します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | [1 1 0 0 1 1 1 0] | CEH |  |
|     | [1 0 0 1 0 1 1 1] | 97H |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | ↑ | ↑ |

| 例    |   | 設定値  |    | 結果 |   |   |  |
|------|---|------|----|----|---|---|--|
| [HL] | C | [HL] | SC |    |   |   |  |
|      |   |      | N  | V  | C | Z |  |
| E3H  | 0 | C7H  | 1  | —  | 1 | 0 |  |
| 3BH  | 1 | 76H  | 0  | —  | 0 | 0 |  |

**RR r** /////////////// Rotate right r reg. with carry /////////////// 3 cycle //

機能  $\rightarrow 7\ 6\ 5\ 4\ 3\ 2\ 1\ 0 \rightarrow C \ r$

モード レジスタ直接

rレジスタ(A/B)の内容をキャリー(C)を含めて1ビット分右に回転させます。キャリー(C)の内容がレジスタのピット7に、レジスタのピット0はキャリー(C)に移動します。

| コード | MSB             | LSB     |  |
|-----|-----------------|---------|--|
|     | 1 1 0 0 1 1 1 0 | CEH     |  |
|     | 1 0 0 1 1 0 0 r | 98H、99H |  |

| r   | ニーモニック | コード |
|-----|--------|-----|
| A 0 | RR A   | 98H |
| B 1 | RR B   | 99H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | ↑ | ↑ |

| 例 | 設定値 |   | 結果  |    |   |   |   |
|---|-----|---|-----|----|---|---|---|
|   | r   | C | r   | SC |   |   |   |
|   |     |   |     | N  | V | C |   |
|   | 7EH | 0 | 3FH | 0  | — | 0 | 0 |
|   | 51H | 0 | 28H | 0  | — | 1 | 0 |
|   | D4H | 1 | EAH | 1  | — | 0 | 0 |

**RR [BR:l]** /////////////// Rotate right location [BR:l] with carry /////////////// 5 cycle //

機能  $\rightarrow 7\ 6\ 5\ 4\ 3\ 2\ 1\ 0 \rightarrow C \ [BR:l]$

モード 8ビット絶対

BRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されたデータメモリの内容をキャリー(C)を含めて1ビット分右に回転させます。キャリー(C)の内容がデータのピット7に、データのピット0はキャリー(C)に移動します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 0 0 1 1 0 1 0 | 9AH |  |
|     | l l l l l l l l | ll  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | ↑ | ↑ |

| 例 | 設定値    |   | 結果     |    |   |   |   |
|---|--------|---|--------|----|---|---|---|
|   | [BR:l] | C | [BR:l] | SC |   |   |   |
|   |        |   |        | N  | V | C |   |
|   | 7EH    | 0 | 3FH    | 0  | — | 0 | 0 |
|   | 51H    | 0 | 28H    | 0  | — | 1 | 0 |
|   | D4H    | 1 | EAH    | 1  | — | 0 | 0 |

**RR [HL]** /////////////// Rotate right location [HL] with carry /////////////// 4 cycle //機能   [HL]

モード レジスタ間接

HLレジスタで指定されたデータメモリの内容をキャリー(C)を含めて1ビット分右に回転させます。キャリー(C)の内容がデータのピット7に、データのピット0はキャリー(C)に移動します。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| [HL] | C | [HL] | 設定値 |   |     |   | 結果 |   |   |   |
|------|---|------|-----|---|-----|---|----|---|---|---|
|      |   |      | SC  |   |     |   | N  | V | C | Z |
|      |   |      | 7EH | 0 | 3FH | 0 |    |   |   |   |
| 51H  | 0 | 28H  | 0   | — | 1   | 0 |    |   |   |   |
| D4H  | 1 | EAH  | 1   | — | 0   | 0 |    |   |   |   |

コード MSB  LSB CEH 9BHフラグ **RRC r** /////////////// Rotate right r reg. circular /////////////// 3 cycle //機能  

モード レジスタ直接

rレジスタ(A/B)の内容を1ビット分右に回転させます。レジスタのピット0がピット7およびキャリー(C)に移動します。

| r   | C | r   | 設定値 |   |     |   | 結果 |   |   |   |
|-----|---|-----|-----|---|-----|---|----|---|---|---|
|     |   |     | SC  |   |     |   | N  | V | C | Z |
|     |   |     | C6H | 1 | 63H | 0 |    |   |   |   |
| D7H | 0 | EBH | 1   | — | 1   | 0 |    |   |   |   |

コード MSB  LSB CEH 9CH、9DH

|   |        |       |
|---|--------|-------|
| r | ニーモニック | コード   |
| A | 0      | RRC A |
| B | 1      | RRC B |

フラグ 

**RRC [BR:ll]** ////////////// Rotate right location [BR:ll] circular ////////////// 5 cycle //機能 **7 6 5 4 3 2 1 0** **→ C [BR:ll]**

モード 8ビット絶対

BRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されたデータメモリの内容を1ビット分右に回転させます。データのビット0がビット7およびキャリー(C)に移動します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| 例 | 設定値     |   | 結果      |    |   |   |   |
|---|---------|---|---------|----|---|---|---|
|   | [BR:ll] | C | [BR:ll] | SC |   |   |   |
|   |         |   |         | N  | V | C | Z |
|   | C6H     | 1 | 63H     | 0  | — | 0 | 0 |
|   | D7H     | 0 | EBH     | 1  | — | 1 | 0 |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 0 0 1 1 1 1 0 | 9EH |  |
|     | l l             | ll  |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | ↑ | ↑ |

**RRC [HL]** ////////////// Rotate right location [HL] circular ////////////// 4 cycle //機能 **7 6 5 4 3 2 1 0** **→ C [HL]**

モード レジスタ間接

HLレジスタで指定されたデータメモリの内容を1ビット分右に回転させます。データのビット0がビット7およびキャリー(C)に移動します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| 例 | 設定値  |   | 結果   |    |   |   |   |
|---|------|---|------|----|---|---|---|
|   | [HL] | C | [HL] | SC |   |   |   |
|   |      |   |      | N  | V | C | Z |
|   | C6H  | 1 | 63H  | 0  | — | 0 | 0 |
|   | D7H  | 0 | EBH  | 1  | — | 1 | 0 |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 0 0 1 1 1 1 1 | 9FH |  |

  

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | ↑ | ↑ |

**SBC A, r** ////////////////////////////////////////////////////////////////// Subtract with carry r reg. from A reg. ////////////////////////////////////////////////////////////////// 2 cycle //

機能 A A - r - C

レジスタ(A/B)の内容とキャリー(C)をAレジスタから減算します。

| コード | MSB             | LSB      | 18H, 19H |   |   |   |   |   |
|-----|-----------------|----------|----------|---|---|---|---|---|
|     | 0 0 0 1 1 0 0 r |          |          |   |   |   |   |   |
|     | r               | ニーモニック   | コード      |   |   |   |   |   |
| A   | 0               | SBC A, A | 18H      |   |   |   |   |   |
| B   | 1               | SBC A, B | 19H      |   |   |   |   |   |
| フラグ | I1              | I0       | U        | D | N | V | C | Z |
|     | -               | -        |          | ↑ | ↑ | ↓ | ↑ | ↑ |

モード Src: レジスタ直接

Dst: レジスタ直接

| 例           | 設定値 |   |     | 結果 |    |    |           |
|-------------|-----|---|-----|----|----|----|-----------|
|             | A   | B | C   | A  | SC |    |           |
| D=0, U=0の場合 |     |   | A   | N  | V  | C  | Z         |
| A8H         | 42H | 1 | 65H | 0  | 1  | 0  | 0         |
| 36H         | 5AH | 1 | DBH | 1  | 0  | 1  | 0         |
| D=1, U=0の場合 |     |   | 88  | 39 | 1  | 48 | 0 0 0 0 0 |
| D=1, U=1の場合 |     |   | 88  | 39 | 1  | 08 | 0 0 1 0 0 |

**SBC A, #nn** ////////////////////////////////////////////////////////////////// Subtract with carry immediate data nn from A reg. ////////////////////////////////////////////////////////////////// 2 cycle //

機能 A A - nn - C

8ビット即値データnnとキャリー(C)をAレジスタから減算します。

| コード | MSB             | LSB | 1AH |   |   |   |   |   |
|-----|-----------------|-----|-----|---|---|---|---|---|
|     | 0 0 0 1 1 0 1 0 |     |     |   |   |   |   |   |
|     | n n             |     | nn  |   |   |   |   |   |
| フラグ | I1              | I0  | U   | D | N | V | C | Z |
|     | -               | -   |     | ↑ | ↑ | ↑ | ↑ | ↑ |

モード Src: 即値データ

Dst: レジスタ直接

| 例           | 設定値 |    |     | 結果 |    |    |           |
|-------------|-----|----|-----|----|----|----|-----------|
|             | A   | nn | C   | A  | SC |    |           |
| D=0, U=0の場合 |     |    | A   | N  | V  | C  | Z         |
| A8H         | 42H | 1  | 65H | 0  | 1  | 0  | 0         |
| 36H         | 5AH | 1  | DBH | 1  | 0  | 1  | 0         |
| D=1, U=0の場合 |     |    | 88  | 39 | 1  | 48 | 0 0 0 0 0 |
| D=1, U=1の場合 |     |    | 88  | 39 | 1  | 08 | 0 0 1 0 0 |

**SBC A, [BR:ll]** ////////////////////////////////////////////////////////////////// Subtract with carry location [BR:ll] from A reg. ////////////////////////////////////////////////////////////////// 3 cycle //

機能 A A - [BR:ll] - C

BRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されたデータメモリの内容とキャリー(C)をAレジスタから減算します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB | 1CH |   |   |   |   |   |
|-----|-----------------|-----|-----|---|---|---|---|---|
|     | 0 0 0 1 1 1 0 0 |     |     |   |   |   |   |   |
|     | l l             |     | ll  |   |   |   |   |   |
| フラグ | I1              | I0  | U   | D | N | V | C | Z |
|     | -               | -   |     | ↑ | ↑ | ↑ | ↑ | ↑ |

モード Src: 8ビット絶対

Dst: レジスタ直接

| 例           | 設定値 |         |     | 結果 |    |    |           |
|-------------|-----|---------|-----|----|----|----|-----------|
|             | A   | [BR:ll] | C   | A  | SC |    |           |
| D=0, U=0の場合 |     |         | A   | N  | V  | C  | Z         |
| A8H         | 42H | 1       | 65H | 0  | 1  | 0  | 0         |
| 36H         | 5AH | 1       | DBH | 1  | 0  | 1  | 0         |
| D=1, U=0の場合 |     |         | 88  | 39 | 1  | 48 | 0 0 0 0 0 |
| D=1, U=1の場合 |     |         | 88  | 39 | 1  | 08 | 0 0 1 0 0 |

**SBC A, [hhll]** ////////////////////////////////////////////////////////////////// Subtract with carry location [hhll] from A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A A - [hhll] - C

16ビット絶対アドレスhhllでアドレス指定されたデータメモリの内容とキャリー(C)をAレジスタから減算します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB               | LSB       |  |
|-----|-------------------|-----------|--|
|     | 0 0 0 1 1 1 0 1   | 1DH       |  |
|     | <i>l</i> <i>l</i> | <i>ll</i> |  |
|     | <i>h</i> <i>h</i> | <i>hh</i> |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  |   |   | ↑ | ↑ | ↑ | ↑ |

**モード** Src: 16ビット絶対

Dst: レジスタ直接

**例**

| 設定値         |        |   | 結果  |    |   |   |   |
|-------------|--------|---|-----|----|---|---|---|
| A           | [hhll] | C | A   | SC |   |   |   |
|             |        |   |     | N  | V | C | Z |
| D=0, U=0の場合 |        |   |     |    |   |   |   |
| A8H         | 42H    | 1 | 65H | 0  | 1 | 0 | 0 |
| 36H         | 5AH    | 1 | DBH | 1  | 0 | 1 | 0 |
| D=1, U=0の場合 |        |   |     |    |   |   |   |
| 88          | 39     | 1 | 48  | 0  | 0 | 0 | 0 |
| D=1, U=1の場合 |        |   |     |    |   |   |   |
| 88          | 39     | 1 | 08  | 0  | 0 | 1 | 0 |

**SBC A, [HL]** ////////////////////////////////////////////////////////////////// Subtract with carry location [HL] from A reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** A A - [HL] - C

HLレジスタでアドレス指定されたデータメモリの内容とキャリー(C)をAレジスタから減算します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 0 0 1 1 0 1 1 | 1BH |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  |   |   | ↑ | ↑ | ↑ | ↑ |

**モード** Src: レジスタ間接

Dst: レジスタ直接

**例**

| 設定値         |      |   | 結果  |    |   |   |   |
|-------------|------|---|-----|----|---|---|---|
| A           | [HL] | C | A   | SC |   |   |   |
|             |      |   |     | N  | V | C | Z |
| D=0, U=0の場合 |      |   |     |    |   |   |   |
| A8H         | 42H  | 1 | 65H | 0  | 1 | 0 | 0 |
| 36H         | 5AH  | 1 | DBH | 1  | 0 | 1 | 0 |
| D=1, U=0の場合 |      |   |     |    |   |   |   |
| 88          | 39   | 1 | 48  | 0  | 0 | 0 | 0 |
| D=1, U=1の場合 |      |   |     |    |   |   |   |
| 88          | 39   | 1 | 08  | 0  | 0 | 1 | 0 |

**SBC A, [ir]** ////////////////////////////////////////////////////////////////// Subtract with carry location [ir reg.] from A reg. ////////////////////////////////////////////////////////////////// 2 cycle //**機能** A A - [ir] - C

irレジスタ(IX/IY)でアドレス指定されたデータメモリの内容とキャリー(C)をAレジスタから減算します。

XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB      |  |
|-----|------------------|----------|--|
|     | 0 0 0 1 1 1 1 ir | 1EH, 1FH |  |

| ir   | ニーモニック      | コード |
|------|-------------|-----|
| IX 0 | SBC A, [IX] | 1EH |
| IY 1 | SBC A, [IY] | 1FH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  |   |   | ↑ | ↑ | ↑ | ↑ |

**モード** Src: レジスタ間接

Dst: レジスタ直接

**例**

| 設定値         |      |   | 結果  |    |   |   |   |
|-------------|------|---|-----|----|---|---|---|
| A           | [ir] | C | A   | SC |   |   |   |
|             |      |   |     | N  | V | C | Z |
| D=0, U=0の場合 |      |   |     |    |   |   |   |
| A8H         | 42H  | 1 | 65H | 0  | 1 | 0 | 0 |
| 36H         | 5AH  | 1 | DBH | 1  | 0 | 1 | 0 |
| D=1, U=0の場合 |      |   |     |    |   |   |   |
| 88          | 39   | 1 | 48  | 0  | 0 | 0 | 0 |
| D=1, U=1の場合 |      |   |     |    |   |   |   |
| 88          | 39   | 1 | 08  | 0  | 0 | 1 | 0 |

**SBC A, [ir+dd]** ||||| Subtract with carry location [ir reg. + dd] from A reg. ||||||| 4 cycle |||**機能** A A - [ir+dd] - C

irレジスタ(IX/IY)の内容とディスプレースメントddの和でアドレス指定されたデータメモリの内容とキャリー(C)をAレジスタから減算します。  
ddは符号付きデータとして扱われ、範囲は-128～127です。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード  | MSB              | LSB | CEH     |   |   |   |   |   |
|------|------------------|-----|---------|---|---|---|---|---|
|      | 1 1 0 0 1 1 1 0  |     |         |   |   |   |   |   |
|      | 0 0 0 1 1 0 0 ir |     | 18H、19H |   |   |   |   |   |
|      | d d              |     | dd      |   |   |   |   |   |
| ir   | ニーモニック           | コード |         |   |   |   |   |   |
| IX 0 | SBC A, [IX+dd]   | 18H |         |   |   |   |   |   |
| IY 1 | SBC A, [IY+dd]   | 19H |         |   |   |   |   |   |
| フラグ  | I1               | I0  | U       | D | N | V | C | Z |
|      | -                | -   |         | ↑ | ↑ | ↑ | ↑ | ↑ |

**モード** Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ直接

| 例           | 設定値 |         |     | 結果 |    |   |   |  |
|-------------|-----|---------|-----|----|----|---|---|--|
|             | A   | [ir+dd] | C   | A  | SC |   |   |  |
|             |     |         | N   | V  | C  | Z |   |  |
| D=0, U=0の場合 |     |         |     |    |    |   |   |  |
| A8H         | 42H | 1       | 65H | 0  | 1  | 0 | 0 |  |
| 36H         | 5AH | 1       | DBH | 1  | 0  | 1 | 0 |  |
| D=1, U=0の場合 |     |         |     |    |    |   |   |  |
| 88          | 39  | 1       | 48  | 0  | 0  | 0 | 0 |  |
| D=1, U=1の場合 |     |         |     |    |    |   |   |  |
| 88          | 39  | 1       | 08  | 0  | 0  | 1 | 0 |  |

**SBC A, [ir+L]** ||||||| Subtract with carry location [ir reg. + L] from A reg. ||||||| 4 cycle |||**機能** A A - [ir+L] - C

irレジスタ(IX/IY)の内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容とキャリー(C)をAレジスタから減算します。  
Lレジスタの内容は符号付きデータとして扱われ、範囲は-128～127です。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード  | MSB              | LSB | CEH     |   |   |   |   |   |
|------|------------------|-----|---------|---|---|---|---|---|
|      | 1 1 0 0 1 1 1 0  |     |         |   |   |   |   |   |
|      | 0 0 0 1 1 0 1 ir |     | 1AH、1BH |   |   |   |   |   |
|      | d d              |     | dd      |   |   |   |   |   |
| ir   | ニーモニック           | コード |         |   |   |   |   |   |
| IX 0 | SBC A, [IX+L]    | 1AH |         |   |   |   |   |   |
| IY 1 | SBC A, [IY+L]    | 1BH |         |   |   |   |   |   |
| フラグ  | I1               | I0  | U       | D | N | V | C | Z |
|      | -                | -   |         | ↓ | ↓ | ↓ | ↓ | ↑ |

**モード** Src: インデックスレジスタ付きレジスタ間接

Dst: レジスタ直接

| 例           | 設定値 |        |     | 結果 |    |   |   |  |
|-------------|-----|--------|-----|----|----|---|---|--|
|             | A   | [ir+L] | C   | A  | SC |   |   |  |
|             |     |        | N   | V  | C  | Z |   |  |
| D=0, U=0の場合 |     |        |     |    |    |   |   |  |
| A8H         | 42H | 1      | 65H | 0  | 1  | 0 | 0 |  |
| 36H         | 5AH | 1      | DBH | 1  | 0  | 1 | 0 |  |
| D=1, U=0の場合 |     |        |     |    |    |   |   |  |
| 88          | 39  | 1      | 48  | 0  | 0  | 0 | 0 |  |
| D=1, U=1の場合 |     |        |     |    |    |   |   |  |
| 88          | 39  | 1      | 08  | 0  | 0  | 1 | 0 |  |

**SBC [HL], A** ////////////// Subtract with carry A reg. from location [HL] ////////////// 4 cycle //

機能 [HL] - [HL] - A - C

Aレジスタの内容とキャリー(C)をHLレジスタでアドレス指定されたデータメモリから減算します。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |   |   |   |   |   |   |
|-----|-----------------|-----|---|---|---|---|---|---|
|     | 1 1 0 0 1 1 1 0 | CEH |   |   |   |   |   |   |
|     | 0 0 0 1 1 1 0 0 | 1CH |   |   |   |   |   |   |
| フラグ | I1              | I0  | U | D | N | V | C | Z |
|     | -               | -   |   |   | ↓ | ↓ | ↓ | ↑ |

モード Src: レジスタ直接

Dst: レジスタ間接

| 例           | 設定値  |   |     | 結果   |    |   |   |   |   |
|-------------|------|---|-----|------|----|---|---|---|---|
|             | [HL] | A | C   | [HL] | SC | N | V | C | Z |
| D=0, U=0の場合 |      |   |     |      |    |   |   |   |   |
| A8H         | 42H  | 1 | 65H | 0    | 1  | 0 | 0 |   |   |
| 36H         | 5AH  | 1 | DBH | 1    | 0  | 1 | 0 |   |   |
| D=1, U=0の場合 |      |   |     |      |    |   |   |   |   |
| 88          | 39   | 1 | 48  | 0    | 0  | 0 | 0 |   |   |
| D=1, U=1の場合 |      |   |     |      |    |   |   |   |   |
| 88          | 39   | 1 | 08  | 0    | 0  | 1 | 0 |   |   |

**SBC [HL], #nn** ////////////// Subtract with carry immediate data nn from location [HL] // 5 cycle //

機能 [HL] - [HL] - nn - C

8ビット即値データnnとキャリー(C)をHLレジスタでアドレス指定されたデータメモリから減算します。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |   |   |   |   |   |   |
|-----|-----------------|-----|---|---|---|---|---|---|
|     | 1 1 0 0 1 1 1 0 | CEH |   |   |   |   |   |   |
|     | 0 0 0 1 1 1 0 1 | 1DH |   |   |   |   |   |   |
|     | n n             | nn  |   |   |   |   |   |   |
| フラグ | I1              | I0  | U | D | N | V | C | Z |
|     | -               | -   |   |   | ↓ | ↓ | ↓ | ↑ |

モード Src: 即値データ

Dst: レジスタ間接

| 例           | 設定値  |    |     | 結果   |    |   |   |   |   |
|-------------|------|----|-----|------|----|---|---|---|---|
|             | [HL] | nn | C   | [HL] | SC | N | V | C | Z |
| D=0, U=0の場合 |      |    |     |      |    |   |   |   |   |
| A8H         | 42H  | 1  | 65H | 0    | 1  | 0 | 0 |   |   |
| 36H         | 5AH  | 1  | DBH | 1    | 0  | 1 | 0 |   |   |
| D=1, U=0の場合 |      |    |     |      |    |   |   |   |   |
| 88          | 39   | 1  | 48  | 0    | 0  | 0 | 0 |   |   |
| D=1, U=1の場合 |      |    |     |      |    |   |   |   |   |
| 88          | 39   | 1  | 08  | 0    | 0  | 1 | 0 |   |   |

**SBC [HL], [ir]** ////////////// Subtract with carry location [ir reg.] from location [HL] // 5 cycle //

機能 [HL] - [HL] - [ir] - C

irレジスタ(IX/IY)でアドレス指定されたデータメモリの内容とキャリー(C)をHLレジスタでアドレス指定されるデータメモリから減算します。  
EPレジスタの内容がデータメモリ[HL]のページアドレス、XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリ[ir]のページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB            |     |
|-----|------------------|----------------|-----|
|     | 1 1 0 0 1 1 1 0  | CEH            |     |
|     | 0 0 0 1 1 1 1 ir | 1EH, 1FH       |     |
|     | ir               | ニーモニック         | コード |
| IX  | 0                | SBC [HL], [IX] | 1EH |
| IY  | 1                | SBC [HL], [IY] | 1FH |

モード Src: レジスタ間接

Dst: レジスタ間接

| 例           | 設定値  |      |     | 結果   |    |   |   |   |   |
|-------------|------|------|-----|------|----|---|---|---|---|
|             | [HL] | [ir] | C   | [HL] | SC | N | V | C | Z |
| D=0, U=0の場合 |      |      |     |      |    |   |   |   |   |
| A8H         | 42H  | 1    | 65H | 0    | 1  | 0 | 0 |   |   |
| 36H         | 5AH  | 1    | DBH | 1    | 0  | 1 | 0 |   |   |
| D=1, U=0の場合 |      |      |     |      |    |   |   |   |   |
| 88          | 39   | 1    | 48  | 0    | 0  | 0 | 0 |   |   |
| D=1, U=1の場合 |      |      |     |      |    |   |   |   |   |
| 88          | 39   | 1    | 08  | 0    | 0  | 1 | 0 |   |   |

**SBC BA, rp** ////////////////////////////////////////////////////////////////// Subtract with carry rp reg. from BA reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** BA BA - rp - Crpレジスタ(BA/HL/IX/IY)の内容とキャリー(C)を  
BAレジスタから減算します。

| コード | MSB             | LSB       |  |
|-----|-----------------|-----------|--|
|     | 1 1 0 0 1 1 1 1 | CFH       |  |
|     | 0 0 0 0 1 1 rp  | 0CH ~ 0FH |  |

**モード** Src: レジスタ直接

Dst: レジスタ直接

| 例 | 設定値   |       |   | 結果    |    |   |   |
|---|-------|-------|---|-------|----|---|---|
|   | BA    | rp    | C | BA    | SC |   |   |
|   |       |       |   |       | N  | V | C |
|   | 63C2H | 2125H | 1 | 429CH | 0  | 1 | 0 |
|   | 205CH | 7120H | 1 | AF3BH | 1  | 0 | 1 |

(rp BA)

| rp | ニーモニック | コード        |
|----|--------|------------|
| BA | 00     | SBC BA, BA |
| HL | 01     | SBC BA, HL |
| IX | 10     | SBC BA, IX |
| IY | 11     | SBC BA, IY |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**SBC BA, #mmnn** ////////////////////////////////////////////////////////////////// Subtract with carry immediate data mmnn from BA reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** BA BA - mmnn - C

16ビット即値データmmnnとキャリー(C)をBAレジスタから減算します。

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 0 0 1 1 1 1   | CFH |  |
|     | 0 1 1 0 0 0 0 1 0 | 62H |  |
|     | n n               | nn  |  |
|     | m m               | mm  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値   |       |   | 結果    |    |   |   |
|---|-------|-------|---|-------|----|---|---|
|   | BA    | mmnn  | C | BA    | SC |   |   |
|   |       |       |   |       | N  | V | C |
|   | 63C2H | 2125H | 1 | 429CH | 0  | 1 | 0 |
|   | 205CH | 7120H | 1 | AF3BH | 1  | 0 | 1 |

(mm nn)

**SBC HL, rp** ////////////////////////////////////////////////////////////////// Subtract with carry rp reg. from HL reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** HL HL - rp - Crpレジスタ(BA/HL/IX/IY)の内容とキャリー(C)を  
HLレジスタから減算します。

| コード | MSB             | LSB       |  |
|-----|-----------------|-----------|--|
|     | 1 1 0 0 1 1 1 1 | CFH       |  |
|     | 0 0 1 0 1 1 rp  | 2CH ~ 2FH |  |

**モード** Src: レジスタ直接

Dst: レジスタ直接

| 例 | 設定値   |       |   | 結果    |    |   |   |
|---|-------|-------|---|-------|----|---|---|
|   | HL    | rp    | C | HL    | SC |   |   |
|   |       |       |   |       | N  | V | C |
|   | 63C2H | 2125H | 1 | 429CH | 0  | 1 | 0 |
|   | 205CH | 7120H | 1 | AF3BH | 1  | 0 | 1 |

(rp HL)

| rp | ニーモニック | コード        |
|----|--------|------------|
| BA | 00     | SBC HL, BA |
| HL | 01     | SBC HL, HL |
| IX | 10     | SBC HL, IX |
| IY | 11     | SBC HL, IY |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**SBC HL, #mmnn** // Subtract with carry immediate data mmnn from HL reg. // 4 cycle //

機能 HL HL - mmnn - C

モード Src: 即値データ

16ビット即値データmmnnとキャリー(C)をHLレジスタから減算します。

Dst: レジスタ直接

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 0 0 1 1 1 1   | CFH |  |
|     | 0 1 1 0 0 0 1 1   | 63H |  |
|     | n n               | nn  |  |
|     | m m               | mm  |  |
| フラグ | I1 I0 U D N V C Z |     |  |
|     | - - - - ↓ ↓ ↓ ↓   |     |  |

| 例 | 設定値   |       |   | 結果    |    |   |   |   |
|---|-------|-------|---|-------|----|---|---|---|
|   | HL    | mmnn  | C | HL    | SC |   |   |   |
|   |       |       |   |       | N  | V | C | Z |
|   | 63C2H | 2125H | 1 | 429CH | 0  | 1 | 0 | 0 |
|   | 205CH | 7120H | 1 | AF3BH | 1  | 0 | 1 | 0 |

**SEP** // Sign expand A reg. to BA reg. // 3 cycle //機能 B A B A  
\*\*\*\*\*0\*\*\*\*\* → 00000000 0\*\*\*\*\*  
\*\*\*\*\*1\*\*\*\*\* → 11111111 1\*\*\*\*\*

モード インプライド(レジスタ直接)

Aレジスタにストアされている8ビットデータの符号ビット(ビット7)をBレジスタに拡張し、BAレジスタとして扱う16ビットデータにします。

Aレジスタの値が正(ビット7が'0')の場合にBレジスタは00Hに、負(ビット7が'1')の場合はFFHになります。

| 例 | 設定値 |     | 結果    |    |   |   |   |
|---|-----|-----|-------|----|---|---|---|
|   | B   | A   | BA    | SC |   |   |   |
|   |     |     |       | N  | V | C | Z |
|   | 5CH | 76H | 0076H | —  | — | — | — |
|   | 42H | A5H | FFA5H | —  | — | — | — |

| コード | MSB               | LSB |  |
|-----|-------------------|-----|--|
|     | 1 1 0 0 1 1 1 0   | CEH |  |
|     | 1 0 1 0 1 0 0 0   | A8H |  |
| フラグ | I1 I0 U D N V C Z |     |  |
|     | - - - - - - - -   |     |  |

**SLA r** // Shift r reg. left arithmetic // 3 cycle //機能 **C ← 7 6 5 4 3 2 1 0 ← 0 r**

モード レジスタ直接

rレジスタ(A/B)の内容を1ビット左にシフトします。レジスタのビット7はキャリー(C)に移動し、レジスタのビット0には'0'が入ります。  
"SLL"命令と同様の結果が得られますが、"SLA"命令は算術シフトのため、オーバーフロー(V)フラグも変化します。

| 例        | 設定値      | 結果 |   |   |   |
|----------|----------|----|---|---|---|
|          |          | SC |   |   |   |
| r        | r        | N  | V | C | Z |
| 00111100 | 01111000 | 0  | 0 | 0 | 0 |
| 10010000 | 00100000 | 0  | 1 | 1 | 0 |

コード MSB LSB  

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

 CEH

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

 80H, 81H

| r | ニーモニック | コード   |
|---|--------|-------|
| A | 0      | SLA A |
| B | 1      | SLA B |

フラグ 

|    |    |   |   |   |   |   |   |
|----|----|---|---|---|---|---|---|
| I1 | I0 | U | D | N | V | C | Z |
| -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**SLA [BR:l]** // Shift location [BR:l] left arithmetic // 5 cycle //機能 **C ← 7 6 5 4 3 2 1 0 ← 0 [BR:l]**

モード 8ビット絶対

BRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されたデータメモリの内容を1ビット左にシフトします。データのビット7はキャリー(C)に移動し、データのビット0は'0'になります。

"SLL"命令と同様の結果が得られますが、"SLA"命令は算術シフトのため、オーバーフロー(V)フラグも変化します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| 例        | 設定値      | 結果     |        |    |   |   |   |
|----------|----------|--------|--------|----|---|---|---|
|          |          | [BR:l] | [BR:l] | SC |   |   |   |
|          |          |        |        | N  | V | C | Z |
| 00111100 | 01111000 | 0      | 0      | 0  | 0 | 0 | 0 |
| 10010000 | 00100000 | 0      | 1      | 1  | 0 | 0 | 0 |

コード MSB LSB  

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

 CEH

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

 82H

|   |   |
|---|---|
| l | l |
|---|---|

 ll
フラグ 

|    |    |   |   |   |   |   |   |
|----|----|---|---|---|---|---|---|
| I1 | I0 | U | D | N | V | C | Z |
| -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

**SLA [HL]** ////////////////////////////////////////////////////////////////// Shift location [HL] left arithmetic ////////////////////////////////////////////////////////////////// 4 cycle //

機能 C ← 7|6|5|4|3|2|1|0 ← 0 [HL]

モード レジスタ間接

HLレジスタで指定されたデータメモリの内容を1ビット左にシフトします。データのビット7はキャリー(C)に移動し、データのビット0は'0'になります。

"SLL"命令と同様の結果が得られますが、"SLA"命令は算術シフトのため、オーバーフロー(V)フラグも変化します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| 例 | 設定値      |          | 結果 |   |   |   |
|---|----------|----------|----|---|---|---|
|   | [HL]     | [HL]     | SC |   |   |   |
|   |          |          | N  | V | C | Z |
|   | 00111100 | 01111000 | 0  | 0 | 0 | 0 |
|   | 10010000 | 00100000 | 0  | 1 | 1 | 0 |

| コード | MSB                           | LSB |   |   |   |   |   |   |
|-----|-------------------------------|-----|---|---|---|---|---|---|
|     | 1   1   0   0   1   1   1   0 | CEH |   |   |   |   |   |   |
|     | 1   0   0   0   0   0   1   1 | 83H |   |   |   |   |   |   |
| フラグ | I1                            | I0  | U | D | N | V | C | Z |
|     | -                             | -   | - | - | ↑ | ↑ | ↑ | ↑ |

**SLL r** ////////////////////////////////////////////////////////////////// Shift r reg. left logical ////////////////////////////////////////////////////////////////// 3 cycle //

機能 C ← 7|6|5|4|3|2|1|0 ← 0 r

モード レジスタ直接

rレジスタ(A/B)の内容を1ビット左にシフトします。レジスタのビット7はキャリー(C)に移動し、レジスタのビット0には'0'が入ります。

"SLA"命令と同様の結果が得られますが、"SLL"命令は論理シフトのため、オーバーフロー(V)フラグは変化しません。

| 例 | 設定値      |          | 結果 |   |   |   |
|---|----------|----------|----|---|---|---|
|   | r        | r        | SC |   |   |   |
|   |          |          | N  | V | C | Z |
|   | 00111100 | 01111000 | 1  | — | 0 | 0 |
|   | 10010000 | 00100000 | 0  | — | 1 | 0 |

| コード   | MSB                           | LSB      |  |
|-------|-------------------------------|----------|--|
|       | 1   1   0   0   1   1   1   0 | CEH      |  |
|       | 1   0   0   0   0   1   0   r | 84H, 85H |  |
| r     | ニーモニック                        | コード      |  |
| A   0 | SLL A                         | 84H      |  |
| B   1 | SLL B                         | 85H      |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | ↑ | ↑ |

**SLL [BR:ll]** ////////////////////////////////////////////////////////////////// Shift location [BR:ll] left logical ////////////////////////////////////////////////////////////////// 5 cycle //

機能 C←76543210←0 [BR:ll]

モード 8ビット絶対

BRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されたデータメモリの内容を1ビット左にシフトします。データのビット7はキャリー(C)に移動し、データのビット0は'0'になります。

"SLA"命令と同様の結果が得られますが、"SLL"命令は論理シフトのため、オーバーフロー(V)フラグは変化しません。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| 例 | 設定値      | 結果       |         |    |   |   |
|---|----------|----------|---------|----|---|---|
|   |          | [BR:ll]  | [BR:ll] | SC |   |   |
|   |          |          |         | N  | V | C |
|   | 00111100 | 01111000 | 1       | —  | 0 | 0 |
|   | 10010000 | 00100000 | 0       | —  | 1 | 0 |

| コード | MSB             | LSB |   |   |   |   |   |   |
|-----|-----------------|-----|---|---|---|---|---|---|
|     | 1 1 0 0 1 1 1 0 | CEH |   |   |   |   |   |   |
|     | 1 0 0 0 0 1 1 0 | 86H |   |   |   |   |   |   |
|     | l l             | ll  |   |   |   |   |   |   |
| フラグ | I1              | I0  | U | D | N | V | C | Z |
|     | -               | -   | - | - | ↑ | - | ↑ | ↑ |

**SLL [HL]** ////////////////////////////////////////////////////////////////// Shift location [HL] left logical ////////////////////////////////////////////////////////////////// 4 cycle //

機能 C←76543210←0 [HL]

モード レジスタ間接

HLレジスタで指定されたデータメモリの内容を1ビット左にシフトします。データのビット7はキャリー(C)に移動し、データのビット0は'0'になります。

"SLA"命令と同様の結果が得られますが、"SLL"命令は論理シフトのため、オーバーフロー(V)フラグは変化しません。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| 例 | 設定値      | 結果       |      |    |   |   |
|---|----------|----------|------|----|---|---|
|   |          | [HL]     | [HL] | SC |   |   |
|   |          |          |      | N  | V | C |
|   | 00111100 | 01111000 | 1    | —  | 0 | 0 |
|   | 10010000 | 00100000 | 0    | —  | 1 | 0 |

| コード | MSB             | LSB |   |   |   |   |   |   |
|-----|-----------------|-----|---|---|---|---|---|---|
|     | 1 1 0 0 1 1 1 0 | CEH |   |   |   |   |   |   |
|     | 1 0 0 0 0 1 1 1 | 87H |   |   |   |   |   |   |
| フラグ | I1              | I0  | U | D | N | V | C | Z |
|     | -               | -   | - | - | ↑ | - | ↑ | ↑ |

**SLP** ////////////////////////////////////////////////////////////////// Set CPU to SLEEP mode ////////////////////////////////////////////////////////////////// 3 cycle //**機能** SLEEP

CPUをSLEEP状態にします。

SLEEP状態ではCPUと発振回路を含む周辺回路が動作を停止し、消費電力を大幅に低減できます。SLEEP状態からはMCU外部の割り込みにより通常のプログラム実行状態に戻ります。

☞ "3.7.2 SLEEP状態"

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |

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

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**SRA r** ////////////////////////////////////////////////////////////////// Shift r reg. right arithmetic ////////////////////////////////////////////////////////////////// 3 cycle //**機能**  $\rightarrow 7\ 6\ 5\ 4\ 3\ 2\ 1\ 0 \rightarrow C\ r$ **モード** レジスタ直接

rレジスタ(A/B)の内容を1ビット右にシフトします。レジスタのビット0はキャリー(C)に移動し、レジスタのビット7は変化しません。オーバーフロー(V)フラグは'0'にリセットされます。

| 例 | 設定値      | 結果       |   |   |   |   |
|---|----------|----------|---|---|---|---|
|   |          | SC       |   |   |   |   |
|   |          | N        | V | C | Z |   |
|   | 01000100 | 00100010 | 0 | 0 | 0 | 0 |
|   | 10111001 | 11011100 | 1 | 0 | 1 | 0 |

| コード | MSB             | LSB     |  |
|-----|-----------------|---------|--|
|     | 1 1 0 0 1 1 1 0 | CEH     |  |
|     | 1 0 0 0 1 0 0 r | 88H、89H |  |

| r   | ニーモニック | コード |
|-----|--------|-----|
| A 0 | SRA A  | 88H |
| B 1 | SRA B  | 89H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | 0 | ↑ | ↑ |

**SRA [BR:ll]** ////////////////////////////////////////////////// Shift location [BR:ll] right arithmetic ////////////////////////////////////////////////// 5 cycle //

機能 ▶ 7 6 5 4 3 2 1 0 ▶ C [BR:ll]

モード 8ビット絶対

BRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されたデータメモリの内容を1ビット右にシフトします。データのビット0はキャリー(C)に移動し、データのビット7は変化しません。

オーバーフロー(V)フラグは'0'にリセットされます。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| 例 | 設定値      | 結果       |    |   |   |   |
|---|----------|----------|----|---|---|---|
|   |          | [BR:ll]  | SC |   |   |   |
|   |          |          | N  | V | C | Z |
|   | 01000100 | 00100010 | 0  | 0 | 0 | 0 |
|   | 10111001 | 11011100 | 1  | 0 | 1 | 0 |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 0 0 0 1 0 1 0 | 8AH |  |
|     | l l             | ll  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | 0 | ↑ | ↑ |

**SRA [HL]** ////////////////////////////////////////////////// Shift location [HL] right arithmetic ////////////////////////////////////////////////// 4 cycle //

機能 ▶ 7 6 5 4 3 2 1 0 ▶ C [HL]

モード レジスタ間接

HLレジスタで指定されたデータメモリの内容を1ビット右にシフトします。データのビット0はキャリー(C)に移動し、データのビット7は変化しません。

オーバーフロー(V)フラグは'0'にリセットされます。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| 例 | 設定値      | 結果       |      |    |   |   |   |
|---|----------|----------|------|----|---|---|---|
|   |          | [HL]     | [HL] | SC |   |   |   |
|   |          |          |      | N  | V | C | Z |
|   | 01000100 | 00100010 |      | 0  | 0 | 0 | 0 |
|   | 10111001 | 11011100 |      | 1  | 0 | 1 | 0 |

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 1 0 0 0 1 0 1 1 | 8BH |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | 0 | ↑ | ↑ |

**SRL r** // Shift r reg. right logical // 3 cycle //

機能 0 → 7 6 5 4 3 2 1 0 → C r

モード レジスタ直接

rレジスタ(A/B)の内容を1ビット右にシフトします。レジスタのビット0はキャリー(C)に移動し、レジスタのビット7には'0'が入ります。

| コード | MSB             | LSB | CEH      |
|-----|-----------------|-----|----------|
|     | 1 1 0 0 1 1 1 0 |     | CEH      |
|     | 1 0 0 0 1 1 0 r |     | 8CH, 8DH |

| 例 | 設定値      | 結果       |   |   |     |
|---|----------|----------|---|---|-----|
|   |          | SC       |   |   |     |
|   |          | N        | V | C | Z   |
|   | 01000100 | 00100010 | 0 | — | 0 0 |
|   | 01101101 | 00110110 | 0 | — | 1 0 |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | 0 | - | ↑ | ↑ |

**SRL [BR:l]** // Shift location [BR:l] right logical // 5 cycle //

機能 0 → 7 6 5 4 3 2 1 0 → C [BR:l]

モード 8ビット絶対

BRレジスタの内容を上位バイト、8ビット絶対アドレス//を下位バイトとしてアドレス指定されたデータメモリの内容を1ビット右にシフトします。データのビット0はキャリー(C)に移動し、データのビット7は'0'になります。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB | CEH |
|-----|-----------------|-----|-----|
|     | 1 1 0 0 1 1 1 0 |     | CEH |
|     | 1 0 0 0 1 1 1 0 |     | 8EH |
|     | l l             |     | ll  |

| 例 | 設定値      | 結果       |   |   |     |
|---|----------|----------|---|---|-----|
|   |          | SC       |   |   |     |
|   |          | N        | V | C | Z   |
|   | 01000100 | 00100010 | 0 | — | 0 0 |
|   | 01101101 | 00110110 | 0 | — | 1 0 |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | 0 | - | ↑ | ↑ |

**SRL [HL]** ////////////////////////////////////////////////// Shift location [HL] right logical ////////////////////////////////////////////////// 4 cycle //

機能 0→7|6|5|4|3|2|1|0→C [HL]

モード レジスタ間接

HLレジスタで指定されたデータメモリの内容を1ビット右にシフトします。データのビット0はキャリー(C)に移動し、データのビット7は'0'になります。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| [HL]     | [HL]     | 結果 |   |   |   |
|----------|----------|----|---|---|---|
|          |          | SC |   |   |   |
|          |          | N  | V | C | Z |
| 01000100 | 00100010 | 0  | — | 0 | 0 |
| 01101101 | 00110110 | 0  | — | 1 | 0 |

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 0 0 1 1 1 0 | CEH |
|     | 1 0 0 0 1 1 1 1 | 8FH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | 0 | - | ↑ | ↑ |

**SUB A, r** ////////////////////////////////////////////////// Subtract r reg. from A reg. ////////////////////////////////////////////////// 2 cycle //

機能 A A - r

レジスタ(A/B)の内容をAレジスタから減算します。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB      |
|-----|-----------------|----------|
|     | 0 0 0 1 0 0 0 r | 10H、11H  |
|     | r               | ニーモニック   |
| A   | 0               | SUB A, A |
| B   | 1               | SUB A, B |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | ↑ | ↑ | ↑ | ↑ | ↑ |

| A           | B   | A   | 結果 |   |   |   |
|-------------|-----|-----|----|---|---|---|
|             |     |     | SC |   |   |   |
|             |     |     | N  | V | C | Z |
| D=0, U=0の場合 |     |     |    |   |   |   |
| A8H         | 42H | 66H | 0  | 1 | 0 | 0 |
| 36H         | 5AH | DCH | 1  | 0 | 1 | 0 |
| D=1, U=0の場合 |     |     |    |   |   |   |
| 88          | 39  | 49  | 0  | 0 | 0 | 0 |
| D=1, U=1の場合 |     |     |    |   |   |   |
| 88          | 39  | 09  | 0  | 0 | 1 | 0 |

**SUB A, #nn** ////////////////////////////////////////////////// Subtract immediate data nn from A reg. ////////////////////////////////////////////////// 2 cycle //

機能 A A - nn

8ビット即値データnnをAレジスタから減算します。

モード Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 0 0 0 1 0 0 1 0 | 12H |
|     | n n             | nn  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | ↑ | ↑ | ↑ | ↑ | ↑ |

| A           | nn  | A   | 結果 |   |   |   |
|-------------|-----|-----|----|---|---|---|
|             |     |     | SC |   |   |   |
|             |     |     | N  | V | C | Z |
| D=0, U=0の場合 |     |     |    |   |   |   |
| A8H         | 42H | 66H | 0  | 1 | 0 | 0 |
| 36H         | 5AH | DCH | 1  | 0 | 1 | 0 |
| D=1, U=0の場合 |     |     |    |   |   |   |
| 88          | 39  | 49  | 0  | 0 | 0 | 0 |
| D=1, U=1の場合 |     |     |    |   |   |   |
| 88          | 39  | 09  | 0  | 0 | 1 | 0 |

**SUB A, [BR:ll]** ////////////////////////////////////////////////////////////////// Subtract location [BR:ll] from A reg. ////////////////////////////////////////////////////////////////// 3 cycle //

機能 A A - [BR:ll]

BRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されるデータメモリの内容をAレジスタから減算します。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

コード MSB LSB  

|     |   |   |   |   |   |   |   |     |
|-----|---|---|---|---|---|---|---|-----|
| 0   | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 14H |
| l l |   |   |   |   |   |   |   | ll  |

フラグ I1 I0 U D N V C Z  

|   |   |  |  |   |   |   |   |  |
|---|---|--|--|---|---|---|---|--|
| - | - |  |  | ↑ | ↑ | ↑ | ↑ |  |
|---|---|--|--|---|---|---|---|--|

モード Src: 8ビット絶対

Dst: レジスタ直接

| 例           |         | 設定値 |    | 結果 |   |   |  |
|-------------|---------|-----|----|----|---|---|--|
| A           | [BR:ll] | A   | SC |    |   |   |  |
|             |         |     | N  | V  | C | Z |  |
| D=0, U=0の場合 |         |     |    |    |   |   |  |
| A8H         | 42H     | 66H | 0  | 1  | 0 | 0 |  |
| 36H         | 5AH     | DCH | 1  | 0  | 1 | 0 |  |
| D=1, U=0の場合 |         |     |    |    |   |   |  |
| 88          | 39      | 49  | 0  | 0  | 0 | 0 |  |
| D=1, U=1の場合 |         |     |    |    |   |   |  |
| 88          | 39      | 09  | 0  | 0  | 1 | 0 |  |

**SUB A, [hhll]** ////////////////////////////////////////////////////////////////// Subtract location [hhll] from A reg. ////////////////////////////////////////////////////////////////// 4 cycle //

機能 A A - [hhll]

16ビット絶対アドレスhhllでアドレス指定されたデータメモリの内容をAレジスタから減算します。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

コード MSB LSB  

|     |   |   |   |   |   |   |   |     |
|-----|---|---|---|---|---|---|---|-----|
| 0   | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 15H |
| l l |   |   |   |   |   |   |   | ll  |
| h h |   |   |   |   |   |   |   | hh  |

フラグ I1 I0 U D N V C Z  

|   |   |  |  |   |   |   |   |  |
|---|---|--|--|---|---|---|---|--|
| - | - |  |  | ↑ | ↑ | ↑ | ↑ |  |
|---|---|--|--|---|---|---|---|--|

モード Src: 16ビット絶対

Dst: レジスタ直接

| 例           |        | 設定値 |    | 結果 |   |   |  |
|-------------|--------|-----|----|----|---|---|--|
| A           | [hhll] | A   | SC |    |   |   |  |
|             |        |     | N  | V  | C | Z |  |
| D=0, U=0の場合 |        |     |    |    |   |   |  |
| A8H         | 42H    | 66H | 0  | 1  | 0 | 0 |  |
| 36H         | 5AH    | DCH | 1  | 0  | 1 | 0 |  |
| D=1, U=0の場合 |        |     |    |    |   |   |  |
| 88          | 39     | 49  | 0  | 0  | 0 | 0 |  |
| D=1, U=1の場合 |        |     |    |    |   |   |  |
| 88          | 39     | 09  | 0  | 0  | 1 | 0 |  |

**SUB A, [HL]** ////////////////////////////////////////////////////////////////// Subtract location [HL] from A reg. ////////////////////////////////////////////////////////////////// 2 cycle //

機能 A A - [HL]

HLレジスタでアドレス指定されたデータメモリの内容をAレジスタから減算します。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

コード MSB LSB  

|   |   |   |   |   |   |   |   |     |
|---|---|---|---|---|---|---|---|-----|
| 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 13H |
|---|---|---|---|---|---|---|---|-----|

フラグ I1 I0 U D N V C Z  

|   |   |  |  |   |   |   |   |  |
|---|---|--|--|---|---|---|---|--|
| - | - |  |  | ↑ | ↑ | ↑ | ↑ |  |
|---|---|--|--|---|---|---|---|--|

モード Src: レジスタ間接

Dst: レジスタ直接

| 例           |      | 設定値 |    | 結果 |   |   |  |
|-------------|------|-----|----|----|---|---|--|
| A           | [HL] | A   | SC |    |   |   |  |
|             |      |     | N  | V  | C | Z |  |
| D=0, U=0の場合 |      |     |    |    |   |   |  |
| A8H         | 42H  | 66H | 0  | 1  | 0 | 0 |  |
| 36H         | 5AH  | DCH | 1  | 0  | 1 | 0 |  |
| D=1, U=0の場合 |      |     |    |    |   |   |  |
| 88          | 39   | 49  | 0  | 0  | 0 | 0 |  |
| D=1, U=1の場合 |      |     |    |    |   |   |  |
| 88          | 39   | 09  | 0  | 0  | 1 | 0 |  |

**SUB A, [ir]** ////////////////////////////////////////////////////////////////// SubTRACT location [ir reg.] from A reg. ////////////////////////////////////////////////////////////////// 2 cycle //

機能 A A - [ir]

irレジスタ(IX/IY)でアドレス指定されたデータメモリの内容をAレジスタから減算します。

XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります (MODEL2/3)。

コード MSB LSB  

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

 16H、17H

| ir   | ニーモニック      | コード |
|------|-------------|-----|
| IX 0 | SUB A, [IX] | 16H |
| IY 1 | SUB A, [IY] | 17H |

フラグ I1 I0 U D N V C Z  

|   |   |  |   |   |   |   |   |
|---|---|--|---|---|---|---|---|
| - | - |  | ↑ | ↑ | ↑ | ↑ | ↑ |
|---|---|--|---|---|---|---|---|

モード Src: レジスタ間接

Dst: レジスタ直接

例

|   |      | 設定値 |    | 結果 |   |   |  |
|---|------|-----|----|----|---|---|--|
| A | [ir] | A   | SC |    |   |   |  |
|   |      |     | N  | V  | C | Z |  |

D=0, U=0の場合

|     |     |     |   |   |   |   |
|-----|-----|-----|---|---|---|---|
| A8H | 42H | 66H | 0 | 1 | 0 | 0 |
| 36H | 5AH | DCH | 1 | 0 | 1 | 0 |

D=1, U=0の場合

|    |    |    |   |   |   |   |
|----|----|----|---|---|---|---|
| 88 | 39 | 49 | 0 | 0 | 0 | 0 |
|----|----|----|---|---|---|---|

D=1, U=1の場合

|    |    |    |   |   |   |   |
|----|----|----|---|---|---|---|
| 88 | 39 | 09 | 0 | 0 | 1 | 0 |
|----|----|----|---|---|---|---|

**SUB A, [ir+dd]** ////////////////////////////////////////////////////////////////// SubTRACT location [ir reg. + dd] from A reg. ////////////////////////////////////////////////////////////////// 4 cycle //

機能 A A - [ir+dd]

irレジスタ(IX/IY)の内容とディスプレースメント ddの和でアドレス指定されたデータメモリの内容をAレジスタから減算します。

ddは符号付きデータとして扱われ、範囲は-128 ~ 127です。

XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります (MODEL2/3)。

コード MSB LSB  

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

 CEH

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

 10H、11H

|   |   |
|---|---|
| d | d |
|---|---|

 dd

| ir   | ニーモニック         | コード |
|------|----------------|-----|
| IX 0 | SUB A, [IX+dd] | 10H |
| IY 1 | SUB A, [IY+dd] | 11H |

フラグ I1 I0 U D N V C Z  

|   |   |  |   |   |   |   |   |
|---|---|--|---|---|---|---|---|
| - | - |  | ↑ | ↑ | ↑ | ↑ | ↑ |
|---|---|--|---|---|---|---|---|

モード Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ直接

例

|   |         | 設定値 |    | 結果 |   |   |  |
|---|---------|-----|----|----|---|---|--|
| A | [ir+dd] | A   | SC |    |   |   |  |
|   |         |     | N  | V  | C | Z |  |

D=0, U=0の場合

|     |     |     |   |   |   |   |
|-----|-----|-----|---|---|---|---|
| A8H | 42H | 66H | 0 | 1 | 0 | 0 |
| 36H | 5AH | DCH | 1 | 0 | 1 | 0 |

D=1, U=0の場合

|    |    |    |   |   |   |   |
|----|----|----|---|---|---|---|
| 88 | 39 | 49 | 0 | 0 | 0 | 0 |
|----|----|----|---|---|---|---|

D=1, U=1の場合

|    |    |    |   |   |   |   |
|----|----|----|---|---|---|---|
| 88 | 39 | 09 | 0 | 0 | 1 | 0 |
|----|----|----|---|---|---|---|

**SUB A, [ir+L]** ////////////////////////////////////////////////////////////////// Subtract location [ir reg. + L] from A reg. ////////////////////////////////////////////////////////////////// 4 cycle //**機能** A A - [ir+L]

irレジスタ(IX/IY)の内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容をAレジスタから減算します。

Lレジスタの内容は符号付きデータとして扱われ、範囲は-128 ~ 127です。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB     |  |
|-----|------------------|---------|--|
|     | 1 1 0 0 1 1 1 0  | CEH     |  |
|     | 0 0 0 1 0 0 1 ir | 12H、13H |  |

| ir   | ニーモニック        | コード |
|------|---------------|-----|
| IX 0 | SUB A, [IX+L] | 12H |
| IY 1 | SUB A, [IY+L] | 13H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  |   |   | ↑ | ↑ | ↑ | ↑ |

**モード** Src: インデックスレジスタ付きレジスタ間接  
Dst: レジスタ直接

| 例           | 設定値 |        | 結果 |    |   |   |   |  |
|-------------|-----|--------|----|----|---|---|---|--|
|             | A   | [ir+L] | A  | SC |   |   |   |  |
|             |     |        |    | N  | V | C | Z |  |
| D=0, U=0の場合 |     |        |    |    |   |   |   |  |
| A8H         | 42H | 66H    | 0  | 1  | 0 | 0 | 0 |  |
| 36H         | 5AH | DCH    | 1  | 0  | 1 | 0 | 0 |  |
| D=1, U=0の場合 |     |        |    |    |   |   |   |  |
| 88          | 39  | 49     | 0  | 0  | 0 | 0 | 0 |  |
| D=1, U=1の場合 |     |        |    |    |   |   |   |  |
| 88          | 39  | 09     | 0  | 0  | 1 | 0 | 0 |  |

**SUB [HL], A** ////////////////////////////////////////////////////////////////// Subtract A reg. from location [HL] ////////////////////////////////////////////////////////////////// 4 cycle //**機能** [HL] [HL] - A

Aレジスタの内容をHLレジスタでアドレス指定されたデータメモリから減算します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 0 0 1 0 1 0 0 | 14H |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  |   |   | ↑ | ↑ | ↑ | ↑ |

**モード** Src: レジスタ直接

Dst: レジスタ間接

| 例           | 設定値  |     | 結果   |    |   |   |   |  |
|-------------|------|-----|------|----|---|---|---|--|
|             | [HL] | A   | [HL] | SC |   |   |   |  |
|             |      |     |      | N  | V | C | Z |  |
| D=0, U=0の場合 |      |     |      |    |   |   |   |  |
| A8H         | 42H  | 66H | 0    | 1  | 0 | 0 | 0 |  |
| 36H         | 5AH  | DCH | 1    | 0  | 1 | 0 | 0 |  |
| D=1, U=0の場合 |      |     |      |    |   |   |   |  |
| 88          | 39   | 49  | 0    | 0  | 0 | 0 | 0 |  |
| D=1, U=1の場合 |      |     |      |    |   |   |   |  |
| 88          | 39   | 09  | 0    | 0  | 1 | 0 | 0 |  |

**SUB [HL], #nn** ////////////////////////////////////////////////////////////////// Subtract immediate data nn from location [HL] ////////////////////////////////////////////////////////////////// 5 cycle //**機能** [HL] [HL] - nn

8ビット即値データnnをHLレジスタでアドレス指定されたデータメモリから減算します。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 0 0 1 0 1 0 0 | 15H |  |
|     | n n             | nn  |  |

**モード** Src: 即値データ

Dst: レジスタ間接

| 例           | 設定値  |     | 結果   |    |   |   |   |  |
|-------------|------|-----|------|----|---|---|---|--|
|             | [HL] | nn  | [HL] | SC |   |   |   |  |
|             |      |     | N    | V  | C | Z |   |  |
| D=0, U=0の場合 |      |     |      |    |   |   |   |  |
| A8H         | 42H  | 66H | 0    | 1  | 0 | 0 | 0 |  |
| 36H         | 5AH  | DCH | 1    | 0  | 1 | 0 | 0 |  |
| D=1, U=0の場合 |      |     |      |    |   |   |   |  |
| 88          | 39   | 49  | 0    | 0  | 0 | 0 | 0 |  |
| D=1, U=1の場合 |      |     |      |    |   |   |   |  |
| 88          | 39   | 09  | 0    | 0  | 1 | 0 | 0 |  |

**SUB [HL], [ir]** ////////////////////////////////////////////////////////////////// SubTRACT location [ir reg.] from location [HL] ////////////////////////////////////////////////////////////////// 5 cycle //

機能 [HL] [HL] - [ir]

irレジスタ(IX/IY)でアドレス指定されたデータメモリの内容をHLレジスタでアドレス指定されるデータメモリから減算します。  
EPレジスタの内容がデータメモリ[HL]のページアドレス、XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリ[ir]のページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB      |  |
|-----|------------------|----------|--|
|     | 1 1 0 0 1 1 1 0  | CEH      |  |
|     | 0 0 0 1 0 1 1 ir | 16H, 17H |  |

| ir   | ニーモニック         | コード |
|------|----------------|-----|
| IX 0 | SUB [HL], [IX] | 16H |
| IY 1 | SUB [HL], [IY] | 17H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  |   | ↑ | ↑ | ↑ | ↑ | ↑ |

モード Src: レジスタ間接

Dst: レジスタ間接

| 例           | 設定値  |      | 結果   |    |   |   |
|-------------|------|------|------|----|---|---|
|             | [HL] | [ir] | [HL] | SC |   |   |
|             |      |      | N    | V  | C | Z |
| D=0, U=0の場合 |      |      |      |    |   |   |
| A8H         | 42H  | 66H  | 0    | 1  | 0 | 0 |
| 36H         | 5AH  | DCH  | 1    | 0  | 1 | 0 |
| D=1, U=0の場合 |      |      |      |    |   |   |
| 88          | 39   | 49   | 0    | 0  | 0 | 0 |
| D=1, U=1の場合 |      |      |      |    |   |   |
| 88          | 39   | 09   | 0    | 0  | 1 | 0 |

**SUB BA, rp** ////////////////////////////////////////////////////////////////// SubTRACT rp reg. from BA reg. ////////////////////////////////////////////////////////////////// 4 cycle //

機能 BA BA - rp

rpレジスタ(BA/HL/IX/IY)の内容をBAレジスタから減算します。

| コード | MSB             | LSB       |  |
|-----|-----------------|-----------|--|
|     | 1 1 0 0 1 1 1 1 | CFH       |  |
|     | 0 0 0 0 1 0 rp  | 08H ~ 0BH |  |

| rp    | ニーモニック     | コード |
|-------|------------|-----|
| BA 00 | SUB BA, BA | 08H |
| HL 01 | SUB BA, HL | 09H |
| IX 10 | SUB BA, IX | 0AH |
| IY 11 | SUB BA, IY | 0BH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: レジスタ直接

Dst: レジスタ直接

| 例                         | 設定値   |       | 結果 |    |   |   |
|---------------------------|-------|-------|----|----|---|---|
|                           | BA    | rp    | BA | SC |   |   |
|                           |       |       | N  | V  | C | Z |
| 63C2H 2125H 429DH 0 0 0 0 |       |       |    |    |   |   |
| C261H                     | 5A32H | 682FH | 0  | 1  | 0 | 0 |
| 205CH                     | 7120H | AF3CH | 1  | 0  | 1 | 0 |

(rp BA)

**SUB BA, #mmnn** ////////////////////////////////////////////////////////////////// Subtract immediate data mmnn from BA reg. ////////////////////////////////////////////////////////////////// 3 cycle //

機能 BA BA - mmnn

16ビット即値データmmnnをBAレジスタから減算します。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 1 0 0 0 0 | D0H |  |
|     | n n             | nn  |  |
|     | m m             | mm  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: 即値データ

Dst: レジスタ直接

| 例                         | 設定値   |       | 結果 |    |   |   |
|---------------------------|-------|-------|----|----|---|---|
|                           | BA    | mmnn  | BA | SC |   |   |
|                           |       |       | N  | V  | C | Z |
| 63C2H 2125H 429DH 0 0 0 0 |       |       |    |    |   |   |
| C261H                     | 5A32H | 682FH | 0  | 1  | 0 | 0 |
| 205CH                     | 7120H | AF3CH | 1  | 0  | 1 | 0 |

**SUB HL, rp** ////////////////////////////////////////////////////////////////// Subtract rp reg. from HL reg. ////////////////////////////////////////////////////////////////// 4 cycle //

機能 HL HL - rp

rpレジスタ(BA/HL/IX/IY)の内容をHLレジスタから減算します。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード |        | MSB |        |           |  |  |  |  |  | LSB |  | CFH |  |
|-----|--------|-----|--------|-----------|--|--|--|--|--|-----|--|-----|--|
| rp  | ニーモニック | コード |        | 28H ~ 2BH |  |  |  |  |  |     |  |     |  |
| BA  | 00     | SUB | HL, BA | 28H       |  |  |  |  |  |     |  |     |  |
| HL  | 01     | SUB | HL, HL | 29H       |  |  |  |  |  |     |  |     |  |
| IX  | 10     | SUB | HL, IX | 2AH       |  |  |  |  |  |     |  |     |  |
| IY  | 11     | SUB | HL, IY | 2BH       |  |  |  |  |  |     |  |     |  |

| フラグ |   | I1 | I0 | U | D | N | V | C | Z |
|-----|---|----|----|---|---|---|---|---|---|
| -   | - | -  | -  | ↑ | ↑ | ↑ | ↑ | ↑ | ↑ |

| 例     |       | 設定値   |    | 結果 |   |   |  |
|-------|-------|-------|----|----|---|---|--|
| HL    | rp    | HL    | SC |    |   |   |  |
|       |       |       | N  | V  | C | Z |  |
| 63C2H | 2125H | 429DH | 0  | 0  | 0 | 0 |  |
| C261H | 5A32H | 682FH | 0  | 1  | 0 | 0 |  |
| 205CH | 7120H | AF3CH | 1  | 0  | 1 | 0 |  |

(rp HL)

**SUB HL, #mmnn** ////////////////////////////////////////////////////////////////// Subtract immediate data mmnn from HL reg. ////////////////////////////////////////////////////////////////// 3 cycle //

機能 HL HL - mmnn

16ビット即値データmmnnをHLレジスタから減算します。

モード Src: 即値データ

Dst: レジスタ直接

| コード |    | MSB |   |   |   |   |   |   |   | LSB |   | D1H |   |
|-----|----|-----|---|---|---|---|---|---|---|-----|---|-----|---|
|     |    | nn  |   |   |   |   |   |   |   | nn  |   |     |   |
|     |    | mm  |   |   |   |   |   |   |   | mm  |   |     |   |
|     |    |     |   |   |   |   |   |   |   |     |   |     |   |
| フラグ | I1 | I0  | U | D | N | V | C | Z | - | -   | - | ↑   | ↑ |

| 例     |       | 設定値   |    | 結果 |   |   |  |
|-------|-------|-------|----|----|---|---|--|
| HL    | mmnn  | HL    | SC |    |   |   |  |
|       |       |       | N  | V  | C | Z |  |
| 63C2H | 2125H | 429DH | 0  | 0  | 0 | 0 |  |
| C261H | 5A32H | 682FH | 0  | 1  | 0 | 0 |  |
| 205CH | 7120H | AF3CH | 1  | 0  | 1 | 0 |  |

**SUB IX, rp** ////////////////////////////////////////////////////////////////// Subtract rp reg. from IX reg. ////////////////////////////////////////////////////////////////// 4 cycle //

機能 IX IX - rp

rpレジスタ(BA/HL)の内容をIXレジスタから減算します。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード |   | MSB |        |     |  |  |  |  |  | LSB    |   | CFH      |        |
|-----|---|-----|--------|-----|--|--|--|--|--|--------|---|----------|--------|
|     |   | rp  |        |     |  |  |  |  |  | rp     |   | 48H, 49H |        |
|     |   | rp  |        |     |  |  |  |  |  | ニーモニック |   | コード      |        |
| BA  | 0 | SUB | IX, BA | 48H |  |  |  |  |  | BA     | 0 | SUB      | IX, BA |
| HL  | 1 | SUB | IX, HL | 49H |  |  |  |  |  | HL     | 1 | SUB      | IX, HL |

| フラグ |   | I1 | I0 | U | D | N | V | C | Z |
|-----|---|----|----|---|---|---|---|---|---|
| -   | - | -  | -  | ↑ | ↑ | ↑ | ↑ | ↑ | ↑ |

| 例     |       | 設定値   |    | 結果 |   |   |  |
|-------|-------|-------|----|----|---|---|--|
| IX    | rp    | IX    | SC |    |   |   |  |
|       |       |       | N  | V  | C | Z |  |
| 63C2H | 2125H | 429DH | 0  | 0  | 0 | 0 |  |
| C261H | 5A32H | 682FH | 0  | 1  | 0 | 0 |  |
| 205CH | 7120H | AF3CH | 1  | 0  | 1 | 0 |  |

**SUB IX, #mmnn** //// Subtract immediate data mmnn from IX reg. //// 3 cycle //**機能** IX IX - mmnn

16ビット即値データmmnnをIXレジスタから減算します。

**モード** Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 1 0 0 1 0 | D2H |  |
|     | n n             | nn  |  |
|     | m m             | mm  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

| 例     | 設定値   |       | 結果 |    |   |   |
|-------|-------|-------|----|----|---|---|
|       | IX    | mmnn  | IX | SC |   |   |
|       |       |       |    | N  | V | C |
| 63C2H | 2125H | 429DH | 0  | 0  | 0 | 0 |
| C261H | 5A32H | 682FH | 0  | 1  | 0 | 0 |
| 205CH | 7120H | AF3CH | 1  | 0  | 1 | 0 |

**SUB IY, rp** //// Subtract rp reg. from IY reg. //// 4 cycle //**機能** IY IY - rp

rpレジスタ(BA/HL)の内容をIYレジスタから減算します。

**モード** Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB              | LSB        |     |
|-----|------------------|------------|-----|
|     | 1 1 0 0 1 1 1 1  | CFH        |     |
|     | 0 1 0 0 1 0 1 rp | 4AH, 4BH   |     |
|     | rp               | ニー モニック    | コード |
| BA  | 0                | SUB IY, BA | 4AH |
| HL  | 1                | SUB IY, HL | 4BH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

| 例     | 設定値   |       | 結果 |    |   |   |
|-------|-------|-------|----|----|---|---|
|       | IY    | rp    | IY | SC |   |   |
|       |       |       |    | N  | V | C |
| 63C2H | 2125H | 429DH | 0  | 0  | 0 | 0 |
| C261H | 5A32H | 682FH | 0  | 1  | 0 | 0 |
| 205CH | 7120H | AF3CH | 1  | 0  | 1 | 0 |

**SUB IY, #mmnn** //// Subtract immediate data mmnn from IY reg. //// 3 cycle //**機能** IY IY + mmnn

16ビット即値データmmnnをIYレジスタから減算します。

**モード** Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 1 0 0 1 1 | D3H |  |
|     | n n             | nn  |  |
|     | m m             | mm  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

| 例     | 設定値   |       | 結果 |    |   |   |
|-------|-------|-------|----|----|---|---|
|       | IY    | mmnn  | IY | SC |   |   |
|       |       |       |    | N  | V | C |
| 63C2H | 2125H | 429DH | 0  | 0  | 0 | 0 |
| C261H | 5A32H | 682FH | 0  | 1  | 0 | 0 |
| 205CH | 7120H | AF3CH | 1  | 0  | 1 | 0 |

**SUB SP, rp** ////////////////////////////////////////////////////////////////// Subtract rp reg. from SP ////////////////////////////////////////////////////////////////// 4 cycle //

機能 SP SP - rp

rp レジスタ(BA/HL)の内容をスタックポインタ  
(SP)から減算します。

| コード | MSB              | LSB        |          |
|-----|------------------|------------|----------|
|     | 1 1 0 0 1 1 1 1  |            | CFH      |
|     | 0 1 0 0 1 1 0 rp |            | 4CH, 4DH |
|     | rp               | ニーモニック     | コード      |
| BA  | 0                | SUB SP, BA | 4CH      |
| HL  | 1                | SUB SP, HL | 4DH      |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: レジスタ直接

Dst: レジスタ直接

| SP    | rp    | 設定値   |    | 結果 |   |   |  |
|-------|-------|-------|----|----|---|---|--|
|       |       | SP    | SC |    |   |   |  |
|       |       |       | N  | V  | C | Z |  |
| 63C2H | 2125H | 429DH | 0  | 0  | 0 | 0 |  |
| C261H | 5A32H | 682FH | 0  | 1  | 0 | 0 |  |
| 205CH | 7120H | AF3CH | 1  | 0  | 1 | 0 |  |

**SUB SP, #mmnn** ////////////////////////////////////////////////////////////////// Subtract immediate data mmnn from SP ////////////////////////////////////////////////////////////////// 4 cycle //

機能 SP SP - mmnn

16ビット即値データmmnnをスタックポインタ  
(SP)から減算します。

| コード | MSB             | LSB |     |
|-----|-----------------|-----|-----|
|     | 1 1 0 0 1 1 1 1 |     | CFH |
|     | 0 1 1 0 1 0 1 0 |     | 6AH |
|     | n n             |     | nn  |
|     | m m             |     | mm  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | ↑ | ↑ | ↑ |

モード Src: 即値データ

Dst: レジスタ直接

| SP    | mmnn  | 設定値   |    | 結果 |   |   |  |
|-------|-------|-------|----|----|---|---|--|
|       |       | SP    | SC |    |   |   |  |
|       |       |       | N  | V  | C | Z |  |
| 63C2H | 2125H | 429DH | 0  | 0  | 0 | 0 |  |
| C261H | 5A32H | 682FH | 0  | 1  | 0 | 0 |  |
| 205CH | 7120H | AF3CH | 1  | 0  | 1 | 0 |  |

**SWAP A** ////////////////////////////////////////////////////////////////// Swap high-order and low-order of A reg. ////////////////////////////////////////////////////////////////// 2 cycle //

機能 A(H) ↔ A(L)

Aレジスタの上位4ビットと下位4ビットの内容を  
入れ替えます。

| コード | MSB             | LSB |     |
|-----|-----------------|-----|-----|
|     | 1 1 1 1 0 1 1 0 |     | F6H |
|     | - - - - - - - - |     |     |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

モード レジスタ直接

| A   | A   | 設定値 |    |   |   | 結果 |  |  |  |
|-----|-----|-----|----|---|---|----|--|--|--|
|     |     | A   | SC |   |   |    |  |  |  |
|     |     |     | N  | V | C | Z  |  |  |  |
| 4CH | C4H |     | —  | — | — | —  |  |  |  |
| 62H | 26H |     | —  | — | — | —  |  |  |  |

**SWAP [HL]** ////////////// Swap high-order and low-order of location [HL] ////////////// 3 cycle //機能 [HL](H)  $\leftrightarrow$  [HL](L)

HLレジスタで指定されたデータメモリの上位4ビットと下位4ビットの内容を入れ替えます。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 1 1 0 1 1 1 | F7H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

モード レジスタ間接

| 例    | 設定値  | 結果 |   |   |   |
|------|------|----|---|---|---|
|      |      | SC |   |   |   |
| [HL] | [HL] | N  | V | C | Z |
| 4CH  | C4H  | —  | — | — | — |
| 62H  | 26H  | —  | — | — | — |

**UPCK** ////////////////// Unpack A reg. to BA reg. ////////////////////////////// 2 cycle //機能  $\begin{array}{c} A \\ \boxed{m|n} \longrightarrow \boxed{0m|0n} \end{array}$ 

Aレジスタの内容をアンパックし、BAレジスタにストアします。Bレジスタの下位4ビットがAレジスタの上位4ビットの内容に置き換えられ、Aレジスタ、Bレジスタとも上位4ビットは'0'になります。

モード インプライド(レジスタ直接)

| 例   | 設定値   | 結果 |   |   |   |
|-----|-------|----|---|---|---|
|     |       | SC |   |   |   |
| A   | BA    | N  | V | C | Z |
| 84H | 0804H | —  | — | — | — |

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 0 1 1 1 1 1 | DFH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | - | - | - | - |

**XOR A, r** ////////////////// Exclusive OR r reg. and A reg. ////////////////////////////// 2 cycle //機能 A A  $\forall$  r

rレジスタ(A/B)の内容とAレジスタの内容との排他的論理和をとり、結果をAレジスタにストアします。

モード Src: レジスタ直接

Dst: レジスタ直接

| コード | MSB             | LSB      |
|-----|-----------------|----------|
|     | 0 0 1 1 1 0 0 r | 38H, 39H |

| r |   | ニーモニック   | コード |
|---|---|----------|-----|
| A | 0 | XOR A, A | 38H |
| B | 1 | XOR A, B | 39H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

| 例   | 設定値 | 結果  |   |   |   | SC |
|-----|-----|-----|---|---|---|----|
|     |     | SC  |   |   |   |    |
| A   | B   | A   | N | V | C | Z  |
| 2CH | 41H | 6DH | 0 | — | — | 0  |
| 7AH | B6H | CCH | 1 | — | — | 0  |

**XOR A, #nn** ////////////////////////////////////////////////// Exclusive OR immediate data nn and A reg. ////////////////////////////////////////////////// 2 cycle //機能 A A  $\vee$  nn

8ビット即値データnnとAレジスタの内容との排他的論理和をとり、結果をAレジスタにストアします。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 0 1 1 1 0 1 0 | 3AH |  |
|     | n n             | nn  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

モード Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |   |   |   |
|---|-----|-----|-----|----|---|---|---|
|   | A   | nn  | A   | SC |   |   |   |
|   |     |     |     | N  | V | C | Z |
|   | 2CH | 41H | 6DH | 0  | — | — | 0 |
|   | 7AH | B6H | CCH | 1  | — | — | 0 |

**XOR A, [BR:ll]** ////////////////////////////////////////////////// Exclusive OR location [BR:ll] and A reg. ////////////////////////////////////////////////// 3 cycle //機能 A A  $\vee$  [BR:ll]

BRレジスタの内容を上位バイト、8ビット絶対アドレスllを下位バイトとしてアドレス指定されるデータメモリの内容とAレジスタの内容との排他的論理和をとり、結果をAレジスタにストアします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 0 1 1 1 1 0 0 | 3CH |  |
|     | l l             | ll  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

モード Src: 8ビット絶対

Dst: レジスタ直接

| 例 | 設定値 |         | 結果  |    |   |   |   |
|---|-----|---------|-----|----|---|---|---|
|   | A   | [BR:ll] | A   | SC |   |   |   |
|   |     |         |     | N  | V | C | Z |
|   | 2CH | 41H     | 6DH | 0  | — | — | 0 |
|   | 7AH | B6H     | CCH | 1  | — | — | 0 |

**XOR A, [hhll]** ////////////////////////////////////////////////// Exclusive OR location [hhll] and A reg. ////////////////////////////////////////////////// 4 cycle //機能 A A  $\vee$  [hhll]

16ビット絶対アドレスhhllでアドレス指定されたデータメモリの内容とAレジスタの内容との排他的論理和をとり、結果をAレジスタにストアします。EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 0 0 1 1 1 1 0 1 | 3DH |  |
|     | l l             | ll  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

モード Src: 16ビット絶対

Dst: レジスタ直接

| 例 | 設定値 |        | 結果  |    |   |   |   |
|---|-----|--------|-----|----|---|---|---|
|   | A   | [hhll] | A   | SC |   |   |   |
|   |     |        |     | N  | V | C | Z |
|   | 2CH | 41H    | 6DH | 0  | — | — | 0 |
|   | 7AH | B6H    | CCH | 1  | — | — | 0 |

**XOR A, [HL]** /////////////// Exclusive OR location [HL] and A reg. /////////////// 2 cycle //機能 A A  $\forall$  [HL]

HLレジスタでアドレス指定されたデータメモリの内容とAレジスタの内容との排他的論理和をとり、結果をAレジスタにストアします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 0 0 1 1 1 0 1 1 | 3BH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

モード Src: レジスタ間接

Dst: レジスタ直接

| 例   |      | 設定値 |    | 結果 |   |   |  |
|-----|------|-----|----|----|---|---|--|
| A   | [HL] | A   | SC |    |   |   |  |
|     |      |     | N  | V  | C | Z |  |
| 2CH | 41H  | 6DH | 0  | —  | — | 0 |  |
| 7AH | B6H  | CCH | 1  | —  | — | 0 |  |

**XOR A, [ir]** /////////////// Exclusive OR location [ir reg.] and A reg. /////////////// 2 cycle //機能 A A  $\forall$  [ir]

irレジスタ(IX/IY)でアドレス指定されたデータメモリの内容とAレジスタの内容との排他的論理和をとり、結果をAレジスタにストアします。

XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がページアドレスになります(MODEL2/3)。

| コード | MSB              | LSB      |
|-----|------------------|----------|
|     | 0 0 1 1 1 1 1 ir | 3EH, 3FH |

| ir   | ニーモニック      | コード |
|------|-------------|-----|
| IX 0 | XOR A, [IX] | 3EH |
| IY 1 | XOR A, [IY] | 3FH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

モード Src: レジスタ間接

Dst: レジスタ直接

| 例   |      | 設定値 |    | 結果 |   |   |  |
|-----|------|-----|----|----|---|---|--|
| A   | [ir] | A   | SC |    |   |   |  |
|     |      |     | N  | V  | C | Z |  |
| 2CH | 41H  | 6DH | 0  | —  | — | 0 |  |
| 7AH | B6H  | CCH | 1  | —  | — | 0 |  |

**XOR A, [ir+dd]** /////////////// Exclusive OR location [ir reg. + dd] and A reg. /////////////// 4 cycle //機能 A A  $\forall$  [ir+dd]

irレジスタ(IX/IY)の内容とディスプレースメントddの和でアドレス指定されたデータメモリの内容とAレジスタの内容との排他的論理和をとり、結果をAレジスタにストアします。ddは符号付きデータとして扱われ、範囲は-128 ~ 127です。

XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 0 0 1 1 1 0 | CEH |

|                  |          |
|------------------|----------|
| 0 0 1 1 1 0 0 ir | 38H, 39H |
|------------------|----------|

|     |    |
|-----|----|
| d d | dd |
|-----|----|

| ir   | ニーモニック         | コード |
|------|----------------|-----|
| IX 0 | XOR A, [IX+dd] | 38H |
| IY 1 | XOR A, [IY+dd] | 39H |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

モード Src: ディスプレースメント付きレジスタ間接

Dst: レジスタ直接

| 例   |         | 設定値 |    | 結果 |   |   |  |
|-----|---------|-----|----|----|---|---|--|
| A   | [ir+dd] | A   | SC |    |   |   |  |
|     |         |     | N  | V  | C | Z |  |
| 2CH | 41H     | 6DH | 0  | —  | — | 0 |  |
| 7AH | B6H     | CCH | 1  | —  | — | 0 |  |

**XOR A, [ir+L]** ////////////////////////////////////////////////// Exclusive OR location [ir reg. + L] and A reg. ////////////////////////////////////////////////// 4 cycle //**機能** A A  $\forall$  [ir+L]

irレジスタ(IX/IY)の内容とLレジスタの内容の和でアドレス指定されたデータメモリの内容とAレジスタの内容との排他的論理和をとり、結果をAレジスタにストアします。  
Lレジスタの内容は符号付きデータとして扱われ、範囲は-128~127です。  
XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリのページアドレスになります(MODEL2/3)。

**モード** Src: インデックスレジスタ付きレジスタ間接  
Dst: レジスタ直接

| 例 | 設定値 |        | 結果  |    |   |   |
|---|-----|--------|-----|----|---|---|
|   | A   | [ir+L] | A   | SC |   |   |
|   |     |        |     | N  | V | C |
|   | 2CH | 41H    | 6DH | 0  | — | — |
|   | 7AH | B6H    | CCH | 1  | — | — |

| コード | MSB              | LSB     |
|-----|------------------|---------|
|     | 1 1 0 0 1 1 1 0  | CEH     |
|     | 0 0 1 1 1 0 1 ir | 3AH、3BH |

| ir | ニーモニック | コード               |
|----|--------|-------------------|
| IX | 0      | XOR A, [IX+L] 3AH |
| IY | 1      | XOR A, [IY+L] 3BH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**XOR B, #nn** ////////////////////////////////////////////////// Exclusive OR immediate data nn and B reg. ////////////////////////////////////////////////// 3 cycle //**機能** B B  $\forall$  nn

8ビット即値データnnとBレジスタの内容との排他的論理和をとり、結果をBレジスタにストアします。

**モード** Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 0 0 1 1 1 0 | CEH |
|     | 1 0 1 1 1 0 0 0 | B8H |
|     | n n             | nn  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**XOR L, #nn** ////////////////////////////////////////////////// Exclusive OR immediate data nn and L reg. ////////////////////////////////////////////////// 3 cycle //**機能** L L  $\forall$  nn

8ビット即値データnnとLレジスタの内容との排他的論理和をとり、結果をLレジスタにストアします。

**モード** Src: 即値データ

Dst: レジスタ直接

| コード | MSB             | LSB |
|-----|-----------------|-----|
|     | 1 1 0 0 1 1 1 0 | CEH |
|     | 1 0 1 1 1 0 0 1 | B9H |
|     | n n             | nn  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

| 例 | 設定値 |     | 結果  |    |   |   |
|---|-----|-----|-----|----|---|---|
|   | L   | nn  | L   | SC |   |   |
|   |     |     |     | N  | V | C |
|   | 2CH | 41H | 6DH | 0  | — | — |
|   | 7AH | B6H | CCH | 1  | — | — |

**XOR H, #nn** ////////////// Exclusive OR immediate data nn and H reg. ////////////// 3 cycle //**機能** H H  $\forall$  nn

8ビット即値データnnとHレジスタの内容との排他的論理和をとり、結果をHレジスタにストアします。

| コード | MSB             | LSB |     |
|-----|-----------------|-----|-----|
|     | 1 1 0 0 1 1 1 0 |     | CEH |
|     | 1 0 1 1 1 0 1 0 |     | BAH |

nn

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |   |   |   |  |
|---|-----|-----|-----|----|---|---|---|--|
|   | H   | nn  | H   | SC |   |   |   |  |
|   |     |     |     | N  | V | C | Z |  |
|   | 2CH | 41H | 6DH | 0  | — | — | 0 |  |
|   | 7AH | B6H | CCH | 1  | — | — | 0 |  |

**XOR SC, #nn** ////////////// Exclusive OR immediate data nn and SC ////////////// 3 cycle //**機能** SC SC  $\forall$  nn

8ビット即値データnnとシステムコンディションフラグ(SC)の内容との排他的論理和をとり、結果をシステムコンディションフラグ(SC)にセットします。

| コード | MSB             | LSB |     |
|-----|-----------------|-----|-----|
|     | 1 0 0 1 1 1 1 0 |     | 9EH |

nn

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | ↑  | ↑  | ↑ | ↑ | ↑ | ↑ | ↑ | ↑ |

**モード** Src: 即値データ

Dst: レジスタ直接

| 例 | 設定値 |     | 結果  |    |    |   |   |   |   |   |   |
|---|-----|-----|-----|----|----|---|---|---|---|---|---|
|   | SC  | nn  | SC  | SC |    |   |   |   |   |   |   |
|   |     |     |     | I1 | I0 | U | D | N | V | C | Z |
|   | 2CH | 41H | 6DH | 0  | 1  | 1 | 0 | 1 | 1 | 0 | 1 |
|   | 7AH | B6H | CCH | 1  | 1  | 0 | 0 | 1 | 1 | 0 | 0 |

**XOR [BR:l], #nn** // Exclusive OR immediate data nn and location [BR:l] ////////////// 5 cycle //**機能** [BR:l] [BR:l]  $\forall$  nn

8ビット即値データnnとBRレジスタの内容を上位バイト、8ビット絶対アドレスlを下位バイトとしてアドレス指定されるデータメモリの内容との排他的論理和をとり、結果をそのアドレスにストアします。

EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |     |
|-----|-----------------|-----|-----|
|     | 1 1 0 1 1 0 1 0 |     | DAH |
|     | l l             |     | l   |

nn

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

**モード** Src: 即値データ

Dst: 8ビット絶対

| 例 | 設定値    |     | 結果     |    |   |   |   |  |
|---|--------|-----|--------|----|---|---|---|--|
|   | [BR:l] | nn  | [BR:l] | SC |   |   |   |  |
|   |        |     |        | N  | V | C | Z |  |
|   | 2CH    | 41H | 6DH    | 0  | — | — | 0 |  |
|   | 7AH    | B6H | CCH    | 1  | — | — | 0 |  |

**XOR [HL], A** ////////////////////////////////////////////////// Exclusive OR A reg. and location [HL] ////////////////////////////////////////////////// 4 cycle //機能 [HL] [HL]  $\forall$  A

Aレジスタの内容とHLレジスタでアドレス指定されたデータメモリの内容との排他的論理和をとり、結果をそのアドレスにストアします。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 0 1 1 1 1 0 0 | 3CH |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

モード Src: レジスタ直接

Dst: レジスタ間接

| 例 | 設定値  |     | 結果  |   |   |   |   |
|---|------|-----|-----|---|---|---|---|
|   | [HL] | A   | SC  |   |   |   |   |
|   |      |     | N   | V | C | Z |   |
|   | 2CH  | 41H | 6DH | 0 | — | — | 0 |
|   | 7AH  | B6H | CCH | 1 | — | — | 0 |

**XOR [HL], #nn** ////////////////////////////////////////////////// Exclusive OR immediate data nn and location [HL] ////////////////////////////////////////////////// 5 cycle //機能 [HL] [HL]  $\forall$  nn

8ビット即値データnnとHLレジスタでアドレス指定されたデータメモリの内容との排他的論理和をとり、結果をそのアドレスにストアします。  
EPレジスタの内容がデータメモリのページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB |  |
|-----|-----------------|-----|--|
|     | 1 1 0 0 1 1 1 0 | CEH |  |
|     | 0 0 1 1 1 1 0 1 | 3DH |  |
|     | n n             | nn  |  |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

モード Src: 即値データ

Dst: レジスタ間接

| 例 | 設定値  |     | 結果  |   |   |   |   |
|---|------|-----|-----|---|---|---|---|
|   | [HL] | nn  | SC  |   |   |   |   |
|   |      |     | N   | V | C | Z |   |
|   | 2CH  | 41H | 6DH | 0 | — | — | 0 |
|   | 7AH  | B6H | CCH | 1 | — | — | 0 |

**XOR [HL], [ir]** ////////////////////////////////////////////////// Exclusive OR location [ir reg.] and location [HL] ////////////////////////////////////////////////// 5 cycle //機能 [HL] [HL]  $\forall$  [ir]

irレジスタ(IX/IY)とHLレジスタでそれぞれアドレス指定されたデータメモリの内容の排他的論理和をとり、結果をデータメモリ[HL]にストアします。  
EPレジスタの内容がデータメモリ[HL]のページアドレス、XPレジスタ(IX指定時)、YPレジスタ(IY指定時)の内容がデータメモリ[ir]のページアドレスになります(MODEL2/3)。

| コード | MSB             | LSB    |          |
|-----|-----------------|--------|----------|
|     | 1 1 0 0 1 1 1 0 | CEH    |          |
|     | 0 0 1 1 1 1 1 1 | ir     | 3EH, 3FH |
|     | ir              | ニーモニック | コード      |

|    |   |                |     |
|----|---|----------------|-----|
| IX | 0 | XOR [HL], [IX] | 3EH |
| IY | 1 | XOR [HL], [IY] | 3FH |

| フラグ | I1 | I0 | U | D | N | V | C | Z |
|-----|----|----|---|---|---|---|---|---|
|     | -  | -  | - | - | ↑ | - | - | ↑ |

モード Src: レジスタ間接

Dst: レジスタ間接

| 例 | 設定値  |      | 結果  |   |   |   |   |
|---|------|------|-----|---|---|---|---|
|   | [HL] | [ir] | SC  |   |   |   |   |
|   |      |      | N   | V | C | Z |   |
|   | 2CH  | 41H  | 6DH | 0 | — | — | 0 |
|   | 7AH  | B6H  | CCH | 1 | — | — | 0 |

## APPENDIX A オペコードマップ

オペコードマップ(1/3)

## 第1オペコード

| H | 0               | 1               | 2               | 3               | 4              | 5              | 6              | 7              | 8                  | 9           | A              | B              | C                | D                   | E                     | F          |
|---|-----------------|-----------------|-----------------|-----------------|----------------|----------------|----------------|----------------|--------------------|-------------|----------------|----------------|------------------|---------------------|-----------------------|------------|
| 0 | ADD<br>A,A      | SUB<br>A,A      | AND<br>A,A      | CP<br>A,A       | LD<br>A,A      | LD<br>A,A      | LD<br>A,A      | LD<br>A,A      | INC<br>[Y],A       | INC<br>A    | PUSH<br>BA     | LD<br>A,#nn    | ADD<br>BA,#mmmn  | SUB<br>CARS         | CARS<br>rr            |            |
| 1 | ADD<br>A,B      | SUB<br>A,B      | AND<br>A,B      | CP<br>A,B       | LD<br>B        | LD<br>B        | LD<br>B        | LD<br>B        | INC<br>[Y],B       | INC<br>B    | PUSH<br>HL     | LD<br>B,#nn    | ADD<br>HL,#mmmn  | SUB<br>CARS         | CARS<br>rr            |            |
| 2 | ADD<br>A,#nn    | SUB<br>A,#nn    | AND<br>A,#nn    | CP<br>A,#nn     | LD<br>L,L      | LD<br>L,L      | LD<br>L,L      | LD<br>L,L      | INC<br>[Y],L       | INC<br>L    | PUSH<br>IX     | LD<br>L,#nn    | ADD<br>IX,#mmmn  | SUB<br>CARS         | CARS<br>qqrr          |            |
| 3 | A,[HL]          | SUB<br>A,[HL]   | AND<br>A,[HL]   | CP<br>A,[HL]    | LD<br>L,H      | LD<br>L,H      | LD<br>L,H      | LD<br>L,H      | INC<br>[Y],H       | INC<br>H    | PUSH<br>IY     | LD<br>H,#nn    | ADD<br>IY,#mmmn  | SUB<br>CARS         | CARS<br>Z,rr          |            |
| 4 | ADD<br>A,[BR:J] | SUB<br>A,[BR:J] | AND<br>A,[BR:J] | CP<br>A,[BR:J]  | LD<br>L,[BR:J] | LD<br>L,[BR:J] | LD<br>L,[BR:J] | LD<br>L,[BR:J] | INC<br>[Y],[BR:J]  | INC<br>BR   | PUSH<br>BR,#hh | LD<br>BR       | ADD<br>BA,#mmmn  | SUB<br>CARS         | CARS<br>NZ,rr         |            |
| 5 | A,[hhJ]         | SUB<br>A,[hhJ]  | AND<br>A,[hhJ]  | CP<br>A,[hhJ]   | LD<br>L,[HL]   | LD<br>L,[HL]   | LD<br>L,[HL]   | LD<br>L,[HL]   | INC<br>[Y],[HL]    | INC<br>[HL] | PUSH<br>EP     | LD<br>[HL],#nn | ADD<br>HL,#mmmn  | SUB<br>CARS         | DIR<br>NZ,rr          |            |
| 6 | A,[IX]          | SUB<br>A,[IX]   | AND<br>A,[IX]   | CP<br>A,[IX]    | LD<br>L,[X]    | LD<br>L,[X]    | LD<br>L,[X]    | LD<br>L,[X]    | INC<br>[Y],[IX]    | INC<br>[HL] | PUSH<br>BIT    | LD<br>[IX],#nn | ADD<br>[X],#mmmn | SUB<br>CARS         | SWAP<br>A             |            |
| 7 | A,[Y]           | SUB<br>A,[Y]    | AND<br>A,[Y]    | CP<br>A,[Y]     | LD<br>L,[Y]    | LD<br>L,[Y]    | LD<br>L,[Y]    | LD<br>L,[Y]    | INC<br>[Y],[Y]     | INC<br>SP   | PUSH<br>SC     | LD<br>[Y],#nn  | ADD<br>Y,#mmmn   | SUB<br>CARS<br>[HL] | SWAP<br>[HL]          |            |
| 8 | A,A             | SBC<br>A,A      | OR<br>A,A       | XOR<br>A,A      | LD<br>B,A      | LD<br>B,A      | LD<br>B,A      | LD<br>B,A      | DEC<br>[BR:J],A    | DEC<br>A    | POP<br>BA      | LD<br>BA,[hhJ] | EX<br>BA,[HL]    | AND<br>[BR:J],#nn   | CARL<br>RET           |            |
| 9 | A,B             | SBC<br>A,B      | OR<br>A,B       | XOR<br>A,B      | LD<br>B,B      | LD<br>B,B      | LD<br>B,B      | LD<br>B,B      | DEC<br>[BR:J],B    | DEC<br>B    | POP<br>HL      | LD<br>HL,[hhJ] | EX<br>HL,[HL]    | OR<br>[BR:J],#nn    | CARL<br>RETE          |            |
| A | A,#nn           | SBC<br>A,#nn    | OR<br>A,#nn     | XOR<br>A,#nn    | LD<br>B,L      | LD<br>B,L      | LD<br>B,L      | LD<br>B,L      | DEC<br>[BR:J],L    | DEC<br>L    | POP<br>IX      | LD<br>IX,[hhJ] | EX<br>IX,[HL]    | XOR<br>[BR:J],#nn   | CARL<br>RETS          |            |
| B | A,[HL]          | SBC<br>A,[HL]   | OR<br>A,[HL]    | XOR<br>A,[HL]   | LD<br>B,H      | LD<br>B,H      | LD<br>B,H      | LD<br>B,H      | DEC<br>[BR:J],H    | DEC<br>H    | POP<br>IY      | LD<br>IY,[hhJ] | EX<br>IY,[HL]    | SP<br>BA,SP         | [BR:J],#nn<br>NZ,qqrr |            |
| C | A,[BR:J]        | SBC<br>A,[BR:J] | OR<br>A,[BR:J]  | XOR<br>A,[BR:J] | LD<br>B,[HL]   | LD<br>B,[HL]   | LD<br>B,[HL]   | LD<br>B,[HL]   | 未定義<br>[BR:J],[HL] | DEC<br>BR   | POP<br>SC,#nn  | LD<br>SC,#nn   | EX<br>SC,#nn     | BIT<br>[BR:J],#nn   | INT                   |            |
| D | A,[hhJ]         | SBC<br>A,[hhJ]  | OR<br>A,[hhJ]   | XOR<br>A,[hhJ]  | LD<br>B,[HL]   | LD<br>B,[HL]   | LD<br>B,[HL]   | LD<br>B,[HL]   | DEC<br>[BR:J],[HL] | DEC<br>[HL] | POP<br>EP      | LD<br>EP       | EX<br>A,[HL]     | LD<br>A,[HL]        | JRL<br>JP<br>[kk]     |            |
| E | A,[IX]          | SBC<br>A,[IX]   | OR<br>A,[IX]    | XOR<br>A,[IX]   | LD<br>B,[X]    | LD<br>B,[X]    | LD<br>B,[X]    | LD<br>B,[X]    | DEC<br>[BR:J],[X]  | DEC<br>[HL] | POP<br>IP      | LD<br>IP       | EX<br>IY,[hhJ]   | EX<br>IY,[HL]       | PACK<br>Z,qqrr        | 未定義<br>コード |
| F | A,[Y]           | SBC<br>A,[Y]    | OR<br>A,[Y]     | XOR<br>A,[Y]    | LD<br>B,[Y]    | LD<br>B,[Y]    | LD<br>B,[Y]    | LD<br>B,[Y]    | DEC<br>[BR:J],[Y]  | DEC<br>[HL] | POP<br>SC      | LD<br>SC       | EX<br>SC         | LD<br>SC            | NZ,qqrr               | NOP        |

## オペコードマップ(2/3)

## 第2オペコード(第1オペコード = CE)

| <u>L</u><br>H  | 0            | 1            | 2            | 3           | 4           | 5            | 6           | 7            | 8           | 9           | A          | B           | C           | D | E | F |
|----------------|--------------|--------------|--------------|-------------|-------------|--------------|-------------|--------------|-------------|-------------|------------|-------------|-------------|---|---|---|
| 0 ADD A,[X+dd] | SUB A,[X+dd] | AND A,[X+dd] | CP A,[X+dd]  | LD A,[X+dd] | LD L,[X+dd] | SLA A,[X+dd] | RL A,[X+dd] | CPL A,[X+dd] | AND A,#[nn] | LD A,#[nn]  | LD A,[hh]  | JRS A,[hh]  | CARS L,T,rr |   |   |   |
| 1 ADD A,[Y+dd] | SUB A,[Y+dd] | AND A,[Y+dd] | CP A,[Y+dd]  | LD A,[Y+dd] | LD L,[Y+dd] | SLA B,[Y+dd] | RL B,[Y+dd] | CPL B,[Y+dd] | AND B,#[nn] | LD B,#[nn]  | LD B,[hh]  | JRS B,[hh]  | CARS L,E,rr |   |   |   |
| 2 ADD A,[X+L]  | SUB A,[X+L]  | AND A,[X+L]  | CP A,[X+L]   | LD A,[X+L]  | LD L,[X+L]  | SLA B,[X+L]  | RL B,[X+L]  | CPL B,[X+L]  | AND B,#[nn] | LD B,#[nn]  | LD B,[hh]  | JRS B,[hh]  | CARS GT,rr  |   |   |   |
| 3 ADD A,[Y+L]  | SUB A,[Y+L]  | AND A,[Y+L]  | CP A,[Y+L]   | LD A,[Y+L]  | LD L,[Y+L]  | SLA B,[Y+L]  | RL B,[Y+L]  | CPL B,[Y+L]  | 未定義         | LD C,#[nn]  | LD C,[hh]  | JRS C,[hh]  | CARS GE,rr  |   |   |   |
| 4 ADD [HL],A   | SUB [HL],A   | AND [HL],A   | CP [HL],A    | LD [HL],A   | LD [HL],A   | SLA B,[HL]   | RL B,[HL]   | CPL B,[HL]   | NEG A       | OR A        | LD B,#[nn] | JRS B,#[nn] | CARS V,rr   |   |   |   |
| 5 [HL],#nn     | SUB [HL],#nn | AND [HL],#nn | CP [HL],#nn  | LD [HL],#nn | LD [HL],#nn | SLA B,[HL]   | RL B,[HL]   | CPL B,[HL]   | NEG B,#[nn] | OR B,#[nn]  | LD C,#[nn] | JRS C,#[nn] | CARS NV,rr  |   |   |   |
| 6 ADD [HL],IX  | SUB [HL],IX  | AND [HL],IX  | CP [HL],IX   | LD [HL],IX  | LD [HL],IX  | SLA B,[HL]   | RL B,[HL]   | CPL B,[HL]   | NEG B,#[nn] | OR B,#[nn]  | LD C,#[nn] | JRS C,#[nn] | CARS P,rr   |   |   |   |
| 7 ADD [HL],IY  | SUB [HL],IY  | AND [HL],IY  | CP [HL],IY   | LD [HL],IY  | LD [HL],IY  | SLA B,[HL]   | RL B,[HL]   | CPL B,[HL]   | NEG B,#[nn] | SEP B,#[nn] | LD C,#[nn] | JRS C,#[nn] | CARS M,rr   |   |   |   |
| 8 ADC A,[X+dd] | SBC A,[X+dd] | OR A,[X+dd]  | XOR A,[X+dd] | LD A,[X+dd] | LD A,[X+dd] | SLA B,[HL]   | RL B,[HL]   | CPL B,[HL]   | RR A,#[nn]  | SEP A,#[nn] | LD C,#[nn] | JRS C,#[nn] | CARS F0,rr  |   |   |   |
| 9 A,[Y+dd]     | SBC A,[Y+dd] | OR A,[Y+dd]  | XOR A,[Y+dd] | LD A,[Y+dd] | LD A,[Y+dd] | SLA B,[HL]   | RL B,[HL]   | CPL B,[HL]   | RR A,#[nn]  | SEP A,#[nn] | LD C,#[nn] | JRS C,#[nn] | CARS F1,rr  |   |   |   |
| A A,[X+L]      | SBC A,[X+L]  | OR A,[X+L]   | XOR A,[X+L]  | LD A,[X+L]  | LD A,[X+L]  | SLA B,[HL]   | RL B,[HL]   | CPL B,[HL]   | RR A,#[nn]  | SEP A,#[nn] | LD C,#[nn] | JRS C,#[nn] | CARS F2,rr  |   |   |   |
| B A,[Y+L]      | SBC A,[Y+L]  | OR A,[Y+L]   | XOR A,[Y+L]  | LD A,[Y+L]  | LD A,[Y+L]  | SLA B,[HL]   | RL B,[HL]   | CPL B,[HL]   | 未定義         | LD C,#[nn]  | LD C,#[nn] | JRS C,#[nn] | CARS F3,rr  |   |   |   |
| C [HL],A       | SBC [HL],A   | OR [HL],A    | XOR [HL],A   | LD [HL],A   | LD [HL],A   | SLA B,[HL]   | RL B,[HL]   | CPL B,[HL]   | A,YP        | LD B,#[nn]  | LD B,#[nn] | JRS B,#[nn] | CARS NF0,rr |   |   |   |
| D [HL],#nn     | SBC [HL],#nn | OR [HL],#nn  | XOR [HL],#nn | LD [HL],#nn | LD [HL],#nn | SLA B,[HL]   | RL B,[HL]   | CPL B,[HL]   | B,YP        | LD C,#[nn]  | LD C,#[nn] | JRS C,#[nn] | CARS NF1,rr |   |   |   |
| E [HL],IX      | SBC [HL],IX  | OR [HL],IX   | XOR [HL],IX  | LD [HL],IX  | LD [HL],IX  | SLA B,[HL]   | RL B,[HL]   | CPL B,[HL]   | 未定義         | LD C,#[nn]  | LD C,#[nn] | JRS C,#[nn] | CARS NF2,rr |   |   |   |
| F [HL],IY      | SBC [HL],IY  | OR [HL],IY   | XOR [HL],IY  | LD [HL],IY  | LD [HL],IY  | SLA B,[HL]   | RL B,[HL]   | CPL B,[HL]   | 未定義         | LD C,#[nn]  | LD C,#[nn] | JRS C,#[nn] | CARS NF3,rr |   |   |   |

オペコードマップ(3/3)

## 第2オペコード(第1オペコード = CF)

| H |     | 0     | 1   | 2     | 3     | 4     | 5     | 6        | 7          | 8        | 9 | A        | B          | C         | D        | E         | F  |
|---|-----|-------|-----|-------|-------|-------|-------|----------|------------|----------|---|----------|------------|-----------|----------|-----------|----|
| 0 | ADD |       | ADD | ADD   | IX,BA |       |       | ADC      | LD         |          |   | PUSH A   | LD,BA,[HL] | LD,BA,[X] | LD,BA    | LD,SP,BA  | LD |
| 1 | ADD | BA,BA | ADD | HL,HL |       |       |       | ADC      | LD         |          |   | PUSH B   | LD,HL,[HL] | LD,HL,[X] | LD,BA,HL | LD,SP,HL  | LD |
| 2 | ADD | BA,HL | ADD | IX,HL |       |       |       | SBC      | LD         |          |   | PUSH L   | LD,[HL]    | LD,[X]    | LD,BA,X  | LD,SP,X   | LD |
| 3 | ADD | BA,IX | ADD | HL,IX |       |       |       | SBC      | LD         |          |   | PUSH H   | LD,[HL]    | LD,[X]    | LD,BA,Y  | LD,SP,Y   | LD |
| 4 | ADD | BA,Y  | ADD | Y,HL  |       |       |       | HL,#mmmm | Y,[SP+dd]  |          |   | POP A    | LD,[HL],BA | LD,[X],BA | LD,HL,BA | LD,HL,SP  | LD |
| 5 | ADD | BA,HL | ADD | SP,BA |       |       |       | LD       | [SP+dd],BA |          |   | POP B    | LD,[HL],HL | LD,[X],HL | LD,HL,HL | LD,HL,PC  | LD |
| 6 | ADD | BA,BA | ADD | ADC   |       |       |       | LD       | [SP+dd],HL |          |   | POP L    | LD,[HL],X  | LD,[X],X  | LD,HL,X  | 未定義 コード領域 | LD |
| 7 | ADD | BA,IX | ADD | HL,HL |       |       |       | LD       | [SP+dd],X  |          |   | POP H    | LD,[HL],Y  | LD,[X],Y  | LD,HL,Y  | 未定義 コード領域 | LD |
| 8 | SUB | BA,BA | CP  | SUB   | CP    | SUB   | CP    | ADD      | LD         |          |   | PUSH ALL | LD,BA,[M]  | LD,BA,[Y] | LD,BA    | LD,SP     | LD |
| 9 | SUB | BA,HL | CP  | BA,HL | CP    | HL,HL | HL,HL | SP,#mmmm | SP,[HLH]   |          |   | PUSH ALE | LD,HL,[Y]  | LD,HL,[X] | LD,HL    | LD,BA,PC  | LD |
| A | SUB | BA,IX | CP  | SUB   | CP    | SUB   | CP    | SUB      | SP,#mmmm   |          |   |          | LD,IX,[Y]  | LD,IX,[X] | LD,IX    | LD,SP     | LD |
| B | SUB | BA,Y  | CP  | BA,Y  | CP    | HL,IX | HL,IX | SUB      | SP,[HLH]   |          |   |          | LD,IX,[Y]  | LD,IX,[X] | LD,IX    | 未定義 コード領域 | LD |
| C | SBC | BA,BA | SBC | HL,BA | SP,BA | HL,BA | SP,BA | SUB      | SP,#mmmm   | [HLH]/SP |   | POP ALL  | LD,[Y],BA  | LD,[Y],BA | LD,BA    | LD,SP     | LD |
| D | SBC | BA,HL | SBC | HL,HL | SP,HL | SP,HL | SP,HL | SBC      | SP,[HLH]   |          |   | POP ALE  | LD,[Y],HL  | LD,[Y],HL | LD,HL    | 未定義 コード領域 | LD |
| E | SBC | BA,IX | SBC | HL,IX |       |       |       | SBC      | SP,#mmmm   |          |   |          | LD,[Y],X   | LD,[Y],X  | LD,IX    | LD,SP     | LD |
| F | SBC | BA,Y  | SBC | HL,Y  |       |       |       | SBC      | SP,[HLH]   |          |   |          | LD,[Y],Y   | LD,[Y],Y  | LD,XY    | 未定義 コード   | LD |

## APPENDIX B アドレッシングモード別命令一覧表

アドレッシングモード別命令一覧表(1/12)

## 8ビット算術論理演算命令

| 二-モニック |  | 即値データ   | レジスタ直接     | レジスタ間接                                            | ディスプレースメント                  | インデックスレジスタ<br>付きレジスタ間接                     | 8ビット絶対                   | 16ビット絶対            |            |
|--------|--|---------|------------|---------------------------------------------------|-----------------------------|--------------------------------------------|--------------------------|--------------------|------------|
| ADD    |  | A,#[nn] | A,A<br>A,B | A,[HL]<br>A,[X]<br>A,[Y]<br>[HL],[IX]<br>[HL],[Y] | 1,2<br>1,2<br>1,2<br>4<br>2 | A,[X+dd]<br>A,[Y+dd]<br>A,[X+L]<br>A,[Y+L] | 3,4<br>3,4<br>2,5<br>2,5 | A,[X+L]<br>A,[Y+L] | 2,4<br>2,4 |
| ADC    |  | A,#[nn] | A,A<br>A,B | A,[HL]<br>A,[X]<br>A,[Y]<br>[HL],[X]<br>[HL],[Y]  | 1,2<br>1,2<br>1,2<br>4<br>2 | A,[X+dd]<br>A,[Y+dd]<br>A,[X+L]<br>A,[Y+L] | 3,4<br>3,4<br>2,5<br>2,5 | A,[X+L]<br>A,[Y+L] | 2,4<br>2,4 |
| SUB    |  | A,#[nn] | A,A<br>A,B | A,[HL]<br>A,[X]<br>A,[Y]<br>[HL],[X]<br>[HL],[Y]  | 1,2<br>1,2<br>1,2<br>4<br>2 | A,[X+dd]<br>A,[Y+dd]<br>A,[X+L]<br>A,[Y+L] | 3,4<br>3,4<br>2,5<br>2,5 | A,[X+L]<br>A,[Y+L] | 2,4<br>2,4 |
| SBC    |  | A,#[nn] | A,A<br>A,B | A,[HL]<br>A,[X]<br>A,[Y]<br>[HL],[X]<br>[HL],[Y]  | 1,2<br>1,2<br>1,2<br>4<br>2 | A,[X+dd]<br>A,[Y+dd]<br>A,[X+L]<br>A,[Y+L] | 3,4<br>3,4<br>2,5<br>2,5 | A,[X+L]<br>A,[Y+L] | 2,4<br>2,4 |
| AND    |  | A,#[nn] | A,A<br>A,B | A,[HL]<br>A,[X]<br>A,[Y]<br>[HL],[X]<br>[HL],[Y]  | 1,2<br>1,2<br>1,2<br>4<br>2 | A,[X+dd]<br>A,[Y+dd]<br>A,[X+L]<br>A,[Y+L] | 3,4<br>3,4<br>2,5<br>2,5 | A,[X+L]<br>A,[Y+L] | 2,4<br>2,4 |
| OR     |  | A,#[nn] | A,A<br>A,B | A,[HL]<br>A,[X]<br>A,[Y]<br>[HL],[X]<br>[HL],[Y]  | 1,2<br>1,2<br>1,2<br>4<br>2 | A,[X+dd]<br>A,[Y+dd]<br>A,[X+L]<br>A,[Y+L] | 3,4<br>3,4<br>2,5<br>2,5 | A,[X+L]<br>A,[Y+L] | 2,4<br>2,4 |

アドレッシングモード別命令一覧表(2/12)

## 8ビット算術論理演算命令

| 二-モニック      |        | 即値データ    | レジスタ直接 | レジスタ間接   | ディスプレースメント付きレジスタ間接 | インデックスレジスタ付きレジスタ間接 | 8ビット絶対   | 16ビット絶対  |
|-------------|--------|----------|--------|----------|--------------------|--------------------|----------|----------|
| <b>XOR</b>  | オペランド  | 【イトサイクル】 | オペランド  | 【イトサイクル】 | オペランド              | 【イトサイクル】           | オペランド    | 【イトサイクル】 |
| A,<#nn      | 2      | 2        | A,A    | 1 2      | A,[HL]             | 1 2                | A,[X+dd] | 3 4      |
| B,<#nn      | 3      | 3        | A,B    | 1 2      | A,[X]              | 1 2                | A,[Y+dd] | 3 4      |
| L,<#nn      | 3      | 3        |        |          | A,[Y]              | 1 2                | A,[Y+dd] | 2 4      |
| H,<#nn      | 3      | 3        |        |          |                    |                    | A,[X+H]  | 2 4      |
| SC,<#nn     | 2      | 3        | [HL],A | 2 4      | [HL],[X]           | 2 5                | A,[Y+H]  | 2 3      |
| [BR:ll],#nn | 3      | 5        |        |          | [HL],[Y]           | 2 5                |          |          |
| [HL],#nn    | 3      | 5        |        |          |                    |                    |          |          |
| <b>CP</b>   | A,<#nn | 2        | A,A    | 1 2      | A,[HL]             | 1 2                | A,[X+dd] | 3 4      |
| B,<#nn      | 3      | 3        | A,B    | 1 2      | A,[X]              | 1 2                | A,[Y+dd] | 3 4      |
| L,<#nn      | 3      | 3        |        |          | A,[Y]              | 1 2                | A,[Y+dd] | 2 4      |
| H,<#nn      | 3      | 3        |        |          |                    |                    | A,[X+L]  | 2 4      |
| BR,#hh      | 3      | 3        |        |          |                    |                    |          |          |
| [BR:ll],#nn | 3      | 4        | [HL],A | 2 3      | [HL],[X]           | 2 4                |          |          |
| [HL],#nn    | 3      | 4        |        |          | [HL],[Y]           | 2 4                |          |          |
| <b>BIT</b>  | A,<#nn | 2        | A,B    | 1 2      |                    |                    |          |          |
| B,<#nn      | 2      | 2        |        |          |                    |                    |          |          |
| [BR:ll],#nn | 3      | 4        |        |          |                    |                    |          |          |
| [HL],#nn    | 2      | 3        |        |          |                    |                    |          |          |
| <b>INC</b>  |        |          | A      | 1 2      | [HL]               | 1 3                |          |          |
|             |        |          | B      | 1 2      |                    |                    |          |          |
|             |        |          | L      | 1 2      |                    |                    |          |          |
|             |        |          | H      | 1 2      |                    |                    |          |          |
|             |        |          | BR     | 1 2      |                    |                    |          |          |
| <b>DEC</b>  |        |          | A      | 1 2      | [HL]               | 1 3                |          |          |
|             |        |          | B      | 1 2      |                    |                    |          |          |
|             |        |          | L      | 1 2      |                    |                    |          |          |
|             |        |          | H      | 1 2      |                    |                    |          |          |
|             |        |          | BR     | 1 2      |                    |                    |          |          |
| <b>CPL</b>  |        |          | A      | 2 3      | [HL]               | 2 4                |          |          |
|             |        |          | B      | 2 3      |                    |                    |          |          |
| <b>NEG</b>  |        |          | A      | 2 3      | [HL]               | 2 4                |          |          |
|             |        |          | B      | 2 3      |                    |                    |          |          |

### アドレッシングモード別命令一覧表(3/12)

アドレッシングモード別命令一覧表(4/12)

## 8ビット転送命令

| 二モニック         |          | 即値データ                              | レジスタ直接                                       | レジスタ間接                   | ディスプレースメント付きレジスタ間接                | インデックスレジスタ間接付きレジスタ間接 | 8ビット絶対                   | 16ビット絶対 |
|---------------|----------|------------------------------------|----------------------------------------------|--------------------------|-----------------------------------|----------------------|--------------------------|---------|
| <b>LD</b>     | [HL],#nn | 2 3                                | [HL],A<br>[HL],B<br>[HL],L<br>[HL],H         | 1 2<br>1 2<br>1 2<br>1 2 | [HL],[HL]<br>[HL],[X]<br>[HL],[Y] | 1 3<br>1 3<br>1 3    | [HL],[X+d]<br>[HL],[Y+d] | 3 5     |
|               | [X],#nn  | 2 3                                | [X],A<br>[X],B<br>[X],L<br>[X],H             | 1 2<br>1 2<br>1 2<br>1 2 | [X],[HL]<br>[X],[X]<br>[X],[Y]    | 1 3<br>1 3<br>1 3    | [X],[X+d]<br>[X],[Y+d]   | 3 5     |
|               | [Y],#nn  | 2 3                                | [Y],A<br>[Y],B<br>[Y],L<br>[Y],H             | 1 2<br>1 2<br>1 2<br>1 2 | [Y],[HL]<br>[Y],[X]<br>[Y],[Y]    | 1 3<br>1 3<br>1 3    | [Y],[X+d]<br>[Y],[Y+d]   | 3 5     |
|               |          |                                    | [X+dd],A<br>[X+dd],B<br>[X+dd],L<br>[X+dd],H | 3 4<br>3 4<br>3 4<br>3 4 |                                   |                      | [Y],[X+d]<br>[Y],[Y+d]   | 3 5     |
|               |          |                                    | [Y+dd],A<br>[Y+dd],B<br>[Y+dd],L<br>[Y+dd],H | 3 4<br>3 4<br>3 4<br>3 4 |                                   |                      | [Y],[X+d]<br>[Y],[Y+d]   | 3 5     |
|               |          |                                    | [X+L],A<br>[X+L],B<br>[X+L],L<br>[X+L],H     | 2 4<br>2 4<br>2 4<br>2 4 |                                   |                      |                          |         |
|               |          |                                    | [Y+L],A<br>[Y+L],B<br>[Y+L],L<br>[Y+L],H     | 2 4<br>2 4<br>2 4<br>2 4 |                                   |                      |                          |         |
| <b>NB,#db</b> | 3 4      | NB,A<br>EP,#dp<br>XP,#dp<br>YP,#dp | 2 3<br>2 3<br>2 3<br>2 3                     |                          |                                   |                      |                          |         |
| <b>EX</b>     |          | A,B                                | 1 2                                          | A,[HL]                   | 1 3                               |                      |                          |         |
| <b>SWAP</b>   |          | A                                  | 1 2                                          | [HL]                     | 1 3                               |                      |                          |         |

## アドレッシングモード別命令一覧表(5/12)

## ロードーントシフト命令

| モード        | 即値データ | レジスタ直接 | レジスタ間接 | ディスプレースメント<br>付きレジスタ間接 | インデックスレジスタ<br>付きレジスタ間接 | オペランド | オペランド | オペランド | オペランド | オペランド  | オペランド |
|------------|-------|--------|--------|------------------------|------------------------|-------|-------|-------|-------|--------|-------|
| <b>RL</b>  |       | A<br>B | 2<br>3 | [HL]                   | 2                      | 4     |       |       |       | [BR:1] | 3     |
| <b>RLC</b> |       | A<br>B | 2<br>3 | [HL]                   | 2                      | 4     |       |       |       | [BR:1] | 3     |
| <b>RR</b>  |       | A<br>B | 2<br>3 | [HL]                   | 2                      | 4     |       |       |       | [BR:1] | 3     |
| <b>RRC</b> |       | A<br>B | 2<br>3 | [HL]                   | 2                      | 4     |       |       |       | [BR:1] | 3     |
| <b>SLA</b> |       | A<br>B | 2<br>3 | [HL]                   | 2                      | 4     |       |       |       | [BR:1] | 3     |
| <b>SLL</b> |       | A<br>B | 2<br>3 | [HL]                   | 2                      | 4     |       |       |       | [BR:1] | 3     |
| <b>SRA</b> |       | A<br>B | 2<br>3 | [HL]                   | 2                      | 4     |       |       |       | [BR:1] | 3     |
| <b>SRL</b> |       | A<br>B | 2<br>3 | [HL]                   | 2                      | 4     |       |       |       | [BR:1] | 3     |

## アドレッシングモード別命令一覧表(6/12)

## 16ビット算術演算命令

| 二-モニック     |          | 即値データ | レジスタ直接                           | レジスタ間接                   | ディスプレースメント付きレジスタ間接               | インデックスレジスタ間接付きレジスタ間接     | オペランドオペランド             | オペランドオペランド             | 8ビット絶対オペランドオペランド       | 16ビット絶対オペランドオペランド      |
|------------|----------|-------|----------------------------------|--------------------------|----------------------------------|--------------------------|------------------------|------------------------|------------------------|------------------------|
| <b>ADD</b> | BA,#mmmn | 3 3   | BA,BA<br>BA,HL<br>BA,IX<br>BA,IY | 2 4<br>2 4<br>2 4<br>2 4 | HL,BA<br>HL,HL<br>HL,IX<br>HL,IY | 2 4<br>2 4<br>2 4<br>2 4 | オペランドバイタル<br>オペランドバイタル | オペランドバイタル<br>オペランドバイタル | オペランドバイタル<br>オペランドバイタル | オペランドバイタル<br>オペランドバイタル |
|            | HL,#mmmn | 3 3   |                                  |                          |                                  |                          |                        |                        |                        |                        |
|            | IX,#mmmn | 3 3   |                                  |                          |                                  |                          |                        |                        |                        |                        |
|            | IY,#mmmn | 3 3   |                                  |                          |                                  |                          |                        |                        |                        |                        |
|            | SP,#mmmn | 4 4   |                                  |                          |                                  |                          |                        |                        |                        |                        |
| <b>ADC</b> | BA,#mmmn | 4 4   | BA,BA<br>BA,HL<br>BA,IX<br>BA,IY | 2 4<br>2 4<br>2 4<br>2 4 | HL,BA<br>HL,HL<br>HL,IX<br>HL,IY | 2 4<br>2 4<br>2 4<br>2 4 | オペランドバイタル<br>オペランドバイタル | オペランドバイタル<br>オペランドバイタル | オペランドバイタル<br>オペランドバイタル | オペランドバイタル<br>オペランドバイタル |
|            | HL,#mmmn | 4 4   |                                  |                          |                                  |                          |                        |                        |                        |                        |
| <b>SUB</b> | BA,#mmmn | 3 3   | BA,BA<br>BA,HL<br>BA,IX<br>BA,IY | 2 4<br>2 4<br>2 4<br>2 4 | HL,BA<br>HL,HL<br>HL,IX<br>HL,IY | 2 4<br>2 4<br>2 4<br>2 4 | オペランドバイタル<br>オペランドバイタル | オペランドバイタル<br>オペランドバイタル | オペランドバイタル<br>オペランドバイタル | オペランドバイタル<br>オペランドバイタル |
|            | IX,#mmmn | 3 3   |                                  |                          |                                  |                          |                        |                        |                        |                        |
|            | IY,#mmmn | 3 3   |                                  |                          |                                  |                          |                        |                        |                        |                        |
|            | SP,#mmmn | 4 4   |                                  |                          |                                  |                          |                        |                        |                        |                        |

## アドレッシングモード別命令一覧表(7/12)

アドレッシングモード別命令一覧表(8/12)

## 16ビット転送命令

|       |    | 即値データ    |   | レジスタ直接 |         | レジスタ間接 |         | ディスプレスマント |   | インデックスレジスタ<br>付きレジスタ間接 |            | 8ビット絶対 |   | 16ビット絶対 |  |
|-------|----|----------|---|--------|---------|--------|---------|-----------|---|------------------------|------------|--------|---|---------|--|
| 二モニック | LD | BA,#mmmn | 3 | BA,BA  | 2       | 2      | BA,[HL] | 2         | 5 | BA,[SP+dd]             | 3          | 6      |   |         |  |
|       |    | BA,HL    | 2 | 2      | BA,[IX] | 2      | 5       | BA,[IX]   | 2 | 5                      | BA,[SP+dd] | 3      | 6 |         |  |
|       |    | BA,IX    | 2 | 2      | BA,[IY] | 2      | 5       | BA,[IY]   | 2 | 5                      | BA,[SP+dd] | 3      | 6 |         |  |
|       |    | BA,IY    | 2 | 2      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | BA,SP    | 2 | 2      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | BA,PC    | 2 | 2      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | HL,#mmmn | 3 | HL,BA  | 2       | 2      | HL,[HL] | 2         | 5 | HL,[SP+dd]             | 3          | 6      |   |         |  |
|       |    | HL,HL    | 2 | 2      | HL,[IX] | 2      | 5       | HL,[IX]   | 2 | 5                      | HL,[SP+dd] | 3      | 6 |         |  |
|       |    | HL,IX    | 2 | 2      | HL,[IY] | 2      | 5       | HL,[IY]   | 2 | 5                      | HL,[SP+dd] | 3      | 6 |         |  |
|       |    | HL,IY    | 2 | 2      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | HL,SP    | 2 | 2      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | HL,PC    | 2 | 2      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | IX,#mmmn | 3 | IX,BA  | 2       | 2      | IX,[HL] | 2         | 5 | IX,[SP+dd]             | 3          | 6      |   |         |  |
|       |    | IX,HL    | 2 | 2      | IX,[IX] | 2      | 5       | IX,[IX]   | 2 | 5                      | IX,[SP+dd] | 3      | 6 |         |  |
|       |    | IX,IX    | 2 | 2      | IX,[IY] | 2      | 5       | IX,[IY]   | 2 | 5                      | IX,[SP+dd] | 3      | 6 |         |  |
|       |    | IX,IY    | 2 | 2      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | IX,SP    | 2 | 2      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | Y,#mmmn  | 3 | Y,BA   | 2       | 2      | Y,[HL]  | 2         | 5 | Y,[SP+dd]              | 3          | 6      |   |         |  |
|       |    | Y,HL     | 2 | 2      | Y,[IX]  | 2      | 5       | Y,[IX]    | 2 | 5                      | Y,[SP+dd]  | 3      | 6 |         |  |
|       |    | Y,IX     | 2 | 2      | Y,[IY]  | 2      | 5       | Y,[IY]    | 2 | 5                      | Y,[SP+dd]  | 3      | 6 |         |  |
|       |    | Y,IY     | 2 | 2      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | Y,SP     | 2 | 2      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | SP,#mmmn | 4 | SP,BA  | 2       | 2      |         |           |   |                        |            |        |   |         |  |
|       |    | SP,HL    | 2 | 2      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | SP,IX    | 2 | 2      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | SP,IY    | 2 | 2      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | [hh],BA  | 3 | 5      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | [hh],HL  | 3 | 5      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | [hh],IX  | 3 | 5      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | [hh],IY  | 3 | 5      |         |        |         |           |   |                        |            |        |   |         |  |
|       |    | [hh],SP  | 4 | 6      |         |        |         |           |   |                        |            |        |   |         |  |

アドレッシングモード別命令一覧表(9/12)

| 16ビット転送命令 |       | 即値データ   | レジスタ直接     | レジスタ間接  | ディスプレースメント付きレジスタ間接 | インデックスレジスタ付きレジスタ間接 | 8ビット絶対 | 16ビット絶対 |
|-----------|-------|---------|------------|---------|--------------------|--------------------|--------|---------|
| 二モニック     | オペランド | /バイタルクル | オペランド      | /Mトライアル | オペランド              | /バイタルクル            | オペランド  | /Mトライアル |
| LD        |       |         | [HL],BA    | 2 5     |                    |                    |        |         |
|           |       |         | [HL],HL    | 2 5     |                    |                    |        |         |
|           |       |         | [HL],IX    | 2 5     |                    |                    |        |         |
|           |       |         | [HL],IY    | 2 5     |                    |                    |        |         |
|           |       |         | [IX],BA    | 2 5     |                    |                    |        |         |
|           |       |         | [IX],HL    | 2 5     |                    |                    |        |         |
|           |       |         | [IX],IX    | 2 5     |                    |                    |        |         |
|           |       |         | [IX],IY    | 2 5     |                    |                    |        |         |
|           |       |         | [IY],BA    | 2 5     |                    |                    |        |         |
|           |       |         | [IY],HL    | 2 5     |                    |                    |        |         |
|           |       |         | [IY],IX    | 2 5     |                    |                    |        |         |
|           |       |         | [IY],IY    | 2 5     |                    |                    |        |         |
|           |       |         | [SP+dd],BA | 3 6     |                    |                    |        |         |
|           |       |         | [SP+dd],HL | 3 6     |                    |                    |        |         |
|           |       |         | [SP+dd],IX | 3 6     |                    |                    |        |         |
|           |       |         | [SP+dd],IY | 3 6     |                    |                    |        |         |
| EX        |       |         | BA,HL      | 1 3     |                    |                    |        |         |
|           |       |         | BA,IX      | 1 3     |                    |                    |        |         |
|           |       |         | BA,IY      | 1 3     |                    |                    |        |         |
|           |       |         | BA,SP      | 1 3     |                    |                    |        |         |

アドレッシングモード別命令一覧表(10/12)

| 分岐命令 | 8ビット間接 |       | 16ビット間接 |       | 符号付き8ビット |       | 符号付き16ビット |       | レジスタ直接 |       | その他 |
|------|--------|-------|---------|-------|----------|-------|-----------|-------|--------|-------|-----|
|      | モード    | オペランド | モード     | オペランド | モード      | オペランド | モード       | オペランド | モード    | オペランド |     |
| JRS  | モード    | オペランド | モード     | オペランド | モード      | オペランド | モード       | オペランド | モード    | オペランド | モード |
|      |        |       |         |       | rr       | rr    | rr        | rr    | rr     | rr    |     |
|      |        |       |         |       | C,rr     | 2     | 2         | 2     | 2      | 2     |     |
|      |        |       |         |       | NC,rr    | 2     | 2         | 2     | 2      | 2     |     |
|      |        |       |         |       | Z,rr     | 2     | 2         | 2     | 2      | 2     |     |
|      |        |       |         |       | NZ,rr    | 2     | 2         | 2     | 2      | 2     |     |
|      |        |       |         |       | LT,rr    | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | LE,rr    | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | GT,rr    | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | GE,rr    | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | V,rr     | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | NV,rr    | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | P,rr     | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | M,rr     | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | F0,rr    | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | F1,rr    | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | F2,rr    | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | F3,rr    | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | NF0,rr   | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | NF1,rr   | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | NF2,rr   | 3     | 3         | 3     | 3      | 3     |     |
|      |        |       |         |       | NF3,rr   | 3     | 3         | 3     | 3      | 3     |     |
| JRL  |        |       |         |       |          |       |           |       |        |       |     |
|      |        |       |         |       |          |       |           |       |        |       |     |
| JP   | [kk]   | 2     | 4       |       |          |       |           |       |        |       |     |
| DJR  |        |       |         |       |          |       |           |       |        |       |     |

アドレッシングモード別命令一覧表(11/12)

| 分岐命令<br>二モニック | 8ビット間接       |                   | 16ビット間接      |                   | 符号付き8ビットPC相対 |                   | 符号付き16ビットPC相対 |                   | その他          |                   |
|---------------|--------------|-------------------|--------------|-------------------|--------------|-------------------|---------------|-------------------|--------------|-------------------|
|               | オペランド<br>/レト | サイクル<br>Min. Max. | オペランド<br>/レト | サイクル<br>Min. Max. | オペランド<br>/レト | サイクル<br>Min. Max. | オペランド<br>/レト  | サイクル<br>Min. Max. | オペランド<br>/レト | サイクル<br>Min. Max. |
| <b>CARS</b>   |              |                   |              |                   | rr           | 2                 | 4             | 5                 | —            |                   |
|               |              |                   |              |                   | C,rr         | 2                 | 4             | 5                 | 2            |                   |
|               |              |                   |              |                   | NC,rr        | 2                 | 4             | 5                 | 2            |                   |
|               |              |                   |              |                   | Z,rr         | 2                 | 4             | 5                 | 2            |                   |
|               |              |                   |              |                   | NZ,rr        | 2                 | 4             | 5                 | 2            |                   |
|               |              |                   |              |                   | LT,rr        | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | LE,rr        | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | GT,rr        | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | GE,rr        | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | VE,rr        | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | NV,rr        | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | P,rr         | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | M,rr         | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | F0,rr        | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | F1,rr        | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | F2,rr        | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | F3,rr        | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | NF0,rr       | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | NF1,rr       | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | NF2,rr       | 3                 | 5             | 6                 | 3            |                   |
|               |              |                   |              |                   | NF3,rr       | 3                 | 5             | 6                 | 3            |                   |
| <b>CARL</b>   |              |                   |              |                   |              |                   |               |                   |              |                   |
|               |              |                   |              |                   |              |                   |               |                   |              |                   |
|               |              |                   |              |                   |              |                   |               |                   |              |                   |
|               |              |                   |              |                   |              |                   |               |                   |              |                   |
|               |              |                   |              |                   |              |                   |               |                   |              |                   |
| <b>CALL</b>   |              |                   |              |                   | [hhll]       | 3                 | 7             | 8                 |              |                   |
| <b>RET</b>    |              |                   |              |                   |              |                   |               |                   |              | 2 3 4             |
| <b>RETE</b>   |              |                   |              |                   |              |                   |               |                   |              | 1 4 5             |
| <b>RETS</b>   |              |                   |              |                   |              |                   |               |                   |              | 1 5 6             |
| <b>INT</b>    | [kk]         | 2 7 8             |              |                   |              |                   |               |                   |              |                   |

## アドレッシングモード別命令一覧表(12/12)

| スタック制御命令    |               | 乗除算命令         |               | 演算補助命令     |               | システム制御命令   |               |
|-------------|---------------|---------------|---------------|------------|---------------|------------|---------------|
| 二モニック       | レジスタ直接        | 二モニック         | インプライド        | 二モニック      | インプライド        | 二モニック      | インプライド        |
| <b>POP</b>  | オペランド /バイトサブル | オペランド /バイトサブル | オペランド /バイトサブル | <b>MLT</b> | オペランド /バイトサブル | <b>NOP</b> | オペランド /バイトサブル |
| A           | 2             | 3             | ALL           | 2          | 11            | 1          | 2             |
| B           | 2             | 3             |               |            |               | HALT       | 2             |
| L           | 2             | 3             |               |            |               | SLP        | 3             |
| H           | 2             | 3             |               |            |               |            | 2             |
| BR          | 1             | 2             | ALE           | 2          | 14            |            | 3             |
| SC          | 1             | 2             |               |            |               |            |               |
| EP          | 1             | 2             |               |            |               |            |               |
| IP          | 1             | 3             |               |            |               |            |               |
| BA          | 1             | 3             |               |            |               |            |               |
| HL          | 1             | 3             |               |            |               |            |               |
| IX          | 1             | 3             |               |            |               |            |               |
| IY          | 1             | 3             |               |            |               |            |               |
| <b>PUSH</b> | A             | 2             | 3             | ALL        | 2             | 12         |               |
|             | B             | 2             | 3             |            |               |            |               |
|             | L             | 2             | 3             |            |               |            |               |
|             | H             | 2             | 3             |            |               |            |               |
|             | BR            | 1             | 3             | ALE        | 2             | 15         |               |
|             | SC            | 1             | 3             |            |               |            |               |
|             | EP            | 1             | 3             |            |               |            |               |
|             | IP            | 1             | 4             |            |               |            |               |
|             | BA            | 1             | 4             |            |               |            |               |
|             | HL            | 1             | 4             |            |               |            |               |
|             | IX            | 1             | 4             |            |               |            |               |
|             | IY            | 1             | 4             |            |               |            |               |

## APPENDIX C 命令索引

(アルファベット順)

## ADC 8ビットキャリー付き加算

|                      |    |
|----------------------|----|
| ADC A, A .....       | 55 |
| ADC A, B .....       | 55 |
| ADC A, #nn .....     | 55 |
| ADC A, [BR:II] ..... | 55 |
| ADC A, [hhII] .....  | 56 |
| ADC A, [HL] .....    | 56 |
| ADC A, [IX] .....    | 56 |
| ADC A, [IX+dd] ..... | 57 |
| ADC A, [IX+L] .....  | 57 |
| ADC A, [IY] .....    | 56 |
| ADC A, [IY+dd] ..... | 57 |
| ADC A, [IY+L] .....  | 57 |
| ADC [HL], A .....    | 58 |
| ADC [HL], #nn .....  | 58 |
| ADC [HL], [IX] ..... | 58 |
| ADC [HL], [IY] ..... | 58 |

## ADC 16ビットキャリー付き加算

|                     |    |
|---------------------|----|
| ADC BA, BA .....    | 59 |
| ADC BA, HL .....    | 59 |
| ADC BA, IX .....    | 59 |
| ADC BA, IY .....    | 59 |
| ADC BA, #mmnn ..... | 59 |
| ADC HL, BA .....    | 59 |
| ADC HL, HL .....    | 59 |
| ADC HL, IX .....    | 59 |
| ADC HL, IY .....    | 59 |
| ADC HL, #mmnn ..... | 60 |

## ADD 8ビット加算

|                      |    |
|----------------------|----|
| ADD A, A .....       | 60 |
| ADD A, B .....       | 60 |
| ADD A, #nn .....     | 60 |
| ADD A, [BR:II] ..... | 61 |
| ADD A, [hhII] .....  | 61 |
| ADD A, [HL] .....    | 61 |
| ADD A, [IX] .....    | 62 |
| ADD A, [IX+dd] ..... | 62 |
| ADD A, [IX+L] .....  | 63 |
| ADD A, [IY] .....    | 62 |
| ADD A, [IY+dd] ..... | 62 |
| ADD A, [IY+L] .....  | 63 |
| ADD [HL], A .....    | 63 |
| ADD [HL], #nn .....  | 63 |
| ADD [HL], [IX] ..... | 64 |
| ADD [HL], [IY] ..... | 64 |

## ADD 16ビット加算

|                  |    |
|------------------|----|
| ADD BA, BA ..... | 64 |
|------------------|----|

## ADD 16ビット加算

|                     |    |
|---------------------|----|
| ADD BA, HL .....    | 64 |
| ADD BA, IX .....    | 64 |
| ADD BA, IY .....    | 64 |
| ADD BA, #mmnn ..... | 64 |
| ADD HL, BA .....    | 65 |
| ADD HL, HL .....    | 65 |
| ADD HL, IX .....    | 65 |
| ADD HL, IY .....    | 65 |
| ADD HL, #mmnn ..... | 65 |
| ADD IX, BA .....    | 65 |
| ADD IX, HL .....    | 65 |
| ADD IX, #mmnn ..... | 66 |
| ADD IY, BA .....    | 66 |
| ADD IY, HL .....    | 66 |
| ADD IY, #mmnn ..... | 66 |
| ADD SP, BA .....    | 67 |
| ADD SP, HL .....    | 67 |
| ADD SP, #mmnn ..... | 67 |

## AND 論理積

|                        |    |
|------------------------|----|
| AND A, A .....         | 67 |
| AND A, B .....         | 67 |
| AND A, #nn .....       | 68 |
| AND A, [BR:II] .....   | 68 |
| AND A, [hhII] .....    | 68 |
| AND A, [HL] .....      | 69 |
| AND A, [IX] .....      | 69 |
| AND A, [IX+dd] .....   | 69 |
| AND A, [IX+L] .....    | 70 |
| AND A, [IY] .....      | 69 |
| AND A, [IY+dd] .....   | 69 |
| AND A, [IY+L] .....    | 70 |
| AND B, #nn .....       | 70 |
| AND H, #nn .....       | 71 |
| AND L, #nn .....       | 70 |
| AND SC, #nn .....      | 71 |
| AND [BR:II], #nn ..... | 71 |
| AND [HL], A .....      | 72 |
| AND [HL], #nn .....    | 72 |
| AND [HL], [IX] .....   | 72 |
| AND [HL], [IY] .....   | 72 |

## BIT ビットテスト

|                        |    |
|------------------------|----|
| BIT A, B .....         | 73 |
| BIT A, #nn .....       | 73 |
| BIT B, #nn .....       | 73 |
| BIT [BR:II], #nn ..... | 74 |
| BIT [HL], #nn .....    | 74 |

## CALL 間接コール

|                   |    |
|-------------------|----|
| CALL [hhII] ..... | 75 |
|-------------------|----|

|                      |             |                    |                                 |
|----------------------|-------------|--------------------|---------------------------------|
| <b>CARL</b>          | PC相対ロングコール  | <b>CP</b>          | 16ビット比較                         |
| CARL C, qqrr .....   | 76          | CP BA, BA .....    | 86                              |
| CARL NC, qqrr .....  | 76          | CP BA, HL .....    | 86                              |
| CARL NZ, qqrr .....  | 76          | CP BA, IX .....    | 86                              |
| CARL qqrr .....      | 76          | CP BA, IY .....    | 86                              |
| CARL Z, qqrr .....   | 76          | CP BA, #mmnn ..... | 86                              |
|                      |             | CP HL, BA .....    | 87                              |
|                      |             | CP HL, HL .....    | 87                              |
| <b>CARS</b>          | PC相対ショートコール | CP HL, IX .....    | 87                              |
| CARS C, rr .....     | 77          | CP HL, IY .....    | 87                              |
| CARS F0, rr .....    | 78          | CP HL, #mmnn ..... | 87                              |
| CARS F1, rr .....    | 78          | CP IX, #mmnn ..... | 88                              |
| CARS F2, rr .....    | 78          | CP IY, #mmnn ..... | 88                              |
| CARS F3, rr .....    | 78          | CP SP, BA .....    | 88                              |
| CARS GE, rr .....    | 78          | CP SP, HL .....    | 88                              |
| CARS GT, rr .....    | 78          | CP SP, #mmnn ..... | 89                              |
| CARS LE, rr .....    | 78          |                    |                                 |
| CARS LT, rr .....    | 78          |                    |                                 |
| CARS M, rr .....     | 78          |                    |                                 |
| CARS NC, rr .....    | 77          | <b>CPL</b>         | ビット反転(1の補数)                     |
| CARS NF0, rr .....   | 78          | CPL A .....        | 89                              |
| CARS NF1, rr .....   | 78          | CPL B .....        | 89                              |
| CARS NF2, rr .....   | 78          | CPL [BR:I] .....   | 89                              |
| CARS NF3, rr .....   | 78          | CPL [HL] .....     | 90                              |
| CARS NV, rr .....    | 78          |                    |                                 |
| CARS NZ, rr .....    | 77          | <b>DEC</b>         | 8ビットデクリメント(-1)                  |
| CARS P, rr .....     | 78          | DEC A .....        | 90                              |
| CARS rr .....        | 77          | DEC B .....        | 90                              |
| CARS V, rr .....     | 78          | DEC BR .....       | 90                              |
| CARS Z, rr .....     | 77          | DEC H .....        | 90                              |
|                      |             | DEC L .....        | 90                              |
|                      |             | DEC [BR:I] .....   | 91                              |
| <b>CP</b>            | 8ビット比較      | DEC [HL] .....     | 91                              |
| CP A, A .....        | 80          |                    |                                 |
| CP A, B .....        | 80          | <b>DEC</b>         | 16ビットデクリメント(-1)                 |
| CP A, #nn .....      | 80          | DEC BA .....       | 91                              |
| CP A, [BR:I] .....   | 80          | DEC HL .....       | 91                              |
| CP A, [hhI] .....    | 81          | DEC IX .....       | 91                              |
| CP A, [HL] .....     | 81          | DEC IY .....       | 91                              |
| CP A, [IX] .....     | 81          | DEC SP .....       | 92                              |
| CP A, [IX+dd] .....  | 82          |                    |                                 |
| CP A, [IX+L] .....   | 82          | <b>DIV</b>         | 除算                              |
| CP A, [IY] .....     | 81          | DIV .....          | 92                              |
| CP A, [IY+dd] .....  | 82          |                    |                                 |
| CP A, [IY+L] .....   | 82          | <b>DJR</b>         | PC相対ショートジャンプ<br>(Bレジスタデクリメント付き) |
| CP B, #nn .....      | 83          | DJR NZ, rr .....   | 92                              |
| CP BR, #hh .....     | 84          |                    |                                 |
| CP H, #nn .....      | 83          | <b>EX</b>          | 8ビットデータ交換                       |
| CP L, #nn .....      | 83          | EX A, B .....      | 93                              |
| CP [BR:I], #nn ..... | 84          | EX A, [HL] .....   | 93                              |
| CP [HL], A .....     | 84          |                    |                                 |
| CP [HL], #nn .....   | 85          | <b>EX</b>          | 16ビットデータ交換                      |
| CP [HL], [IX] .....  | 85          | EX BA, HL .....    | 93                              |
| CP [HL], [IY] .....  | 85          | EX BA, IX .....    | 93                              |

|              |                  |               |              |
|--------------|------------------|---------------|--------------|
| <b>EX</b>    | 16ビットデータ交換       | <b>JRS</b>    | PC相対ショートジャンプ |
| EX BA, IY    | 93               | JRS NV, rr    | 100          |
| EX BA, SP    | 93               | JRS NZ, rr    | 99           |
| <b>HALT</b>  | HALT             | JRS P, rr     | 100          |
| HALT         | 94               | JRS rr        | 99           |
| <b>INC</b>   | 8ビットインクリメント(+1)  | <b>LD</b>     | 8ビットロード      |
| INC A        | 94               | LD A, A       | 101          |
| INC B        | 94               | LD A, B       | 101          |
| INC BR       | 94               | LD A, BR      | 101          |
| INC H        | 94               | LD A, EP      | 102          |
| INC L        | 94               | LD A, H       | 101          |
| INC [BR:II]  | 95               | LD A, L       | 101          |
| INC [HL]     | 95               | LD A, NB      | 102          |
| <b>INC</b>   | 16ビットインクリメント(+1) | LD A, SC      | 101          |
| INC BA       | 95               | LD A, XP      | 102          |
| INC HL       | 95               | LD A, YP      | 102          |
| INC IX       | 95               | LD A, #nn     | 108          |
| INC IY       | 95               | LD A, [BR:II] | 111          |
| INC SP       | 96               | LD A, [hhII]  | 113          |
| <b>INT</b>   | ソフトウェア割り込み       | LD A, [HL]    | 113          |
| INT [kk]     | 96               | LD A, [IX]    | 115          |
| <b>JP</b>    | ジャンプ             | LD A, [IX+dd] | 118          |
| JP HL        | 97               | LD A, [IX+L]  | 121          |
| JP [kk]      | 97               | LD A, [IY]    | 116          |
| <b>JRL</b>   | PC相対ロングジャンプ      | LD A, [IY+dd] | 119          |
| JRL C, qqrr  | 98               | LD A, [IY+L]  | 122          |
| JRL NC, qqrr | 98               | LD B, A       | 101          |
| JRL NZ, qqrr | 98               | LD B, B       | 101          |
| JRL qqrr     | 98               | LD B, H       | 101          |
| JRL Z, qqrr  | 98               | LD B, L       | 101          |
| <b>JRS</b>   | PC相対ショートジャンプ     | LD B, #nn     | 108          |
| JRS C, rr    | 99               | LD B, [BR:II] | 111          |
| JRS F0, rr   | 100              | LD B, [hhII]  | 113          |
| JRS F1, rr   | 100              | LD B, [HL]    | 113          |
| JRS F2, rr   | 100              | LD B, [IX]    | 115          |
| JRS F3, rr   | 100              | LD B, [IX+dd] | 118          |
| JRS GE, rr   | 100              | LD B, [IX+L]  | 121          |
| JRS GT, rr   | 100              | LD B, [IY]    | 116          |
| JRS LE, rr   | 100              | LD B, [IY+dd] | 119          |
| JRS LT, rr   | 100              | LD B, [IY+L]  | 122          |
| JRS M, rr    | 100              | LD BR, A      | 102          |
| JRS NC, rr   | 99               | LD BR, #hh    | 108          |
| JRS NF0, rr  | 100              | LD EP, A      | 103          |
| JRS NF1, rr  | 100              | LD EP, #pp    | 109          |
| JRS NF2, rr  | 100              | LD H, A       | 101          |
| JRS NF3, rr  | 100              | LD H, B       | 101          |
|              |                  | LD H, H       | 101          |
|              |                  | LD H, L       | 101          |
|              |                  | LD H, #nn     | 108          |
|              |                  | LD H, [BR:II] | 111          |

|                                |                |                                |                 |
|--------------------------------|----------------|--------------------------------|-----------------|
| <b>LD</b>                      | <b>8ビットロード</b> | <b>LD</b>                      | <b>8ビットロード</b>  |
| LD H, [hh <i>l</i> ] .....     | 113            | LD [HL], [IY] .....            | 117             |
| LD H, [HL] .....               | 113            | LD [HL], [IY+dd] .....         | 120             |
| LD H, [IX] .....               | 115            | LD [HL], [IY+L] .....          | 123             |
| LD H, [IX+dd] .....            | 118            | LD [IX], A .....               | 105             |
| LD H, [IX+L] .....             | 121            | LD [IX], B .....               | 105             |
| LD H, [IY] .....               | 116            | LD [IX], H .....               | 105             |
| LD H, [IY+dd] .....            | 119            | LD [IX], L .....               | 105             |
| LD H, [IY+L] .....             | 122            | LD [IX], #nn .....             | 111             |
| LD L, A .....                  | 101            | LD [IX], [BR: <i>l</i> ] ..... | 112             |
| LD L, B .....                  | 101            | LD [IX], [HL] .....            | 114             |
| LD L, H .....                  | 101            | LD [IX], [IX] .....            | 116             |
| LD L, L .....                  | 101            | LD [IX], [IX+dd] .....         | 119             |
| LD L, #nn .....                | 108            | LD [IX], [IX+L] .....          | 122             |
| LD L, [BR: <i>l</i> ] .....    | 111            | LD [IX], [IY] .....            | 117             |
| LD L, [hh <i>l</i> ] .....     | 113            | LD [IX], [IY+dd] .....         | 120             |
| LD L, [HL] .....               | 113            | LD [IX], [IY+L] .....          | 123             |
| LD L, [IX] .....               | 115            | LD [IX+dd], A .....            | 106             |
| LD L, [IX+dd] .....            | 118            | LD [IX+dd], B .....            | 106             |
| LD L, [IX+L] .....             | 121            | LD [IX+dd], H .....            | 106             |
| LD L, [IY] .....               | 116            | LD [IX+dd], L .....            | 106             |
| LD L, [IY+dd] .....            | 119            | LD [IX+L], A .....             | 107             |
| LD L, [IY+L] .....             | 122            | LD [IX+L], B .....             | 107             |
| LD NB, A .....                 | 103            | LD [IX+L], H .....             | 107             |
| LD NB, #bb .....               | 109            | LD [IX+L], L .....             | 107             |
| LD SC, A .....                 | 102            | LD [IY], A .....               | 105             |
| LD SC, #nn .....               | 108            | LD [IY], B .....               | 105             |
| LD XP, A .....                 | 103            | LD [IY], H .....               | 105             |
| LD XP, #pp .....               | 109            | LD [IY], L .....               | 105             |
| LD YP, A .....                 | 103            | LD [IY], #nn .....             | 111             |
| LD YP, #pp .....               | 110            | LD [IY], [BR: <i>l</i> ] ..... | 112             |
| LD [BR: <i>l</i> ], A .....    | 103            | LD [IY], [HL] .....            | 114             |
| LD [BR: <i>l</i> ], B .....    | 103            | LD [IY], [IX] .....            | 116             |
| LD [BR: <i>l</i> ], H .....    | 103            | LD [IY], [IX+dd] .....         | 119             |
| LD [BR: <i>l</i> ], L .....    | 103            | LD [IY], [IX+L] .....          | 122             |
| LD [BR: <i>l</i> ], #nn .....  | 110            | LD [IY], [IY] .....            | 117             |
| LD [BR: <i>l</i> ], [HL] ..... | 114            | LD [IY], [IY+dd] .....         | 120             |
| LD [BR: <i>l</i> ], [IX] ..... | 115            | LD [IY], [IY+L] .....          | 123             |
| LD [BR: <i>l</i> ], [IY] ..... | 117            | LD [IY+dd], A .....            | 106             |
| LD [hh <i>l</i> ], A .....     | 104            | LD [IY+dd], B .....            | 106             |
| LD [hh <i>l</i> ], B .....     | 104            | LD [IY+dd], H .....            | 106             |
| LD [hh <i>l</i> ], H .....     | 104            | LD [IY+dd], L .....            | 106             |
| LD [hh <i>l</i> ], L .....     | 104            | LD [IY+L], A .....             | 107             |
| LD [HL], A .....               | 104            | LD [IY+L], B .....             | 107             |
| LD [HL], B .....               | 104            | LD [IY+L], H .....             | 107             |
| LD [HL], H .....               | 104            | LD [IY+L], L .....             | 107             |
| LD [HL], L .....               | 104            |                                |                 |
| LD [HL], #nn .....             | 110            | <b>LD</b>                      | <b>16ビットロード</b> |
| LD [HL], [BR: <i>l</i> ] ..... | 112            | LD BA, BA .....                | 124             |
| LD [HL], [HL] .....            | 114            | LD BA, HL .....                | 124             |
| LD [HL], [IX] .....            | 115            | LD BA, IX .....                | 124             |
| LD [HL], [IX+dd] .....         | 118            | LD BA, IY .....                | 124             |
| LD [HL], [IX+L] .....          | 121            | LD BA, PC .....                | 124             |

|                      |          |                       |            |
|----------------------|----------|-----------------------|------------|
| <b>LD</b>            | 16ビットロード | <b>LD</b>             | 16ビットロード   |
| LD BA, SP .....      | 124      | LD [HL], BA .....     | 127        |
| LD BA, #mmnn .....   | 129      | LD [HL], HL .....     | 127        |
| LD BA, [hh//] .....  | 130      | LD [HL], IX .....     | 127        |
| LD BA, [HL] .....    | 131      | LD [HL], IY .....     | 127        |
| LD BA, [IX] .....    | 132      | LD [IX], BA .....     | 128        |
| LD BA, [IY] .....    | 132      | LD [IX], HL .....     | 128        |
| LD BA, [SP+dd] ..... | 133      | LD [IX], IX .....     | 128        |
| LD HL, BA .....      | 124      | LD [IX], IY .....     | 128        |
| LD HL, HL .....      | 124      | LD [IY], BA .....     | 128        |
| LD HL, IX .....      | 124      | LD [IY], HL .....     | 128        |
| LD HL, IY .....      | 124      | LD [IY], IX .....     | 128        |
| LD HL, PC .....      | 125      | LD [IY], IY .....     | 128        |
| LD HL, SP .....      | 125      | LD [SP+dd], BA .....  | 129        |
| LD HL, #mmnn .....   | 129      | LD [SP+dd], HL .....  | 129        |
| LD HL, [hh//] .....  | 130      | LD [SP+dd], IX .....  | 129        |
| LD HL, [HL] .....    | 131      | LD [SP+dd], IY .....  | 129        |
| LD HL, [IX] .....    | 132      |                       |            |
| LD HL, [IY] .....    | 132      |                       |            |
| LD HL, [SP+dd] ..... | 133      |                       |            |
| LD IX, BA .....      | 124      |                       |            |
| LD IX, HL .....      | 124      |                       |            |
| LD IX, IX .....      | 124      |                       |            |
| LD IX, IY .....      | 124      |                       |            |
| LD IX, SP .....      | 125      |                       |            |
| LD IX, #mmnn .....   | 129      |                       |            |
| LD IX, [hh//] .....  | 130      |                       |            |
| LD IX, [HL] .....    | 131      |                       |            |
| LD IX, [IX] .....    | 132      |                       |            |
| LD IX, [IY] .....    | 132      |                       |            |
| LD IX, [SP+dd] ..... | 133      |                       |            |
| LD IY, BA .....      | 124      |                       |            |
| LD IY, HL .....      | 124      |                       |            |
| LD IY, IX .....      | 124      |                       |            |
| LD IY, IY .....      | 124      |                       |            |
| LD IY, SP .....      | 125      |                       |            |
| LD IY, #mmnn .....   | 129      |                       |            |
| LD IY, [hh//] .....  | 130      |                       |            |
| LD IY, [HL] .....    | 131      |                       |            |
| LD IY, [IX] .....    | 132      |                       |            |
| LD IY, [IY] .....    | 132      |                       |            |
| LD IY, [SP+dd] ..... | 133      |                       |            |
| LD SP, BA .....      | 126      |                       |            |
| LD SP, HL .....      | 126      |                       |            |
| LD SP, IX .....      | 126      |                       |            |
| LD SP, IY .....      | 126      |                       |            |
| LD SP, #mmnn .....   | 130      |                       |            |
| LD SP, [hh//] .....  | 131      |                       |            |
| LD [hh//], BA .....  | 126      |                       |            |
| LD [hh//], HL .....  | 126      |                       |            |
| LD [hh//], IX .....  | 126      |                       |            |
| LD [hh//], IY .....  | 126      |                       |            |
| LD [hh//], SP .....  | 127      |                       |            |
|                      |          | <b>MLT</b>            | 乗算         |
|                      |          | MLT                   | ..... 133  |
|                      |          | <b>NEG</b>            | 符号反転(2の補数) |
|                      |          | NEG A .....           | 134        |
|                      |          | NEG B .....           | 134        |
|                      |          | NEG [BR://] .....     | 134        |
|                      |          | NEG [HL] .....        | 134        |
|                      |          | <b>NOP</b>            | ノーオペレーション  |
|                      |          | NOP                   | ..... 135  |
|                      |          | <b>OR</b>             | 論理和        |
|                      |          | OR A, A .....         | 135        |
|                      |          | OR A, B .....         | 135        |
|                      |          | OR A, #nn .....       | 135        |
|                      |          | OR A, [BR://] .....   | 136        |
|                      |          | OR A, [hh//] .....    | 136        |
|                      |          | OR A, [HL] .....      | 136        |
|                      |          | OR A, [IX] .....      | 137        |
|                      |          | OR A, [IX+dd] .....   | 137        |
|                      |          | OR A, [IX+L] .....    | 138        |
|                      |          | OR A, [IY] .....      | 137        |
|                      |          | OR A, [IY+dd] .....   | 137        |
|                      |          | OR A, [IY+L] .....    | 138        |
|                      |          | OR B, #nn .....       | 138        |
|                      |          | OR H, #nn .....       | 139        |
|                      |          | OR L, #nn .....       | 138        |
|                      |          | OR SC, #nn .....      | 139        |
|                      |          | OR [BR://], #nn ..... | 139        |
|                      |          | OR [HL], A .....      | 140        |
|                      |          | OR [HL], #nn .....    | 140        |
|                      |          | OR [HL], [IX] .....   | 140        |
|                      |          | OR [HL], [IY] .....   | 140        |

|                |               |     |
|----------------|---------------|-----|
| <b>PACK</b>    | パック           |     |
| PACK           | .....         | 141 |
| <b>POP</b>     | ポップ           |     |
| POP A          | .....         | 141 |
| POP ALE        | .....         | 143 |
| POP ALL        | .....         | 143 |
| POP B          | .....         | 141 |
| POP BA         | .....         | 141 |
| POP BR         | .....         | 142 |
| POP EP         | .....         | 142 |
| POP H          | .....         | 141 |
| POP HL         | .....         | 141 |
| POP IP         | .....         | 142 |
| POP IX         | .....         | 141 |
| POP IY         | .....         | 141 |
| POP L          | .....         | 141 |
| POP SC         | .....         | 142 |
| <b>PUSH</b>    | プッシュ          |     |
| PUSH A         | .....         | 143 |
| PUSH ALE       | .....         | 145 |
| PUSH ALL       | .....         | 145 |
| PUSH B         | .....         | 143 |
| PUSH BA        | .....         | 144 |
| PUSH BR        | .....         | 144 |
| PUSH EP        | .....         | 144 |
| PUSH H         | .....         | 143 |
| PUSH HL        | .....         | 144 |
| PUSH IP        | .....         | 145 |
| PUSH IX        | .....         | 144 |
| PUSH IY        | .....         | 144 |
| PUSH L         | .....         | 143 |
| PUSH SC        | .....         | 145 |
| <b>RET</b>     | リターン          |     |
| RET            | .....         | 146 |
| <b>RETE</b>    | 例外処理リターン      |     |
| RETE           | .....         | 146 |
| <b>RETS</b>    | スキップリターン      |     |
| RETS           | .....         | 147 |
| <b>RL</b>      | キャリー付き左ローテート  |     |
| RL A           | .....         | 147 |
| RL B           | .....         | 147 |
| RL [BR:II]     | .....         | 148 |
| RL [HL]        | .....         | 148 |
| <b>RLC</b>     | 左ローテート        |     |
| RLC A          | .....         | 149 |
| RLC B          | .....         | 149 |
| RLC [BR:II]    | .....         | 149 |
| RLC [HL]       | .....         | 149 |
| <b>RR</b>      | キャリー付き右ローテート  |     |
| RR A           | .....         | 150 |
| RR B           | .....         | 150 |
| RR [BR:II]     | .....         | 150 |
| RR [HL]        | .....         | 151 |
| <b>RRC</b>     | 右ローテート        |     |
| RRC A          | .....         | 151 |
| RRC B          | .....         | 151 |
| RRC [BR:II]    | .....         | 152 |
| RRC [HL]       | .....         | 152 |
| <b>SBC</b>     | 8ビットキャリー付き減算  |     |
| SBC A, A       | .....         | 153 |
| SBC A, B       | .....         | 153 |
| SBC A, #nn     | .....         | 153 |
| SBC A, [BR:II] | .....         | 153 |
| SBC A, [hhII]  | .....         | 154 |
| SBC A, [HL]    | .....         | 154 |
| SBC A, [IX]    | .....         | 154 |
| SBC A, [IX+dd] | .....         | 155 |
| SBC A, [IX+L]  | .....         | 155 |
| SBC A, [IY]    | .....         | 154 |
| SBC A, [IY+dd] | .....         | 155 |
| SBC A, [IY+L]  | .....         | 155 |
| SBC [HL], A    | .....         | 156 |
| SBC [HL], #nn  | .....         | 156 |
| SBC [HL], [IX] | .....         | 156 |
| SBC [HL], [IY] | .....         | 156 |
| <b>SBC</b>     | 16ビットキャリー付き減算 |     |
| SBC BA, BA     | .....         | 157 |
| SBC BA, HL     | .....         | 157 |
| SBC BA, IX     | .....         | 157 |
| SBC BA, IY     | .....         | 157 |
| SBC BA, #mmnn  | .....         | 157 |
| SBC HL, BA     | .....         | 157 |
| SBC HL, HL     | .....         | 157 |
| SBC HL, IX     | .....         | 157 |
| SBC HL, IY     | .....         | 157 |
| SBC HL, #mmnn  | .....         | 158 |
| <b>SEP</b>     | 符号拡張          |     |
| SEP            | .....         | 158 |
| <b>SLA</b>     | 算術左シフト        |     |
| SLA A          | .....         | 159 |
| SLA B          | .....         | 159 |
| SLA [BR:II]    | .....         | 159 |
| SLA [HL]       | .....         | 160 |
| <b>SLL</b>     | 論理左シフト        |     |
| SLL A          | .....         | 160 |
| SLL B          | .....         | 160 |
| SLL [BR:II]    | .....         | 161 |
| SLL [HL]       | .....         | 161 |

|            |                  |                  |                |
|------------|------------------|------------------|----------------|
| <b>SLP</b> | <b>SLEEP</b>     | <b>SWAP</b>      | 上位/下位4ビットデータ交換 |
| SLP        | .....            | SWAP A           | 172            |
|            |                  | SWAP [HL]        | 173            |
| <b>SRA</b> | <b>算術右シフト</b>    | <b>UPCK</b>      | アンパック          |
| SRA        | A .....          | UPCK             | 173            |
| SRA        | B .....          |                  |                |
| SRA        | [BR:II] .....    |                  |                |
| SRA        | [HL] .....       |                  |                |
| <b>SRL</b> | <b>論理右シフト</b>    | <b>XOR</b>       | 排他的論理和         |
| SRL        | A .....          | XOR A, A         | 173            |
| SRL        | B .....          | XOR A, B         | 173            |
| SRL        | [BR:II] .....    | XOR A, #nn       | 174            |
| SRL        | [HL] .....       | XOR A, [BR:II]   | 174            |
|            |                  | XOR A, [hhII]    | 174            |
|            |                  | XOR A, [HL]      | 175            |
|            |                  | XOR A, [IX]      | 175            |
|            |                  | XOR A, [IX+dd]   | 175            |
|            |                  | XOR A, [IX+L]    | 176            |
|            |                  | XOR A, [IY]      | 175            |
|            |                  | XOR A, [IY+dd]   | 175            |
|            |                  | XOR A, [IY+L]    | 176            |
|            |                  | XOR B, #nn       | 176            |
|            |                  | XOR H, #nn       | 177            |
|            |                  | XOR L, #nn       | 176            |
|            |                  | XOR SC, #nn      | 177            |
|            |                  | XOR [BR:II], #nn | 177            |
|            |                  | XOR [HL], A      | 178            |
|            |                  | XOR [HL], #nn    | 178            |
|            |                  | XOR [HL], [IX]   | 178            |
|            |                  | XOR [HL], [IY]   | 178            |
| <b>SUB</b> | <b>8ビット減算</b>    |                  |                |
| SUB        | A, A .....       |                  |                |
| SUB        | A, B .....       |                  |                |
| SUB        | A, #nn .....     |                  |                |
| SUB        | A, [BR:II] ..... |                  |                |
| SUB        | A, [hhII] .....  |                  |                |
| SUB        | A, [HL] .....    |                  |                |
| SUB        | A, [IX] .....    |                  |                |
| SUB        | A, [IX+dd] ..... |                  |                |
| SUB        | A, [IX+L] .....  |                  |                |
| SUB        | A, [IY] .....    |                  |                |
| SUB        | A, [IY+dd] ..... |                  |                |
| SUB        | A, [IY+L] .....  |                  |                |
| SUB        | [HL], A .....    |                  |                |
| SUB        | [HL], #nn .....  |                  |                |
| SUB        | [HL], [IX] ..... |                  |                |
| SUB        | [HL], [IY] ..... |                  |                |
| <b>SUB</b> | <b>16ビット減算</b>   |                  |                |
| SUB        | BA, BA .....     |                  |                |
| SUB        | BA, HL .....     |                  |                |
| SUB        | BA, IX .....     |                  |                |
| SUB        | BA, IY .....     |                  |                |
| SUB        | BA, #mmnn .....  |                  |                |
| SUB        | HL, #BA .....    |                  |                |
| SUB        | HL, HL .....     |                  |                |
| SUB        | HL, IX .....     |                  |                |
| SUB        | HL, IY .....     |                  |                |
| SUB        | HL, #mmnn .....  |                  |                |
| SUB        | IX, BA .....     |                  |                |
| SUB        | IX, HL .....     |                  |                |
| SUB        | IX, #mmnn .....  |                  |                |
| SUB        | IY, BA .....     |                  |                |
| SUB        | IY, HL .....     |                  |                |
| SUB        | IY, #mmnn .....  |                  |                |
| SUB        | SP, BA .....     |                  |                |
| SUB        | SP, HL .....     |                  |                |
| SUB        | SP, #mmnn .....  |                  |                |

## **セイコーエプソン株式会社 電子デバイス営業本部**

|          |                                         |
|----------|-----------------------------------------|
| ED営業推進部  | 〒191-8501 東京都日野市日野421-8                 |
| IC営業技術G  | TEL (042)587-5816(直通) FAX (042)587-5624 |
| 東日本      |                                         |
| ED東京営業部  | 〒191-8501 東京都日野市日野421-8                 |
| 東京IC営業G  | TEL (042)587-5313(直通) FAX (042)587-5116 |
| 西日本      |                                         |
| ED大阪営業部  | 〒541-0059 大阪市中央区博労町3-5-1 エプソン大阪ビル15F    |
|          | TEL (06)6120-6000(代表) FAX (06)6120-6100 |
| 東海・北陸    |                                         |
| ED名古屋営業部 | 〒461-0005 名古屋市東区東桜1-10-24 栄大野ビル4F       |
|          | TEL (052)953-8031(代表) FAX (052)953-8041 |
| 長野       |                                         |
| ED長野営業部  | 〒392-8502 長野県諏訪市大和3-3-5                 |
|          | TEL (0266)58-8171(直通) FAX (0266)58-9917 |
| 東北       |                                         |
| ED仙台営業所  | 〒980-0013 宮城県仙台市青葉区花京院1-1-20 花京院スクエア19F |
|          | TEL (022)263-7975(代表) FAX (022)263-7990 |

インターネットによる電子デバイスのご紹介 <http://www.epson.co.jp/device/>