

Personal Computer  
**MZ-2000**

**OWNER'S MANUAL**



**SHARP**

Personal Computer  
**mz-2000**

# Owner's Manual

## ご 注意

- (1) 本書の内容は、改良のため変更することがあります。
- (2) 本書は、誤り、記載もれ等のないよう確認、チェックを行った上で作成しましたが、もしお気付きの点がありましたら、最寄りのシャープのサービス窓口（技術サービス部・サービスステーション・サービスブランチ）までご連絡願います。
- (3) 本書の内容の一部または全部を当社に無断で転載することは禁じられています。

MZ-2000は、シャープの多年にわたるエレクトロニクス技術の経験の粋により完成したコンピュータです。製品は出荷前に充分な検査を受けており規定通りの操作によって直ちに動作しますが、開梱時にはまず輸送中に損傷を受けていないかの点検を行なってください。万一、不都合な点が見つかった場合は直ちに購入された販売店に連絡してください。

なお、運用した結果生じる影響については責任を負いかねますのであらかじめご了承ください。

また、使用時には、特に次の各注意を守って、本機を末永くご愛用いただきますようお願い申し上げます。

- 本機はLSIなど精密な電子部品をたくさん使用しています。極端な高温下や低温下や激しい温度変化のあるところ、直射日光の当たるところ、あるいは振動やほこりの多い場所はさけてご使用願います。
- 電源コードを傷つけないようコードを通す場所に注意してください。また電源コードを抜き差しするときは、本体の電源を切り、電源プラグを持って行うようにしてください。
- 電源スイッチを瞬時間でON/OFFすると、コンピュータの初期動作が行えないことがあります。スイッチング操作は時間をおいて丁寧に、確実に行ってください。

その他の重要な使用上の注意については、本書巻末A.4にまとめて示されています。

## はじめに

この度はシャープパーソナルコンピュータMZ-2000をお買上げいただき誠にありがとうございました。

ご使用になる前に、マニュアルに記載された操作方法、注意事項をよく理解され、正しい操作によって本機をご使用されますようお願ひいたします。

パソコンコンピュータMZ-2000の付属マニュアルは次の2冊があります。

- Owner's Manual…………本書
- BASIC／MONITOR Manual

本書の第1章および第2章は、パソコンコンピュータMZ-2000の特徴と一般的な操作方法を解説していますので、はじめにお読みください。続く第3章は、MZ-2000のハードウェア拡張の方法についてまとめています。第4章では、MZ-2000内部のハードウェア構成を回路図と共に解説しており、ユーザの方々が自由なハードウェア拡張、ソフトウェア拡張を行なう場合の参考データとしています。

パソコンコンピュータMZ-2000のシステムソフトウェアは、全てファイル(カセットテープファイルまたはフロッピーディスクットファイル)によって供給されます。このコンピュータには、標準プログラミング言語BASICを使用するための、BASICインタープリタMZ-1Z001およびMONITOR MZ-1Z001Mが入っている1本のカセットテープが付属しており、その拡張された高度なBASICインターパリタによってMZ-2000の特徴を活かした、多様で自由なプログラミングを行うことができます。その他PASCAL言語や、システム拡張によってDISK BASIC、FDOS等のサポートシステムソフトウェアについても自由なソフトウェア対応ができ、より豊かなプログラミングの世界を拡げることができます。

BASIC言語の文法と、コマンド、ステートメント、ファンクションの各機能およびBASICインターパリタMZ-1Z001をカセットテープファイルからロードしたとき同時にロードされるMONITORプログラムMZ-1Z001Mの機能については、BASIC／MONITOR Manualを参照してください。

このマニュアルおよび他の1冊のマニュアルは「保証書」「サービス窓口一覧表」と共に必ず保存するようにしてください。

## 目 次

|                                       |    |
|---------------------------------------|----|
| ご 注意.....                             | 2  |
| はじめに.....                             | 3  |
| 第1章 パーソナルコンピュータ MZ-2000の世界.....       | 7  |
| 1.1 MZ-2000の特徴 .....                  | 8  |
| 1.1.1 メモリ構成の特徴.....                   | 9  |
| 1.1.2 MZ-2000のすぐれた操作性と処理能力.....       | 10 |
| 1.2 MZ-2000システムの拡張 .....              | 12 |
| 第2章 MZ-2000の操作方法 .....                | 13 |
| 2.1 イニシャルプログラムローディング.....             | 15 |
| 2.1.1 カセットテープファイル中のシステムソフトウェアの起動..... | 15 |
| 2.1.2 ディスクケットファイル中のシステムソフトウェアの起動..... | 16 |
| 2.1.3 IPL動作のフローチャート .....             | 17 |
| 2.2 キーボード .....                       | 19 |
| 2.2.1 メインキーボードの使い方 .....              | 20 |
| 2.2.2 数値入力キー .....                    | 27 |
| 2.2.3 デファイナブルファンクションキー .....          | 28 |
| 2.2.4 カーソル・コントロールキー .....             | 29 |
| 2.2.5 カセットテープデッキ・コントロールキー .....       | 30 |
| 2.3 CRTディスプレイコントロール .....             | 31 |
| 2.3.1 キャラクタディスプレイコントロール .....         | 31 |
| 2.3.2 グラフィックディスプレイコントロール .....        | 34 |
| 2.3.3 カラーグラフィックディスプレイコントロール .....     | 34 |
| 第3章 オプションデバイスのセッティング .....            | 35 |
| 3.1 グラフィックボードと拡張I/Oポートのセッティング .....   | 36 |
| 3.1.1 グラフィックボードのセッティング .....          | 38 |
| 3.1.2 拡張I/Oポートのセッティング .....           | 40 |
| 3.2 拡張I/Oポートへのオプションデバイスのセッティング .....  | 42 |
| 第4章 MZ-2000のハードウェア構成 .....            | 45 |
| 4.1 MZ-2000のシステムダイアグラム .....          | 46 |
| 4.2 メモリ構成 .....                       | 47 |
| 4.2.1 IPL動作時のメモリマップ .....             | 47 |

|       |                      |     |
|-------|----------------------|-----|
| 4.2.2 | ノーマル時のメモリマップ         | 48  |
| 4.2.3 | V-RAMアクセス時のメモリマップ    | 49  |
| 4.3   | 8255、8253およびPIOの各信号系 | 54  |
| 4.3.1 | 8255まわりの信号系          | 55  |
| 4.3.2 | 8253まわりの信号系          | 57  |
| 4.3.3 | PIOまわりの信号系           | 58  |
| 4.4   | MZ-2000回路図           | 62  |
| 付 錄   |                      | 77  |
| A.1   | Z80A CPUテクニカルデータ     | 78  |
| A.2   | Z80A PIOテクニカルデータ     | 131 |
| A.3   | MZ-2000の仕様           | 149 |
| A.4   | 取り扱い上の注意             | 151 |



# パーソナルコンピュータ MZ-2000の世界

コンピュータに何を実行させるか？どのように利用するのか？それは実際殆んど無限の可能性を秘めているにちがいありません。事実、現代社会の中のあらゆる場所でそれぞれの用途のためにコンピュータが使われています。

BASIC、PASCAL、FORTRAN、COBOLといった高級言語による複雑な科学技術計算、あらゆる事務処理、シミュレーション、統計処理が行なわれているし、各種のプラント、ネットワークでは、計測システム、自動制御システムを働かせています。またプログラム開発の現場では、オペレーティングシステム等によって、コンピュータのソフトウェアの世界そのものの開拓と研究が、コンピュータ自身を使って続けられています。そしてこの世界に、LSI技術の高度な発展によって誕生したマイクロプロセッサを用いたパーソナルコンピュータシステムが、急速にその役割を拡大して来ているのです。

あなたはコンピュータに何を実行させるか？という質問に対する答えは非常に様々なものになるはずです。したがってあなたが手にしたこのコンピュータは、まさにそうした広範な利用を可能にするコンピュータなのです。

この章では、パーソナルコンピュータMZ-2000の世界を、その特徴、ハードウェアの拡張、ソフトウェアの展望の順にまとめて解説します。

## 1.1 MZ-2000の特徴

MZ-2000の特徴をひとことで言うとコンパクトなボディーの中に、すぐれた操作性を実現していることと、様々なソフトウェアへの自由な対応とハードウェアの自由な拡張を徹底して追求していることだと言えます。

CPU (central processing unit) とメインメモリ装置は、コンピュータの中核に相当しますが、MZ 2000では、最もすぐれたマイクロプロセッサの1つであるZ80A<sup>†</sup>(シャープLH0080A) を使用し、メインメモリは64Kバイト即ちCPUのアドレスバスが直接ランダムアクセス可能な全アドレスを全てRAMで構成しています。従ってメインメモリ空間上には、固定されたプログラムやデータというものがなく、どのようなシステムソフトウェアも外部ファイルからローディングされ、それぞれのプログラムが自由に無駄なくメインメモリを使うことができます。

この中枢部のまわりに、キーボード、カセットテープデッキ等のI/Oデバイス、タイマ、イニシャル・プログラム・ローダなどがすぐれた操作性をもってまとめ上げられています。イニシャル・プログラム・ローダは、コンピュータの電源を入れた時に自動的にスタートし、カセットテープファイルやディスクケットファイルからプログラムを読み出し実行します。

コンソール（操作卓）上には、タイプライタ型メインキーボードをはじめとして、数値入力キー、デファイナブルファンクションキー、カーソルコントロールキーおよび前面パネルにカセットテープデッキコントロールキーが配置されキー入力モードによって、ワンタッチで各種のコントロールデータやデータ入力ができます。

ディスプレイ装置は、キャラクタ表示およびグラフィック表示で多彩なデータ表現が可能です。以下の幾つかのパラグラフに於て、これらの特徴をそれぞれ解説します。



図 1-1 パーソナルコンピュータ MZ-2000

<sup>†</sup>) Z80-CPUのクロック周波数の上限を倍の4MHzにしたタイプであり、高速処理が行われます。

### 1.1.1 メモリ構成の特徴

メインメモリ空間64Kバイトを全てRAM (random access memory) で構成するというやり方は、もともとコンピュータのメモリ構成として最も自然なものといえます。より大型のコンピュータ、たとえばミニコンピュータでは殆どがそうした構成をとっています。即ち、コンピュータに実行させるプログラムは、プログラムテキストも、プログラミング言語もすべてユーザの自由な選択に任せられるのです。

実際プログラミング言語には、BASIC言語、PASCAL言語等の各種の高級言語があり、目的によってアルゴリズムの記述に最適な言語を使い分ける必要があるし、機械語によるプログラムを行なう場合は、開発システムプログラムとしてのAssembler、Linker、ディスク装置を用いたオペレーティングシステムをコンピュータで動かせる要求が出てきます。こうしたソフトウェアの各様の使い方をあらかじめ想定した上で、このMZ-2000でも、上位のコンピュータが行っているのと同様のフリーなメインメモリ構成をとっているのです。

それでは、実行させるべきプログラムを選択し、メインメモリ上へ持つて来るにはどうすればよいのかというと、あなたは実行すべきプログラムの入っているカセットテープをカセットテープデッキにセットしておく、あるいはフロッピーディスク装置を周辺機器を持っているなら、システムソフトウェアのマスターディスクケットをセットしておくと、MZ-2000のIPLプログラムが電源ONと同時にスタートして、自動的にプログラムの初期ロードと起動を行ってくれます。この自動操作は、カセットテープを用いた場合平均2～3分で、フロッピーディスクケットを用いた場合わずか数秒で終了します。

IPLプログラムは、メインメモリとは別のアドレス空間上のROMにあり、電源ON時にだけCPUをコントロールします。



図 1-2 メインメモリとIPLプログラム

### 1.1.2 MZ-2000のすぐれた操作性と処理能力

パーソナルコンピュータ MZ-2000 の第 1 の特徴として、MZ-2000 が、1 つのプログラミング言語に固定されない汎用コンピュータであることを述べましたが、第 2 に、どのシステムソフトウェアを使う場合も、すぐれた操作性とハードウェアの処理能力によって効率のよいプログラミングや処理が行えるという特徴があります。

- 図 1-3 に、MZ-2000 のコンソール（操作卓）を示しています。タイプライタ型メインキーボードを中心にして、その右側に数値入力キー、上部に 10 個のデファイナブルファンクションキー、左右上下の矢印がついたカーソルコントロールキーがそれぞれグループ分けして配置されています。また、カセットテープコントロールキーは前面パネルに配置されています。

メインキーボードからはモードコントロールキーによるモード切り替えによって、アルファベットの大文字、小文字、大文字の反転文字、数字とその反転文字、カナ文字、シンボル記号、擬似グラフィックパターンの合計 225 の異った文字を直接キー入力することができます。アルファベット、数字、シンボル記号の並び、およびカナ文字の並びは、それぞれ ASCII 準拠、JIS 準拠の配列を探っています。

スペースバーの左側に、**TAB** キーが備えられており、任意の 15 個のタビュレーションを設定し活用することができます。

数値入力キーは、たくさんの数値を続けてキー入力する場合便利です。**0** ~ **9** のキーの他に、**00**、**+**、**-**、小数点 **.**、それにエントリキー **ENT** が備えられています。

デファイナブルファンクションキーは、文字通り、プログラマが自由にそのファンクションを決めることができます。インストラクションをワンタッチでコンピュータに与えたり、常時使用する特殊な定数、ストリングメッセージ等をそこに定義して置くことができます。各ファンクションキーのすぐ上には、写真のようにファンクションラベルがセットできるようになっています。

カーソルコントロールキーは、スクリーンエディションを行う際に用いられます。4 個のキーを独立した場所に置くことによってカーソル操作が扱い易くなっています。



図 1-3 MZ-2000 のコンソール

- カセットテープデッキはソフトウェアでコントロールされ、IPL操作、プログラムテキストのセーブ／ロード、データファイルのデータ書き込み／読み出し、巻き戻し、早送りをプログラムでコントロールできます。各システムソフトウェアのファイルサーチにはAPSS機能 (Automatic Program Search System) があり、早送りによって所望のファイルを早く見つけ出す働きがあります。カセットテープファイルによるデータ入出力は、2000ビット／秒と高速で、しかも高い信頼性を持って実行されます。前面パネルには、巻き戻し、早送り、ストップ、イジェクトをマニュアル操作するための4個のコントロールキーが用意されています。
- CRTディスプレイには、キャラクタ表示の他に、高分解能グラフィック表示を行うことができ、多彩なデータ表示を行なうことができます。  
キャラクタ表示は、1行の桁数を40キャラクタ／80キャラクタの2通りの表示が可能であり、項目数の多い表をディスプレイする場合など80キャラクタ表示が便利です。キャラクタ表示は、スクローリングエリアを任意に決めたり、画面全体の白／黒表示を反転させることもできます。  
オプションのグラフィックボードを本体内にセットすることによって320×200ドットまたは640×200ドットの高分解能グラフィック表示が可能です。BASICインターフリタMZ-1Z001をはじめ、サポートシステムソフトウェアにはグラフィックコントロール文 (SET文、LINE文、PATTERN文など) が備えられており、関数曲線の表示、デザインへの応用、漢字、仮名表示といった応用が容易にできます。  
さらに、カラーディスプレイを接続し、拡張用BASICインタプリタを使用することにより640×200ドットの高分解能カラーグラフィック表示が可能 (COLOR文、CCOLOR文などによりキャラクターの色、グラフィックの色、キャラクタ／グラフィックのプライオリティおよび白黒、カラー両画面へのデータの重ね合わせ等の指定が可能) です。また、この場合、本体側のCRTディスプレイも640×200ドット／両面となります。
- オーディオ回路を内蔵しており、音声出力をデータエントリベル、警告音、効果音などに用いることができます。BASIC、PASCAL等には、3オクターブの音域内の任意の楽曲を演奏する機能が用意されており、音楽の自動演奏ができます。また内蔵時計によってデジタル時計の働きをいつでも使うことができます。

## 1.2 MZ-2000システムの拡張

MZ-2000は、拡張周辺機器としてフロッピーディスクドライブ、プリンタをはじめとして、カラーディスプレイやマークカードリーダなどの豊かなペリフェラルファミリーをシステムに持っています。

フロッピーディスクドライブ MZ-80BF は、5.25インチ両面倍密度フロッピーディスクケットを媒体としたデュアルドライブユニットであり、ディスクベースのサポートソフトウェア、DISK BASIC、倍精度 DISK BASIC、フロッピーDOS、BASICコンパイラ、JIS漢字コード等を走らせながら、高速で、大容量データ処理を実行することができます。プリンタは、文書ファイル、伝票等の出力、プログラムテキストやCRTディスプレイ表示のハードコピーの出力、グラフィックイメージのプリント等の幅広いプリント能力を備えており、この基本システムは、各種のビジネス、プロジェクト分野で要求されるニーズの土台として充分応えられる能力を持っていることができます。

図1-4は、MZ-2000システムのペリフェラルファミリーの展望を示したものです。グラフィックディスプレイ用コントロールカードと拡張I/Oポートは、MZ-2000本体内に設置場所が用意され、その他のペリフェラルは、拡張I/Oポート上にインターフェイスカードをセッティングする形で簡単に接続できます。

拡張I/Oポートには、同時に合計4枚までインターフェイスカードをセットすることができます。



図に示されているように、各種の周辺装置の他に、標準インターフェイスである、RS-232Cシリアルインターフェイス、IEEE-488インターフェイス、8ビットパラレル・ユニバーサルインターフェイスがサポートされ、システムの拡張性を、より柔軟で幅広いものとしています。

# MZ-2000の操作方法

Chapter  
2

この章は、MZ-2000の操作方法をまとめています。次の順序で解説が行われています。

- MZ-2000本体の正面図と背面図
- イニシャルプログラムローディングの方法
- キーボードの操作
- ディスプレイコントロール

## ■ MZ-2000の正面図



図 2-1

## ■ MZ-2000の背面図



図 2-2

## 2.1 イニシャルプログラムローディング

MZ-2000はクリーンコンピュータと呼ばれているように、すべてのシステムソフトウェアをファイルによってサポートし、それらの外部ファイルによって各ソフトウェアを起動するシステムを探っています。「MZ-2000の特徴」の項で解説されているように、その際必要となるシステムソフトウェアのローディングは、補助プログラムである IPL (initial program loader) が実行します。この項では、このIPLの動作と一般的な操作方法について解説を行います。

MZ-2000を使用するには、先ず電源スイッチをONにしますが、IPLはそれと同時に動作を開始し、自動的に目的ファイルのイニシャルプログラムローディングを実行することになります。IPLがカセットテープファイルまたはディスクケットファイルからシステムソフトウェアのローディングを終了すると、ロードされたソフトウェアにコントロールが移され、プログラムの起動が完了することになります。従ってプログラマがあらかじめ外部ファイルを所定の入力装置にセットしておけば、MZ-2000の電源をONにするだけで簡単にシステムソフトウェアの起動が行えるようになっているのです。

以下、カセットテープファイル中のシステムソフトウェアの起動と、ディスクケットファイル中のシステムソフトウェアの起動について、それぞれの操作方法を解説します。

### 2.1.1 カセットテープファイル中のシステムソフトウェアの起動

カセットテープファイル中のシステムソフトウェア、たとえばMZ-2000に付属しているBASICインタープリタMZ-1Z001(MONITOR MZ-1Z001Mと同じファイル中に含む)を起動する方法を見てみることにします。

MZ-2000の電源をONにするとIPLプログラムがスタートし、あらかじめカセットテープデッキにテープがセットされていれば、続けて自動的にローディングを開始します。

セットされていない場合は、カセットデッキの蓋が開き、

Make ready CMT

とメッセージが表示されます。ここで、BASIC テープをデッキに挿入して蓋を閉めると、続けて自動的に BASIC テープのローディングが実行されます。

ローディングをスタートすると、最初にシステムソフトウェアのサーチを行い、次のメッセージを表示します。

IPL is looking for a program

BASICをサーチしたら、BASIC(およびMONITOR)をメインメモリへロードし、その時、次のような表示が行われます。

IPL is loading BASIC MZ-1Z001

図2-3は、BASICテープのイニシャルローディングを終了して、BASICインターパリタMZ-1Z001が起動した状態を示しています。



図 2-3 BASIC インタープリタ MZ-1Z001 が起動したことを示すメッセージ

MONITORプログラムのバージョンナンバーは、MZ-1Z001M、BASICインタープリタはMZ-1Z001、BASICテキストエリアのサイズは、43500バイトであること（および、ソフトウェアの権利がシャープ株式会社にあること）、そしてカーソル点滅によって、システムコントロールがBASICコマンドレベルにあることが示されています。（BASICテープは2分程度でローディングを終了します。）

カセットテープは IPL動作終了時に自動的に巻き戻されます。

〔注意〕

イニシャルプログラムローディングは、フロッピーディスク装置を接続している場合はディスクケットファイル中のシステムソフトウェアの起動が優先となり、その場合、カセットテープ中のシステムソフトウェアの起動は上記の操作とは異なる手順が必要となります。2.1.3節の一般の操作手順を参照してください。

### 2.1.2 ディスクケットファイル中のシステムソフトウェアの起動

ディスクケットファイル中のシステムソフトウェアを起動するには、勿論フロッピーディスクドライブが正しく接続されていなければなりません。

フロッピーディスクドライブの電源をONにした後システムソフトウェア、DISK BASIC インタープリタ、倍精度DISK BASIC インタープリタ、FDOS 等のマスターディスクケットを、ドライブナンバ1番のドライブに正しくセットします。その状態で MZ-2000の電源をONにすると、数秒間で各システムソフトウェアが起動されます。

### 2.1.3 IPL動作のフローチャート

カセットテープファイル、ディスクケットファイルのいずれのファイル中にあるシステムソフトウェアも前記の簡単な操作によって、イニシャルプログラムローディングおよび起動が行われますが、この項ではIPL動作の全体を示すフローチャートに基づいて、特殊なブート操作方法やIPLのメッセージ表示、コントロールの分岐等について詳しく解説を行っています。たとえば、フロッピーディスクドライブを接続しているながら、カセットテープ上のシステムソフトウェアを起動する場合や、ディスクドライブ1番以外のドライブによってロードする場合やエラー発生時の処理等について解説されます。

図2-4はIPL動作の概要をフローチャートに示したものです。前の2項で解説した最もシンプルな自動的なローディング手順は、図の太線に沿った流れによっています。ただし分歧点の条件によってはマニュアル操作が必要なこともあります。



図 2-4 IPL動作フローチャート

フロッピーディスクドライブを接続していながら（即ち、フロッピーディスク用インターフェイスカードを MZ-2000 の I/O ポートに挿入している状態）カセットテープからシステムソフトウェアを読み出すには、**C** キーを押しながら MZ-2000 の電源を ON にします。（コントロールの流れは  $\alpha$  を通過します。）

**C** キーを押さずに MZ-2000 の電源を ON にすると、ドライブ 1 番中にマスターディスクケットがセットされている場合、それぞれが起動しますが、ドライブ 1 番が無効状態（たとえば電源が OFF かドライブの蓋があいているかディスクケットがセットされていない状態）のとき分岐点  $\beta$  でカセットテープかディスクケットかを訊いてきますので、**C** をそこでキー入力することによってもカセットテープからの IPL 動作を行うことができます。

ドライブナンバ 1 以外のドライブによって IPL 動作を実行させるには、ドライブナンバ 1 番を無効状態として（ディスクケットを入れておかないかフタを開けておくか、或いはドライブの電源を OFF にしておく） IPL をスタートし、分岐点  $\beta$  に流れを移します。

そこでシステムはあらためて、カセットテープかディスクケットかを訊いてきますので **F**（フロッピーディスクケット）をキー入力します。続いてイニシャルローディングするドライブ番号を訊いてきますので、該当ナンバをキー入力します。

カセットテープの巻き戻しを行ってから IPL 動作を行う必要のある時は、カセットテープによる IPL 動作をスタートし、続いて **BREAK** キーを押します。**BREAK** キーを押すと、分岐点  $\beta$  へコントロールが移り、自動的に巻き戻しが実行されます。巻き戻しが終ったら **C** をキー入力します。巻き戻しの途中で **C** をキー入力すると、その場所からファイルサーチが行われます。

早送りをする必要のあるときは、カセットテープによる IPL 動作をブレークすると自動的に巻き戻しが行われますので、カセットコントロールの **STOP** キーによってそれを止め、逆に **FF** キーを押して早送りを行います。早送りした後は、**STOP** キーによって止め、**C** をキー入力すると、その場所からファイルサーチが行われます。

IPL によるシステムソフトウェアの起動が実行された後の動作は、各システムソフトウェアのプログラムに従うので、それぞれのシステムソフトウェアのマニュアルを参照してください。

MONITOR や FDOS 等の開発プログラムによってユーザが作成したシステムソフトウェアを IPL で起動することも勿論できます。

IPL はカセットテープファイルをファイル名によってサーチする働きを持っておらず、最初に見つかったシステムソフトウェア（即ちファイルモードが O B J であるもの）をローディングします。たとえば BTX（BASIC テキストファイル）等がサーチされた場合は、その場で "File mode error" が発生します。

IPL 動作時のメモリマップ等は、第 4 章の技術資料に、また IPL プログラムの全アセンブリリストは別冊の BASIC / MONITOR Manual に示されています。

特殊なイニシャルプログラムローディング方法として、I/O ポート上のメモリボードからのシステムソフトウェアの起動があります。たとえば、BASIC インターフェース等のシステムプログラムを専用に常時使用する場合、IPL を瞬時に行うため、それを ROM カード上に置いておき、IPL によってメインメモリへ高速にブロック転送するという方法です。前記の解説およびフローチャートには示していませんが、スラッシュ "／" をキー入力することにより、この動作がシステムの状態によってスタートします。

## 2.2 キーボード

この節は MZ-2000 のコンソール（操作卓）上の各キーの機能と使い方を解説します。コンソール上には、図 2-5 に示すように 4 つのキーのグループがあります。



メイン・キーボード

図 2-5 コンソール上のキー配列と 4 つのグループ

ASCII 準処メインキーボードは、タイプライターのキーボードに似ており、文字の入力用キーと、キャリッジリターン、ブレークなどのコントロール用のキーと、カナ、グラフィックなどのモードコントロール用のキーとからなっています。

数値入力用キーには、数字と+記号、小数点、ENT（入力）キーが電卓と同じようにまとめられています。

コンソール上部には、左側に青い色の10個のデファイナブル・ファンクションキーがあります。ファンクションキーの働きは、プログラマが任意に決めることができます。

中央の黄色の4個のキーは、カソール移動専用のキーです。

カセットテープデッキの下にある4個のキーは、カセットテープデッキをワンタッチでコントロールするためのキーとなっています。

### 2.2.1 メインキーボードの使い方

メインキーボードは、幾つかの点を除いて ASCII 準拠タイプライタキーボードに倣ったキー配列をとっています。相違点は、以下の項で説明されるように、キー入力に幾つかの入力モードがあること、それにコントロール用特殊キーが備わっていることです。図 2-6 はコンソール上に示すメインキーボードと、そのコントロールキーを示しています。



図 2-6 メインキーボードとそのコントロールキー

コントロール用特殊キー以外の通常のキーには、各キーに 3 個か 4 個のキャラクタが描かれています。そしてそれらはコントロール用特殊キーによる入力モードの設定状態に従ってそれぞれキー入力されることになります。

キー入力モードには次の 3 つがあります。

- [1] ノーマルモード ..... 各キーの上面に描かれた ASCII 準拠のキャラクタを入力するモード。アルファベットキーは、大文字／小文字（シフトポジション）が入力されます。
- [2] グラフィックモード ..... **GRPH** キーによって設定され、作表のためのパターンやハート、スペードなどのキーの前面右側に描かれているグラフィックパターンを入力します。
- [3] カナモード ..... **カナ** キーによって設定され、キーの前面左側に描かれている片仮名をキー入力するモードです。

1 つのキーを例にとって、キー入力モードが異なる時、どのようなキャラクタが入力されるか見ることにしましょう。たとえば Z というキーは、図 2-7 のように全部で 6 種類のキャラクタの入力ができます。



図 2-7 **Z** のキーによって入力される 6 つのキャラクタ

次に、コントロール用特殊キーの機能を解説します。

### SHIFT

タイプライターのシフトキーと同様に各キーのシフトポジションにあるキャラクタをキー入力する補助キーです。ノーマルモード時には、アルファベットキーについてはその小文字を、その他のキーは上部に描かれているキャラクタを入力します。グラフィックモード時には、アルファベットキーと数字キーについてはその反転文字を入力します。カナモードの場合は、カナ小文字"ア"、"ヨ"などが"ア"、"ヨ"等のキーから入力されます。

BASIC には CHANGE 文が用意されており、この文の実行によってアルファベットキー26文字の大文字／小文字のシフトポジションを逆にすることができます。

### CR

キャリッジ・リターンキー。1行のデータ入力を行うキーです。**CR** キーを押すとカーソルは次の行の先頭に移ります。数値入力用キーにある **ENT** キーも **CR** キーと同じ機能を持っています。(CR : carriage return)

### CLR HOME

HOME は、カーソルを CRT ディスプレイの左上隅に移します。

CLR は、CRT ディスプレイのキャラクタ表示をクリアして、カーソルホームを行います。(CLR : clear)

### INST DEL

DEL は、カーソルの左隣りの1キャラクタを消し、カーソル位置以降の1行分の文字列を左に1文字分詰める働きがあります。

(DEL : delete)

INST は、カーソル位置にスペース1個を挿入し、カーソル位置以降に続く1行分の文字列を1文字右へ送る働きがあります。

(INST : insert)

### BREAK

ブレークコードを入力します。BASIC プログラムの実行中、カセットテープデッキのコントロール中等にこのキーを押すとプログラムやコントロールを中断することができます。

### SFT LOCK

シフトポジションをロックするコントロールキーです。このキーを押すとシフトポジションがロックされ、もう一度このキーを押すか **CR** キー、他のモード切替えキーが押されてキャンセルされるまでシフトポジションのキャラクタがキー入力されます。

(SFT LOCK : shift lock)

### GRPH

メインキー ボードをグラフィックモードにするモード切替えキーです。このキーを押すとグラフィックモードになります。グラフィックモードでは、各キーの前面右側に描いているグラフィックハターンがキー入力されます。このモードで **SHIFT** キーを押しながら英数字キーを押すと、英数字の反転文字が入力されます。もう一度このキーを押すか **CR** キー、他のモード切り替えキーの入力によって解除されます。

(GRPH : graphic)

**カナ**

メインキーボードをカナモードにするモード切り替えキーです。このキーを押すとカナモードになります。カナモードでは、各キーの前面左側に描いているカナ文字が入力されます。このモードで **SHIFT** キーを押しながら、"ツ" "ヤ" "ア"などのキーを押すと、カナ小文字"ツ"、"ヤ"、"ア"などが入力されます。もう一度このキーを押すか **CR** キー、他のモード切り替えキーの入力によってカナモードはキャンセルされます。

なお、CRTディスプレイのカーソルは、ノーマルモードではチェックマーク、その他のモードではマル●が点滅します。

**TAB**

タビュレーションコントロールキー。キー入力の際のタビュレーション操作を行うためのキーです。タビュレーションの設定は、各モニタプログラムのタビュレーションデータエリアを決めることによって行います。

## 〔1〕 ノーマルモード



図 2-8

ノーマルモードは、BASIC インターフリタやその他のシステムソフトウェアを起動した時のメインキーボードの最初の状態であり、**SHIFT** キーを押したシフトポジションと共にアルファベット大文字／小文字、数字、クオーテーションマーク、ドルマーク "\$ "、アステリスク "\*" 等のASCII標準キャラクタを入力するキーモードです。

たとえばアルファベット大文字の " B " (図2-8を参照) をキー入力するには **B** キーを押します。普通のタイプライタでは、大文字をタイプする場合 **SHIFT** キーを使用しますが、コンピュータプログラミングでは、各種コマンド、ステートメントがアルファベット大文字で表記するので、小文字の方をシフトポジションに置いているのです。(但し前記の BASIC インターフリタの大文字／小文字を逆にする CHANGE 文がそうであるように、ソフトウェアコントロールによって逆にさせることもできます。)

## 〔2〕 グラフィックモード



図 2-9 グラフィックキャラクタを持つキー

グラフィックモード、即ち [GRPH] キーを押した状態のキー入力モードでは、図 2-9 でアミを施した29個のキーについては、それぞれが持つグラフィックパターン（擬似グラフィックパターン）を入力するためのものです。

たとえば、このモードで、[B] キーを押すと、グラフィックパターン "♣" がキー入力されるし、BASIC インターフェリタのシステム定数 "π" (円周率) をキー入力するには、メインキーボードをグラフィックモードにして [;] キーを押せばよい、ということになります。

図 2-10 は、グラフィックパターンを用いて表を CRT ディスプレイ上に表示させた例です。



図 2-10 グラフィックモードの表の作成例

グラフィックモードで、**SHIFT** キーを使用する場合は、図2-11に示す36個のキー、即ち英字の大文字と数字のキーについてそれぞれの反転文字をキー入力することができます。



図 2-11 反転キャラクタを持つキー

たとえば、**B** キーについては、**SHIFT** キーを押しながら押すと、" **B** " 即ち " **B** " の反転文字が入力されます。反転文字は、表のタイトル等によく使われます。

図2-12は、図2-10で作った表の枠に反転文字を使って各項目を記入した例です。

図 2-12 反転文字を使って項目を表示した例

## 〔3〕 カナ入力モード



図 2-13 カナ文字の入力キーとカナ小文字の入力キー(濃いアミのキー)

カナ入力は、**カナ** キーを押すことによって設定され、図 2-13でアミを施した48個のキー（即ちコントロールキー以外の全部のキー）について、それぞれが持っているカナ文字を入力するためのモードです。それぞれのカナ文字は、キーの前面左側に白で示されています。ただし **CLR HOME** キーの左の2つのキーは、濁点と半濁点を示しています。

このモードでキーを押すと、アミを施したキーについては、それぞれが持っているカナ文字が入力されます。たとえば **Z** キーは、カナ文字“ツ”を持っているので、このキーを押すと、“ツ”が入力されます。

**SHIFT** キーを用いるとカナ小文字“ツ”が入力されます。即ち“ツ”的他“ア”、“イ”、“ウ”、“エ”、“オ”、“ヤ”、“ユ”、“ヨ”的各カナ文字は、**SHIFT** キーを押しているとそれぞれカナ小文字が入力されます。

おなじく“ル”、“ム”、“。”は、**SHIFT** キーを押しているとそれぞれ“。”、“』”、“『”の記号が入力されます。

図 2-14はカナ文字によって表の項目を記入した例です。

| ヒヨウ.33 サイコ ヒンモク |     |       |      |
|-----------------|-----|-------|------|
|                 | タンカ | スウリョウ | ソウカク |
| エンピツ            | ■   |       |      |
| ペン              |     |       |      |
| ノート             |     |       |      |
| ケシゴム            |     |       |      |
| インク             |     |       |      |
| フウトウ            |     |       |      |
| ヨウジ             |     |       |      |
| カッター            |     |       |      |
| モリタシ            |     |       |      |
| 1981年 4カツ 10カ   |     |       |      |

図 2-14 カナ文字を使って項目を表示した例

## 2.2.2 数値入力



図 2-15 数値入力キー

メインキーボードの右側にまとめられたキーグループを数値入力キーと呼びます。数値入力キーには、10個の数字に加えて0を2つ並べた **00** キー、それに **+** **-** **ENT** キーが置かれています。

**■** **+** **-** キーはメインキーボード上にもあるし、**ENT** キーすなわちエントリーキーは、メインキーボード上の **CR** キーと全く同じ機能を果たします。<sup>†)</sup> にもかかわらずこれらのキーを数値入力キーとしてまとめた（グループとした）のは、たくさんの数値データを入力する場合の便宜を圖っているからです。<sup>†)</sup> 実際、多くの数値処理応用プログラムでそうした要求が頻繁に生じるにちがいありません。

**00** キーを1回押すと、**0** キーを2回押した時のように00が入力されます。

**5** キーのキートップの中央には、小さな突起がついています。数値入力キーから目を離して操作する時の案内役になります。

数値入力キー上のキーは、メインキーボードのキー入力モードや **SHIFT** キー操作とは関係がありません。

<sup>†)</sup> ただしキースキャニングにおけるストローブ信号は異ります。従って、機械語プログラムで、数値入力キー上のキーとメインキーボード上の同じキーを区別することは可能ですが。(ただし **CR** と **ENT** は区別できません)。表4-5を参照のこと。

### 2.2.3 デファインブルファンクションキー



図 2-16

メインキーボードの上に並んでいるF1からF10までの名前のついた青い色の10個のキーを、デファインブルファンクションキーと呼びます。

これらのキーは、各システムソフトウェアの起動時に定義されますが、自由にこれらのキーの機能を再定義して使うことができます。たとえばBASIC MZ-1Z001では、DEF KEYステートメントによってデファインブルファンクションキーの定義を行います。BASIC コマンドRUNを、ファンクションキー1番に定義するには次のステートメントを実行します。

```
DEF KEY(1)=RUN
```

一度このステートメントを実行すると、新たに定義し直さない限りデファインブルファンクションキー1番は、RUNコマンドと同じ機能を持つことになります。即ち、直接モードでファンクションキー1番を押すと"RUN"の表示が現われます。続いて CR キーを押すとプログラムが実行されます。更に、RUN コマンドプラス CR キーをまとめて定義することができます。それには次のステートメントを実行します。

```
DEF KEY(1)=RUN ↴
```

ここで"↓"という記号は CR キーを押すのと同じ機能を表し SFT LOCK キーと GRPH キーを同時に押すことによって入力することができます。こうして定義しておけばファンクションキー1番を1回押すだけでプログラムが実行されます。ファンクションキーの定義内容はBASICでは KLIST コマンドによって調べることができます。デファインブルファンクションキーには、RUN コマンドのような直接実行命令を定義しておくと便利ですが、その他の任意の数字データやストリングデータを自由に定義することができます。

#### ■ファンクションキーラベルのセット

付属のキーラベルをファンクションキーの後方にあるラベル格納場所にセットしておくと便利です。

透明のラベルカバーを後方へ引き出し各ファンクションキーに対応するラベルをセットしてください。



## 2.2.4 カーソル・コントロールキー

デファイナブル・ファンクションキーの右側の、矢印記号のある4個の黄色のキーはCRTディスプレイ上のカーソルを移動させるコントロールキーです。



図 2-17 カーソル・コントロールキー

左、右、上、下の各方向へそれぞれカーソルを移動させます。各システムプログラムのスクリーンエディションの際に用います。

BASIC インタープリタでは、メインキーボードの **SHIFT** キーを押しながらカーソル・コントロールキーを押すとオート・リピートが行われスクリーンの離れた所へ早くカーソルを移動させるのに便利です。(システムソフトウェアによっては **SHIFT** キーを押さなくともカーソル・コントロールキーを押し続ける間オート・リピートするものもあります。)

## 2.2.5 カセットテープデッキ・コントロールキー

カセットテープデッキの下にある4個のキーはカセットテープデッキのコントロールキーです。



図2-18 カセットテープデッキ・コントロールキー

これらのキーは、カセットテープデッキに直接つながったコントロールキーであり、他のキーとはメカニズムが異っています。<sup>†)</sup>

- |  |                                     |
|--|-------------------------------------|
|  | .....カセットテープの巻き戻しを行う (LEDランプが点灯します) |
|  | .....カセットテープの早送りを行う (LEDランプが点灯します)  |
|  | .....停止する                           |
|  | .....カセットの出し入れのためのイジェクトを行う          |

これらのコントロールはコンピュータの動作モードとは関係なく実行できます。

読み出し／書き込み時に応するLEDランプ (READ…緑色、WRITE…赤色) が点灯します。

テープカウンタの右横のボタンはカウントリセット用です。

カセットテープへのデータの書き込みや、データの読み出しこそはソフトウェアによるオートマティックコントロールになっています。

BASIC インターパリタには、プログラムテキストの書き込み／読み出しこそは SAVE、LOAD コマンド、データファイルの書き込み／読み出しこそは PRINT/T、INPUT/T ステートメントによって自動的に行われます。また、各システムソフトウェアには必ず書き込み／読み出しこそはインストラクションが備わっています。

<sup>†)</sup> 即ち、他のキーは、PIO によるキースキャニング (4.3.3 節を参照のこと) によってキー入力が検知されソフトウェアによって処理が行われますが、カセットテープデッキ・コントロールキーは、カセットデッキのモータ制御、イジェクト機構の制御をダイレクトに行います。

## 2.3 CRTディスプレイコントロール

MZ-2000には、3つのディスプレイコントロールシステムがあります。キャラクタディスプレイコントロールとグラフィックディスプレイコントロールさらにカラーグラフィックディスプレイコントロールです。キャラクタディスプレイコントロールでは、アルファベット大文字、小文字、反転文字、数字、カナ文字、擬似グラフィックパターン等をキャラクタジェネレータを用いてCRTディスプレイに表示させます。グラフィックディスプレイコントロールでは、オプションのグラフィックボードを用いて、320×200ドット／画面または640×200ドット／画面で任意のグラフィック表示ができます。上記のグラフィックボードに、グラフィックメモリページ2、3を装備後カラーディスプレイを接続し、拡張用BASICを使用することにより、カラーグラフィック表示ができます。

### 2.3.1 キャラクタディスプレイコントロール

キャラクタ表示は、キャラクタコード(ASCIIコード)によってキャラクタフォントをキャラクタジェネレータから呼び出してCRTディスプレイ上へ表示されます。図2-20には、MZ-2000が持っているすべてのキャラクタのフォントをASCIIコードに対応させて示しています。これらのキャラクタは、前節で述べたように各モードによってメインキーボードから直接キー入力することができます。(ただしチェックマーク■、ベタ■およびマル●を除きます。)

CRTディスプレイのキャラクタ表示には、80キャラクタ表示モードと40キャラクタ表示モードとがあります。各モードでのキャラクタフォント構成は同じですが、80キャラクタ表示モードでは、1文字の大きさが左右に縮少されます。また画面全体の白／黒反転機構があり、1つのキャラクタ、たとえば"A"は、図2-19に示すような4種類の表示が行れます。



図 2-19 キャラクタ "A" の4種類の表示例

| L \ U | 0   | 1 | 2  | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
|-------|-----|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0     | □   | □ | □  | □ | □ | □ | □ | □ | □ | □ | □ | □ | □ | □ | □ | □ |
| 1     | !   | ！ | 1  | 1 | 2 | 2 | 3 | 3 | 4 | 4 | 5 | 5 | 6 | 6 | 7 | 7 |
| 2     | “   | ” | 2  | 2 | 3 | 3 | 4 | 4 | 5 | 5 | 6 | 6 | 7 | 7 | 8 | 8 |
| 3     | H   | H | 3  | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 |
| 4     | ＄   | 4 | 4  | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 |
| 5     | ×   | 5 | 5  | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 |
| 6     | ＆   | 6 | 6  | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 |
| 7     | ‘   | 7 | 7  | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 |
| 8     | （   | 8 | 8  | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 |
| 9     | ）   | 9 | 9  | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 |
| A     | ＊   | ： | ：J | J | J | J | J | J | J | J | J | J | J | J | J | J |
| B     | +   | ； | K  | K | K | K | K | K | K | K | K | K | K | K | K | K |
| C     | :   | ＜ | L  | N | I | I | I | I | I | I | I | I | I | I | I | I |
| D     | ……  | ＝ | M  | J | M | M | M | M | M | M | M | M | M | M | M | M |
| E     | ■■■ | ： | N  | N | N | N | N | N | N | N | N | N | N | N | N | N |
| F     | ■■■ | ／ | ？  | ？ | ○ | ○ | ○ | ○ | ○ | ○ | ○ | ○ | ○ | ○ | ○ | ○ |

図 2-20 キャラクタフォントによるASCIIコード表

U…………上位4ビット

L…………下位4ビット

|   | 上位 4 ビット     |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|---|--------------|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|   | 0            | 1 | 2  | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |   |
| 0 | NULL         |   | O  | @ | P | 、 | p |   |   | V | Y | タ | ミ | Z | O |   |   |
| 1 | ↓            |   | !  | I | A | Q | a | q |   | ¥ | 。 | ア | チ | ム | A | I |   |
| 2 | ↑            |   | "  | 2 | B | R | b | r |   | U | 「 | イ | ツ | メ | B | 2 |   |
| 3 | →            |   | #  | 3 | C | S | c | s |   | → | ○ | 」 | ウ | テ | モ | C | 3 |
| 4 | ←            |   | \$ | 4 | D | T | d | t |   | ← | ○ | W | エ | ト | ヤ | D | 4 |
| 5 | HOME         |   | %  | 5 | E | U | e | u |   | ♠ | X | オ | ナ | ユ | E | 5 |   |
| 6 | CLR          |   | &  | 6 | F | V | f | v |   | ♥ | ヲ | カ | ニ | ヨ | F | 6 |   |
| 7 | DEL          |   | '  | 7 | G | W | g | w |   | ♦ | ア | キ | ヌ | ラ | G | 7 |   |
| 8 | INST         |   | (  | 8 | H | X | h | x |   | ♣ | イ | ク | ネ | リ | H | 8 |   |
| 9 | GRPH         |   | )  | 9 | I | Y | i | y |   | £ | ウ | ケ | ノ | ル | I | 9 |   |
| A | SET LOCK     |   | *  | : | J | Z | j | z |   | £ | エ | コ | ハ | レ | J | P |   |
| B |              |   | +  | ; | K | 〔 | k | { |   | £ | オ | サ | ヒ | ロ | K | Q |   |
| C | カナ           |   | ,  | < | L | \ | l | । |   | £ | ヤ | シ | フ | ワ | L | R |   |
| D |              |   | -  | = | M | 〕 | m | } |   | £ | ユ | ス | ヘ | ン | M | S |   |
| E | L<br>SCRIPT  |   | .  | > | N | ^ | n | ~ |   | £ | ヨ | セ | ホ | 』 | N | T |   |
| F | カナ<br>CANCEL |   | /  | ? | O | — | o | 』 |   | £ | ツ | ソ | マ | ° | O | π |   |

図 2-21 ASCIIコード表：キャラクタおよびコントロールコード

### 2.3.2 グラフィックディスプレイコントロール

図2-22は、グラフィックディスプレイコントロールをBASICインターパリタによって行った例を示しています。左は、3次元曲線をSET文によって描いたもの、右は、ドイツ文字をPATTERN文によって表示させたものです。BASICによるコントロールの詳細は、BASIC/MONITOR Manualを参照してください。



図 2-22

### 2.3.3 カラーグラフィックディスプレイコントロール

キャラクタ、グラフィックデータ、およびバックランド（背景）に対して、それぞれ表2-1のごとく、計8色の中から自由に色の指定ができます。

#### ■ キャラクタのカラー表示

カラーディスプレイ画面全体のキャラクタに対して色を指定できます。ただし、キャラクタ単位での色指定は行えません。

プライオリティ（キャラクタとグラフィックデータをカラーディスプレイ画面上の同じ場所に表示する際、どちらの色を優先して表示するかを決めます。）の指定ができます。

出力ポート：\$F5

| *出力データ | 指定色 |
|--------|-----|
| 0 (8)  | 黒   |
| 1 (9)  | 青   |
| 2 (10) | 赤   |
| 3 (11) | 紫   |
| 4 (12) | 緑   |
| 5 (13) | 水色  |
| 6 (14) | 黄   |
| 7 (15) | 白   |

\*ポート \$F5, \$F4への出力データ

表 2-1

#### ■ グラフィックのカラー表示

1ドット単位で色の指定ができます。また、カラーディスプレイ上のグラフィックデータを白黒ディスプレイ画面へ重ね合わせて表示するか否かの指定ができます。

出力ポート：\$F7, \$F6

#### ■ バックランドのカラー表示

カラーディスプレイ画面のバックランドの色を指定できます。使用例として、カラーディスプレイ画面上にキャラクタを表示させずにグラフィックデータのみの表示とする場合、キャラクタとバックランドの色を同色にし、プライオリティをグラフィックに指定します。

出力ポート：\$F4

詳細については、P.52～P.53 の出力ポート \$F7～\$F4 の項を参照ください。

## オプションデバイスの セッティング

この章では、MZ-2000の拡張オプションデバイスのセッティングの概要を解説しています。

オプションデバイスのうち次のものは、MZ-2000のメインキャビネット内にセッティングされ、本章の最初に取り付け方法が示されます。

MZ-1R01 グラフィックボード：コントローラ（ページ 1 … 16Kバイト  
RAM含む）

MZ-1R02 グラフィックメモリ：16Kバイト RAM（ページ 2 またはペー  
ジ 3）

MZ-1U01 拡張I/Oポートユニット

他のオプションデバイスはすべてMZ-1U01 拡張I/Oポートに各I/Oカードをセットし入出力機器とのインターフェイスをとります。本章の後半はその概要を示しています。取り扱いの詳細については各周辺機器のオペレーションマニュアルによってください。

### 3.1 グラフィックボードと拡張I/Oポートのセッティング

グラフィックボード MZ-1R01、グラフィックメモリ MZ-1R02 および拡張I/Oポート MZ-1U01 は、MZ-2000本体内の定められた取り付け場所に、正しくセッティングしなければなりません。

図3-1は、このオプションデバイスと、MZ-2000本体内で、それをセットすべき場所を示しています。



MZ-1R01



MZ-1U01



図 3-1 MZ-1R01、MZ-1U01とそのセッティング場所

これらのオプションデバイスをセットするために、はじめにMZ-2000の上部（CRTディスプレイ＋カセットテープデッキ部）を持ち上げなくてはなりません。その手順を次に示します。

- (1) MZ-2000の電源スイッチをOFFにし、電源プラグを外します。
- (2) MZ-2000 キーボード部下側の固定ビス 2本を図3-1に示すように外します。

- (3) 固定ビスを外したら、本体上部を手前より静かに持ち上げ、図3-2に示すように支持アームを本体上部の底面から引き出し、下部のキャビネットに付けられているホールに入れて支えます。



図 3-2 支持アームで支える

**[注 意]** 本体上部を持ち上げた状態で電源を入れてはなりません。電源を入れたまま接続操作を行うと回路部品を壊したり感電する危険性があります。

また、ビス等の金属類を本体内に落としたままにすると故障の原因となるので充分な注意が必要です。

### 3.1.1 グラフィックボードのセッティング

#### 3.1.1.a グラフィックメモリのセッティング

グラフィックボード MZ-1R01 には、グラフィックメモリ／ページ 1 が標準装備されています。このボードにページ 2、3（いずれも機種名は MZ-1R02）を拡張する場合は、グラフィックボード内の所定の位置に正しくセッティングをしなくてはなりません。

図 3-3 にグラフィックボード内のグラフィックメモリ／ページ 2、3 のセッティング場所を示します。



図 3-3

グラフィックメモリ (D-RAM) IC の装着方向は、すでに装着されているページ 1 のメモリ IC と同方向となるように IC ソケットに挿入してください。（逆方向に装着しますと、IC が破壊しますので充分注意して行ってください。）

ページ 2、ページ 3 ともメモリ IC を 8 個とも装着します。

グラフィックメモリを拡張しない場合（ページ 1 のみで使用）は、この手順は不要です。

\* VR1：カラーディスプレイ画面の水平方向のポジション設定用の調整ボリューム

\* VR2：カラーディスプレイ画面の垂直方向のポジション設定用の調整ボリューム

上記 2 個のボリュームは、カラーディスプレイ MZ-1D01 用に調整されていますので、このディスプレイ以外を使用する場合に限り再調整ください。

### 3.1.1.b グラフィックボードのセッティング

グラフィックボードは、CPUボードの真上に装着します。(図3-4) まずグラフィックボードをグラフィックボード固定用リブに挿入し(①)、つぎにグラフィックボードのコネクタAをCPUボードのコネクタBに差し込みます(②)。最後にカラーディスプレイ用DINコネクタからきているケーブルコネクタCをグラフィックボード上のコネクタD (6pin) に差し込みます(③)。これでグラフィックボードのセッティングは終了です。



図 3-4

なお参考のため、MZ-2000本体背面よりみた、カラーディスプレイ(MZ-1D01)用DIN端子の信号配置を下図に示します。



[カラーディスプレイ用DIN端子]

### 3.1.2 拡張I/Oポートのセッティング

MZ-2000の拡張I/Oポート MZ-1U01は、前掲の図 3-1 に示されている通り、MZ-2000本体内の一番後部のスペースにセッティングを行います。この拡張I/Oポートのセッティング手順を図 3-5、図 3-6 に示します。



図 3-5

- (1) MZ-2000本体後部にあるI/Oポート取付部のウシロブタの両サイドにある2本のビス①を外し、本体よりウシロブタを取り外します。
- (2) この開口部へ拡張I/Oポート MZ-1U01を図の向きに挿入します。この際、I/Oポートの電源用コネクタFを本体内部の電源ユニットへ接続できるように、図に示す開口部の奥の窓へ通しておきます。
- (3) 開口部の奥にあるCPUボードの端子部とI/OポートのマザーボードにあるコネクタEを接続します。
- (4) (1)で取り外した2本のビス①で本体とI/Oポートを固定します。(以上の作業は図 3-5 を参照ください)
- (5) I/Oポート電源用コネクタFを図 3-6 に示すように本体電源1次側基板上のコネクタGに差し込みます。



図 3-6

### 3.2 拡張I/Oポートへのオプションデバイスのセッティング

前節でセッティング方法を説明したデバイス以外のオプションデバイスは、全てそのインターフェイスカードを拡張I/Oポートの端子に差し込みます。

MZ-1U01は、4枚のインターフェイスカードをセッティングできるよう1番から4番までのスロットが用意されています。プリンタインターフェイスカードはI/Oポートのスロット2番に、フロッピーディスクドライブインターフェイスカードはスロット4番にセッティングしてください。(各スロットの端子へは、まったく同一の信号が供給されていますが、カードの大きさの関係から、この2種類のカードのみスロットの場所を上記のごとく限定しています。)

その他のインターフェイスカードは、スロット1番か、スロット3番のいずれかにセッティングしてください。

図3-7にプリンタインターフェイスカードのセッティング方法を示します。

- (1) 4本のビス②を外し、コネクタパネルをI/Oポートより取り外します。
- (2) 2本のビス③を外し、コネクタブタをコネクタパネルより取り外します。
- (3) プリンタインターフェイスカードを部品側を上にしてI/Oポートのスロット2番に差し込みます。

I/Oポート内には、それぞれインターフェイス用のレールガイドがありますので、これに沿って挿入します。

(確実にI/Oポートのマザーボードにあるコネクタへ、このカードを差し込んでください。)

- (4) カードを正しくセットしたら、コネクタパネルを4本のビス②で元の位置に固定します。



図 3-7

図3-8にインターフェイスカードと信号ケーブルの接続方法を示します。

- (1) 右図は、プリンタインターフェイスカードをI/Oポートのスロット2番に装着した状態を示しています。



- (2) プリンタの信号ケーブルをインターフェイスカードの信号 terminal に接続します。ケーブルのコネクタは左右どちらを用いてもかまいませんが、接続の際、方向性がありますので注意してください。(逆方向の接続はできない構造になっています。)



- (3) このコネクタの左右にある穴にケーブル付属のビスを通して、しっかりとビス止めし、コネクタを固定します。このビス止めは、かららず行ってください(ビス止め2箇所)。プリンタ側の接続については、各プリンタの取扱い説明書を参照の上、行ってください。



図 3-8

その他のオプションデバイスについても、スロット1、3または4番を用い、この節の説明に準じて正しくセッティングを行ってください。



# MZ-2000のハードウェア構成

Chapter  
4

この章は、MZ-2000のハードウェアを次の各セクションで概説しています。

- MZ-2000システムダイアグラム
- メモリ構成：メインメモリとIPL、V-RAMとの関係
- 8255の信号系
- 8253の信号系
- PIOの信号系
- MZ-2000本体およびグラフィックボード、拡張I/Oポートの全回路図

ただし、この章の内容は参考データであり、内容についてのお問い合わせには応じかねます。

## 4.1 MZ-2000のシステムダイアグラム

図4-1にパーソナルコンピュータ MZ-2000内部のハードウェア構成を示します。



図 4-1 MZ-2000システム・ダイアグラム

## 4.2 メモリ構成

### 4.2.1 IPL動作時のメモリマップ

MZ-2000の電源スイッチをONにした時、あるいはIPLリセットスイッチを押した時もしくはプログラムによって(たとえばBASICのBOOTコマンドの実行)補助プログラムIPLがスタートする場合、MZ-2000は、図4-2に示すメモリ構成をとります。



図 4-2 IPL動作時のメモリマップ

即ち、IPLプログラムを持つ2KバイトのBOOT ROMがアドレス\$0000～\$07FFに、メインメモリ64Kバイトのうち前半の32KバイトのRAMエリア(以後RAMブロック1と呼ぶ)がアドレス\$8000～\$FFFFに設定されます(後半の32KバイトRAMエリアはCPUから切り離されていた状態にあります)。この状態でIPLはカセットテープファイルまたはディスクケットファイルからアドレス\$8000以降のRAMエリアへシステムソフトウェアのイニシャルローディングを実行します。

イニシャルローディングを終えるとシステムは、メモリ構成をノーマルステートに変え、そのアドレス\$0000へコントロールを移します。

#### 4.2.2 ノーマル時のメモリマップ

IPLによるシステムプログラムのイニシャルローディングを終了すると、MZ-2000は図4-3に示すメモリ構成をとります。



図 4-3 ノーマル時のメモリマップ

システムソフトウェアは、前記の IPL動作時に RAM ブロック 1 の先頭アドレス \$8000 からロードされますが、ノーマルステートへのメモリ構成の変換によって、上図のように、システムソフトウェアがストアされた RAM ブロック 1 のアドレスは、\$0000～\$7FFF となり、RAM ブロック 2 が、\$8000～\$FFFF の各アドレス空間を占めるようになります。このメモリ構成の変換直後に CPU のリセットがかかってアドレス \$0000 即ち、システムソフトウェアの先頭からプログラムが実行されます。

### 4.2.3 V-RAMアクセス時のメモリマップ

メモリアドレスの切り替えは、V-RAMアクセス時にも行なわれます。

V-RAMアクセス時のメモリアドレスの切り替えはキャラクタまたはグラフィックのいずれかを選択することによって行なわれその際のメモリマップは、それぞれ異なります。

すなわち、V-RAMキャラクタを選択した場合、図4-4に示すようにRAMブロック3の4Kバイト(\$D000～\$DFFF)をアドレッシング空間からはずして、そのかわりにV-RAMをアクセス状態とします。したがってもし表示プログラムまたはデータが、RAMブロック3にある場合は、コントロールができないことになります。V-RAMグラフィックを指定した場合、図4-5に示すようにRAMブロック3の16Kバイト(\$C000～\$FFFF)をアドレッシング空間からはずし、V-RAMをアクセス状態とします。

メインメモリとV-RAMのアドレス切り替えはPIOのA7ポートによって実行され、またキャラクタとグラフィックの切り替えは同じくPIOのA6ポートによって実行されます。さらにグラフィックRAMのページ1、ページ2及びページ3の切り替えはOUTポート\$F7によって決められます。



図 4-4 メインメモリとV-RAM(キャラクタ)のアドレス切り替え



図 4-5 メインメモリとV-RAMグラフィックのアドレス切り替え

#### V-RAMグラフィックの名称について

このマニュアル内でのV-RAMグラフィックの各名称は標準BASIC使用時にはおのおの下記名称に対応します。(標準BASICとはBASICインターパリタ MZ-1Z001およびMZ-2Z001のことです。)

| マニュアル内での名称      | 標準BASIC使用時の名称 |         |
|-----------------|---------------|---------|
| V-RAMグラフィックBLUE | V-RAMグラフィック 1 | (ページ 1) |
| " RED           | " 2           | (ページ 2) |
| " GREEN         | " 3           | (ページ 3) |

V-RAM（キャラクタ、グラフィック）の出力とCRTディスプレイのつながりを図4-6に示します。



**注]** プライオリティとは、カラー CRTディスプレイ上にキャラクタとグラフィックの重ね合わせ表示を行なう場合、両データを同じ場所に表示する際、どちらのデータを優先して表示するかを決めるものです。

**【例】**

| プライオリティ | 表示 |
|---------|----|
| キャラクタ   |    |
| グラフィック  |    |

図 4-6 V-RAMとCRTディスプレイのつながり

V-RAMアドレスとCRTディスプレイ上の該当位置との関係を図4-7に示します。

#### <1> V-RAMキャラクタ



#### <2> V-RAMグラフィック



図 4-7 V-RAMアドレスとCRTディスプレイ

グラフィック用 V-RAM の入出力制御は、OUT ポート \$F4、\$F5、\$F6および\$F7に出力するデータによっておのの、次のように制御することができます。(表中の○は可を、×は不可を示します。)

#### 〈ポート \$F7〉

グラフィックエリアの切り替え

表 4-1a

| ポート \$F7への出力データ | V-RAM(BLUE) | V-RAM(RED) | V-RAM(GREEN) |
|-----------------|-------------|------------|--------------|
| 00              | ×           | ×          | ×            |
| 01              | ○           | ×          | ×            |
| 02              | ×           | ○          | ×            |
| 03              | ×           | ×          | ○            |

F7(16進) = 247(10進)

ここで ○ V-RAM転送(データの読み出し／書き込み)可  
× V-RAM転送(データの読み出し／書き込み)不可

V-RAM (グラフィック) に対して転送を行う場合、同時に 2つ以上のV-RAMを指定するとハード上の破壊を生じる場合があるので、上表のよう、かならずグラフィックエリアのいずれか1つのV-RAMのみを選択するように配慮されています (したがってソフト上誤って、このポートにデータ04を与えて、B・G 転送可とはならずR・G・B共転送不可の状態となります)。

(具体例) \$F7ポートに02Hを出力して、\$C000に01Hを格納したとすると、V-RAMグラフィック (RED) 上の \$C000に01Hが転送されます。

#### 〈ポート \$F6〉

V-RAM グラフィックデータの白黒画面への重ね合わせ表示およびR・G・Bのディスプレイ表示選択

表 4-1b

| ポート \$F6への出力データ | グラフィックデータの白黒画面への重ね合わせ | V-RAMグラフィックのディスプレイ表示 |     |       |
|-----------------|-----------------------|----------------------|-----|-------|
|                 |                       | BLUE                 | RED | GREEN |
| 00              | ○                     | ×                    | ×   | ×     |
| 01              | ○                     | ○                    | ×   | ×     |
| 02              | ○                     | ×                    | ○   | ×     |
| 03              | ○                     | ○                    | ○   | ×     |
| 04              | ○                     | ×                    | ×   | ○     |
| 05              | ○                     | ○                    | ×   | ○     |
| 06              | ○                     | ×                    | ○   | ○     |
| 07              | ○                     | ○                    | ○   | ○     |
| 08              | ×                     | ×                    | ×   | ×     |
| 09              | ○                     | ○                    | ×   | ×     |
| 0A              | ○                     | ×                    | ○   | ×     |
| 0B              | ○                     | ○                    | ○   | ×     |
| 0C              | ○                     | ×                    | ×   | ○     |
| 0D              | ○                     | ○                    | ×   | ○     |
| 0E              | ○                     | ×                    | ○   | ○     |
| 0F              | ○                     | ○                    | ○   | ○     |

F6(16進) = 246(10進)

(具体例) \$F6ポートに06Hを出力したとすると、カラーCRTディスプレイ上にV-RAM グラフィック(BLUE) のデータは表示されず、V-RAM グラフィック(RED)、(GREEN) のデータがディスプレイ表示され、その表示されたデータが白黒CRT画面上にキャラクタデータと重ね合わせて表示されます。

## &lt;ポート \$ F5&gt;

キャラクタデータのカラーCRT画面上への重ね合わせ表示、キャラクタデータの色調選択およびキャラクタとグラフィックの両データが表示画面上重なった時に、どちらの色調を優先するかを選択（プライオリティー）…第4-6図の（注）参照。

表 4-1c

| ポート \$ F5への出力データ | プライオリティー | キャラクターの色調 |     |       | 色調 |
|------------------|----------|-----------|-----|-------|----|
|                  |          | BLUE      | RED | GREEN |    |
| 00               | キャラクタ    | ×         | ×   | ×     | 黒  |
| 01               |          | ○         | ×   | ×     | 青  |
| 02               |          | ×         | ○   | ×     | 赤  |
| 03               |          | ○         | ○   | ×     | 紫  |
| 04               |          | ×         | ×   | ○     | 緑  |
| 05               |          | ○         | ×   | ○     | 水色 |
| 06               |          | ×         | ○   | ○     | 黄  |
| 07               |          | ○         | ○   | ○     | 白  |
| 08               |          | ×         | ×   | ×     | 黒  |
| 09               |          | ○         | ×   | ×     | 青  |
| 0A               |          | ×         | ○   | ×     | 赤  |
| 0B               |          | ○         | ○   | ×     | 紫  |
| 0C               |          | ×         | ×   | ○     | 緑  |
| 0D               |          | ○         | ×   | ○     | 水色 |
| 0E               |          | ×         | ○   | ○     | 黄  |
| 0F               |          | ○         | ○   | ○     | 白  |

F5(16進) = 245(10進)

(注) プライオリティをグラフィック側に選択し、バックランドとキャラクタの色調選択を同一にするとカラーCRT画面上へのキャラクタデータの表示はされず、グラフィックデータのディスプレイ表示のみとなります。

## &lt;ポート \$ F4&gt;

カラーCRT画面のバックランドの色調選択

表 4-1d

| ポート \$ F4への出力データ | バックランドの色調 |     |       | 色調 |
|------------------|-----------|-----|-------|----|
|                  | BLUE      | RED | GREEN |    |
| 00               | ×         | ×   | ×     | 黒  |
| 01               | ○         | ×   | ×     | 青  |
| 02               | ×         | ○   | ×     | 赤  |
| 03               | ○         | ○   | ×     | 紫  |
| 04               | ×         | ×   | ○     | 緑  |
| 05               | ○         | ×   | ○     | 水色 |
| 06               | ×         | ○   | ○     | 黄  |
| 07               | ○         | ○   | ○     | 白  |

F4(16進) = 244(10進)

### 4.3 8255, 8253およびPIOの各信号系

この節では、回路中で重要な役割りを果たしているコントローラ、8255、8253、PIOについてそのコントロール内容と信号系を解説しています。各ICは次に示すように、CPUの入出力ポート\$E0～\$EBを介してアクセスされます。

表 4-2

| CPUの入出力ポート | コントローラ | 各ポートのサービスモード                          |
|------------|--------|---------------------------------------|
| \$ E 0     | 8255   | P <sub>A</sub> ：出力                    |
| \$ E 1     |        | P <sub>B</sub> ：入力                    |
| \$ E 2     |        | P <sub>C</sub> ：出力                    |
| \$ E 3     |        | モードコントロール                             |
| \$ E 4     | 8253   | C <sub>0</sub> ：モード2（16ビット・レートジェネレータ） |
| \$ E 5     |        | C <sub>1</sub> ：モード2（16ビット・レートジェネレータ） |
| \$ E 6     |        | C <sub>2</sub> ：モード2（16ビット・レートジェネレータ） |
| \$ E 7     |        | モードコントロール                             |
| \$ E 8     | PIO    | A：出力モード3（ピットコントロール）                   |
| \$ E 9     |        | モードコントロールA                            |
| \$ E A     |        | B：入力モード3（ピットコントロール）                   |
| \$ E B     |        | モードコントロールB                            |

#### 4.3.1 8255まわりの信号系

8255 (programmable peripheral interface) は、オートカセットコントロール、C R Tディスプレイのリバース、ブランクコントロール、ブート／ノーマルのメモリ切替え、サウンド発生用ソースパルスの出力のそれぞれ制御を行っています。

図4-8は8255まわりの信号系をまとめたものです。表4-3に各ポートのコントロール内容を示します。



図 4-8 8255まわりの信号系

表 4-3

ポートA (ポートアドレス=\$E0)

| ポート端子           | アクティブ | コントロール内容                 | 信号名        |
|-----------------|-------|--------------------------|------------|
| PA <sub>7</sub> | L     | プログラム頭出し(APSS)の準備(カセット)  | * 1 APSS-P |
| PA <sub>6</sub> | L     | 巻き戻し終了時の自動再生 (カセット)      | * 2 APLAY  |
| PA <sub>5</sub> | L     | 再生(録音)時の自動巻き戻し (カセット)    | * 3 AREW   |
| PA <sub>4</sub> | L     | 表示画面全体のB/Wを反転させる(ディスプレイ) | VID        |
| PA <sub>3</sub> | L     | カセットの動作停止 (□□□)          | STOP       |
| PA <sub>2</sub> | L     | カセットのPLAY (□□□)          | PLAY       |
| PA <sub>1</sub> | L     | カセットのFF (□□□)            | FF         |
| PA <sub>0</sub> | L     | カセットのREW (□□□)           | REW        |

ポートB (ポートアドレス=\$E1)

| ポート端子           | アクティブ | コントロール内容                       | 信号名      |
|-----------------|-------|--------------------------------|----------|
| PB <sub>7</sub> | L     | カセット PLAY 中の [BREAK] キーの検出     | —        |
| PB <sub>6</sub> | —     | カセット読み出しデータ                    | RDATA    |
| PB <sub>5</sub> | L     | カセットがセットされている状態                | TREADY   |
| PB <sub>4</sub> | L     | 書き込み可能状態(ライトプロジェクト用リブ有り)(カセット) | WREADY   |
| PB <sub>3</sub> | L     | テープ動作中信号 (カセット)                | TAPE END |
| PB <sub>2</sub> | —     | —                              | —        |
| PB <sub>1</sub> | —     | —                              | —        |
| PB <sub>0</sub> | H     | ディスプレイのブランкиング期間               | Blank    |

ポートC (ポートアドレス=\$E2)

| ポート端子           | アクティブ | コントロール内容                   | 信号名   |
|-----------------|-------|----------------------------|-------|
| PC <sub>7</sub> | —     | カセットへの書き込みデータ              | WDATA |
| PC <sub>6</sub> | L     | REC待機(PLAY □□□ で WRITE 状態) | REC   |
| PC <sub>5</sub> | H     | FF、REW、STOPの各キー入力を禁止       | KINH  |
| PC <sub>4</sub> | L     | EJECT動作(□□□)               | OPEN  |
| PC <sub>3</sub> | L     | IPLスタート                    | BST   |
| PC <sub>2</sub> | —     | サウンド発生用ソースパルス出力            | SOUND |
| PC <sub>1</sub> | H     | メモリをノーマル状態とし\$0000スタート     | NST   |
| PC <sub>0</sub> | —     | (Lに固定)                     | VGATE |

## 補足説明

\* 1 APSS-P FF、REW以外のモードの際にこの入力を'L'とする(約40ms)→PLAYソレノイドがONする(テープ・セット状態でなければONしない)→FF又はREWを'L'にするとAPSSモードとなります(ヘッドとテープがタッチ、ピンチローラとテープはタッチしない状態にて、FF又はREWとなり所望のファイルを早く探し出すことができます。



\* 2 APLAY H……テープ巻き戻し終了時にストップ状態となります。

L……テープ巻き戻し終了時に一度ストップ状態となり、自動的に再生(PLAY)状態となります。

\* 3 AREW H……テープ再生(PLAY)又は録音中にテープエンドにきた時ストップ状態となります。

L……テープ再生(PLAY)又は録音中にテープエンドにきた時一度ストップ状態となり、自動的に巻き戻し(REW)状態となります。

早送り(FF)終了時はAREWに無関係にストップ状態となります。

### 4.3.2 8253まわりの信号系

8253 (programmable interval timer) は、そのカウンタ#0、#1、#2で内蔵時計の役割りを果しています。

カウンタ#0、#1、#2とも mode 2：レート・ジェネレータ (rate generator) として使用し、いずれも16bit バイナリカウンタです。

カウンタ#0は、31.25 kHzの入力パルスをカウントし1sec毎にOUT0にパルスを出力します。カウンタ#1はそのパルスをカウントして、12h毎OUT1にパルスを出力します。カウンタ#2は、そのパルスをカウントして0、1を繰り返し、AM/PMのフラグの役割りを果たします。図4-9参照。



図 4-9 8253まわりの信号系

### 4.3.3 PIOまわりの信号系

Z80A-PIO (parallel input/output interface controller) は、キー ボードスキャン用ストローブ信号の出力、キーデータの入力、キーストローブを low にする操作、およびV-RAMのアドレス切替え、40キャラ/80キャラモード切替えコントロール信号の出力を行います。

図4-10は、PIOまわりの信号系をまとめたものです。次表に各ポートのコントロール内容を示します。



図 4-10 PIOまわりの信号系

表 4-4

ポートA (ポートアドレス=\$E8)

| ポート端子          | アクティブ | コントロール内容                                                   | 信号名  |
|----------------|-------|------------------------------------------------------------|------|
| A <sub>7</sub> | H     | (キャラクタ\$D000～\$D7FF、グラフィック\$C000～\$FFFF)のアドレスをV-RAMに切替えます。 | DISP |
| A <sub>6</sub> | H     | V-RAMキャラクタをアクセスします(L: V-RAMグラフィックをアクセス)                    | C/G  |
| A <sub>5</sub> | H     | 画面を80キャラクタモードとします(L: 40キャラ)                                | CH80 |
| A <sub>4</sub> | L     | キーストローブ信号を全てLにします。                                         | —    |
| A <sub>3</sub> |       |                                                            | —    |
| A <sub>2</sub> |       |                                                            | —    |
| A <sub>1</sub> |       |                                                            | —    |
| A <sub>0</sub> |       | キーボードスキャン用ストローブ信号の出力                                       | —    |

ポートB (ポートアドレス=\$EA)

| ポート端子          | アクティブ | コントロール内容             | 信号名 |
|----------------|-------|----------------------|-----|
| B <sub>7</sub> |       |                      |     |
| B <sub>6</sub> |       |                      |     |
| B <sub>5</sub> |       |                      |     |
| B <sub>4</sub> |       |                      |     |
| B <sub>3</sub> |       | キーボードスキャン用データ入力(負論理) |     |
| B <sub>2</sub> |       |                      |     |
| B <sub>1</sub> |       |                      |     |
| B <sub>0</sub> |       |                      |     |

キーボードスキャンのストロープ信号とビットデータの関係を表4-5に示しています。

キーストローブ信号はPIOのポートAのA<sub>3</sub>～A<sub>0</sub>から出力され、マルチプレクサ159によってキーマトリクスの12端子に順番に出力されます。表の右端の欄がそのキーストローブ0H～BHを分類しています。(CH～FHは無効)

PIOのポートBに入力されるビットデータが列に示されています。

たとえばキーストローブ" 6 "のとき、ビットデータが" F7H "であれば、ビット3に対応するキー、即ち **S** キーが押されていることが判別されます。

表 4-5 キースキャニングのストローブとビットデータ

| E レジスタ<br>上位4ビット | キー<br>モード数 | ビットデータの各ビット(負論理)                 |                 |                |                |                |                |                |                |   | キー<br>ストローブ |
|------------------|------------|----------------------------------|-----------------|----------------|----------------|----------------|----------------|----------------|----------------|---|-------------|
|                  |            | 0                                | 1               | 2              | 3              | 4              | 5              | 6              | 7              |   |             |
| 0                | 1          | F <sub>1</sub>                   | F <sub>2</sub>  | F <sub>3</sub> | F <sub>4</sub> | F <sub>5</sub> | F <sub>6</sub> | F <sub>7</sub> | F <sub>8</sub> | 0 |             |
|                  |            | F <sub>9</sub>                   | F <sub>10</sub> | 8              | 9              | 00             | ・              | +              | -              | 1 |             |
| 1                | 1          | 0                                | 1               | 2              | 3              | 4              | 5              | 6              | 7              | 2 |             |
|                  |            | TAB                              | SPACE           | CR             | ↑              | ↓              | ←              | →              | BREAK          | 3 |             |
| 2                | 3          | / ← A a B b C c D d E e F f G g  |                 |                |                |                |                |                |                | 4 |             |
|                  |            | メ → チ □ コ ♣ ソ ♥ シ □ イイ田 ハ □ キ 田  |                 |                |                |                |                |                |                |   |             |
| 3                | 6          | H h I i J j K k L l M m N n O o  |                 |                |                |                |                |                |                | 5 |             |
|                  |            | ク □ ニ □ マ □ ノ □ リ □ モ ¥ ミ □ ラ □  |                 |                |                |                |                |                |                |   |             |
| 4                | 6          | P p Q q R r S s T t U u V v W w  |                 |                |                |                |                |                |                | 6 |             |
|                  |            | セ □ タ □ ス □ ト □ カ □ ナ □ ヒ ◆ テ □  |                 |                |                |                |                |                |                |   |             |
| 5                | 4          | X x Y y Z z へ ~ ノ   ? ↑ . > , <  |                 |                |                |                |                |                |                | 7 |             |
|                  |            | サ ♠ ン □ ツ ツ □ ヘ ヲ □ ロ ↓ ル 。 ネ π  |                 |                |                |                |                |                |                |   |             |
| 6                | 2          | 0 一 1 ! 2 " 3 # 4 \$ 5 % 6 & 7 ' |                 |                |                |                |                |                |                | 8 |             |
|                  |            | ワ ヌ フ ア ア ウ ウ エ エ オ オ ヤ ャ        |                 |                |                |                |                |                |                |   |             |
| 7                | 4          | 8 ( 9 ) : * ; + - = @ ` [ {      |                 |                |                |                |                |                |                | 9 |             |
|                  |            | ユ ュ ョ ョ ケ レ ホ ` 。 「              |                 |                |                |                |                |                |                |   |             |
| 8                | 5          | ] }                              |                 | CLR HOME       | INST DEL       |                |                |                |                | A |             |
|                  |            | ム ]                              |                 |                |                |                |                |                |                | B |             |
| 特殊キー             |            | GRPH                             | SFT LOCK        | SHIFT          | カナ             |                |                |                |                |   |             |

## ■ キー割り込みを行うために

PIO をプログラムすることによってキー割り込みコントロールを行うことができます。次に示すプログラム例は **BREAK** キーが押された時、CPUに割り込みをかけて、コントロールをブレーク割り込み処理ルーチンへ移してやるもので、ここで各条件は、次のそれぞれの値を例にとってみることにします。

PIO……………ビット制御モード（モード3）とする

CPU割り込みモード……………モード2、ベクトル割り込み（従ってIレジスタには割り込み処理ルーチンのアドレス  
テーブルの上位8ビットがセットされなければならない。）

メモリ上のブレーク割り込み処理ルーチンのスタートアドレス……………\$5080番地

メモリ上のブレーク割り込み処理ルーチンのスタートアドレステーブル……………\$3370番地（従って\$3370番地に80H、  
\$3371番地に50Hがストアされなければならない）

|                |                                                                         |
|----------------|-------------------------------------------------------------------------|
| LD A, 33H      | CPUの割り込みベクトルレジスタ I を33Hとする                                              |
| LD I, A        |                                                                         |
| IM 2           | CPUの割り込みモード2を設定する                                                       |
| LD HL, 5080H   | メモリ上のブレーク割り込み処理ルーチンのアドレステーブル\$3370番地に、アドレス\$5080番地をセットする                |
| LD (3370H), HL |                                                                         |
| LD A, 70H      | PIOに割り込みベクトル70H（\$3370の下位8ビット）をセットする（転送データ70Hの最下位ビットが“0”であるのでこの設定が行われる） |
| OUT (EBH), A   |                                                                         |
| LD A, CFH      | PIOのポートBをモード3（ビット制御モード）とする                                              |
| OUT (EBH), A   |                                                                         |
| LD A, FFH      | PIOのポートBをすべて入力ポートとする                                                    |
| OUT (EBH), A   |                                                                         |
| LD A, 97H      | 割り込みイネーブル・フリップ・フロップをセットし割り込み制御語を設定する                                    |
| OUT (EBH), A   |                                                                         |
| LD A, 7FH      | <b>BREAK</b> キーのビットデータ“7”をマスクとしてセットする                                   |
| OUT (EBH), A   |                                                                         |
| IN A, (E8H)    |                                                                         |
| AND F0H        | キーストローブ信号を“3”にセットする。ストローブゲートはPIOのA4ポートを“H”                              |
| OR 13H         | にすることによってオープンされる                                                        |
| OUT (E8H), A   |                                                                         |

上記のモードセッティングを実行した後は、**BREAK** キーを押すことによってテーブル\$3370番地が参照され、コントロールが、\$5080番地へ移されます。ブレーク割り込み処理を終えて、割り込みがかけられた箇所からメインプログラムを実行再開するには、RETI命令を実行させねばよいことになります。

## 4.4 MZ-2000回路図

この節ではユーザの参考のため、MZ-2000本体と、グラフィックボード、拡張I／Oポートの全回路図を次の順に掲載しています。

### ■MZ-2000本体の回路図

- 〔1〕 CPU ボード・ブロック 1 : CPU信号系
- 〔2〕 CPU ボード・ブロック 2
- 〔3〕 CPU ボード・ブロック 3 : 8255、PIO 信号系
- 〔4〕 CPU ボード・ブロック 4 : RAM ブロック
- 〔5〕 CPU ボード・ブロック 5 (各端子表)
- 〔6〕 CRT ディスプレイコントロール部
- 〔7〕 カセットテープデッキコントロール部
- 〔8〕 電源回路

### ■ グラフィックボードMZ-1R01の回路図

- 〔1〕 コントロール部
- 〔2〕 RAMブロック

### ■ 拡張I／Oポートユニット、MZ-1U01の回路図

図 4-11 CPUポート(1): CPU信号系





図 4-12 CPU ボード [2]

図 4-13 CPU 機—F(3) : 8255, PIO 信号系



図 4-14 CPUポート[4] : RAM ブロック



CN6 → MZ-2000  
 CN2 → MZ-1R01

|          |    |    |        |
|----------|----|----|--------|
| GND      | 2  | I  | GND    |
| GND      | 4  | 3  | GND    |
| GND      | 6  | 5  | GND    |
| +12V     | 8  | 7  | +12V   |
| +5V      | 10 | 9  | +5V    |
| +5V      | 12 | 11 | +5V    |
| -5V      | 14 | 13 | -5V    |
| D2       | 16 | 15 | D3     |
| D1       | 18 | 17 | D4     |
| Do       | 20 | 19 | D5     |
| D7       | 22 | 21 | D6     |
| Q1       | 24 | 23 | Q0     |
| Q3       | 26 | 25 | Q2     |
| Q5       | 28 | 27 | Q4     |
| Q7       | 30 | 29 | Q6     |
| Q9       | 32 | 31 | Q8     |
| QB       | 34 | 33 | QA     |
| QD       | 36 | 35 | QC     |
| F4WR     | 38 | 37 | I6M    |
| GOUT     | 40 | 39 | Gsel   |
| Video QH | 42 | 41 | QG     |
| Hblank F | 44 | 43 | Hsync  |
| Vsync    | 46 | 45 | Vblank |
| Vgate    | 48 | 47 | Vid    |
| BMREQ    | 50 | 49 | blank  |
| BWR      | 52 | 51 | BRFSH  |
|          |    | 53 | BRD    |



図 4-15 CPUボード[5]：端子表

## 4-16 CRTディスプレイ回路



図 4-17 カセットテープデッキコントローラー





DBOXD0044PAZZ



図 4-19 グラフィックボード MZ-1R01 コントロール部(1)……オプション

図 4-20 ディスプレイ MZ-1 R01 コントロール部(2)……オプション



図 4-21 デラフィックボード MZ-1R01 RAM ブロック [1] ……オプション



図 4-22 デラフィックボード MZ-1R01 RAM プロック詳細図





図 4-24 MZ-1U01電源回路(オプション)

MZ-IU01 I/O MOTHER BOARD

図 4-23 拡張I/OポートユニットMZ-IU01(オプション)

| CN5     |        |
|---------|--------|
| A       | B      |
| D1      | I Do   |
| D3      | 2 D2   |
| GND     | 3 GND  |
| D5      | 4 D4   |
| D7      | 5 D6   |
| GND     | 6 Ao   |
| RESET   | 7 A1   |
| GND     | 8 A2   |
| HALT    | 9 A3   |
| MI      | 10 A4  |
| GND     | 11 A5  |
| WR      | 12 A6  |
| RD      | 13 A7  |
| GND     | 14 A8  |
| IOREQ   | 15 A9  |
| MREQ    | 16 A10 |
| GND     | 17 A11 |
| EXINT   | 18 A12 |
| IEO     | 19 A13 |
| NMI     | 20 A14 |
| EXWALT  | 21 A15 |
| EXRESET | 22 Ø   |

A: PARTS SIDE



| CN1~CN4 |            |
|---------|------------|
| A       | B          |
| +5V     | I +5V      |
| D2      | 2 D3       |
| D1      | 3 D4       |
| Do      | 4 D5       |
| GND     | 5 D6       |
| A15     | 6 D7       |
| A14     | 7 Ø        |
| A13     | 8 MI       |
| A12     | 9 WR       |
| A11     | 10 RD      |
| A10     | 11 IOREQ   |
| A9      | 12 MREQ    |
| A8      | 13 GND     |
| A7      | 14 HALT    |
| A6      | 15 IEI     |
| A5      | 16 IEO     |
| A4      | 17 RESET   |
| A3      | 18 EXRESET |
| A2      | 19 EXINT   |
| A1      | 20 EXWAIT  |
| A0      | 21 NMI     |
| GND     | 22 GND     |

A: PARTS SIDE

# 付 錄

Appendix

付録には、LH0080A(Z80A-CPU)およびLH0081A(Z80A-PIO)の各テクニカルデータを参考のため掲載しています。(A.1とA.2)

A.3はMZ-2000の仕様の一覧

A.4には、MZ-2000の取り扱いの注意がまとめられています。

## A.1 Z80A CPU テクニカルデータ

## 1. アーキテクチャ

Z-80A CPUの内部構成のブロック図を図1-1に示す。この図はCPU内部の主要な部分を示している。それについての説明を参考されたい。



図1-1 Z-80A CPUの内部構成のブロック図

## 1.1 CPU レジスタ群

Z-80A CPUには207ビットの読み出し／書き込みメモリがあり、プログラマによって任意にアクセスできるようになっている。図1-2にこのメモリの配列を示す。これらは16個の8ビット・レジスタ、4個の16ビット・レジスタから成っている。

Z-80AのレジスタはすべてスタティックRAMで構成されている。

6個の汎用レジスタがそれぞれ2セット用意されていて、これを単独の8ビット・レジスタとして使用してもよいし、対にして16ビット・レジスタとして用いることもできる。

2セットあるアクチュエータ、フラグ・レジスタについても同様である。

## 専用レジスタ

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

プログラム・カウンタは現在実行中の命令のメモリ・アドレス16ビットを保持しており、CPUはPCで示されるメモリ・アドレスから命令をフェッチする。

このPCはその内容をアドレス線に送り出すと、インクリメンタによりPCの値を自動的に+1する。プログラム・ジャンプの場合、インクリメンタは動作せず、新しい値が直接PCにセットされる。

## 2. スタック・ポインタ (SP)

スタック・ポインタは外部RAM上のスタック領域のその時点での最上位のアドレス16ビットを保持するものである。外部スタックはLIFO (Last-in, First-out) ファイルとして構成される。

データはPUSHおよびPOP命令により、CPUの指定レジスタからスタックへ、またスタックからCPUの指定レジスタへ転送される。

データのスタックからの取り出し (POP) は一番最後に押し込んだ (PUSH) データから行われる。このスタックは、多重レベルの割り込み、無限のサブルーチン・ネスティング、あるいは種々の形のデータ操作などを簡単にする場合に有効である。



図1-2 Z-80A CPUのレジスタ構成

### 3. インデックス・レジスタ (IX&IY)

インデックス・モードのアドレッシング用として16ビットの基準アドレスを保持する2個の独立したインデックス・レジスタIX、IYがある。

このモードでは、インデックス・レジスタはデータを出し入れするメモリ領域を指定するための基準アドレスとして使用される。インデックス・アドレッシング命令では、このレジスタの内容に1バイトのディスプレイスメント(偏位値)を加算した値が実効アドレスとなる。この偏位値は2の補数の符号付整数で与えられる。

このアドレッシング・モードは種々のプログラム、とくに、データ・テーブルを参照するといったプログラムなどによく使用される。

### 4. 割り込みページ・アドレス・レジスタ (I)

Z-80A CPUには、割り込みに応じてどのメモリの位置へでも、イン・ダイレクト・コール(間接サブルーチン・ジャンプ)できるモードがある。

この目的のために、Iレジスタが用意されていて、間接アドレスの上位8ビットにこのレジスタの内容が相当する。下位8ビットには、割り込みをかけてきたデバイスに対応するアドレスが当てられる。この方式によれば、割り込み処理ルーチンを動的にメモリのどこへでも配置でき、極めて短いアクセス時間で処理ルーチンへ飛ばせ得るという特長をもっている。

### 5. メモリ・リフレッシュ・レジスタ (R)

Z-80A CPUはメモリ・リフレッシュ・カウンタを内蔵しているので、スタティック・メモリと同じ手軽さでダイナミック・メモリを使用できる。

この8ビットのRレジスタは各命令のフェッチごとに自動的にインクリメントされる。

RカウンタのデータはCPUがフェッチした命令をデコードし、実行している間に、リフレッシュ制御信号と同期してアドレス・バスの下位に乗せられる。

このリフレッシュのモードは、プログラムがとくに気をつかう必要もなく、またCPUの動作を遅らせるものでもないという特長がある。Rレジスタにテストの目的でプログラムによってデータをロードすることもできるが、普通は使用しない方がよい。

リフレッシュの期間、アドレス・バスの上位8ビットにはIレジスタの内容が出力する。

### アキュムレータとフラグ・レジスタ

CPUは2組の独立した8ビットのアキュムレータと、それと組み合わせた2組の8ビットのフラグ・レジスタをもっている。

アキュムレータは8ビットの算術・論理演算の結果を保持する。一方、フラグ・レジスタは8ビットあるいは16ビットの演算結果の状態、たとえば結果が零に等しいか否かをセットする。

プログラムによって1つの交換命令を用いて、アキュムレータとフラグの対(ペア)のうちどちらか使いやすい方を選べばよい。

### 汎用レジスタ

2組の対になった汎用レジスタ群があり、それぞれ単独で8ビットのレジスタとして使用でき、また16ビットのレジスタ・ペアとしても使用できる。一方のセットとしてBC、DE、HLがあり、他方、BC'、DE'、HL'のセットがある。

プログラムによって、どの時点においても交換命令を用いてどちらかの側のレジスタ群を作業用として使用することができる。システム内で高速の割り込み応答が要求される場合、この手法を使ってアキュムレータ、フラグ類、汎用レジスタ群の内容を他方へすばやく退避させてもよいだろう。

1つの簡単な交換命令を用いるだけでルーチン間の移行が行える。

これにより割り込み、あるいはサブルーチン処理の期間、レジスタの内容を外部スタックへ移したり、戻したりする必要がなくなるので、割り込みサービス時間を大幅に短縮するのに役立つ。

これらの汎用レジスタ群は、どのような幅広い用途に対しても利用し得るものである。

単純なプログラム、とくにROMベースのシステムなどで、簡単な読み出し/書き込みメモリが必要な場合に、汎用レジスタで代用すればよい。

### 1.2 算術、論理演算ユニット (ALU)

8ビットの算術、論理演算命令はCPU内のALUで実行される。

ALUは各レジスタと内部バスとを接続しており、それらの間でデータの送受を行う。

ALUに関連した機能には次のようなものがある。

|                             |                |
|-----------------------------|----------------|
| Add                         | (加 算)          |
| Subtract                    | (減 算)          |
| AND                         | (論 理 積)        |
| OR                          | (論 理 和)        |
| XOR                         | (排他的論理和)       |
| Compare                     | (比 較)          |
| Shift Left, Right           | (左、右シフト)       |
| Rotates arithmetic, logical | (算術的、論理的ローテイト) |
| Increment                   | (インクリメント；+1)   |
| Decrement                   | (デクリメント；-1)    |
| Set bit                     | (ビット・セット)      |
| Reset bit                   | (ビット・リセット)     |
| Test bit                    | (ビット・テスト)      |

### 1.3 命令レジスタ、CPU制御

各命令はメモリから読み出されてきて、命令レジスタに保持され、デコードされる。制御部はこの制御を行うとともに、レジスタ群からのまたはそれへの、データの読み込み、書き出しに必要な制御信号を発生している。

さらに、ALUの制御信号や必要な外部制御信号を作り出す。

## 2. 端子説明

Z-80A CPUは標準型40ピンDIPパッケージに納められている。入出力端子配置図を図2-1に示す。以下にそれぞれの機能を説明する。



図2-1 Z-80A CPUの端子配置図

A<sub>0</sub>–A<sub>15</sub>

(アドレス・バス)

トライ・ステート、アクティブ“H”。

A<sub>0</sub>–A<sub>15</sub>は16ビットのアドレス・バスである。このアドレス・バスにより、メモリ（最大64Kバイト）内のデータや入出力デバイスのデータの送受のためのアドレス指定を行う。入出力アレシング用として下位8ビットを用いる。ユーザは直接256の入力ポートまたは256の出力ポートを選択できるようになっている。A<sub>0</sub>がLSB（最下位ビット）となる。リフレッシュ期間には、アドレス・バスの下位7ビットにリフレッシュ用の実効アドレスが乗せられる。

D<sub>0</sub>–D<sub>7</sub>

(データ・バス)

トライ・ステート入出力、アクティブ“H”。

D<sub>0</sub>–D<sub>7</sub>は8ビットの双方向性データ・バスである。データ・バスはメモリ、入出力間、あるいはそれらの相互間で、データ交換を行うために用いる。

$\overline{M}_1$

(マシン・サイクル1)

出力、アクティブ“L”。

$\overline{M}_1$ は、現在のマシン・サイクルが、命令実行中のOPコードのフェッチ・サイクルであるときに出力する。2バイトのOPコードの実行時には、 $\overline{M}_1$ はOPコードのフェッチ・サイクルごとに出されることに注意されたい。これらの2バイトのOPコードを持つ命令では、先頭のOPコードはCB<sub>H</sub>、DD<sub>H</sub>、E<sub>H</sub>あるいはFD<sub>H</sub>で始まっている。

さらに、M<sub>1</sub>は割り込みアクノリッジ時にも出力する。CPUは $\overline{M}_1$ と $\overline{IORQ}$ により外部のデバイスに対して割り込みアクノリッジを通知する。

$\overline{MREQ}$

(メモリ要求)

トライ・ステート出力、アクティブ“L”。

メモリ要求信号は、メモリ読み出し、あるいはメモリ書き込みのための実効アドレスが、アドレス・バスに乗っているときに出される。

|                              |                                                                                                                                                                                                                                                                                                                            |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>IORQ</u><br>(入出力要求)       | トライ・ステート出力、アクティブ "L"。<br><u>IORQ</u> 信号は入出力の読み出し、書き込みのための実効入出力アドレスが、アドレス・バスの下位8ビット上に乗っているときに出される。また <u>IORQ</u> 信号は割り込みアクノリッジ時に <u>M<sub>1</sub></u> とともに出力され、この2つの信号により割り込み応答ベクトルをデータ・バス上に乗せててもよいことを入出力装置に知らせる。この <u>M<sub>1</sub></u> の期間では入出力装置の処理は行われず、割り込みアクノリッジの処理が行われる。                                             |
| <u>RD</u><br>(メモリ読み出し)       | トライ・ステート出力、アクティブ "L"。<br><u>RD</u> はCPUがメモリ、あるいは入出力デバイスからデータを受け入れられる期間で出される。指定された入出力デバイス、あるいはメモリのデータは、この信号でゲートして、CPUデータ・バスに乗せるとよい。                                                                                                                                                                                         |
| <u>WR</u><br>(メモリ書き込み)       | トライ・ステート出力、アクティブ "L"。<br><u>WR</u> は、CPUデータ・バスに、指定したメモリあるいは入出力デバイスにストアするべきデータが乗っているときに出される。                                                                                                                                                                                                                                |
| <u>RFSH</u><br>(リフレッシュ)      | 出力、アクティブ "L"。<br><u>RFSH</u> は、ダイナミック・メモリのためのリフレッシュ・アドレスがアドレス・バスの下位7ビットに乗っているときに出される。なお、ダイナミック・メモリをリフレッシュ(リフレッシュ読み出し)する場合は <u>MREQ</u> 信号も必要である。                                                                                                                                                                           |
| <u>HALT</u><br>(ホールト)        | 出力、アクティブ "L"。<br><u>HALT</u> は、CPUがHALT命令を実行し、ノン・マスカブルあるいは、マスカブルな割り込み待ちとなつたときに出される。<br>ホールト時には、CPUはNOP命令を実行することによりリフレッシュ信号を出し続けている。                                                                                                                                                                                        |
| <u>WAIT</u><br>(ウェイト)        | 入力、アクティブ "L"。<br>この入力信号を用いて、メモリあるいは入出力デバイスがデータの送出の用意ができるない旨をZ-80A CPUに伝える。この信号がアクティブである限り、CPUはウェイト状態を続ける。この期間リフレッシュ信号は出力しないので注意されたい。この信号を用いることによりどのような動作速度のメモリや入出力デバイスに対してもCPUを同期させることができる。                                                                                                                                |
| <u>INT</u><br>(割り込み要求)       | 入力、アクティブ "L"。<br>割り込み要求信号は入出力デバイスから発せられる。ソフト的に(プログラムで)、割り込みの許可フラグ(IFF)がセットしており、 <u>BUSRQ</u> 信号がノン・アクティブならば、割り込み要求は実行中の命令が終わり次第受け付けられる。<br>CPUは割り込みを受け付ければ、アクノリッジ信号( <u>M<sub>1</sub></u> 期間の <u>IORQ</u> )を次の命令サイクルの始めで送出する。第5章(CPUを制御する命令群)に詳細を示すがマスク可能な割り込みは3種ある。                                                       |
| <u>NMI</u><br>(ノン・マスカブル割り込み) | 入力、立ち上がりエッジ検知。<br>ノン・マスカブル割り込み要求は <u>INT</u> より高位の優先順位を持っていて、現在実行中の命令の最後のTサイクルの立ち上がりまでに入力していると、その命令完了後受け付けられる。これは割り込みの許可フラグの状態には関係しない。 <u>NMI</u> 入力でCPUは自動的に、0066 <sub>H</sub> の番地からリストアする。プログラム・カウンタの内容は、割り込みがかけられた元のプログラムへ戻れるように、外部スタッフへ自動的に逃避される。<br>連続してWAITサイクルがあれば、NMIは待たされ、また <u>BUSRQ</u> は <u>NMI</u> より優先順位が高い。 |
| <u>RESET</u>                 | 入力、アクティブ "L"。<br><u>RESET</u> 入力によりプログラム・カウンタは零となり、CPUは初期化される。このとき次の状態となる。<br>1) 割り込みの許可フラグがリセットされる。<br>2) レジスタI=00 <sub>H</sub> にセットされる。<br>3) レジスタR=00 <sub>H</sub> にセットされる。<br>4) 割り込みはモード0にセットされる。<br>リセット期間中、アドレス・バスとデータ・バスは高インピーダンスとなり、すべての制御出力は非アクティブ状態となる。                                                         |

|                             |                                                                                                                                                                             |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>BUSRQ</u><br>(バス要求)      | 入力、アクティブ "L"。<br>バス要求信号により、CPUのアドレス・バス、データ・バスおよびトライ・ステート出力の制御線は、他のデバイスがバスを使用できるようにするため高インピーダンスとなる。<br><u>BUSRQ</u> がアクティブになったとき、その時点でのCPUのマシン・サイクルが終わった瞬間に、バス線は高インピーダンスとなる。 |
| <u>BUSAK</u><br>(バス・アクノリッジ) | 出力、アクティブ "L"。<br>バス・アクノリッジは、CPUのアドレス・バス、データ・バスおよびトライ・ステート制御バスが高インピーダンスとなり、外部デバイスがこれらのバスを使用できるようになった時点で、要求のあったデバイスに対して出力する。                                                  |
| Φ                           | 単相のTTLレベルのクロック入力。                                                                                                                                                           |

### 3. タイミング

Z-80A CPUは基本的な操作を組み合わせ、1ステップずつ命令を実行していく。その操作は次のものから構成される。

メモリ・読み出し、書き込み、

### 入出力デバイス・読み出し、書き込み

## 割り込み、アクノリッジ

すべての命令はたんにこれらの基本的操作を組み合わせたものである。この基本操作は3~6クロックで行われる。これらの操作はCPUを外部デバイスの速度に同期させるために延長することもできる。基本のクロック期間をTサイクルとし、基本操作をMサイクル（マシン・サイクル）とする。図3-1に、ある命令に対して特定のMとTサイクルの配列がどのようにになっているかを例として示す。ただし、この例では、3マシン・サイクル（M1, M2, M3）の命令について示してある。

最初のMサイクルはどの命令でも命令のフェッチ・サイクルである。このフェッチ・サイクルには、4、5、6Tサイクルの3種があるが、ウェイト信号(次節で詳述する。)を用いると、このサイクル数を変えることもできる。このフェッチ・サイクル(M1)は、次に実行すべき命令のOPコードをフェッチするための期間である。

後続するMサイクルで、CPUとメモリ、入出力デバイス間のデータ転送が行われる。これらも基本的には3~5Tサイクルであるが、外部デバイスと同期させるために入力するWAIT信号によりサイクル数は変化する。

次項から基本マシン・サイクル内のタイミングについて説明する。



図3-1 CPU基本タイミング例

すべてのCPUタイミングは、図3-2に示すような、いくつかの非常に簡単なタイミング図に分解できる。ウェイトを含む場合と含まない場合の基本動作タイミングを以下において示す。(ウェイト状態は遅いメモリや入出力デバイスにCPUを同期させるために付加される。)

### 3.1 命令フェッチ

図3-2にM1サイクル（OPコード・フェッチ）のタイミングを示す。プログラム・カウンタの内容はM1サイクルの先頭でアドレス・バス上に乗せられ、クロックの半サイクル後MREQがアクティブとなる。このときすでに、メモリに対するアドレス信号は安定しているので、MREQの立ち下がりエッジをダイナミック・メモリへのチップ・イネーブル・クロックとして直接使用することができる。

RDもメモリから読み出すデータをCPUのデータ・バスに乗せてよいことを指示するためにアクティブとなる。

CPUはデータ・バス上にあるメモリからのデータを、 $T_3$ のクロックの立ち上がりエッジでサンプルする。その立ち上がりエッジで、RD、MREQ信号が切り換わるが、CPUはデータのサンプリングを、RDが非アクティブになる前に行っている。

フェッチ・サイクルのクロック  $T_3$ ,  $T_4$  のステートはダイナミック・メモリをリフレッシュするために使用する。(この期間においては、CPU内ではフェッチされた命令のデコードとその実行を行っているので、外部に対する他の動作は行われない。)

$T_3$ 、 $T_4$ の期間で、アドレス・バスの下位7ビットにメモリのリフレッシュ・アドレスが乗せられ、RFSH信号がアクティブとなる。この信号により、すべてのダイナミック・メモリのリフレッシュがこの期間内に行われるよう指示する。

注意する点として、データ・バスに接続されているはずの他のメモリ・セグメントからデータが乗らないように、リフレッシュの期間にはRD信号は出されていない、ということがあげられる。

リフレッシュ期間のMREQは、すべてのダイナミック・メモリに対するリフレッシュのための読み出しを行うために用いられる。リフレッシュ信号は単独では使用できない。その理由はリフレッシュ・アドレスは、MREQが出力している期間においてのみ安定しているので、MREQと併用しなければならないからである。



図3-2 命令OPコード・フェッチ(M1サイクル)

図3-2AにWAIT信号が入っている場合のフェッチ・サイクルの遅延状態を示す。T<sub>2</sub>およびそれに続く各T<sub>w</sub>のクロックΦの下がリエッジにおいて、CPUはWAIT信号をサンプルする。このサンプル時点において、もしWAITがアクティブならば、次のサイクルはさらに待ち状態になる。この方法を用いると、どのようなタイプのメモリ・デバイスのアクセス時間に対しても読み出し時間を延長することによって対処できる。



図3-2A 待ち状態を含む命令OPコード・フェッチ

### 3.2 メモリ読み出し、書き込み

図3-3はOPコード・フェッチ(M1サイクル)以外の場合のメモリの読み出し、書き込みサイクルのタイミング図である。

これらのサイクルは、メモリ側から出されるWAIT信号がなければ、通常3クロック・サイクルの長さである。

MREQ信号とRD信号はフェッチ・サイクルの場合と同様に用いられる。



図3-3 メモリ読み出し、書き込みサイクル

メモリ書き込みサイクルにおいても、MREQはアドレス・バスが安定したときにアクティブになるので、これをダイナミック・メモリのチップ・イネーブル用に直接使用することができる。

WR出力はデータ・バスが安定になったときアクティブとなるので、これを直接メモリの読み出し、書き込みパルスとして使用してもよい。実際上、このWR出力はほとんどのタイプの半導体メモリの読み出し、書き込み信号として使用できる。

さらに、WR信号はアドレス・バス、データ・バスの内容が変化するサイクルの前のTサイクルの中央で非アクティブとなるので、実際上どんなタイプの半導体メモリのオーバ・ラップ条件に対しても、問題なく使用できる。

図3-3Aにメモリの読み出しや書き込み動作時にWAIT要求信号がある場合の状態を示す。

この動作はさきにフェッチ・サイクルのところで述べた動作と同様である。実際には、メモリの読み出しと書き込みサイクルは同時に起こり得ないが、この図では便宜上これらを同一図上に書いてある。



図3-3A 待ち状態を含むメモリ読み出し、書き込みサイクル

### 3.3 入力、出力サイクル

図3-4に入出力に対する読み出しや書き込みの動作を示す。この場合、自動的に1つの待ち状態 $T_w$ サイクルが挿入される点に注意されたい。

このようにした理由は入出力装置の処理を行う場合、IORQがアクティブになってからCPUがWAIT信号をサンプルするまでの時間が非常に短いため、もしこの余分なステート $T_w$ がなければポート・アドレスをデコードしてからWAIT信号を起動していたのでは時間が足りないからである。

さらに、この待ち状態を設けなければ、MOS入出力デバイスを組み入れて、CPUを最高速で動作させるということもむずかしくなる。

この $T_w$ の期間にWAIT要求信号をサンプリングする。メモリの読み出しの場合と同様に、入出力読み出し動作においても指定したポートをデータ・バスに接続するためにはRD信号を使用すればよい。入出力書き込み動作において、入出力ポートのクロックとしてWR信号を用いるが、充分なオーバ・ラップ時間が自動的に作られるのでこの立ち上がりエッジをデータ・クロックとして使用することができる。

図3-4AにWAIT信号が入った場合に、余分の待ち状態サイクルが追加されるようすを示す。この動作はさきに述べた例(図3-2、図3-2Aなど)と同様である。



図3-4 入力、出力サイクル



図3-4A 待ち状態を含む入力、出力サイクル

### 3.4 バス要求／アクノリッジ・サイクル

図3-5にバス要求／アクノリッジ・サイクルのタイミングを示す。

CPUは、各マシン・サイクルの最終クロックの立ち上がりエッジでBUSRQ信号を調べ、もしBUSRQ信号がアクティブならば、次のクロック・パルスの立ち上がりエッジでアドレス、データ、トライ・ステート制御線を高インピーダンスにする。この時点以後、外部のデバイスによりこれらのバスを制御でき、メモリと入出力間のデータ転送に使用することが可能になる。(これは一般にサイクル・スティール方式のダイレクト・メモリ・アクセスDMAとして知られている。)

バス要求に対するCPUの応答遅れは大きくとも1マシン・サイクル長であり、外部のコントローラは必要な時間だけバスを制御できる。

しかしダイナミック・メモリを使用していて、長時間DMAサイクルを続けたい場合には、外部の制御回路によりダイナミック・メモリのリフレッシュが行えるようにしておかなければならない。

このような状態は、多数のデータ・ブロックをDMAで転送する場合にのみ生じる。

さらに、バス利用可の状態では、NMI信号あるいはINT信号による割り込みは無視される点に注意する必要がある。



図3-5 バス要求／アクノリッジ・サイクル

### 3.5 割り込み要求／アクノリッジ・サイクル

図3-6に、割り込みサイクルに関連したタイミング例を示す。

CPUは各命令実行の最終クロックの立ち上がりエッジで割り込み信号INTをサンプルする。

CPU内部の割り込みイネーブル・フリップ・フロップがセットされていなければこの信号は受け付けられない。また、BUSRQ信号がアクティブであるときも同様である。

割り込み信号を受け付けると、CPUは特別なM1サイクルを発生する。

このM1サイクルの期間中に、IORQ信号が通常のMREQ信号に代ってアクティブとなる。これによって、割り込みの要求を出したデバイスからデータ・バス上に、8ビットのベクトルを乗せてもよい状態になる。これを割り込みアクノリッジという。

このサイクルには、自動的に待ち状態2サイクルが追加されるので注意を要する。

これらのサイクルの追加によって、リップル・プライオリティの割り込み方式が使用できるようになる。待ち状態として2サイクルあれば、リップル信号が安定に伝わり、入出力デバイスが出した応答ベクトルをCPUが確実にとり込むための時間としては、これで充分である。

第7章で、CPU内での割り込み応答ベクトルの処理形式について詳述してあるので参照されたい。



図3-6 割り込み要求／アクノリッジ・サイクル

図3-6A、図3-6Bにプログラマブル・カウンタを使用してアクノリッジ時間を延長する方法を示す。



図3-6A ウェイト・ステートを含む延長された割り込みアクノリッジ



図3-6B ウェイト・ステートを1つ加えた要求／アクノリッジ・サイクル

### 3.6 ノン・マスカブル割り込みの応答

図3-7にノン・マスカブル割り込みのある場合の要求／アクノリッジ・サイクルの例を示す。

この信号はINTと異なり立ち下がりエッジが有効信号となっており、さらに各命令のどのタイミングで入力してもよい。ただし、現命令の実行完了後に割り込みアクノリッジ・サイクルに入るためには、少なくとも命令の最後のTサイクルまでに、NMIが立ち下がっていなければならない。この信号線はINT信号よりも優先順位が高く、またソフトウェアによってその機能を無効にすることもできない。

CPUはこのノン・マスカブル割り込みに対しては通常のメモリ読み出し動作と同じ応答をする。異なる点は、CPUがその時点でのデータ・バス上の内容を無視して自動的にPC（プログラム・カウンタ）の内容を外部スタックに退避した後、0066<sub>H</sub>番地へジャンプする点である。

この割り込み方式を使用する場合、ノン・マスカブル割り込みのためのサービス・ルーチンは0066<sub>H</sub>番地から書いておかねばならない。

### 3.7 ホールト状態解除

プログラム内のホールト命令ではCPUはNOP命令を実行し続けるが、割り込み入力があれば、この状態から抜け出る。（この場合の割り込みはノン・マスカブル割り込みか、割り込みフリップ・フロップがセットされている場合のマスカブル割り込みのいずれでもよい。）

これら2種の割り込み線を図3-8に示すように、各T<sub>4</sub>サイクルのクロックの立ち上がりエッジで調べて上述のいずれかであれば、CPUは次のクロックの立ち上がりエッジで、ホールト状態から解除される。

次のサイクルで、受け付けた割り込みの種類に応じてそれぞれの割り込みのアクノリッジ・サイクルに入ることになる。

もし、同時にノン・マスカブルとマスカブルの割り込み信号が入った場合には、優先順位の高いノン・マスカブル割り込みが受け付けられる。

ホールト状態でNOP命令を実行させている理由は、メモリ用のリフレッシュ信号を出し続けるためである。

この状態での各サイクルは、メモリからのデータを無視する以外は通常のM1（フェッチ）サイクルと同様であり、CPU内部で自動的にNOP命令を実行している。ホールト命令を実行すると、CPUはホールト状態に入ったことを外部に対して知らせるためにHALT信号がアクティブとなる。



図3-7 ノン・マスクアブル割り込み、要求動作



図3-8 ホールト状態解除

## 4. 命令セット

Z-80A CPU には158種の命令があり、これらの命令には 8080A CPU の78種の命令がすべて含まれている。命令群は大別して次のようなグループに分けられる。

- ロード、交換
- ブロック転送、ブロック・サーチ
- 算術、論理処理
- ローテイト、シフト
- ビット操作（セット、リセット、テスト）
- ジャンプ、コール、リターン
- 入力、出力
- CPU制御

### 4.1 命令の型について

ロード命令は、データとCPU内部のレジスタ間で、あるいはCPUレジスタと外部メモリ間で、データを転送する機能を持っている。

この命令では、データを取り出すソースの番地と、それを格納するデスティネーションの番地を指定しなければならない。

ロード命令ではその実行後においてソースの内容は変化しない。

ロード命令の例として、レジスタ C からレジスタ B へデータを移すというような汎用レジスタ間のデータ転送命令がある。

また各CPUレジスタあるいは外部メモリに直接データをロードする命令や、CPUレジスタとメモリ間のデータの転送を行う命令がある。

交換命令は2つのレジスタ内のデータを入れ替える機能がある。

Z-80A にはブロック転送というユニークな命令群がある。1命令で、どのようなサイズのメモリ・ブロックでも、メモリの他の領域に移し換える。このブロック転送の命令群は、大量のデータを処理する必要のあるときに非常に有効なものである。

Z-80A のブロック・サーチ命令群も上記のような処理に有効である。1命令で必要な範囲だけ外部メモリのブロックをサーチし、特定の8ビット・キャラクタを探し出せる。目的のキャラクタが見つかれば命令は自動的に終了する。

これらの命令の実行中に割り込みをかけることは可能であり、長時間CPUが独占されてしまうという弊害はない。

算術および論理演算命令は、アキュムレータ内のデータとCPU汎用レジスタあるいは外部メモリ内のデータの操作を行うものである。

この操作の結果はアキュムレータに入り、その結果に応じて関係するフラグがセットされる。

算術演算命令の例として、アキュムレータと外部メモリの内容の加算命令がある。加算の結果はアキュムレータに入る。

これらの命令群のうちには、16ビットCPUレジスタ間の加減算命令などがある。

ローテイト、シフトの命令群によりどのようなレジスタまたはメモリであれ、キャリまたはキャリなしに、算術的または論理的に左右にローテイトできる。またアキュムレータ内の1ディジットとメモリ内の2ディジットで左右にローテイトすることもできる。

ビット操作命令は1命令でアキュムレータ、各汎用レジスタ、あるいは外部メモリ内のデータのどのビットでも、セット、リセットあるいはテストができるものである。たとえば、レジスタ H 内のデータの最上位ビットをリセットする、といったことが可能である。

この命令群は、制御への応用や一般的のプログラミングにおいてフラグを多用する場合にとくに有効なものである。

ジャンプ、コール、リターン命令はユーザ・プログラムの流れを変えるためのものである。

この命令群にはいくつかの異なった形式があり、これらの形式により外部メモリの特定アドレスからプログラム・カウンタに更新データ（新しいアドレス値）を取ってくる形式も異なる。

ジャンプのうち、リストア命令はユニークなもので、8ビットOPコードの一部に新アドレスを含んでいる。この命令では外部メモリのページ・ゼロ内の8箇所のアドレスを指定できる。

プログラム・ジャンプには、レジスタ HL、IX、IY の内容を直接PCに移して行う方法もあり、ジャンプ先のアドレスをその時点で実行中のルーチンに関連させて決めることもできる。

Z-80A の入出力命令群は、外部メモリあるいはCPU汎用レジスタ群と多数の外部入出力デバイス群とのデータ転送に適している。

入出力処理を行う際のポート番号はアドレス・バスの下位8ビットにより256ポートを指定できる。ある種の命令では、このポート番号を命令の2バイト目に持ち、また他の命令では、Cレジスタの内容で指定できるようになっている。

C レジスタを入出力デバイスのポインタとして用いる方式の利点は、異なった入出力ポートでも共通の駆動ルーチンが使用できる点にある。これは、ルーチンが ROM に入っていて、アドレスが OP コードの一部になっている場合には不可能である。

他の特長として、入力命令でフラグ・レジスタが自動的にセットされるので、入力データの状態（たとえば、入力のパリティ）を決めるのに余分の命令を使用する必要がない点があげられる。

Z-80A CPU には、自動的に 256 バイト以上のブロック・データをメモリのある領域から入出力ポートへ、またその逆に転送する命令もある。

対になっている汎用レジスタ群を両方使用して、これらの命令により高速の入出力ブロック転送ができる。

この入出力命令群の真価は次の例でよくわかるだろう。割り込み駆動形式を用いて倍密度フロッピー・ディスクを動作させる場合、Z-80A CPU は必要なフロッピー・ディスク・フォーマット（すなわち、プレ・アンプル、アドレス、データ、CRC コード使用・未使用など）をプログラムによってたやすく用意できる。

最後の CPU 制御命令は種々の選択、モード設定のためのものである。この命令群には割り込みイネーブル・フリップ・フロップをセット、リセットしたり、割り込み応答のモードを設定したりする命令などがある。

#### 4.2 アドレシング・モード

Z-80A 命令群には、CPU 内部レジスタ、外部メモリあるいは入出力ポート内にストアされたデータの操作命令が多く設けられている。

これらのデータのある番地の指定を行うことをアドレシングという。

この節では、Z-80A で使用されるアドレシングのタイプについて簡単な説明をし、あとで各命令群の説明を行う際にさらに詳しく述べる。

**イミディエット・アドレシング** このアドレシング・モードでは、OP コードに続く 1 バイトを実効オペランドとする。



例として、アキュムレータに定数をロードするような命令がある。

OP コードに続く 1 バイトが直接その定数値となる。

**拡張イミディエット・アドレシング** このモードは上述のモードを拡張したものであり、オペランドが 2 バイトになっているものである。



たとえば、16 ビット（2 バイト）データを HL レジスタ対にロードする命令がある。

**ゼロ・ページ修飾アドレシング** Z-80A には、メモリのゼロ・ページの 8 箇所を 1 バイトで指定する特別なコール命令がある。これはリストアート命令と呼ばれ、PC をゼロ・ページの実効アドレスにセットするものである。この命令の値は、共通に使用するサブルーチンのアドレス（16 ビット）を 1 バイトで指定できるようになっていて、ステップ数を節約できる。



**相対アドレシング** このモードでは、OP コードに続く 1 バイトにより、ジャンプ命令のある場所からのディスプレイスメントを指定する。このディスプレイスメントは符号付の 2 の補数であり、次の命令の先頭番地の値にこのディスプレイスメントを加えた値がジャンプ先の番地となる。



このモードは近隣のアドレスへ2バイトでジャンプでき、3バイトのジャンプ命令を使用する必要がないときに役に立つ。多くの場合、関係のあるプログラムのセグメントは近接して置かれるのが普通でありこのモードを利用してメモリの節約が図れる。

符号付2の補数の範囲は-128から+127であり、これをA+2に対して加えるのでOPコードのアドレスから計算すると、+129から-126の範囲へのジャンプ指定となる。

このモードの最大の特長はリロケータブル・コードとなる点である。

**拡張アドレシング** このアドレシング・モードは命令に2バイトのアドレス・データを含む。64Kバイト内のどのアドレスに対しても、プログラムをジャンプさせられる。



拡張アドレシングはメモリのある位置から他の位置へジャンプしたり、ある位置でのデータの出し入れの命令に必要なものである。

このモードにおいて、ソースあるいはデスティネーション・アドレスを指定するオペランドとしてこれを(nn)と書いたとき、nn番地のメモリの内容を意味する。ここで、nnは16ビットのアドレス指定値であり、括弧の中のnnは2バイトのメモリ番地ポインタである。

たとえば(1200)は1200番地のメモリの内容である。

**インデックス・アドレシング** このアドレシングでは、OPコードのあとにはメモリ・アドレスのポインタである2つのインデックス・レジスタのうち、いずれか一方(OPコードで指定する)の内容に加えるディスプレイスメントを指定するデータ・バイトが置かれる。この操作ではインデックス・レジスタの内容は変わらない。



インデックス・アドレシング命令の例として、アキュムレータにメモリ(インデックス+ディスプレイスメント)の内容をロードする命令がある。ディスプレイスメントは符号付の2の補数である。

インデックス・モードの特長として、データ・テーブルを使用する場合、インデックス・レジスタにはどのテーブルのスタート・アドレスでも入れておけるので、非常に簡単に使用できるという点がある。2つのインデックス・レジスタがあるので、2つ以上のテーブルをよく使用する必要があるときには都合がよい。インデックス・モードも相対アドレシングと同様にリロケータブル・コードである。

インデックス・レジスタとしてIX、IYがある。インデックス・アドレシングでは次のような書き方が使用される。

(IX+d) または (IY+d)

ここで、dはOPコードのあとに置かれるディスプレイスメントである。括弧はこの中の値が外部メモリのポインタとして使用されていることを意味している。

**レジスタ・アドレシング** Z-80Aの多くのOPコードにはレジスタ指定ビットがあり、どのCPUレジスタを操作用として使用するかを指定するようになっている。レジスタ・アドレシングの例として、Bレジスタの内容をCレジスタにロードする命令などがある。

**インプライド・アドレシング** このモードでは、OPコード自体がレジスタ指定を含んでいて、1つまたは2つのレジスタが自動的

に指定される。

たとえば、算術演算命令では、つねにアキュムレータが結果をセットするレジスタとなる。

**レジスタ間接アドレシング** このタイプでは、メモリ内の位置指定のポインタとして16ビットのレジスタ・ペア（例：HL）が使用される。これは大変強力で役に立つ命令である。

|        |             |
|--------|-------------|
| OP コード | 1 または 2 バイト |
|--------|-------------|

例として、HL レジスタの内容をメモリの位置ポインタとし、その位置の内容をアキュムレータにロードするといった命令がある。インデックス・アドレシングは、インデックス・レジスタの内容にディスプレイスメントを加えるといった操作を含んでいる以外は、レジスタ間接アドレシング・モードの一形式である。

ロック転送、ロック・サーチの命令はこのモードの拡張形であり、レジスタの内容の自動インクリメント、デクリメントおよび比較機能が付加されている。間接モードでの記法はレジスタ名を括弧で囲む。そしてそのレジスタをポインタとする。メモリ位置ポインタが HL レジスタの内容である場合、

(HL)

と書く。間接モードでは16ビット・オペランドをよく使用するがこの場合、レジスタの内容はまず、オペランドの下位バイトを指し、次にレジスタの内容が自動的にインクリメントされ、上位バイトを指す。

**ビット・アドレシング** Z-80Aには、多くのビット・セット、リセットおよびテスト命令がある。これらの命令は、どのメモリ位置、CPU レジスタに対しても有効で、前述した 3 モード（レジスタ、レジスタ間接、およびインデックス）のいずれかのアドレシング・モードでビット操作ができる。

8 ビットのうちのどのビットを操作するかは OP コード内の 3 ビットにより指定する。

#### アドレシング・モードの組み合わせ

これらの命令には、算術演算やロード命令のように、1 つ以上のオペランドが含まれている命令が多い。これらの命令では、2 つのアドレシング・モードを組み合わせて用いる。たとえば、ロード命令で、ソースの指定はイミディエット、デスティネーションの指定はレジスタ間接あるいはインデックス・アドレシングで行う場合などである。

### 4.3 命令 OP コード

この節では、Z-80A の各命令について説明し、それらの OP コード表を示す。これら各表の陰影部で示した OP コードは 8080A のものと同一である。

各命令に対応するアセンブリ語ニーモニックを同時に示す。OP コードは16進数表現にしてあり、1 バイトのコードは 2 行の16進数、2 バイトでは 4 行の16進数で書く。16進から 2 進への変換は次の表を利用するとよい。

| 16進数 | 2進数    | 10進数 | 16進数 | 2進数    | 10進数 |
|------|--------|------|------|--------|------|
| 0    | = 0000 | = 0  | 8    | = 1000 | = 8  |
| 1    | = 0001 | = 1  | 9    | = 1001 | = 9  |
| 2    | = 0010 | = 2  | A    | = 1010 | = 10 |
| 3    | = 0011 | = 3  | B    | = 1011 | = 11 |
| 4    | = 0100 | = 4  | C    | = 1100 | = 12 |
| 5    | = 0101 | = 5  | D    | = 1101 | = 13 |
| 6    | = 0110 | = 6  | E    | = 1110 | = 14 |
| 7    | = 0111 | = 7  | F    | = 1111 | = 15 |

Z-80A の命令ニーモニックとして OP コード単独のものと、OP コードと 1 つまたは 2 つのオペランドより構成されているものがある。オペランドのない命令はオペランドが OP コードに内蔵されていると考える。

1 つの論理オペランドのみの場合、あるいはロジカル OR のような片方のオペランドが不定の場合には、1 オペランド・ニーモニックになっている。

2 変数を扱う命令は 2 オペランド・ニーモニックである。

#### ロードと交換命令 (LD, PUSH, POP)

表 4-1 に CPU の 8 ビット・ロード命令群を示す。各命令で使用されるアドレシングの型も併記しておく。データのソースは上欄に、デスティネーションは左側端に示してある。例として、B レジスタから C レジスタへのロードは OP コード 48H となる。

表中のコードはすべて16進数表現であるが、この $48_{\text{H}}$ （2進数 $0100\ 1000$ ）コードはM1サイクル時に外部メモリからCPUにフェッチされ、CPUはこれをデコードしてレジスタ間のデータの転送を実行する。

この命令群のアセンブリ語ニーモニックはLDであり、これのあとにデスティネーション、ソースの順で書く。（LD DEST., SOURCE）

これらの命令ではいくつかのアドレシング・モードを組み合わせて使用できる。たとえば、ソースをレジスタ・モード、デスティネーションをレジスタ間接モードとした命令では次のように記述できる。

LD (HL), D

これはHLレジスタで指定されたメモリへDレジスタの内容をロード（移す）するニーモニック命令で、OPコードは $72_{\text{H}}$ である。ここでHLを囲んだ括弧は、HLの内容をメモリの位置ポインタとして使う、ということを意味している。

Z-80Aのアセンブリ言語はプログラミングが容易なようにできている。

各命令は自己説明的（セルフ・ドキュメンティング）で意味がわかりやすく、プログラムの保守も楽である。

Z-80Aで使用されるOPコードには、2バイトのものがいくつかあるので注意されたい。

命令には8ビット、16ビット、24ビット、32ビットの命令があるが、これはメモリの有効利用に役立つ。つまり、算術、論理演算のような命令で、8ビットで済む場合にでも、16ビット固定の命令を使用しなければならないとしたら、メモリのむだになるからである。

LD命令で、ソースあるいはデスティネーションの位置のアドレシングにインデックス・モードを使用した場合、メモリは3バイト必要で、3バイト目はディスプレイスメントdとなる。

たとえば、次のような命令ニーモニックは、IXの内容から8バイト目の場所の内容をレジスタEにロードするもので、数字8がオフセットでありディスプレイスメントとなる。

LD E, (IX+8)

命令のメモリ上での順序は次のようになる。



拡張アドレシング命令も3バイトである。メモリ $6F32_{\text{H}}$ 番地の内容をアキュムレータにロードする次のような命令では、メモリ上の順序は次のようになる。

LD A, (6F32H)



アドレスの下位バイトはつねに第1オペランドである点に注意しなければならない。

汎用8ビット・レジスタへ直接ロードする命令は2バイト命令である。値 $36_{\text{H}}$ をレジスタHへロードする命令は次のように書ける。

LD H, 36H



デスティネーション側のメモリをインデックス・アドレシングで指定し、ソース側をイミディエットで指定してロードする場合、4バイトを必要とする。

LD (IX-15), 21H



インデックス・アドレッシングでは、いつもディスプレイスメントはOPコードの直後にあるので注意を要する。

表4-2に16ビット・ロード命令群のOPコードを示す。これは8ビットのものとよく似ている。注意すべき点は、拡張アドレッシングは全部のレジスタ・ペアに対して使用できることである。

さらに、スタック・ポインタを用いたレジスタ間接アドレッシング命令として、PUSHとPOP命令がある。これらの二モニックはそれぞれ“PUSH”、“POP”である。この命令ではスタックへあるいはスタックからプッシュやポップする際、スタックポインタが自動的にインクリメントあるいはデクリメントされる点が、他の16ビット命令と異なっている。

#### PUSH AF

これはOPコードF5Hの1バイト命令であるが、次のような操作が自動的に行われる。

- (SP)を-1する。
- LD (SP), A
- (SP)を-1する。
- LD (SP), F

この結果、外部スタックは次のようになる。



| ソース       |        |          |          |               |               |               |               |               |               |               |      |      |        |               |               |                    |         |
|-----------|--------|----------|----------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|------|------|--------|---------------|---------------|--------------------|---------|
| インプライド    |        |          | レジスタ     |               |               |               |               |               |               |               |      |      |        | インデックス        |               | イミディエット            |         |
| I         | R      |          | A        | B             | C             | D             | E             | H             | L             | (HL)          | (BC) | (DE) | (IX+d) | (IY+d)        | (nn)          | n                  |         |
| レジスタ      | A      | ED<br>57 | ED<br>5F | 7F            | 78            | 79            | 7A            | 7B            | 7C            | 7D            | 7E   | 0A   | 1A     | DD<br>7E<br>d | FD<br>7E<br>d | 3A<br>n<br>n       | 3E<br>n |
|           | B      |          |          | 47            | 40            | 41            | 42            | 43            | 44            | 45            | 46   |      |        | DD<br>46<br>d | FD<br>46<br>d |                    | 06<br>n |
|           | C      |          |          | 4F            | 48            | 49            | 4A            | 4B            | 4C            | 4D            | 4E   |      |        | DD<br>4E<br>d | FD<br>4E<br>d |                    | 0E<br>n |
|           | D      |          |          | 57            | 50            | 51            | 52            | 53            | 54            | 55            | 56   |      |        | DD<br>56<br>d | FD<br>56<br>d |                    | 16<br>n |
|           | E      |          |          | 5F            | 58            | 59            | 5A            | 5B            | 5C            | 5D            | 5E   |      |        | DD<br>5E<br>d | FD<br>5E<br>d |                    | 1E<br>n |
|           | H      |          |          | 67            | 60            | 61            | 62            | 63            | 64            | 65            | 66   |      |        | DD<br>66<br>d | FD<br>66<br>d |                    | 26<br>n |
|           | L      |          |          | 6F            | 68            | 69            | 6A            | 6B            | 6C            | 6D            | 6E   |      |        | DD<br>6E<br>d | FD<br>6E<br>d |                    | 2E<br>n |
| デスティネーション | (HL)   |          |          | 77            | 70            | 71            | 72            | 73            | 74            | 75            |      |      |        |               |               |                    | 36<br>n |
|           | レジスタ間接 | (BC)     |          | 02            |               |               |               |               |               |               |      |      |        |               |               |                    |         |
|           | (DE)   |          |          | 12            |               |               |               |               |               |               |      |      |        |               |               |                    |         |
| インデックス    | (IX+d) |          |          | DD<br>77<br>d | DD<br>70<br>d | DD<br>71<br>d | DD<br>72<br>d | DD<br>73<br>d | DD<br>74<br>d | DD<br>75<br>d |      |      |        |               |               | DD<br>36<br>d<br>n |         |
|           | (IY+d) |          |          | FD<br>77<br>d | FD<br>70<br>d | FD<br>71<br>d | FD<br>72<br>d | FD<br>73<br>d | FD<br>74<br>d | FD<br>75<br>d |      |      |        |               |               | FD<br>36<br>d<br>n |         |
| 拡張アドレス    | (nn)   |          |          | 32<br>n<br>n  |               |               |               |               |               |               |      |      |        |               |               |                    |         |
| インプライド    | I      |          |          | ED<br>47      |               |               |               |               |               |               |      |      |        |               |               |                    |         |
|           | R      |          |          | ED<br>4F      |               |               |               |               |               |               |      |      |        |               |               |                    |         |

表4-1 8ビットロード "LD"

ポップ命令はプッシュ命令とちょうど逆の操作になる。

これらの命令では、オペランドは16ビットであり、上位バイトが最初にプッシュされ、また最後にポップされる。

PUSH BC は PUSH B そして C  
 PUSH DE は PUSH D そして E  
 PUSH HL は PUSH H そして L  
 POP HL は POP L そして H

となる。

ソースに対する拡張イミディエット・アドレシングでは、OPコードのあとに2バイトのデータが付く。

LD DE, 0659H

|       |    |                 |
|-------|----|-----------------|
| アドレスA | 11 | OPコード           |
| A+1   | 59 | 下位バイト(レジスタEへ入る) |
| A+2   | 06 | 上位バイト(レジスタDへ入る) |

すべての拡張イミディエットあるいは拡張モードでは、下位バイトがOPコードのすぐあとに続く。

表4-3にZ-80Aに設けられている16ビット・データの交換命令を示す。

OPコード $08_H$ は、2組のアキュムレータとフラグ類の切り換えをプログラムで実行させるためのもので、また $D9_H$ で、6個の汎用レジスタ群をもう一方のレジスタ群に切り換えることができる。

これらのOPコードは、これ以下に短くできないという最短の1バイト命令であり、2セットのレジスタ群を即時切り換えて使用できるので、高速の割り込み応答が必要な場合に利用できる。

#### ロック転送およびサーチ

表4-4に、非常に特長があり、しかも強力なロック転送命令を示す。これらの操作は次の3つのレジスタを使用して行う。

HL ソースの位置のポインタ

DE デスティネーションのポインタ

BC バイト・カウンタ

プログラムでは、これらのいずれかのロック転送命令を使用するまえに、上記の3つのレジスタに値をセットしておく必要がある。

LDI（ロード&インクリメント）命令は、(HL)で指定される位置から(DE)で指定される位置へ、1バイトだけ転送する。その後、2つのレジスタの内容はインクリメントされて次の位置を指している。

バイト・カウンタ(BC)はデクリメントされる。この命令は、データ転送の途中で他の処理を行いたい場合に便利である。

LDIR（ロード&インクリメント&リピート）命令はLDIの拡張形で、自動的に全部（バイト・カウンタが零になるまで）データを転送してしまいたい場合に便利である。

16ビット・レジスタを使用するので、ブロックの大きさは最大64Kバイト（1Kバイト=1024バイト）まで指定でき、ソース、デスティネーションのアドレスはメモリ空間のどこにでも配置できる。

さらに、ブロック相互のオーバラップも可能で、3つのレジスタ・ペアを使用して扱えるデータに何ら制限のないことに注目されたい。

LDDとLDDRはさきの2つとよく似ている。ただ、データ転送後、レジスタ・ペア HL、DE がデクリメントされる点が異なっていて、位置の高い方から低い方へ転送する場合に使用するのに適している。

|           |        | ソース  |    |                    |                    |              |                    |                    |                    |                    |          |
|-----------|--------|------|----|--------------------|--------------------|--------------|--------------------|--------------------|--------------------|--------------------|----------|
|           |        | レジスタ |    |                    |                    |              |                    |                    | 拡張イミディエット          | 拡張アドレス             | レジスタ間接   |
|           |        | AF   | BC | DE                 | HL                 | SP           | IX                 | IY                 | nn                 | (nn)               | (SP)     |
| デスティネーション | AF     |      |    |                    |                    |              |                    |                    |                    |                    | F1       |
|           | BC     |      |    |                    |                    |              |                    |                    | 01<br>n<br>n       | ED<br>4B<br>n<br>n | C1       |
|           | DE     |      |    |                    |                    |              |                    |                    | 11<br>n<br>n       | ED<br>5B<br>n<br>n | D1       |
|           | HL     |      |    |                    |                    |              |                    |                    | 21<br>n<br>n       | 2A<br>n<br>n       | E1       |
|           | SP     |      |    |                    | F9                 |              | DD<br>F9           | FD<br>F9           | 31<br>n<br>n       | ED<br>7B<br>n<br>n |          |
|           | IX     |      |    |                    |                    |              |                    |                    | DD<br>21<br>n<br>n | DD<br>2A<br>n<br>n | DD<br>E1 |
|           | IY     |      |    |                    |                    |              |                    |                    | FD<br>21<br>n<br>n | FD<br>2A<br>n<br>n | FD<br>E1 |
| PUSH命令 →  | 拡張アドレス | (nn) |    | ED<br>43<br>n<br>n | ED<br>53<br>n<br>n | 22<br>n<br>n | ED<br>73<br>n<br>n | DD<br>22<br>n<br>n | FD<br>22<br>n<br>n |                    |          |
|           | レジスタ間接 | (SP) | F5 | C5                 | D5                 | E5           |                    | DD<br>E5           | FD<br>E5           |                    |          |

(注) PUSHおよびPOP命令の全実行が終ったあとにSPが修正される。

POP命令

表4-2 16ビットロード“LD”

|        |                      | インプライド・アドレシング |                |    |          |          |
|--------|----------------------|---------------|----------------|----|----------|----------|
|        |                      | AF'           | BC', DE' & HL' | HL | IX       | IY       |
| インプライド | AF                   | 08            |                |    |          |          |
|        | BC,<br>DE<br>&<br>HL |               | D9             |    |          |          |
|        | DE                   |               |                | EB |          |          |
| レジスタ間接 | (SP)                 |               |                | E3 | DD<br>E3 | FD<br>E3 |

表4-3 交換

|           |        | ソース    |          |                                                                     |
|-----------|--------|--------|----------|---------------------------------------------------------------------|
|           |        | レジスタ間接 | (HL)     | HLはソースのポインタ<br>DEはデスティネーションのポインタ<br>BCはバイトカウンタ                      |
| デスティネーション | レジスタ間接 | (DE)   | ED<br>A0 | "LDI" - Load (DE) ← (HL)<br>Inc HL & DE, Dec BC                     |
|           |        |        | ED<br>B0 | "LDIR" - Load (DE) ← (HL)<br>Inc HL & DE, Dec BC, Repeat until BC=0 |
|           |        |        | ED<br>A8 | "LDD" - Load (DE) ← (HL)<br>Dec HL & DE, Dec BC                     |
|           |        |        | ED<br>B8 | "LDDR" - Load (DE) ← (HL)<br>Dec HL & DE, Dec BC, Repeat until BC=0 |

表4-4 ブロック転送グループ

| サーチロケーション |                                                          |
|-----------|----------------------------------------------------------|
| レジスタ間接    | (HL)                                                     |
|           | HLはアクチュムレータの内容と照合するメモリの位置のポインタ<br>BCはバイトカウンタ             |
| ED<br>A1  | "CPI"<br>Inc HL, Dec BC                                  |
| ED<br>B1  | "CPIR" Inc HL, Dec BC<br>repeat until BC=0 or find match |
| ED<br>A9  | "CPD" Dec HL & BC                                        |
| ED<br>B9  | "CPDR" Dec HL & BC<br>Repeat until BC=0 or find match    |

表4-5 ブロックサーチ

表4-5に4種のブロック・サーチ命令のOPコードを示す。

CPI (コンペア&インクリメント) は、HL レジスタで指定されるメモリの内容とアキュムレータ内のデータを比較し、その結果をフラグ・ビット（第5章を参照）の1つにセットする。その後、HL レジスタ・ペアをインクリメントし、バイト・カウンタ (BC レジスタ・ペア) をデクリメントする。

CPIR は CPI 命令の拡張形であり、バイト・カウンタが零になるまで比較を繰り返す。この1命令で、ある8ビット・キャラクタを全メモリ内で探すこともできる。

CPD (コンペア&デクリメント) と CPDR (コンペア&デクリメント&リピート) は同様な命令であるが、各比較のうち HL レジスタをデクリメントする点のみが異なっている。したがって、逆方向へのメモリのサーチが行える。（このサーチはメモリ・ブロックの最高アドレス近くからスタートし、下位アドレスへすすむ。）

このブロック転送、サーチ命令は、文字列の操作などの応用に非常に強力な道具となる。

#### 算術と論理演算

表4-6にアキュムレータを中心とした8ビット算術演算命令群を示す。インクリメント (INC)、デクリメント (DEC) 命令もともに示す。

これらのうち、INC、DEC を除いた8ビット操作命令で、アキュムレータと表に示したソース・データとの間の操作が行われ、その結果は、コンペア (CP) 命令を除き、アキュムレータに置かれる。CP では命令実行の前後でアキュムレータの内容は変わらない。これらの操作の結果で、フラグ・レジスタがセットされる。（各命令でセットされるフラグの詳細については、第5章に述べる。）

INC、DEC 命令は、レジスタはどのメモリの位置に対しても実行できるが、ソースとデスティネーションを別々にとることはできない。

ソース・オペランド（ソースの指定）にインデックス・レジスタを使用した場合、ディスペリスマントをすぐあとに続けて指定しておく。

イミディエット・アドレシングを使用した場合には、実際のオペランドで直接指定する。例として、次のような命令では、あとのようなメモリ配置となる。

AND 07H

|       |    |        |
|-------|----|--------|
| アドレスA | E6 | OP コード |
| A+1   | 07 | オペランド  |

アキュムレータの内容が F3H であれば、結果として 03H が得られ、最終的にアキュムレータの内容は 03H となる。

## ソース

|                      | レジスタ・アドレッシング |    |    |    |    |    |    | レジスタ間接 | インデックス        |               | イミディエット |
|----------------------|--------------|----|----|----|----|----|----|--------|---------------|---------------|---------|
|                      | A            | B  | C  | D  | E  | H  | L  |        | (IX+d)        | (IY+d)        |         |
| "ADD"                | 87           | 80 | 81 | 82 | 83 | 84 | 85 | 86     | DD<br>86<br>d | FD<br>86<br>d | C6<br>n |
| ADD w CARRY<br>"ADC" | 8F           | 88 | 89 | 8A | 8B | 8C | 8D | 8E     | DD<br>8E<br>d | FD<br>8E<br>d | CE<br>n |
| SUBTRACT<br>"SUB"    | 97           | 90 | 91 | 92 | 93 | 94 | 95 | 96     | DD<br>96<br>d | FD<br>96<br>d | D6<br>n |
| SUB w CARRY<br>"SBC" | 9F           | 98 | 99 | 9A | 9B | 9C | 9D | 9E     | DD<br>9E<br>d | FD<br>9E<br>d | DE<br>n |
| "AND"                | A7           | A0 | A1 | A2 | A3 | A4 | A5 | A6     | DD<br>A6<br>d | FD<br>A6<br>d | E6<br>n |
| "XOR"                | AF           | A8 | A9 | AA | AB | AC | AD | AE     | DD<br>AE<br>d | FD<br>AE<br>d | EE<br>n |
| "OR"                 | B7           | B0 | B1 | B2 | B3 | B4 | B5 | B6     | DD<br>B6<br>d | FD<br>B6<br>d | F6<br>n |
| COMPARE<br>"CP"      | BF           | B8 | B9 | BA | BB | BC | BD | BE     | DD<br>BE<br>d | FD<br>BE<br>d | FE<br>n |
| INCREMENT<br>"INC"   | 3C           | 04 | 0C | 14 | 1C | 24 | 2C | 34     | DD<br>34<br>d | FD<br>34<br>d |         |
| DECREMENT<br>"DEC"   | 3D           | 05 | 0D | 15 | 1D | 25 | 2D | 35     | DD<br>35<br>d | FD<br>35<br>d |         |

表4-6 8ビット算術、論理演算

|                                       |          |
|---------------------------------------|----------|
| Decimal Adjust Acc. "DAA"             | 27       |
| Complement Acc. "CPL"                 | 2F       |
| Negate Acc. "NEG"<br>(2's complement) | ED<br>44 |
| Complement Carry Flag, "CCF"          | 3F       |
| Set Carry Flag, "SCF"                 | 37       |

表4-7 その他の操作

## AND 07H の操作と結果

|              |                 |
|--------------|-----------------|
| 操作前の ACC の内容 | 1111 0011 = F3H |
| オペランド        | 0000 0111 = 07H |
| <hr/>        |                 |
| 操作後の ACC の内容 | 0000 0011 = 03H |

ADD 命令 (ADD) は、ソースの位置内のデータとアキュムレータ (ACC) のデータ間で 2 進加算を行い、SUB 命令は 2 進減算を行う命令である。

キャリを含めた操作を行う場合、ADC (加算)、SBC (減算) を使用すればよい。それぞれキャリ・フラグの内容を演算に関与させられる。

Z-80A では、フラグとデシマル・アジャスト（10進補正）の命令を次のような算術演算操作に対して使用できる。

- バックされたBCD数の高精度演算
- 符号付2進数の高精度演算
- 符号付2の補数値の高精度演算

この命令群には他に論理積AND、論理和OR、排他的論理和XOR、比較CPがある。

アキュムレータあるいは、キャリ・フラグを操作する5つの汎用算術演算命令があるが、これを表5-7に示す。10進補正是加算と同様減算に対しても行うことができ、BCD算術演算が簡単に見える。この減算補正にはNフラグを利用するとよい。このフラグは前の算術演算命令が減算であればセットされている。

NEG命令はアキュムレータ内の値の2の補数値をアキュムレータに置く（セットする）。

ここで、Z-80Aにはキャリをリセットする命令がないことに注意されたい。この操作はアキュムレータ自身でANDをとるなどの操作をすれば、キャリ・フラグがリセットされるので、その命令をとくに設けていない。

表4-8に16ビット・レジスタ間の16ビット演算命令群を示す。これらにはキャリを含めた加、減算を入れて、5グループある。ADC、SBC命令は全フラグに影響を与える。これらの命令を使用すればアドレス計算あるいは16ビット算術演算操作の簡単化が図れる。

|                                    |    | ソース      |          |          |          |          |          |
|------------------------------------|----|----------|----------|----------|----------|----------|----------|
|                                    |    | BC       | DE       | HL       | SP       | IX       | IY       |
| デスティネーション                          | HL | 09       | 19       | 29       | 39       |          |          |
|                                    | IX | DD<br>09 | DD<br>19 |          | DD<br>39 | DD<br>29 |          |
|                                    | IY | FD<br>09 | FD<br>19 |          | FD<br>39 |          | FD<br>29 |
| "ADD"                              |    |          |          |          |          |          |          |
| ADD WITH CARRY AND SET FLAGS "ADC" |    | HL       | ED<br>4A | ED<br>5A | ED<br>6A | ED<br>7A |          |
| SUB WITH CARRY AND SET FLAGS "SBC" |    | HL       | ED<br>42 | ED<br>52 | ED<br>62 | ED<br>72 |          |
| INCREMENT "INC"                    |    |          | 03       | 13       | 23       | 33       | DD<br>23 |
| DECREMENT "DEC"                    |    |          | 0B       | 1B       | 2B       | 3B       | DD<br>2B |

表4-8 16ビット算術演算

#### ローテイトとシフト

Z-80Aの主な特長として、アキュムレータ、汎用レジスタあるいはメモリ内のデータのローテイトあるいはシフト命令が充実している点があげられる。

ローテイトとシフト命令のOPコードを表4-9に示す。Z-80Aには、算術および論理シフト操作も設けられている。これらの操作は整数の乗算および除算を含む広範囲の用途に使用でき、大層便利なものである。

2つのBCDディジット・ローテイト命令（RRDとRLD）は、HLレジスタ・ペアで指定されるメモリ内の2桁（ディジット、4ビットで1桁を表わす）とアキュムレータ内の1桁とのローテイト（入れ替え）が行える。（表4-9を参照）これらの命令はBCDデータの演算に利用できる。

ソースおよびデスティネーション

|                        | A     | B     | C     | D     | E     | H     | L     | (HL)  | (IX+d) | (IY+d)     | A          |
|------------------------|-------|-------|-------|-------|-------|-------|-------|-------|--------|------------|------------|
| ローテイト<br>あるいは<br>シフトの型 | "RLC" | CB 07 | CB 00 | CB 01 | CB 02 | CB 03 | CB 04 | CB 05 | CB 06  | DD CB d 06 | FD CB d 06 |
|                        | "RRC" | CB 0F | CB 08 | CB 09 | CB 0A | CB 0B | CB 0C | CB 0D | CB 0E  | DD CB d 0E | FD CB d 0E |
|                        | "RL"  | CB 17 | CB 10 | CB 11 | CB 12 | CB 13 | CB 14 | CB 15 | CB 16  | DD CB d 16 | FD CB d 16 |
|                        | "RR"  | CB 1F | CB 18 | CB 19 | CB 1A | CB 1B | CB 1C | CB 1D | CB 1E  | DD CB d 1E | FD CB d 1E |
|                        | "SLA" | CB 27 | CB 20 | CB 21 | CB 22 | CB 23 | CB 24 | CB 25 | CB 26  | DD CB d 26 | FD CB d 26 |
|                        | "SRA" | CB 2F | CB 28 | CB 29 | CB 2A | CB 2B | CB 2C | CB 2D | CB 2E  | DD CB d 2E | FD CB d 2E |
|                        | "SRL" | CB 3F | CB 38 | CB 39 | CB 3A | CB 3B | CB 3C | CB 3D | CB 3E  | DD CB d 3E | FD CB d 3E |
|                        | "RLD" |       |       |       |       |       |       |       | ED 6F  |            |            |
|                        | "RRD" |       |       |       |       |       |       |       | ED 67  |            |            |



表4-9 ローテイトとシフト

**ビット操作**

ビットごとのセット、リセットあるいはテストといった操作はどのようなプログラムでも必要なものである。とくにその操作がレジスタに限らずメモリ内でできれば、大変便利である。このビットは普通汎用ソフトウェア・ルーチン、外部の制御状態の指示

あるいはメモリの有効利用のためにパックしておくデータ群の指標などのためのフラグとしてよく使用される。

Z-80A には、1 命令によりアキュムレータ、各汎用レジスタ、あるいはどのメモリ位置に対してもその中の各ビットのセット、リセット、あるいはテストができる能力がある。

表 4-10 にこの目的のための 240 の命令群を示す。

レジスタ・アドレシングでは、アキュムレータあるいはいずれかの汎用レジスタを指定でき、そこでのビット操作ができる。

レジスタ間接およびインデックス・アドレシングでは、その指定によって外部メモリ上でビット操作ができる。

ビット・テスト操作では、ビットの状態をゼロ・フラグ (Z) で判定する。たとえば、Z フラグがセットされているならば、テストされるビットは零である。

|                       | ビット | レジスタ・アドレッシング |       |       |       |       |       |       | レジスター間接 | インデックス     |            |
|-----------------------|-----|--------------|-------|-------|-------|-------|-------|-------|---------|------------|------------|
|                       |     | A            | B     | C     | D     | E     | H     | L     | (HL)    | (IX+d)     | (IY+d)     |
| TEST<br>"BIT"         | 0   | CB 47        | CB 40 | CB 41 | CB 42 | CB 43 | CB 44 | CB 45 | CB 46   | DD CB d 46 | FD CB d 46 |
|                       | 1   | CB 4F        | CB 48 | CB 49 | CB 4A | CB 4B | CB 4C | CB 4D | CB 4E   | DD CB d 4E | FD CB d 4E |
|                       | 2   | CB 57        | CB 50 | CB 51 | CB 52 | CB 53 | CB 54 | CB 55 | CB 56   | DD CB d 56 | FD CB d 56 |
|                       | 3   | CB 5F        | CB 58 | CB 59 | CB 5A | CB 5B | CB 5C | CB 5D | CB 5E   | DD CB d 5E | FD CB d 5E |
|                       | 4   | CB 67        | CB 60 | CB 61 | CB 62 | CB 63 | CB 64 | CB 65 | CB 66   | DD CB d 66 | FD CB d 66 |
|                       | 5   | CB 6F        | CB 68 | CB 69 | CB 6A | CB 6B | CB 6C | CB 6D | CB 6E   | DD CB d 6E | FD CB d 6E |
|                       | 6   | CB 77        | CB 70 | CB 71 | CB 72 | CB 73 | CB 74 | CB 75 | CB 76   | DD CB d 76 | FD CB d 76 |
|                       | 7   | CB 7F        | CB 78 | CB 79 | CB 7A | CB 7B | CB 7C | CB 7D | CB 7E   | DD CB d 7E | FD CB d 7E |
| RESET<br>BIT<br>"RES" | 0   | CB 87        | CB 80 | CB 81 | CB 82 | CB 83 | CB 84 | CB 85 | CB 86   | DD CB d 86 | FD CB d 86 |
|                       | 1   | CB 8F        | CB 88 | CB 89 | CB 8A | CB 8B | CB 8C | CB 8D | CB 8E   | DD CB d 8E | FD CB d 8E |
|                       | 2   | CB 97        | CB 90 | CB 91 | CB 92 | CB 93 | CB 94 | CB 95 | CB 96   | DD CB d 96 | FD CB d 96 |
|                       | 3   | CB 9F        | CB 98 | CB 99 | CB 9A | CB 9B | CB 9C | CB 9D | CB 9E   | DD CB d 9E | FD CB d 9E |
|                       | 4   | CB A7        | CB A0 | CB A1 | CB A2 | CB A3 | CB A4 | CB A5 | CB A6   | DD CB d A6 | FD CB d A6 |
|                       | 5   | CB AF        | CB A8 | CB A9 | CB AA | CB AB | CB AC | CB AD | CB AE   | DD CB d AE | FD CB d AE |
|                       | 6   | CB B7        | CB B0 | CB B1 | CB B2 | CB B3 | CB B4 | CB B5 | CB B6   | DD CB d B6 | FD CB d B6 |
|                       | 7   | CB BF        | CB B8 | CB B9 | CB BA | CB BB | CB BC | CB BD | CB BE   | DD CB d BE | FD CB d BE |
| SET<br>BIT<br>"SET"   | 0   | CB C7        | CB C0 | CB C1 | CB C2 | CB C3 | CB C4 | CB C5 | CB C6   | DD CB d C6 | FD CB d C6 |
|                       | 1   | CB CF        | CB C8 | CB C9 | CB CA | CB CB | CB CC | CB CD | CB CE   | DD CB d CE | FD CB d CE |
|                       | 2   | CB D7        | CB D0 | CB D1 | CB D2 | CB D3 | CB D4 | CB D5 | CB D6   | DD CB d D6 | FD CB d D6 |
|                       | 3   | CB DF        | CB D8 | CB D9 | CB DA | CB DB | CB DC | CB DD | CB DE   | DD CB d DE | FD CB d DE |
|                       | 4   | CB E7        | CB E0 | CB E1 | CB E2 | CB E3 | CB E4 | CB E5 | CB E6   | DD CB d E6 | FD CB d E6 |
|                       | 5   | CB EF        | CB E8 | CB E9 | CB EA | CB EB | CB EC | CB ED | CB EE   | DD CB d EE | FD CB d EE |
|                       | 6   | CB F7        | CB F0 | CB F1 | CB F2 | CB F3 | CB F4 | CB F5 | CB F6   | DD CB d F6 | FD CB d F6 |
|                       | 7   | CB FF        | CB F8 | CB F9 | CB FA | CB FB | CB FC | CB FD | CB FE   | DD CB d FE | FD CB d FE |

表4-10 ビット操作グループ

### ジャンプ、コール、リターン

表4-11にジャンプ、コール、およびリターン命令群を示す。ジャンプとはプログラム中のステップの変更であり、プログラム・カウンタには、3つの適当なアドレッシング・モード（拡張イミディエット、相対、またはレジスタ間接）のいずれかで指定される16ビットの値がロードされる。

ジャンプ命令群には条件ジャンプがある。これらはジャンプ命令直前の条件によってジャンプしたり、そのまま次の命令ステップへ続けられるものである。この条件はフラグ・レジスタ内のデータにセットされている。（フラグ・レジスタに関しては、第5章を参照）

拡張イミディエット・アドレッシングを使用すれば、メモリのどの位置へでもジャンプできる。この命令は3バイト必要で、OPコードの次のバイトが下位アドレス・バイトであり、その後に上位アドレス・バイトが続く。（2バイトで64Kバイト全メモリを指定する。）

たとえば、メモリの位置3E32<sub>H</sub>への無条件ジャンプは次のようになる。



相対ジャンプ命令は2バイト命令であり、2バイト目はその時点でのPCの内容に加えるためのディスプレイスメント（2の補数値）である。

このディスプレイスメントによりOPコードのあるアドレスから+129～-126の範囲を指定できる。

レジスタ間接ジャンプには3種あって、レジスタ・ペアHL、インデックス・レジスタIX、IYの内容を直接PCにロードして行う。このモードでは、まえで計算した値をもとにジャンプ先を決めてジャンプすることができる。

コール命令はジャンプ命令の特殊な形であり、戻り番地（コール命令のあとのあるバイトのアドレス）をスタックにプッシュしていくジャンプを実行するものである。リターン命令はコールの逆で、スタックからデータをポップしてきて、それを直接PCにロードしてジャンプする命令である。

コールおよびリターン命令で、サブルーチンあるいは割り込みの処理が、簡単に行える。

Z-80Aファミリ用に、2つの特殊リターン命令が設けられている。RETI（マスク可能な割り込みからのリターン）とRETN（ノン・マスク割り込みからのリターン）の2種で、CPU内ではOPコードC9<sub>H</sub>の無条件リターンと同様に扱われるが、次の点で異なっている。

RETIは割り込み処理ルーチンの終わりで使用するが、Z-80Aの周辺チップはこの命令の実行を検知して、ネスティングしていた割り込みに対して適切な処理が行われたことを認識できる。

Z-80Aの周辺デバイスの構成を考慮したこの命令を使用すれば、ネスティングしていた割り込みからの正常リターンの手続きが簡単になる。もし、このような命令がなければ、割り込み処理ルーチンが完了し、割り込みをかけてきたデバイスにそれを伝えるためには、次のようなプログラム・ステップが必要であろう。

```

DI      ; このルーチンが始まるまえにまず割り込みを禁止する（ディセーブル割り込み）。
LD A, n ; } サービス・ルーチン完了をデバイスへ通知する。
OUT n, A ;
RET    ; リターン。

```

Z-80Aでは、2バイトのRETI命令で、さきのような6バイトのステップを置き換えることができる。これは割り込みサービスの時間をできる限り短縮しなければならない場合には重要となる。

プログラムでループ制御を簡単にするためにDJNZ命令があり、便利なものである。これは2バイトの条件付相対ジャンプ命令で、しかも命令実行ごとにBレジスタがデクリメントされる。Bレジスタが零になるまで繰り返しジャンプを行い、零になれば次の命令ステップに移る。オペランド（ディスプレイスメント）は2の補数値で与える。次に簡単な例を示しておく。

| アドレス      | 命 令          | コメント                                      |
|-----------|--------------|-------------------------------------------|
| N、N+1     | LD B, 7      | ; B レジスタをカウント 7 にセット。                     |
| N+2       | (プログラム・ステップ) | ; 7 回繰り返す内容。→                             |
| ⋮         |              |                                           |
| N+9       |              |                                           |
| N+10、N+11 | DJNZ -10     | ; もし、B レジスタが 0 でなければ<br>N+12 から N+2 へ戻る。→ |
| N+12      | (次のステップ)     | ; (B レジスタ) = 0 のとき、ここへ。                   |

条件

|                                            |           |                | 無条件          | キャリ          | ノン・キャリ       | ゼロ           | ノン・ゼロ        | バリティ偶数       | バリティ奇数       | 負            | 正            | カウント      |
|--------------------------------------------|-----------|----------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|-----------|
| JUMP "JP"                                  | 拡張イミディエット | nn             | C3<br>n<br>n | DA<br>n<br>n | D2<br>n<br>n | CA<br>n<br>n | C2<br>n<br>n | EA<br>n<br>n | E2<br>n<br>n | FA<br>n<br>n | F2<br>n<br>n |           |
| JUMP "JR"                                  | 相対        | PC+e           | 18<br>e-2    | 38<br>e-2    | 30<br>e-2    | 28<br>e-2    | 20<br>e-2    |              |              |              |              |           |
| JUMP "JP"                                  | レジスタ間接    | (HL)           | E9           |              |              |              |              |              |              |              |              |           |
| JUMP "JP"                                  |           | (IX)           | DD<br>E9     |              |              |              |              |              |              |              |              |           |
| JUMP "JP"                                  |           | (IY)           | FD<br>E9     |              |              |              |              |              |              |              |              |           |
| "CALL"                                     | 拡張イミディエット | nn             | CD<br>n<br>n | DC<br>n<br>n | D4<br>n<br>n | CC<br>n<br>n | C4<br>n<br>n | EC<br>n<br>n | E4<br>n<br>n | FC<br>n<br>n | F4<br>n<br>n |           |
| DECREMENT B,<br>JUMP IF NON<br>ZERO "DJNZ" | 相対        | PC+e           |              |              |              |              |              |              |              |              |              | 10<br>e-2 |
| RETURN<br>"RET"                            | レジスタ間接    | (SP)<br>(SP+1) | C9           | D8           | D0           | C8           | C0           | E8           | E0           | F8           | F0           |           |
| RETURN FROM<br>INT "RETI"                  | レジスタ間接    | (SP)<br>(SP+1) | ED<br>4D     |              |              |              |              |              |              |              |              |           |
| RETURN FROM<br>NON MASKABLE<br>INT "RETN"  | レジスタ間接    | (SP)<br>(SP+1) | ED<br>45     |              |              |              |              |              |              |              |              |           |

あるフラグは1つ以上の目的で用いられる。  
詳細は第5章参照。

表4-11 ジャンプ、コール、リターン グループ

表4-12に8種のリスタート (RST) 命令のOPコードおよびニーモニックを示す。この命令は1バイトで8箇所のいずれかをコールできる。

この命令の特長は、よく使用するルーチンをこれで呼べば、プログラム・ステップ数、すなわちメモリ使用量を節減できる点にある。

|                                      |                   | OP コード   |
|--------------------------------------|-------------------|----------|
| コ<br>ー<br>ル<br>・<br>ア<br>ド<br>レ<br>ス | 0000 <sub>H</sub> | 07       |
|                                      | 0008 <sub>H</sub> | CF       |
|                                      | 0010 <sub>H</sub> | D7       |
|                                      | 0018 <sub>H</sub> | DF       |
|                                      | 0020 <sub>H</sub> | E7       |
|                                      | 0028 <sub>H</sub> | EF       |
|                                      | 0030 <sub>H</sub> | F7       |
|                                      | 0038 <sub>H</sub> | FF       |
|                                      |                   |          |
|                                      |                   | "RST 0"  |
|                                      |                   | "RST 8"  |
|                                      |                   | "RST 16" |
|                                      |                   | "RST 24" |
|                                      |                   | "RST 32" |
|                                      |                   | "RST 40" |
|                                      |                   | "RST 48" |
|                                      |                   | "RST 56" |

表4-12 リスタート

### 入力／出力

Z-80A CPUには表4-13および表4-14に示すように、多種の入出力命令群がある。

入力／出力デバイスのアドレシングには、絶対モードあるいは、Cレジスタを使用したレジスタ間接モードがある。

レジスタ間接モードでは、入出力デバイス群と内部レジスタ間のデータの直接転送が可能である点に注意されたい。さらに、8つのブロック転送命令が設けられている。

これらの命令群はメモリ・ブロック転送と同種のものであるが、HLレジスタ・ペアをメモリ・ソース（出力要求の場合）またはメモリ・デスティネーション（入力要求の場合）のポインタとして用いる点が異なる。一方、Bレジスタは同様にバイト・カウンタとして使用する。

Cレジスタは入力／出力の必要なデバイスのポートのアドレスを保持する。

Bレジスタは8ビット長なので、入出力ブロック転送は256バイトまでである。

次のような入出力命令ではnはアドレス・バスの下位8ビットに出力される。

```
IN A, n
OUT n, A
```

同時にアキュムレータの内容がアドレス・バスの上位8ビットへ出力される。

入出力ブロック転送も含めたレジスタ間接入出力命令のいずれにおいても、レジスタCの内容は、アドレス・バスの下位8ビットで転送され同時にレジスタBの内容がアドレス・バスの上位8ビットに出力される。

|                                                   |            | ソース<br>入力ポート |       |
|---------------------------------------------------|------------|--------------|-------|
|                                                   | イミディエット    | レジスタ間接       |       |
|                                                   | (n)        | (C)          |       |
| INPUT "IN"                                        | A          | DB n         | ED 78 |
|                                                   | B          |              | ED 40 |
|                                                   | C          |              | ED 48 |
|                                                   | D          |              | ED 50 |
|                                                   | E          |              | ED 58 |
|                                                   | H          |              | ED 60 |
|                                                   | L          |              | ED 68 |
| "INI" - INPUT &<br>Inc HL, Dec B                  |            |              | ED A2 |
| "INIR" - INP, Inc HL,<br>Dec B, REPEAT IF B ≠ 0   | レジスタ<br>間接 | (HL)         | ED B2 |
| "IND" - INPUT &<br>Dec HL, Dec B                  |            |              | ED AA |
| "INDR" - INPUT, Dec HL,<br>Dec B, REPEAT IF B ≠ 0 |            |              | ED BA |
|                                                   |            |              |       |

デスティネーション  
入力

ブロック入力  
コマンド

表4-13 入力命令群

|                                                    |            | ソース  |       |       |       |       |       |       |            |
|----------------------------------------------------|------------|------|-------|-------|-------|-------|-------|-------|------------|
|                                                    |            | レジスタ |       |       |       |       |       |       | レジスタ<br>間接 |
|                                                    |            | A    | B     | C     | D     | E     | H     | L     | (HL)       |
| "OUT"                                              | イミディエット    | (n)  | D3 n  |       |       |       |       |       |            |
|                                                    | レジスタ間接     | (C)  | ED 79 | ED 41 | ED 49 | ED 51 | ED 59 | ED 61 | ED 69      |
| "OUTI" - OUTPUT<br>Inc HL, Dec b                   | レジスタ<br>間接 | (C)  |       |       |       |       |       |       | ED A3      |
| "OTIR" - OUTPUT, Inc HL,<br>Dec B, REPEAT IF B ≠ 0 | レジスタ<br>間接 | (C)  |       |       |       |       |       |       | ED B3      |
| "OUTD" - OUTPUT<br>Dec HL & B                      | レジスタ<br>間接 | (C)  |       |       |       |       |       |       | ED AB      |
| "OTDR" - OUTPUT, Dec HL<br>& B, REPEAT IF B ≠ 0    | レジスタ<br>間接 | (C)  |       |       |       |       |       |       | ED BB      |

デスティネーション  
出力ポート

ブロック出力  
コマンド

表4-14 出力命令群

### CPU制御命令

表4-15に6つの汎用CPU制御命令を示す。NOPは何もしない命令である。HALTはCPUの動作を次に割り込みが入るまで停止させる命令であるが、この割り込みはDI、EI命令によってソフト的に受け付け可否の制御ができる。

3種類の割り込み動作モードの指定命令によって、CPUはそれぞれ次のような対応する割り込み応答モードになる。

モード0にセットされた場合、割り込みを発しているデバイスがデータ・バス上に何らかの命令を乗せて、CPUがそれを実行する形式となる。

モード1は簡単なもので、CPUは自動的に位置 $0038_{16}$ からリスタート(RST)するので、外部回路からの指令は何ら必要でない。(前のPCの内容はスタックにプッシュされる。)

モード2は最も強力なもので、全メモリの位置への間接コールができる。このモードでは、CPUはレジスタIの内容により上位8ビットを指定し、割り込みを発生しているデバイスからのデータで下位8ビットを指定し、計16ビット・メモリ・アドレスを形成する。

このアドレスとそれに続くアドレスの内容2バイトにより、サービス・ルーチンの先頭アドレスを指定する。

CPUは自動的にこのデータ2バイトで指定されるアドレスへのCALL命令を実行する。



|                          |          |                                                                                     |
|--------------------------|----------|-------------------------------------------------------------------------------------|
| "NOP"                    | 00       | 8080A モード<br>38 <sub>16</sub> 番地へのコール命令<br>レジスターIと割り込みデバイスからの<br>8ビットデータを用いた間接コール命令 |
| "HALT"                   | 76       |                                                                                     |
| DISABLE INT "(DI)"       | F3       |                                                                                     |
| ENABLE INT "(EI)"        | FB       |                                                                                     |
| SET INT MODE 0<br>"IM 0" | ED<br>46 |                                                                                     |
| SET INT MODE 1<br>"IM 1" | ED<br>56 |                                                                                     |
| SET INT MODE 2<br>"IM 2" | ED<br>5E |                                                                                     |

表4-15 CPU制御命令

## 5. フラグ類

Z-80A CPU の 2 組のフラグ・レジスタは種々の CPU 操作による結果を 6 ビットで保持する。

このうち、4 つのビットはプログラムによりテストでき、ジャンプの条件として使用できる。これらについて説明する。

1) キャリ・フラグ (C) — アキュムレータの最上位ビットからの桁上がりでセットされる。加算命令でのキャリ、または減算命令でボロー発生の場合などでセットされる。シフト、ローテイト命令ではこの C ビットが関係する。

2) ゼロ・フラグ (Z) — 演算の結果、アキュムレータに零がロードされたときにセットされる。他の場合リセットされる。

3) サイン・フラグ (S) — このフラグは符号付数値を扱う場合に使用し、演算の結果が負ならばセットされる。符号としてビット 7 (MSB) を使用するので、アキュムレータのビット 7 の内容がこのフラグに置かれる。(負の数ならば 1 が立つ。)

4) パリティ／オーバフロー・フラグ (P/V) — この 2 つの目的を持ったフラグは論理演算 (AND A, B など) が行われた場合にはパリティを示し、また符号付 2 の補数値の算術演算が行われた場合にはオーバフローの有無を示すために用いられる。Z-80A のオーバフローはアキュムレータ内の 2 の補数値が +127 を超えるか、-128 より小さくなつた場合に出される。次のような加算ではオーバフローとなる。

$$\begin{array}{r}
 +120 = 0111\ 1000 \\
 +105 = 0110\ 1001 \\
 \hline
 C = 0\ 1110\ 0001 = (-31) \text{ オーバフロー発生 (エラー)}
 \end{array}$$

これはエラーであり、オーバフローがあるがキャリは出ないので、エラー表示のためにオーバフロー・フラグがセットされる。

次のような 2 の補数値の加算では正しい結果が出て、キャリ・フラグがセットされる。この場合、オーバフローではないので、オーバフロー・フラグはセットされない。

$$\begin{array}{r}
 -5 = 1111\ 1011 \\
 -16 = 1111\ 0000 \\
 \hline
 C = 1\ 1110\ 1011 = (-21) \text{ キャリ発生 (正答)}
 \end{array}$$

キャリは結果の正誤に直接関係しないので、オーバフロー・フラグが特別に必要である点に注意されたい。論理演算 (AND, OR, XOR) では、結果のパリティが偶数ならばこのフラグはセットされ、奇数ならばリセットされる。

プログラマが直接に関与する必要のないフラグ・レジスタの残りのビットは、いずれも BCD 算術演算用として使用される。

1) ハーフ・キャリ (H) — BCD 演算結果の下位 4 ビットからのキャリ、ボロー用である。命令 DAA を用いて 10 進補正演算を行う場合、このフラグ H を用いて、CPU は自動的にパックされた 10 進数の加算結果または減算結果に対して補正を行い、正しい結果を算出する。

2) サブトラクト・フラグ (N) — BCD 演算で、加算と減算とではアルゴリズムが異なつてるので、このフラグを見て、先に実行された命令が加算か減算かを判定し、正しく DAA 命令を実行する。

このフラグ・レジスタはプログラムによって調べたり操作したりすることができ、フォーマットは次のようになっている。

|   |   |   |   |   |     |   |   |
|---|---|---|---|---|-----|---|---|
| S | Z | X | H | X | P/V | N | C |
|---|---|---|---|---|-----|---|---|

X は未定義

表 5-1 に各種の CPU 命令でどのようにフラグ・ビットが変化するかを示す。各記号は次のような意味を持つ。

● — フラグ 変化なし。

X — フラグ 不定。

0 — リセットされる。

1 — セットされる。

↑ — 各条件 (前述) にしたがって、セットあるいはリセットされる。

この表に書かれていらないその他の命令はフラグに影響を与えない。

表5-1には、説明の必要があるいく種かの場合が含まれている。Zフラグは、ブロック・サーチにおいて、それらの結果、状態を示すのに用いられる。

ブロック・サーチで、ソースとアキュムレータのデータが一致すればZフラグはセットされる。またバリティ・フラグは、バイト・カウンタ（BCレジスタ・ペア）が零でなければセットされている。バリティ・フラグはブロック転送の際にも同様になっている。

ブロック入出力命令においては、Zフラグはバイト・カウンタとしてのBレジスタの状態を示すために用いられる。入出力ブロック転送が終了したとき、Zフラグは零（すなわち、B=0）にリセットされる。他方、メモリ間ブロック転送の終了時には、バリティ・フラグがリセットされる。

リフレッシュ時、あるいはIレジスタの内容がアキュムレータにロードされたとき、割り込みのイネーブル・フリップ・フロップ（IFF）の内容は、バリティ・フラグに退避されるので、CPUの状態はいつでも完全に保存されている。

| 命 命                      | C | Z | P/V | S | N | H | 備 考                                                                          |
|--------------------------|---|---|-----|---|---|---|------------------------------------------------------------------------------|
| ADD A,s; ADC A,s         | ↑ | ↑ | V   | ↑ | 0 | ↑ | 8ビット加算、キャリを含む加算                                                              |
| SUB s; SBC A,s, CP s     | ↑ | ↑ | V   | ↑ | 1 | ↑ | 8ビット減算、キャリを含む加算、比較                                                           |
| NEG                      | ↑ | ↑ | V   | ↑ | 1 | ↑ | 符号反転(ニゲイト)                                                                   |
| AND s                    | 0 | ↑ | P   | ↑ | 0 | 1 |                                                                              |
| OR s; XOR s              | 0 | ↑ | P   | ↑ | 0 | 0 | 論理演算                                                                         |
| INC                      | ● | ↑ | V   | ↑ | 0 | ↑ | 8ビット・インクリメント                                                                 |
| DEC s                    | ● | ↑ | V   | ↑ | 1 | ↑ | 8ビット・デクリメント                                                                  |
| ADD dd,ss                | ↑ | ● | ●   | ● | 0 | X | 16ビット加算                                                                      |
| ADC HL,ss                | ↑ | ↑ | V   | ↑ | 0 | X | 16ビットキャリを含む加算                                                                |
| SBC HL,ss                | ↑ | ↑ | V   | ↑ | 1 | X | 16ビットキャリを含む減算                                                                |
| RLA ; RLCA ; RRA ; RRCA  | ↑ | ● | ●   | ● | 0 | 0 | ローテイト・アキュムレータ                                                                |
| RL s; RLC s; RR s; RRC s | ↑ | ↑ | P   | ↑ | 0 | 0 | ローテイト、シフトS                                                                   |
| SLA s; SRA s; SRL s      |   |   |     |   |   |   |                                                                              |
| RLD, RRD                 | ● | ↑ | P   | ↑ | 0 | 0 | ローテイト・ディジット 左、右                                                              |
| DAA                      | ↑ | ↑ | P   | ↑ | ● | ↑ | デシマル・アジャスト・アキュムレータ                                                           |
| CPL                      | ● | ● | ●   | ● | 1 | 1 | アキュムレータ補数変換                                                                  |
| SCF                      | 1 | ● | ●   | ● | 0 | 0 | セット・キャリ                                                                      |
| CCF                      | ↑ | ● | ●   | ● | 0 | X | キャリ補数変換                                                                      |
| IN r,(C)                 | ● | ↑ | P   | ↑ | 0 | 0 | レジスタ間接入力                                                                     |
| INI; IND; OUTI; OUTD     | ● | ↑ | X   | X | 1 | X | ブロック入出力                                                                      |
| INIR; INDR; OTIR; OTDR   | ● | 1 | X   | X | 1 | X | B ≠ 0 ならば Z = 0、その他は Z = 1                                                   |
| LDI, LDD                 | ● | X | ↑   | X | 0 | 0 | ブロック転送                                                                       |
| LDIR, LDDR               | ● | X | 0   | X | 0 | 0 | B ≠ 0 ならば P/V = 0、その他は P/V = 0                                               |
| CPI, CPIR, CPD, CPDR     | ● | ↑ | ↑   | X | 1 | X | ブロック・サーチ<br>A = (HL) ならば Z = 1、その他は Z = 0<br>BC ≠ 0 ならば P/V = 1、その他は P/V = 0 |
| LDA, I; LD A, R          | ● | ↑ | IFF | ↑ | 0 | 0 | IFF の内容が P/V にコピーされる。                                                        |
| BIT b,s                  | ● | ↑ | X   | X | 0 | 1 | S のビット b の内容が Z にコピーされる。                                                     |

## 記号の説明

|                        |                                                  |
|------------------------|--------------------------------------------------|
| C : キャリ／リンク・フラグ        | 結果のMSBからのキャリがあれば、C = 1。                          |
| Z : ゼロ・フラグ             | 零ならば、Z = 1。                                      |
| S : サイン・フラグ            | 結果のMSBが1ならば、S = 1。                               |
| P/V : パリティとオーバフロー兼用フラグ | 結果が奇数、またはオーバフローならば、P/V = 1。<br>結果が偶数ならば、P/V = 0。 |
| H : ハーフ・キャリフラグ         | 結果にキャリ、ボローがあれば、H = 1。                            |
| N : 加算／減算フラグ           | さきの演算が減算ならば、N = 1。                               |
| ↑ :                    | 操作の結果、変化する。                                      |
| ● :                    | 操作の結果、変化しない。                                     |
| 0 :                    | 操作により、リセットされる。                                   |
| 1 :                    | 操作により、セットされる。                                    |
| X :                    | 無視してよい。                                          |
| V :                    | オーバ・フラグとして扱われる。                                  |
| P :                    | パリティ・フラグとして扱われる。                                 |
| s :                    | 8ビット・ロケーション。                                     |
| R :                    | リフレッシュ・カウンタ。                                     |
| I :                    | Iレジスタ(割り込みベクトルの上位バイト用)。                          |
| r :                    | CPUレジスタ A, B, C, D, E, H, L。                     |
| ss :                   | 16ビット・ロケーション。                                    |
| n :                    | 8ビット値(0 ~ 255)。                                  |
| nn :                   | 16ビット値(0 ~ 65535)。                               |

表5-1

## 6. オペコードとタイミング表

この章で、Z-80A の命令セットをまとめておく。これらをグループ別に表 6-1 から表 6-11 に示し、各表で、次の各項について示す。

アセンブリ語ニーモニックの OP コード

マシン語の OP コード

シンボリック・オペレーション (CPU の動作、または操作)

命令実行後のフラグ・レジスタの内容

命令のバイト数 (メモリ・サイクル数)

フェッチ、実行に必要な T ステート (外部クロック周期) の総数

これらの表はできるだけその表だけで意味がわかるよう配慮されている。

| ニーモニック<br>コード | シンボリック<br>オペレーション | フラグ |   |      |   |   |   | オペコード                                      | バイト<br>数 | Mサイ<br>クル数 | Tステ<br>ート数 | コメント                     |                  |
|---------------|-------------------|-----|---|------|---|---|---|--------------------------------------------|----------|------------|------------|--------------------------|------------------|
|               |                   | C   | Z | P/V  | S | N | H |                                            |          |            |            | r, r'                    | レジスタ             |
| LD r, r'      | r←r'              | ●   | ● | ●    | ● | ● | ● | 01 r r'                                    | 1        | 1          | 4          |                          |                  |
| LD r, n       | r←n               | ●   | ● | ●    | ● | ● | ● | 00 r 110<br>← n →                          | 2        | 2          | 7          | 000                      | B                |
| LD r, (HL)    | r←(HL)            | ●   | ● | ●    | ● | ● | ● | 01 r 110                                   | 1        | 2          | 7          | 001                      | C                |
| LD r, (IX+d)  | r←(IX+d)          | ●   | ● | ●    | ● | ● | ● | 11 011 101<br>01 r 110<br>← d →            | 3        | 5          | 19         | 010<br>011<br>100<br>101 | D<br>E<br>H<br>L |
| LD r, (IY+d)  | r←(IY+d)          | ●   | ● | ●    | ● | ● | ● | 11 111 101<br>01 r 110<br>← d →            | 3        | 5          | 19         | 111                      | A                |
| LD (HL), r    | (HL)←r            | ●   | ● | ●    | ● | ● | ● | 01 110 r                                   | 1        | 2          | 7          |                          |                  |
| LD (IX+d), r  | (IX+d)←r          | ●   | ● | ●    | ● | ● | ● | 11 011 101<br>01 110 r<br>← d →            | 3        | 5          | 19         |                          |                  |
| LD (IY+d), r  | (IY+d)←r          | ●   | ● | ●    | ● | ● | ● | 11 111 101<br>01 110 r<br>← d →            | 3        | 5          | 19         |                          |                  |
| LD (HL), n    | (HL)←n            | ●   | ● | ●    | ● | ● | ● | 00 110 110<br>← n →                        | 2        | 3          | 10         |                          |                  |
| LD (IX+d), n  | (IX+d)←n          | ●   | ● | ●    | ● | ● | ● | 11 011 101<br>00 110 110<br>← d →<br>← n → | 4        | 5          | 19         |                          |                  |
| LD (IY+d), n  | (IY+d)←n          | ●   | ● | ●    | ● | ● | ● | 11 111 101<br>00 110 110<br>← d →<br>← n → | 4        | 5          | 19         |                          |                  |
| LD A, (BC)    | A←(BC)            | ●   | ● | ●    | ● | ● | ● | 00 001 010                                 | 1        | 2          | 7          |                          |                  |
| LD A, (DE)    | A←(DE)            | ●   | ● | ●    | ● | ● | ● | 00 011 010                                 | 1        | 2          | 7          |                          |                  |
| LD A, (nn)    | A←(nn)            | ●   | ● | ●    | ● | ● | ● | 00 111 010<br>← n →<br>← n →               | 3        | 4          | 13         |                          |                  |
| LD (BC), A    | (BC)←A            | ●   | ● | ●    | ● | ● | ● | 00 000 010                                 | 1        | 2          | 7          |                          |                  |
| LD (DE), A    | (DE)←A            | ●   | ● | ●    | ● | ● | ● | 00 010 010                                 | 1        | 2          | 7          |                          |                  |
| LD (nn), A    | (nn)←A            | ●   | ● | ●    | ● | ● | ● | 00 110 010<br>← n →<br>← n →               | 3        | 4          | 13         |                          |                  |
| LD A, I       | A←I               | ●   | † | IFF2 | † | 0 | 0 | 11 101 101<br>01 010 111                   | 2        | 2          | 9          |                          |                  |
| LD A, R       | A←R               | ●   | † | IFF2 | † | 0 | 0 | 11 101 101<br>01 011 111                   | 2        | 2          | 9          |                          |                  |
| LD I, A       | I←A               | ●   | ● | ●    | ● | ● | ● | 11 101 101<br>01 000 111                   | 2        | 2          | 9          |                          |                  |
| LD R, A       | R←A               | ●   | ● | ●    | ● | ● | ● | 11 101 101<br>01 001 111                   | 2        | 2          | 9          |                          |                  |

注) r, r' は A, B, C, D, E, H, L レジスタを指す。

IFF (割り込みイネーブル・フリップ) は P/V フラグにコピーされる。

フラグ: ● = 変化せず、0 = リセット、1 = セット、X = 不定。

† = 操作の結果でセットまたはリセットされる。

表6-1 8ビット・ロード

| ニーモニック<br>コード | シンボリック<br>オペレーション      | フ ラ グ |   |     |   |   |   | オペコード                                      | バイト<br>数 | Mサイ<br>クル数 | Tステ<br>ート数 | コ メ ン ト                                      |    |
|---------------|------------------------|-------|---|-----|---|---|---|--------------------------------------------|----------|------------|------------|----------------------------------------------|----|
|               |                        | C     | Z | P/V | S | N | H |                                            |          |            |            | dd                                           | 00 |
| LD dd,nn      | dd←nn                  | ●     | ● | ●   | ● | ● | ● | 00 dd0 001<br>← n →<br>← n →               | 3        | 3          | 10         | 00                                           | BC |
| LD IX,nn      | IX←nn                  | ●     | ● | ●   | ● | ● | ● | 11 011 101<br>00 100 001<br>← n →<br>← n → | 4        | 4          | 14         | 01                                           | DE |
| LD IY,nn      | IY←nn                  | ●     | ● | ●   | ● | ● | ● | 11 111 101<br>00 100 001<br>← n →<br>← n → | 4        | 4          | 14         | 10                                           | HL |
| LD HL,(nn)    | H←(nn+1)<br>L←(nn)     | ●     | ● | ●   | ● | ● | ● | 00 101 010<br>← n →<br>← n →               | 3        | 5          | 16         | nnは2バイトの数、下位1バイトはオペコードの直後。<br>上位1バイトはその次に入る。 |    |
| LD dd,(nn)    | ddH←(nn+1)<br>ddL←(nn) | ●     | ● | ●   | ● | ● | ● | 11 101 101<br>01 dd0 011<br>← n →<br>← n → | 4        | 6          | 20         |                                              |    |
| LD IX,(nn)    | IXH←(nn+1)<br>IXL←(nn) | ●     | ● | ●   | ● | ● | ● | 11 011 101<br>00 101 010<br>← n →<br>← n → | 4        | 6          | 20         |                                              |    |
| LD IY,(nn)    | IYH←(nn+1)<br>IYL←(nn) | ●     | ● | ●   | ● | ● | ● | 11 111 101<br>00 101 010<br>← n →<br>← n → | 4        | 6          | 20         |                                              |    |
| LD (nn),HL    | (nn+1)←H<br>(nn)←L     | ●     | ● | ●   | ● | ● | ● | 00 100 010<br>← n →<br>← n →               | 3        | 5          | 16         |                                              |    |
| LD (nn),dd    | (nn+1)←ddH<br>(nn)←ddL | ●     | ● | ●   | ● | ● | ● | 11 101 101<br>01 dd0 011<br>← n →<br>← n → | 4        | 6          | 20         |                                              |    |
| LD (nn),IX    | (nn+1)←IXH<br>(nn)←IXL | ●     | ● | ●   | ● | ● | ● | 11 011 101<br>00 100 010<br>← n →<br>← n → | 4        | 6          | 20         |                                              |    |
| LD (nn),IY    | (nn+1)←IYH<br>(nn)←IYL | ●     | ● | ●   | ● | ● | ● | 11 111 101<br>00 100 010<br>← n →<br>← n → | 4        | 6          | 20         |                                              |    |
| LD SP,HL      | SP←HL                  | ●     | ● | ●   | ● | ● | ● | 11 111 001                                 | 1        | 1          | 6          |                                              |    |
| LD SP,IX      | SP←IX                  | ●     | ● | ●   | ● | ● | ● | 11 011 101<br>11 111 001                   | 2        | 2          | 10         |                                              |    |
| LD SP,IY      | SP←IY                  | ●     | ● | ●   | ● | ● | ● | 11 111 101<br>11 111 001                   | 2        | 2          | 10         |                                              |    |

| ニーモニック<br>コード | シンボリック<br>オペレーション                                | フラグ |   |     |   |   |   | オペコード      |         | バイト<br>数 | Mサイ<br>クル数 | Tステ<br>ート数 | コメント |      |
|---------------|--------------------------------------------------|-----|---|-----|---|---|---|------------|---------|----------|------------|------------|------|------|
|               |                                                  | C   | Z | P/V | S | N | H | 76 543 210 | qq0 101 |          |            |            | qq   | レジスタ |
| PUSH qq       | (SP-2)←qq <sub>L</sub><br>(SP-1)←qq <sub>H</sub> | ●   | ● | ●   | ● | ● | ● | 11         | qq0 101 | 1        | 3          | 11         | qq   |      |
| PUSH IX       | (SP-2)←IX <sub>L</sub><br>(SP-1)←IX <sub>H</sub> | ●   | ● | ●   | ● | ● | ● | 11         | 011 101 | 2        | 4          | 15         | 00   | BC   |
| PUSH IY       | (SP-2)←IY <sub>L</sub><br>(SP-1)←IY <sub>H</sub> | ●   | ● | ●   | ● | ● | ● | 11         | 111 101 | 2        | 4          | 15         | 01   | DE   |
| POP qq        | qq <sub>H</sub> ←(SP+1)<br>qq <sub>L</sub> ←(SP) | ●   | ● | ●   | ● | ● | ● | 11         | qq0 001 | 1        | 3          | 10         | 10   | HL   |
| POP IX        | IX <sub>H</sub> ←(SP+1)<br>IX <sub>L</sub> ←(SP) | ●   | ● | ●   | ● | ● | ● | 11         | 011 101 | 2        | 4          | 14         | 11   | AF   |
| POP IY        | IY <sub>H</sub> ←(SP+1)<br>IY <sub>L</sub> ←(SP) | ●   | ● | ●   | ● | ● | ● | 11         | 111 101 | 2        | 4          | 14         |      |      |
|               |                                                  |     |   |     |   |   |   | 11         | 100 001 |          |            |            |      |      |

注) ddはレジスタ・ペアBC、HL、SP。

qqはレジスタ・ペアAF、BC、DE、HL。

添字H、Lはそれぞれ高位バイト、低位バイトを表わす。

例) BC<sub>L</sub>=C, AF<sub>H</sub>=A

フラグ: ●=変化せず。

0=リセットされる。

1=セットされる。

X=不定である。

↓=操作の結果により、セットまたはリセットされる。

表6-2 16ビット・ロード

| ニーモニック<br>コード | シンボリック<br>オペレーション                                                                                       | フラグ |   |     |   |   |   | オペコード                    | バイト<br>数 | Mサイ<br>クル数 | Tステ<br>ート数 | コメ<br>ント                            |
|---------------|---------------------------------------------------------------------------------------------------------|-----|---|-----|---|---|---|--------------------------|----------|------------|------------|-------------------------------------|
|               |                                                                                                         | C   | Z | P/V | S | N | H |                          |          |            |            |                                     |
| EX DE, HL     | DE↔HL                                                                                                   | ●   | ● | ●   | ● | ● | ● | 11 101 011               | 1        | 1          | 4          |                                     |
| EX AF, AF'    | AF↔AF'                                                                                                  | ●   | ● | ●   | ● | ● | ● | 00 001 000               | 1        | 1          | 4          |                                     |
| EXX           | $\begin{pmatrix} BC \\ DE \end{pmatrix} \leftrightarrow \begin{pmatrix} BC' \\ DE' \\ HL \end{pmatrix}$ | ●   | ● | ●   | ● | ● | ● | 11 011 001               | 1        | 1          | 4          | レジスタ・ペアの内容とその補助レジスタ・ペアの内容を交換する      |
| EX (SP), HL   | H↔(SP+1)<br>L↔(SP)                                                                                      | ●   | ● | ●   | ● | ● | ● | 11 100 011               | 1        | 5          | 19         |                                     |
| EX (SP), IX   | IX <sub>H</sub> ↔(SP+1)<br>IX <sub>L</sub> ↔(SP)                                                        | ●   | ● | ●   | ● | ● | ● | 11 011 101<br>11 100 011 | 2        | 6          | 23         |                                     |
| EX (SP), IY   | IY <sub>H</sub> ↔(SP+1)<br>IY <sub>L</sub> ↔(SP)                                                        | ●   | ● | ●   | ● | ● | ● | 11 111 101<br>11 100 011 | 2        | 6          | 23         |                                     |
| LDI           | (DE)↔(HL)<br>DE↔DE+1<br>HL↔HL+1<br>BC↔BC-1                                                              | ●   | ● | ↑   | ● | 0 | 0 | 11 101 101<br>10 100 000 | 2        | 4          | 16         | ポインタ 1増<br>バイトカウンタ 1減               |
| LDIR          | (DE)↔(HL)<br>DE↔DE+1<br>HL↔HL+1<br>BC↔BC-1<br>BC=0まで繰り返す                                                | ●   | ● | 0   | ● | 0 | 0 | 11 101 101<br>10 110 000 | 2        | 5          | 21         | BC≠0の場合<br>BC=0の場合                  |
| LDD           | (DE)↔(HL)<br>DE↔DE-1<br>HL↔HL-1<br>BC↔BC-1                                                              | ●   | ● | ↑   | ● | 0 | 0 | 11 101 101<br>10 101 000 | 2        | 4          | 16         |                                     |
| LDDR          | (DE)↔(HL)<br>DE↔DE-1<br>HL↔HL-1<br>BC↔BC-1<br>BC=0まで繰り返す                                                | ●   | ● | 0   | ● | 0 | 0 | 11 101 101<br>10 111 000 | 2        | 5          | 21         | BC≠0の場合<br>BC=0の場合                  |
| CPI           | A-(HL)<br>HL↔HL+1<br>BC↔BC-1                                                                            | ●   | ↑ | ↑   | ↑ | 1 | ↑ | 11 101 101<br>10 100 001 | 2        | 4          | 16         |                                     |
| CPIR          | A-(HL)<br>HL↔HL+1<br>BC↔BC-1<br>A=(HL)または<br>BC=0まで繰り返す                                                 | ●   | ↑ | ↑   | ↑ | 1 | ↑ | 11 101 101<br>10 110 001 | 2        | 5          | 21         | BC≠0かつA=(HL)の場合<br>BC=0またはA=(HL)の場合 |
| CPD           | A-(HL)<br>HL↔HL-1<br>BC↔BC-1                                                                            | ●   | ↑ | ↑   | ↑ | 1 | ↑ | 11 101 101<br>10 101 001 | 2        | 4          | 16         |                                     |
| CPDR          | A-(HL)<br>HL↔HL-1<br>BC↔BC-1<br>A=(HL)または<br>BC=0まで繰り返す                                                 | ●   | ↑ | ↑   | ↑ | 1 | ↑ | 11 101 101<br>10 111 001 | 2        | 5          | 21         | BC≠0かつA=(HL)の場合<br>BC=0またはA=(HL)の場合 |

注) ①BC-1 = 0 ならばP/Vは0、その他は1。

フラグ: ● = 変化せず。

②A=(HL)ならばZは1、その他は0。

0 = セット、1 = リセット。

↑ = 操作結果で変化する。

表6-3 交換、ブロック転送、サーチ

| ニーモニック<br>コード | シンボリック<br>オペレーション | フラグ |   |     |   |   |   | オペコード                               |   |      | バイト<br>数 | Mサイ<br>クル数 | Tステ<br>ート数 | コメント |      |
|---------------|-------------------|-----|---|-----|---|---|---|-------------------------------------|---|------|----------|------------|------------|------|------|
|               |                   | C   | Z | P/V | S | N | H | 76 543 210                          | r | レジスタ |          |            |            | r    | レジスタ |
| ADD A,r       | A←A+r             | ↑   | ↑ | V   | ↑ | 0 | ↑ | 10 [000] r                          | 1 | 1    | 4        |            |            |      |      |
| ADD A,n       | A←A+n             | ↑   | ↑ | V   | ↑ | 0 | ↑ | 11 [000] 110<br>← n →               | 2 | 2    | 7        | 000        |            | B    |      |
| ADD A,(HL)    | A←A+(HL)          | ↑   | ↑ | V   | ↑ | 0 | ↑ | 10 [000] 110                        | 1 | 2    | 7        | 010        |            | D    |      |
| ADD A,(IX+d)  | A←A+(IX+d)        | ↑   | ↑ | V   | ↑ | 0 | ↑ | 11 011 101<br>10 [000] 110<br>← d → | 3 | 5    | 19       | 011        |            | E    |      |
| ADD A,(IY+d)  | A←A+(IY+d)        | ↑   | ↑ | V   | ↑ | 0 | ↑ | 11 111 101<br>10 [000] 110<br>← d → | 3 | 5    | 19       | 100        |            | H    |      |
|               |                   |     |   |     |   |   |   |                                     |   |      |          | 101        |            | L    |      |
|               |                   |     |   |     |   |   |   |                                     |   |      |          | 111        |            | A    |      |
| ADC A,s       | A←A+s+CY          | ↑   | ↑ | V   | ↑ | 0 | ↑ | [001]                               |   |      |          |            |            |      |      |
| SUB s         | A←A-s             | ↑   | ↑ | V   | ↑ | 1 | ↑ | [010]                               |   |      |          |            |            |      |      |
| SBC A,s       | A←A-s-CY          | ↑   | ↑ | V   | ↑ | 1 | ↑ | [011]                               |   |      |          |            |            |      |      |
| AND s         | A←A&s             | 0   | ↑ | P   | ↑ | 0 | 1 | [100]                               |   |      |          |            |            |      |      |
| OR s          | A←A∨s             | 0   | ↑ | P   | ↑ | 0 | 0 | [110]                               |   |      |          |            |            |      |      |
| XOR s         | A←A⊻s             | 0   | ↑ | P   | ↑ | 0 | 0 | [101]                               |   |      |          |            |            |      |      |
| CP s          | A-s               | ↑   | ↑ | V   | ↑ | 1 | ↑ | [111]                               |   |      |          |            |            |      |      |
| INC r         | r←r+1             | ●   | ↑ | V   | ↑ | 0 | ↑ | 00 r [100]                          | 1 | 1    | 4        |            |            |      |      |
| INC (HL)      | (HL)←(HL)+1       | ●   | ↑ | V   | ↑ | 0 | ↑ | 00 110 [100]                        | 1 | 3    | 11       |            |            |      |      |
| INC (IX+d)    | (IX+d)←(IX+d)+1   | ●   | ↑ | V   | ↑ | 0 | ↑ | 11 011 101<br>00 110 [100]<br>← d → | 3 | 6    | 23       |            |            |      |      |
| INC (IY+d)    | (IY+d)←(IY+d)+1   | ●   | ↑ | V   | ↑ | 0 | ↑ | 11 111 101<br>00 110 [100]<br>← d → | 3 | 6    | 23       |            |            |      |      |
| DEC m         | m←m-1             | ●   | ↑ | V   | ↑ | 1 | ↑ | [101]                               |   |      |          |            |            |      |      |

注) Vはオーバフロー・フラグとして、Pはバリティフラグとして扱われることを意味する。

フラグ: • =変化せず。

0 =リセットされる。

1 =セットされる。

X =不定。

↑ =操作結果により、セットまたはリセットされる。

表6-4 8ビット算術・論理演算

| ニーモニック<br>コード | シンボリック<br>オペレーション   | フラグ |   |     |   |   |   | オペコード                    | バイト<br>数 | Mサイ<br>クル数 | Tステ<br>ート数 | コメ<br>ント       |
|---------------|---------------------|-----|---|-----|---|---|---|--------------------------|----------|------------|------------|----------------|
|               |                     | C   | Z | P/V | S | N | H |                          |          |            |            |                |
| DAA           |                     | ↑   | ↑ | P   | ↑ | ● | ↑ | 00 100 111               | 1        | 1          | 4          | 2進化10進数(BCD)補正 |
| CPL           | A←A                 | ●   | ● | ●   | ● | 1 | 1 | 00 101 111               | 1        | 1          | 4          | 1の補数 Acc       |
| NEG           | A← $\bar{A}+1$      | ↑   | ↑ | V   | ↑ | 1 | ↑ | 11 101 101<br>01 000 100 | 2        | 2          | 8          | 2の補数 Acc       |
| CCF           | CY← $\overline{CY}$ | ↑   | ● | ●   | ● | 0 | X | 00 111 111               | 1        | 1          | 4          | キャリの反転         |
| SCF           | CY←1                | 1   | ● | ●   | ● | 0 | 0 | 00 110 111               | 1        | 1          | 4          | キャリ・セット        |
| NOP           | 何も実行しないが<br>PC←PC+1 | ●   | ● | ●   | ● | ● | ● | 00 000 000               | 1        | 1          | 4          |                |
| HALT          | CPU停止               | ●   | ● | ●   | ● | ● | ● | 01 110 110               | 1        | 1          | 4          |                |
| DI            | IFF←0               | ●   | ● | ●   | ● | ● | ● | 11 110 011               | 1        | 1          | 4          | ディセーブル割り込み     |
| EI            | IFF←1               | ●   | ● | ●   | ● | ● | ● | 11 111 011               | 1        | 1          | 4          | イネーブル割り込み      |
| IM 0          | 割り込みモード<br>0にする     | ●   | ● | ●   | ● | ● | ● | 11 101 101<br>01 000 110 | 2        | 2          | 8          | 割り込みモードのセット    |
| IM 1          | 割り込みモード<br>1にする     | ●   | ● | ●   | ● | ● | ● | 11 101 101<br>01 010 110 | 2        | 2          | 8          |                |
| IM 2          | 割り込みモード<br>2にする     | ●   | ● | ●   | ● | ● | ● | 11 101 101<br>01 011 110 | 2        | 2          | 8          |                |

注) IFFは割り込みフリップ・フロップ。

CYはキャリ・フリップ・フロップ。

フラグ: ● = 変化せず。

0 = リセットされる。

1 = セットされる。

X = 不定。

↑ = 操作の結果により、セットまたはリセットされる。

表6-5 各種操作およびCPU制御

| ニーモニック<br>コード | シンボリック<br>オペレーション | フラグ |   |     |   |   |   | オペコード                    | バイト<br>数 | Mサイ<br>クル数 | Tステ<br>ート数 | コメ<br>ント |      |
|---------------|-------------------|-----|---|-----|---|---|---|--------------------------|----------|------------|------------|----------|------|
|               |                   | C   | Z | P/V | S | N | H |                          |          |            |            | ss       | レジスタ |
| ADD HL,ss     | HL←HL+ss          | †   | ● | ●   | ● | 0 | X | 00 ss1 001               | 1        | 3          | 11         |          |      |
| ADC HL,ss     | HL←HL+ss+CY       | †   | † | V   | † | 0 | X | 11 101 101<br>01 ss1 010 | 2        | 4          | 15         | 00       | BC   |
| SBC HL,ss     | HL←HL-ss-CY       | †   | † | V   | † | 1 | X | 11 101 101<br>01 ss0 010 | 2        | 4          | 15         | 01       | DE   |
| ADD IX,pp     | IX←IX+pp          | †   | ● | ●   | ● | 0 | X | 11 011 101<br>00 pp1 001 | 2        | 4          | 15         | 10       | HL   |
|               |                   |     |   |     |   |   |   |                          |          |            |            | 11       | SP   |
|               |                   |     |   |     |   |   |   |                          |          |            |            | pp       | レジスタ |
|               |                   |     |   |     |   |   |   |                          |          |            |            | 00       | BC   |
|               |                   |     |   |     |   |   |   |                          |          |            |            | 01       | DE   |
|               |                   |     |   |     |   |   |   |                          |          |            |            | 10       | IX   |
|               |                   |     |   |     |   |   |   |                          |          |            |            | 11       | SP   |
| ADD IY,rr     | IY←IY+rr          | †   | ● | ●   | ● | 0 | X | 11 111 101<br>00 rr1 001 | 2        | 4          | 15         | rr       | レジスタ |
|               |                   |     |   |     |   |   |   |                          |          |            |            | 00       | BC   |
|               |                   |     |   |     |   |   |   |                          |          |            |            | 01       | DE   |
|               |                   |     |   |     |   |   |   |                          |          |            |            | 10       | IY   |
|               |                   |     |   |     |   |   |   |                          |          |            |            | 11       | SP   |
| INC ss        | ss←ss+1           | ●   | ● | ●   | ● | ● | ● | 00 ss0 011               | 1        | 1          | 6          |          |      |
| INC IX        | IX←IX+1           | ●   | ● | ●   | ● | ● | ● | 11 011 101<br>00 100 011 | 2        | 2          | 10         |          |      |
| INC IY        | IY←IY+1           | ●   | ● | ●   | ● | ● | ● | 11 111 101<br>00 100 011 | 2        | 2          | 10         |          |      |
| DEC ss        | ss←ss-1           | ●   | ● | ●   | ● | ● | ● | 00 ss1 011               | 1        | 1          | 6          |          |      |
| DEC IX        | IX←IX-1           | ●   | ● | ●   | ● | ● | ● | 11 011 101<br>00 101 011 | 2        | 2          | 10         |          |      |
| DEC IY        | IY←IY-1           | ●   | ● | ●   | ● | ● | ● | 11 111 101<br>00 101 011 | 2        | 2          | 10         |          |      |

注) ssはレジスタ・ペア BC, DE, HL, SP。

ppはレジスタ・ペア BC, DE, IX, SP。

rrはレジスタ・ペア BC, DE, IY, SP。

フラグ: ● = 変化せず。

0 = リセットされる。

X = 不定。

† = 操作の結果により、セットまたはリセットされる。

表6-6 16ビット算術演算

| ニーモニック<br>コード | シンボリック<br>オペレーション                                                                   | フラグ |   |     |   |   |   | オペコード                                             | バイト<br>数 | Mサイ<br>クル数 | Tステ<br>ート数 | コメ<br>ント             |      |
|---------------|-------------------------------------------------------------------------------------|-----|---|-----|---|---|---|---------------------------------------------------|----------|------------|------------|----------------------|------|
|               |                                                                                     | C   | Z | P/V | S | N | H |                                                   |          |            |            |                      |      |
| RLC A         |    | ↑   | ● | ●   | ● | 0 | 0 | 00 000 111                                        | 1        | 1          | 4          | アキュムレータの内容を左へローテイトする |      |
| RL A          |    | ↑   | ● | ●   | ● | 0 | 0 | 00 010 111                                        | 1        | 1          | 4          |                      |      |
| RRC A         |    | ↑   | ● | ●   | ● | 0 | 0 | 00 001 111                                        | 1        | 1          | 4          | アキュムレータの内容を右へローテイトする |      |
| RR A          |    | ↑   | ● | ●   | ● | 0 | 0 | 00 011 111                                        | 1        | 1          | 4          |                      |      |
| RLC r         |                                                                                     | ↑   | ↑ | P   | ↑ | 0 | 0 | 11 001 011<br>00 [000] r                          | 2        | 2          | 8          | レジスタ r の内容を左へローテイトする |      |
| RLC (HL)      |                                                                                     | ↑   | ↑ | P   | ↑ | 0 | 0 | 11 001 011<br>00 [000] 110                        | 2        | 4          | 15         | r                    | レジスタ |
| RLC (IX+d)    |    | ↑   | ↑ | P   | ↑ | 0 | 0 | 11 011 101<br>11 001 011<br>← d →<br>00 [000] 110 | 4        | 6          | 23         | 000                  | B    |
| RLC (IY+d)    |                                                                                     | ↑   | ↑ | P   | ↑ | 0 | 0 | 11 111 101<br>11 001 011<br>← d →<br>00 [000] 110 | 4        | 6          | 23         | 001                  | C    |
| RL s          |   | ↑   | ↑ | P   | ↑ | 0 | 0 | [010]                                             |          |            |            |                      |      |
| RRC s         |  | ↑   | ↑ | P   | ↑ | 0 | 0 | [001]                                             |          |            |            |                      |      |
| RR s          |  | ↑   | ↑ | P   | ↑ | 0 | 0 | [011]                                             |          |            |            |                      |      |
| SLA s         |  | ↑   | ↑ | P   | ↑ | 0 | 0 | [100]                                             |          |            |            |                      |      |
| SRA s         |  | ↑   | ↑ | P   | ↑ | 0 | 0 | [101]                                             |          |            |            |                      |      |
| SRL s         |  | ↑   | ↑ | P   | ↑ | 0 | 0 | [111]                                             |          |            |            |                      |      |
| RLD           |  | ●   | ↑ | P   | ↑ | 0 | 0 | 11 101 101<br>01 101 111                          | 2        | 5          | 18         |                      |      |
| RRD           |  | ●   | ↑ | P   | ↑ | 0 | 0 | 11 101 101<br>01 100 111                          | 2        | 5          | 18         |                      |      |

フラグ: ● = 変化せず。  
 0 = リセットされる。  
 1 = セットされる。  
 X = 不定。  
 ↓ = 操作結果により、セットまたはリセットされる。

表6-7 ローテイト、シフト

| ニーモニック<br>コード | シンボリック<br>オペレーション                                                  | フラグ |   |     |   |   |   | オペコード                                         | バイト<br>数 | Mサイ<br>クル数 | Tステ<br>ート数 | コメント                     |                  |
|---------------|--------------------------------------------------------------------|-----|---|-----|---|---|---|-----------------------------------------------|----------|------------|------------|--------------------------|------------------|
|               |                                                                    | C   | Z | P/V | S | N | H | 76 543 210                                    |          |            |            | r                        | レジスタ             |
| BIT b,r       | $Z \leftarrow \bar{r}_b$                                           | ●   | † | X   | X | 0 | 1 | 11 001 011<br>01 b r                          | 2        | 2          | 8          | r                        | レジスタ             |
| BIT b,(HL)    | $Z \leftarrow \overline{(HL)}_b$                                   | ●   | † | X   | X | 0 | 1 | 11 001 011<br>01 b 110                        | 2        | 3          | 12         | 000<br>001<br>010        | B<br>C<br>D      |
| BIT b,(IX+d)  | $Z \leftarrow \overline{(IX+d)}_b$                                 | ●   | † | X   | X | 0 | 1 | 11 011 101<br>11 001 011<br>← d →<br>01 b 110 | 4        | 5          | 20         | 011<br>100<br>101<br>111 | E<br>H<br>L<br>A |
| BIT b,(IY+d)  | $Z \leftarrow \overline{(IY+d)}_b$                                 | ●   | † | X   | X | 0 | 1 | 11 111 101<br>11 001 011<br>← d →<br>01 b 110 | 4        | 5          | 20         | b                        | テストビット           |
| SET b,r       | $r_b \leftarrow 1$                                                 | ●   | ● | ●   | ● | ● | ● | 11 001 011<br>11 b r                          | 2        | 2          | 8          | 000<br>001<br>010        | 0<br>1<br>2      |
| SET b,(HL)    | $(HL)_b \leftarrow 1$                                              | ●   | ● | ●   | ● | ● | ● | 11 001 011<br>11 b 110                        | 2        | 4          | 15         | 100<br>101<br>110<br>111 | 4<br>5<br>6<br>7 |
| SET b,(IX+d)  | $(IX+d)_b \leftarrow 1$                                            | ●   | ● | ●   | ● | ● | ● | 11 011 101<br>11 001 011<br>← d →<br>11 b 110 | 4        | 6          | 23         |                          |                  |
| SET b,(IY+d)  | $(IY+d)_b \leftarrow 1$                                            | ●   | ● | ●   | ● | ● | ● | 11 111 101<br>11 001 011<br>← d →<br>11 b 110 | 4        | 6          | 23         |                          |                  |
| RES b,s       | $s_b \leftarrow 0$<br>$s \equiv r, (HL),$<br>$(IX+d),$<br>$(IY+d)$ |     |   |     |   |   |   | 10                                            |          |            |            | オペランド s のビット b をリセットする   |                  |

注)  $m_b$  の  $b$  は m の示すメモリの位置またはレジスタのビット 0 ~ 7 を示す。

フラグ: ● = 変化せず。

0 = リセットされる。

1 = セットされる。

X = 不定。

† = 操作の結果により、セットまたはリセットされる。

表6-8 ビット操作、テスト

| ニーモニック<br>コード | シンボリック<br>オペレーション           | フラグ |   |     |   |   |   | オペコード                        | バイト<br>数 | Mサイ<br>クル数 | Tステ<br>ート数 | コメント   |                 |
|---------------|-----------------------------|-----|---|-----|---|---|---|------------------------------|----------|------------|------------|--------|-----------------|
|               |                             | C   | Z | P/V | S | N | H |                              |          |            |            |        |                 |
| JP nn         | PC←nn                       | ●   | ● | ●   | ● | ● | ● | 11 000 011<br>← n →<br>← n → | 3        | 3          | 10         |        |                 |
| JP cc,nn      | ccが真なら<br>PC←nn<br>偽なら次の命令へ | ●   | ● | ●   | ● | ● | ● | 11 cc 010<br>← n →<br>← n →  | 3        | 3          | 10         | cc     | 条件              |
|               |                             |     |   |     |   |   |   |                              |          |            |            | 000    | NZnon zero      |
|               |                             |     |   |     |   |   |   |                              |          |            |            | 001    | Z zero          |
|               |                             |     |   |     |   |   |   |                              |          |            |            | 010    | NCnon carry     |
|               |                             |     |   |     |   |   |   |                              |          |            |            | 011    | C carry         |
|               |                             |     |   |     |   |   |   |                              |          |            |            | 100    | PO parity odd   |
|               |                             |     |   |     |   |   |   |                              |          |            |            | 101    | PE parity even  |
|               |                             |     |   |     |   |   |   |                              |          |            |            | 110    | P sign positive |
|               |                             |     |   |     |   |   |   |                              |          |            |            | 111    | M sign negative |
| JR e          | PC←PC+e                     | ●   | ● | ●   | ● | ● | ● | 00 011 000<br>← e-2 →        | 2        | 3          | 12         |        |                 |
| JR C,e        | C=0なら次の命令<br>～              | ●   | ● | ●   | ● | ● | ● | 00 111 000<br>← e-2 →        | 2        | 2          | 7          |        |                 |
|               | C=1なら<br>PC←PC+e            |     |   |     |   |   |   |                              | 2        | 3          | 12         |        |                 |
| JR NC,e       | C=1なら<br>次の命令へ              | ●   | ● | ●   | ● | ● | ● | 00 110 000<br>← e-2 →        | 2        | 2          | 7          |        |                 |
|               | C=0なら<br>PC←PC+e            |     |   |     |   |   |   |                              | 2        | 3          | 12         |        |                 |
| JR Z,e        | Z=0なら次の命令<br>～              | ●   | ● | ●   | ● | ● | ● | 00 101 000<br>← e-2 →        | 2        | 2          | 7          |        |                 |
|               | Z=1なら<br>PC←PC+e            |     |   |     |   |   |   |                              | 2        | 3          | 12         |        |                 |
| JR NZ,e       | Z=1なら次の命令<br>～              | ●   | ● | ●   | ● | ● | ● | 00 100 000<br>← e-2 →        | 2        | 2          | 7          |        |                 |
|               | Z=0なら<br>PC←PC+e            |     |   |     |   |   |   |                              | 2        | 3          | 12         |        |                 |
| JP (HL)       | PC←HL                       | ●   | ● | ●   | ● | ● | ● | 11 101 001                   | 1        | 1          | 4          |        |                 |
| JP (IX)       | PC←IX                       | ●   | ● | ●   | ● | ● | ● | 11 011 101<br>11 101 001     | 2        | 2          | 8          |        |                 |
| JP (IY)       | PC←IY                       | ●   | ● | ●   | ● | ● | ● | 11 111 101<br>11 101 001     | 2        | 2          | 8          |        |                 |
| DJNZ,e        | B←B-1<br>B=0なら次の命令<br>～     | ●   | ● | ●   | ● | ● | ● | 00 010 000<br>← e-2 →        | 2        | 2          | 8          | B=0の場合 |                 |
|               | B≠0なら<br>PC←PC+e            |     |   |     |   |   |   |                              | 2        | 3          | 13         | B≠0の場合 |                 |

注) eは相対アドレシング・モードでのイクステンション。

eは符号付2の補数値(-126～+129)。

e-2はPCが自動的に+2されてしまうので、これをキャンセルした値である。

eそのものは、OPコードの位置から計算した値である。

フラグ: ● = 変化せず。

0 = リセットされる。

1 = セットされる。

X = 不定。

↑ = 操作の結果により、セットまたはリセットされる。

表6-9 ジャンプ

| ニーモニック<br>コード | シンボリック<br>オペレーション                                                                            | フラグ |   |     |   |   |   | オペコード      |       | バイト<br>数 | Mサイ<br>クル数 | Tステ<br>ート数 | コメント    |              |
|---------------|----------------------------------------------------------------------------------------------|-----|---|-----|---|---|---|------------|-------|----------|------------|------------|---------|--------------|
|               |                                                                                              | C   | Z | P/V | S | N | H | 76 543 210 | ← n → |          |            |            | ← n →   | コメント         |
| CALL nn       | (SP-1)←PC <sub>H</sub><br>(SP-2)←PC <sub>L</sub><br>PC←nn                                    | ●   | ● | ●   | ● | ● | ● | 11 001 101 | ← n → | 3        | 5          | 17         |         |              |
| CALL cc,nn    | ccが真ならば<br>CALL nnと同じ、<br>偽なら次の命令へ                                                           | ●   | ● | ●   | ● | ● | ● | 11 cc 100  | ← n → | 3        | 3          | 10         | ccが偽の場合 |              |
| RET           | PC <sub>L</sub> ←(SP)<br>PC <sub>H</sub> ←(SP+1)                                             | ●   | ● | ●   | ● | ● | ● | 11 001 001 | ← n → | 1        | 3          | 10         | ccが真の場合 |              |
| RET cc        | ccが真ならばRET<br>と同じ、偽なら次<br>の命令へ                                                               | ●   | ● | ●   | ● | ● | ● | 11 cc 000  | ← n → | 1        | 1          | 5          | ccが偽の場合 |              |
| RETI          | 割り込みからのリ<br>ターン                                                                              | ●   | ● | ●   | ● | ● | ● | 11 101 101 | ← n → | 2        | 4          | 14         | 000     | NZ non zero  |
|               |                                                                                              |     |   |     |   |   |   | 01 001 101 |       |          |            |            | 001     | Z zero       |
| RETN          | NMIからのリター<br>ン                                                                               | ●   | ● | ●   | ● | ● | ● | 11 101 101 | ← n → | 2        | 4          | 14         | 010     | NC non carry |
|               |                                                                                              |     |   |     |   |   |   | 01 000 101 |       |          |            |            | 011     | C carry      |
| RST p         | (SP-1)←PC <sub>H</sub><br>(SP-2)←PC <sub>L</sub><br>PC <sub>H</sub> ←0<br>PC <sub>L</sub> ←P | ●   | ● | ●   | ● | ● | ● | 11 t 111   | ← n → | 1        | 3          | 11         | t       | P            |
|               |                                                                                              |     |   |     |   |   |   |            |       |          |            |            | 000     | 00H          |
|               |                                                                                              |     |   |     |   |   |   |            |       |          |            |            | 001     | 08H          |
|               |                                                                                              |     |   |     |   |   |   |            |       |          |            |            | 010     | 10H          |
|               |                                                                                              |     |   |     |   |   |   |            |       |          |            |            | 011     | 18H          |
|               |                                                                                              |     |   |     |   |   |   |            |       |          |            |            | 100     | 20H          |
|               |                                                                                              |     |   |     |   |   |   |            |       |          |            |            | 101     | 28H          |
|               |                                                                                              |     |   |     |   |   |   |            |       |          |            |            | 110     | 30H          |
|               |                                                                                              |     |   |     |   |   |   |            |       |          |            |            | 111     | 38H          |

フラグ: ● = 変化せず。

0 = リセットされる。

1 = セットされる。

X = 不定。

† = 操作の結果により、セットまたはリセットされる。

表6-10 コール、リターン

| ニーモニック<br>コード | シンボリック<br>オペレーション                         | フラグ |   |     |   |   |   | オペコード                    | バイト<br>数 | Mサイ<br>クル数          | Tステ<br>ート数 | コメ<br>ント                                                                      |
|---------------|-------------------------------------------|-----|---|-----|---|---|---|--------------------------|----------|---------------------|------------|-------------------------------------------------------------------------------|
|               |                                           | C   | Z | P/V | S | N | H |                          |          |                     |            |                                                                               |
| IN A,(n)      | A←(n)                                     | ●   | ● | ●   | ● | ● | ● | 11 011 011<br>↔ n →      | 2        | 3                   | 11         | n to A <sub>0</sub> ~A <sub>7</sub><br>Acc to A <sub>8</sub> ~A <sub>15</sub> |
| IN r,(C)      | r←(C)                                     | ●   | ↑ | P   | ↑ | 0 | 0 | 11 101 101<br>01 r 000   | 2        | 3                   | 12         | C to A <sub>0</sub> ~A <sub>7</sub><br>B to A <sub>8</sub> ~A <sub>15</sub>   |
| INI           | (HL)←(C)<br>B←B-1<br>HL←HL+1              | ●   | ↑ | X   | X | 1 | X | 11 101 101<br>10 100 010 | 2        | 4                   | 16         | C to A <sub>0</sub> ~A <sub>7</sub><br>B to A <sub>8</sub> ~A <sub>15</sub>   |
| INIR          | (HL)←(C)<br>B←B-1<br>HL←HL+1<br>B=0まで繰り返す | ●   | 1 | X   | X | 1 | X | 11 101 101<br>10 110 010 | 2        | 5<br>(B≠0)<br>(のとき) | 21         | C to A <sub>0</sub> ~A <sub>7</sub><br>B to A <sub>8</sub> ~A <sub>15</sub>   |
| IND           | (HL)←(C)<br>B←B-1<br>HL←HL-1              | ●   | ↑ | X   | X | 1 | X | 11 101 101<br>10 101 010 | 2        | 4<br>(B=0)<br>(のとき) | 16         | C to A <sub>0</sub> ~A <sub>7</sub><br>B to A <sub>8</sub> ~A <sub>15</sub>   |
| INDR          | (HL)←(C)<br>B←B-1<br>HL←HL-1<br>B=0まで繰り返す | ●   | 1 | X   | X | 1 | X | 11 101 101<br>10 111 010 | 2        | 5<br>(B=0)<br>(のとき) | 21         | C to A <sub>0</sub> ~A <sub>7</sub><br>B to A <sub>8</sub> ~A <sub>15</sub>   |
| OUT (n),A     | (n)←A                                     | ●   | ● | ●   | ● | ● | ● | 11 010 011               | 2        | 3                   | 11         | n to A <sub>0</sub> ~A <sub>7</sub><br>Acc to A <sub>8</sub> ~A <sub>15</sub> |
| OUT (C),r     | (C)←r                                     | ●   | ● | ●   | ● | ● | ● | 11 101 101<br>01 r 001   | 2        | 3                   | 12         | C to A <sub>0</sub> ~A <sub>7</sub><br>B to A <sub>8</sub> ~A <sub>15</sub>   |
| OUTI          | (C)←(HL)<br>B←B-1<br>HL←HL+1              | ●   | ↑ | X   | X | 1 | X | 11 101 101<br>10 100 011 | 2        | 4                   | 16         | C to A <sub>0</sub> ~A <sub>7</sub><br>B to A <sub>8</sub> ~A <sub>15</sub>   |
| OTIR          | (C)←(HL)<br>B←B-1<br>HL←HL+1<br>B=0まで繰り返す | ●   | 1 | X   | X | 1 | X | 11 101 101<br>10 110 011 | 2        | 5<br>(B≠0)<br>(のとき) | 21         | C to A <sub>0</sub> ~A <sub>7</sub><br>B to A <sub>8</sub> ~A <sub>15</sub>   |
| OUTD          | (C)←(HL)<br>B←B-1<br>HL←HL-1              | ●   | ↑ | X   | X | 1 | X | 11 101 101<br>10 101 011 | 2        | 4<br>(B=0)<br>(のとき) | 16         | C to A <sub>0</sub> ~A <sub>7</sub><br>B to A <sub>8</sub> ~A <sub>15</sub>   |
| OTDR          | (C)←(HL)<br>B←B-1<br>HL←HL-1<br>B=0まで繰り返す | ●   | 1 | X   | X | 1 | X | 11 101 101<br>10 111 011 | 2        | 5<br>(B≠0)<br>(のとき) | 21         | C to A <sub>0</sub> ~A <sub>7</sub><br>B to A <sub>8</sub> ~A <sub>15</sub>   |
|               |                                           |     |   |     |   |   |   |                          |          |                     |            |                                                                               |

注) ①B-1が零になればZフラグがセットされ、それ以外のときはリセットされる。

A<sub>0</sub>~A<sub>15</sub>はアドレス・バス。

フラグ: ● = 変化せず。

0 = リセットされる。

1 = セットされる。

X = 不定。

↑操作結果により、セットまたはリセットされる。

表6-11 入力／出力

## 7. 割り込み応答

割り込みは、周辺デバイスがCPUの通常処理を一時保留させ、周辺デバイスの処理ルーチンを実行させるために設けられている。普通このサービス（処理）には、CPUと周辺とのデータ、ステータス、あるいは制御情報の送受などが含まれている。このサービス・ルーチンが終了すれば、CPUは割り込みがかかったまえの処理に戻る。

### 割り込みのイネーブル／ディセーブル

Z-80A CPUには、ソフト的にマスク可能な割り込みの2つの割り込み入力端子が設けられている。

ノン・マスカブル割り込み（NMI）はプログラムによってディセーブル（禁止）できず、周辺デバイスが要求を出せば必ず受け付けられる。この割り込みは普通重要な機能、たとえば不意の停電のようないつ起こるかわからない事故に対する処置用として使用される。

マスカブル割り込み（INT）はプログラムによりイネーブル（許可）、ディセーブル（禁止）を自由に選択できるもので、計時（タイマ）のように途中で邪魔（割り込み）が入っては困る場合に、プログラムにより適当にディセーブルしておくことができる。

CPU内にイネーブル・フリップ・フロップ（IFF）が設けられているので、これをプログラムによってEI（イネーブル割り込み）またはDI（ディセーブル割り込み）命令でセット、またはリセットする。

IFFがリセットされれば、CPUは割り込みを受け付けなくなる。

実際には、IFFはIFF<sub>1</sub>とIFF<sub>2</sub>の2つのイネーブル・フリップ・フロップにより構成される。



リセットされれば割り込み禁止となる。

IFF<sub>1</sub>の一時保持用

IFF<sub>1</sub>の状態で、イネーブルかディセーブルかが決まる。IFF<sub>2</sub>はIFF<sub>1</sub>の一時保持用である。このIFF<sub>2</sub>が必要な理由をあとで述べる。

CPUがリセットされたとき、IFF<sub>1</sub>、IFF<sub>2</sub>もリセット状態となり、割り込みはディセーブルとなる。この後、任意の時点でEI命令を使用して割り込みをイネーブルにすることができる。

EI命令が実行されたとき、待たされている割り込み要求はEI命令の次の命令が実行されたあとでなければ受け付けられない。

この1命令分の遅延は、次の命令がリターン命令の場合、EI命令を実行させたとき、リターン命令が完了した後で待機中の割り込みが受け付けられるようにするために、設けられている。

EI命令でIFF<sub>1</sub>、IFF<sub>2</sub>の両方がセットされ、イネーブル状態となる。割り込みが受け付けられたときには自動的に両方ともリセットされ、プログラムが新たにEI命令を実行させることができれば割り込みは禁止されたままになる。

上に述べた場合においては、いずれもIFF<sub>1</sub>、IFF<sub>2</sub>はつねに同様である点に注意されたい。

IFF<sub>2</sub>はNMI（ノン・マスカブル割り込み）の発生時にIFF<sub>1</sub>の状態をセーブしておくために設けられている。

NMIが受け付けられたとき、続けて割り込みが入るのを禁止するためにIFF<sub>1</sub>はリセットされるが、さきの状態がリセットかセットか（つまり、今INTの処理中であるか否か）を保存しておく必要がある。IFF<sub>2</sub>はこのためのもので、IFF<sub>1</sub>と同じ状態をIFF<sub>2</sub>に入れておく。

LD命令（LD A, IあるいはLD A, R）を実行したとき、IFF<sub>2</sub>の状態がパリティ・フラグにコピーされるので、それをテストしたり、別の場所にストアしたりすることができる。

RETN（ノン・マスカブル割り込みからのリターン）命令を実行すると、IFF<sub>2</sub>の内容がIFF<sub>1</sub>にコピー・バックされ、NMIの入るまえのIFF<sub>1</sub>の状態が再生される。

図7-1に、2つのフリップ・フロップの状態を示す。

| 操作                 | IFF <sub>1</sub> | IFF <sub>2</sub> |                                    |
|--------------------|------------------|------------------|------------------------------------|
| CPUリセット            | 0                | 0                |                                    |
| DI                 | 0                | 0                |                                    |
| EI                 | 1                | 1                |                                    |
| LD A, I            | ●                | ●                | IFF <sub>2</sub> →パリティ・フラグ         |
| LD A, R            | ●                | ●                | IFF <sub>2</sub> →パリティ・フラグ         |
| NMI                | 0                | ●                |                                    |
| RETN               | IFF <sub>2</sub> | ●                | IFF <sub>2</sub> →IFF <sub>1</sub> |
| DI, then NMI       | 0                | 0                |                                    |
| EI, then NMI       | 0                | 1                |                                    |
| EI, NMI, then RETN | 1                | 1                | ●=変化なしの意味                          |

図7-1 IFF<sub>1</sub>, IFF<sub>2</sub>の状態

## CPUの応答

### ノン・マスカブル

ノン・マスカブル割り込みはどの時点でも受け付けられる。これが入力すると、CPUはフェッチした次の命令を無視して、メモリ番地 0066<sub>H</sub> にある命令から実行する。つまり、あたかもリスタート命令をフェッチしたかのように動作するが、この場合、正しくはプログラム可能な 8 つのリスタート・ロケーションのいずれかにリスタートするわけではない。メモリのページ・ゼロの特定のアドレス (66<sub>H</sub>) へのコール命令の実行である。

### マスカブル

Z-80A CPUにはプログラムで指定できる 3 種のマスク可能な割り込みモードがある。

#### モード 0

このモードは 8080A の割り込み応答モードと同様である。このモードでは、割り込みをかけているデバイスがデータ・バス上に何らかの命令を置き、CPUがそれを実行する。

割り込みをかけているデバイスは、プログラム・メモリに代って次に実行すべき命令をデータ・バスに乗せる。この命令は 1 バイト命令の場合、通常リスタート命令である。3 バイトのコール命令を用いた場合、メモリのどの位置からでも実行を始めることができる。

必要なクロック・サイクル数は通常の数より 2 クロック多くなる。これは CPU が自動的に 2 つのウエイト・サイクルを挿入して、割り込み制御用の外部デージー・チェーンを全部動作させるのに必要な時間をとるためである。

割り込み応答の詳細なタイミングについては第 4 章に示してある。

RESETを行えば、自動的に CPU はモード 0 になる。

#### モード 1

このモードをプログラムで選択しておくと、CPU は割り込みに対し、位置 0038<sub>H</sub>へのリスタートを実行する。この応答はコールする位置が 0066<sub>H</sub> の代りに、0038<sub>H</sub> になっている以外は NMI 応答とはほぼ同様である。他の異なる点として、2 つのウエイト・サイクルが追加される点がある。

#### モード 2

このモードは最も強力な応答モードであり、1 バイトの指定でどのメモリの位置でも間接コールができる。

このモードを使用する場合、まえもってプログラムにより割り込みサービス・ルーチンのスタート・アドレス (16 ビット) のテーブルを適当な位置に配置しておく。この位置はメモリのどの場所でもよい。

割り込みを受け付けたとき、16 ビットのポインタで、必要な割り込みサービス・ルーチンのスタート・アドレスをテーブルからもってくるが、このポインタとして上位 8 ビットには I レジスタの内容を充当する。

この I レジスタには、まえもってプログラムにより LD 命令で必要な値をロードしておかねばならない。

CPU のリセットにより I レジスタもクリアされるので、I レジスタの初期値は零である。

ポインタの下位 8 ビットには割り込みをかけているデバイスから供給しなければならないが、実際は 7 ビットが有効で最下位ビットはこのモードではつねに零である。というのは、テーブル上のスタート・アドレスは 2 バイトずつで、この 2 バイトは必ず偶数アドレスから順に下位バイト、上位バイトと入れておかねばならないからである。



プログラムにより割り込みを受け付けるまでに、必要なアドレスをテーブルにセットしておけばよい。このテーブルを読み出し・書き込みメモリ内に指定しておくと、いつでもプログラムで変更ができるので、異なる周辺デバイスを異なったサービス・ルーチンで処理することもできる。

割り込みをかけているデバイスがポインタの下位8ビットを乗せたあと、CPUは自動的に次に実行すべきPC（プログラム・カウンタ）の内容をスタックにプッシュし、テーブルからスタート・アドレスを持ってそのアドレスへジャンプする。

この応答モードでは、19クロック周期を必要とし、7クロックで割り込みをかけているデバイスからの下位8ビットをフェッチ、6クロックでPCの内容のセーブ、6クロックでジャンプ・アドレスを得る。

Z-80A周辺デバイスはすべてデージー・チェーン構造の割り込み優先順位回路を含んでおり、割り込みアクノリッジ期間中CPUにベクトル（プログラムされている）を自動的に供給するようになっている点に注意されたい。

これについてはZ-80A PIO、Z-80A CTCなどの仕様を参照のこと。

## A.2 Z80A-PIOテクニカルデータ

### 1. 緒論

Z-80A PIO (Parallel Input/Output Interface Controller) はZ-80A CPUと周辺装置とのインターフェース用のデバイスで、種々の動作モードをプログラムで指示することができる。また本デバイスはTTLコンパチブルの入出力ポートを2個もっている。

Z-80A PIOはこれをCPUのインターフェース・デバイスとして用いると、余分な外部論理回路を追加しないで広範囲の周辺装置に適用することができる。

Z-80A PIOと接続可能な周辺装置は、たとえば、キーボード、紙テープ・リーダ、紙テープ・パンチャ、プリンタなどがある。

Z-80A PIOはNチャネル・シリコンゲート・デブリーション・ロード技術で製造され、40ピンDIPパッケージである。

Z-80A PIOの主な特長は、

- 2つの独立した8ビット双方向性の周辺装置用インターフェース・ポートがあり、それぞれにデータ転送の制御用の“ハンドシェーク”線がある。
- 割り込みは高速応答に適した“ハンドシェーク”で起動される。
- 各ポートごとに、次の動作モードの選択ができる。

  バイト出力

  バイト入力

  バイト単位の双方向バス（ポートAのみ）

  ビット制御モード

これらにはすべてハンドシェークで制御される割り込み機能がある。

- 外部論理回路なしで自動的に割り込みベクトルを出せるデージー・チェーン構造の割り込み優先順位回路を内蔵している。
- 8出力はダーリントン・トランジスタを駆動できる。
- 全入出力はTTLコンパチブルである。
- 単一5V電源、単相クロックのみで動作する。

Z-80A PIOは他のインターフェース・コントローラと異なり、周辺装置とCPUとの間のデータ転送を割り込み制御の方法により効率よく行うことができる。またZ-80A PIOには、Z-80A CPUの効率の良い割り込み処理能力を入出力データの転送期間に充分に発揮できるように、割り込み処理用の論理回路が組み込まれており、かつ多重の割り込みをネストさせるために必要な論理回路も内蔵している。このため割り込み処理用の余分な外部回路を必要としない。

その他、周辺装置が特定の状態になったときに、割り込み信号が出るようにプログラムしておくこともできるようになっているのも特記すべき点である。たとえば、プログラミングによって、ある周辺装置に特定の状態となる条件が発生したときに割り込みを出すことができる。

この割り込みの能力によってプロセッサが周辺装置のステータスをポーリングする（調べる）間の時間を節約するのに役立つことがある。

なお、Z-80A PIOは周波数の上限を4MHzまで保証したZ-80 PIO高速タイプである。

## 2. アーキテクチャ

図2-1にZ-80A PIOのブロック図を示す。

Z-80A PIOの内部は次の各部で構成されている。

- Z-80A CPU用バス・インターフェース
- 内部制御回路
- ポートA入出力論理回路
- ポートB入出力論理回路
- 割り込み制御回路

CPUバス・インターフェース用論理回路は他の外部回路を追加せずに直接CPUに接続できるようになっているが、大きなシステムでは必要に応じてアドレス・デコーダやライン・バッファを付加しなければならないこともある。

内部制御回路はCPUデータ・バスを周辺装置用インターフェース部（ポートA, B）と同期させるためのものである。2つの入出力ポート（A, B）は、ほぼ同様に使用でき、直接周辺装置と結合する部分である。



図2-1 Z-80A PIO ブロック図

ポート入出力論理回路は図2-2に示すように、“ハンドシェーク”用論理回路を含む6つのレジスタから構成されている。

これらはそれぞれ8ビット・データ入力レジスタ、8ビット・データ出力レジスタ、2ビットのモード制御用レジスタ、8ビットのマスク・レジスタ、8ビット入出力選択レジスタ、2ビットのマスク制御用レジスタである。



図2-2 ポート入出力ブロック図

2ビットのモード制御用レジスタは4つの動作モード（バイト入力、バイト出力、バイト双方向バス、ビット制御モード）のうちいずれかを指定するためのもので、CPUからの制御で設定される。

周辺装置とCPUとの間のデータ転送はすべて入出力用レジスタを介して行われ、CPUからの出力データは出力レジスタを通して周辺装置へ送られ、CPUへの入力データは入力レジスタを通してCPUに読み込まれる。データの入出力はどの時点で行ってもよい。

各ポートのハンドシェーク線はPIOと周辺装置との間のデータ転送の制御用として用いる。

8ビット・マスク・レジスタと8ビット入出力選択用レジスタはビット制御モードのときにのみ使用される。このモードでは、周辺と結ばれるデータ転送、もしくは制御用の8本のバス端子を個々に入力用または出力用に指定できる。これはプログラムで選択レジスタを設定することにより行う。

このモードでは、特定の割り込み発生条件を設定しておくためにマスク・レジスタを使用する。このマスク・レジスタは入出力用バス端子のどれをモニタするかを決めるために使用し、またどのようにモニタするかは次のようにマスク制御レジスタを使用して行う。

2ビットのマスク制御レジスタは、モニタすべきポート端子の入力すべてについて、AND条件をとるか、OR条件をとるか、あるいは入力が“H”レベルのときアクティブとするか、“L”レベルのときアクティブとするかを規定するためにある。これらの指定に合ったステータスになれば、割り込みが発生する。

このように、あらかじめ条件設定をプログラミングしておく方式では、周辺装置の特定のステータスで自動的に割り込みが発生させられるので、CPUが周辺のステータス・チェックをする必要がないという利点がある。システム内に3種の緊急条件がある場合、プログラムでこのうちの1種でも起これば(OR条件)、あるいは3種すべてが起これば(AND条件)割り込みを発生させる、といった使い分けもできる。

割り込み制御用論理回路はCPUの割り込みに関するすべての処理を行い、優先順位の決定などについても関与している部分である。デージー・チェーンの接続によって、各デバイスはその物理的な位置によって優先順位が決まり、CPUに近いデバイスほど優先順位が高くなる。このデージー・チェーンを形成するために、各PIOから2本の線(IEI, IEO)が出ている。また、同一PIO内ではポートAがポートBより優先順位が高い。

バイト入力モード、バイト出力モード、バイト双方向バスモードでは、周辺装置からの次のデータ・バイト転送の要求のあるたびごとに割り込みが発生する。

ビット制御モードでは、周辺のステータスがプログラムした値と一致したとき割り込みが発生する。

PIOはネスト構造の割り込みに関して完全な制御機能をもつていて、CPUが上位の優先順位をもつデバイスの割り込みサービスを行っているときには、下位のデバイスからのサービス要求は通さない(下位の優先順位のデバイスから、割り込みを発生させない)ようになっている。

しかし、上位の優先順位のデバイスは、サービス中のデバイスが下位のものであれば、割り込みをかけることができるようになっている。

モード2で、割り込みをかける場合、割り込みをかけるデバイスは8ビットの割り込みベクトルをCPUに送る必要がある。

このベクトルはメモリ位置を指定するポインタの下位データとして使用され、指定された位置にはその割り込みデバイスに対するサービス・ルーチンのスタート・アドレスを与える。

デバイスからの8ビットのベクトルはポインタ(間接)の下位8ビットとなり、CPU内のIレジスタのデータが、そのポインタの上位8ビットとなる。

なお、PIOの各ポート(AとB)の割り込みのベクトルはプログラムによって指定するものであることに注意を要する。

ベクトルの最下位ビットはスタート・アドレスを連続する2バイト(16ビット)で指定しなければならないので、プログラム側で0を指定しなければならない。

PIO自身でCPUデータ・バスに乗るRETI(割り込みからのリターン)命令を直接解続できるので、システム内の各PIOはCPUとの間に別の通信線を引かなくても、CPUの割り込みサービスが終了する時期を検知できるようになっている。

### 3. 端子説明

図3-1にZ-80A PIOの端子配置図を示す。以下この章では、各端子の機能を説明する。

|                                |                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D <sub>0</sub> ～D <sub>7</sub> | Z-80A CPUのデータ・バス（双方向性トライ・ステート）<br>このバスはCPU-PIO間ですべてのデータや命令などを転送するために使用される。<br>D <sub>0</sub> はバスの最下位ビットである。                                                                                                                                                                                                                                                                             |
| B/A SEL                        | ポートB、Aの選択（入力、アクティブ“H”）<br>この端子で、CPU-PIO間でデータ転送を行う際に、アクセスされるポートを指定する。この端子への入力が“L”レベルのときポートAを選択し、“H”レベルのときポートBを選択する。<br>通常CPUからのアドレス・ビットA <sub>1</sub> をポート選択用として使用する。                                                                                                                                                                                                                    |
| C/D SEL                        | 制御信号、データの選択（入力、アクティブ“H”）<br>この端子で、CPU-PIO間で行われるデータ転送の型を指定する。この端子への入力が“H”レベルのとき、PIOへの書き込みデータはB/A選択で指定されたポートへのコマンド（命令）として解釈され、この端子への入力が“L”レベルのときには通常のデータ転送となる。<br>通常CPUからのアドレス・ビットA <sub>0</sub> を制御信号、データ選択用として使用する。                                                                                                                                                                     |
| CE                             | チップ・イネーブル（入力、アクティブ“L”）<br>この端子を“L”レベルにすると、PIOは書き込みサイクルの期間ではCPUからコマンドまたはデータを受けとることができ、読み出しサイクルの期間ではCPUへデータを送出することができる。この信号として、通常ポートA、ポートBの各データおよびコマンドのいずれかを指定できる入出力ポート・アドレスのデコード信号を使用する。                                                                                                                                                                                                 |
| Φ                              | システム・クロック（入力）<br>Z-80A PIO内部の同期用として、Z-80A CPUの標準システム・クロックを利用している。この信号は単相クロックである。                                                                                                                                                                                                                                                                                                        |
| M1                             | CPUのマシン・サイクル1信号（入力、アクティブ“L”）<br>CPUからのこの信号はPIO内で制御用同期パルスとして使用される。<br>Z-80A CPUは、M1がアクティブでかつRDがアクティブのときには、メモリからの命令をフェッチするが、一方M1がアクティブでIORQがアクティブのときには、INT入力に対する割り込みアクノリッジを出力していることを示している。<br>さらにPIOはM1で次のような動作をする。 <ol style="list-style-type: none"><li>1. M1にPIOの割り込み論理回路を同期させる。</li><li>2. RD、IORQ信号のいずれかがアクティブでないときに、M1があれば、PIO内の論理回路はリセット状態になる。</li></ol>                           |
| IORQ                           | CPUの入力／出力要求（入力、アクティブ“L”）<br>IORQ信号は、CPUとPIO間でコマンドやデータの転送を行う場合に、B/A選択、C/D選択、CE、RD信号などと組み合わせて使用される。<br>CE、RD、IORQがともにアクティブのとき、B/Aで選択されたポートからCPUへのデータ転送が行われる（読み込み動作）。<br>逆に、CE、IORQがともにアクティブであり、RDが非アクティブのとき、B/Aで選択されたポートへ、CPUからC/D選択信号で指定された情報（データまたはコマンド）が送られる。また、CPUが割り込み受け付け状態になれば、M1とIORQがともにアクティブとなり、割り込みを出しているポート（優先順位が最上位で、かつ割り込み要求を出しているとする）から自動的にCPUデータ・バス上へポートの割り込みベクトルが送り込まれる。 |
| RD                             | CPUの読み出しサイクル・ステータス（入力、アクティブ“L”）<br>RDがアクティブのとき、メモリの読み出し、あるいは入出力デバイスの読み出しが行われる。<br>RD信号は、B/A選択、C/D選択、CE、IORQ信号と組み合わせて、PIOからCPUへのデータ転送を行わせるのに使用される。                                                                                                                                                                                                                                       |

|                                |                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IEI                            | 割り込みイネーブル入力（入力、アクティブ “H”）<br>割り込みを発生するデバイスが2個以上ある場合、それらの割り込みの優先順位を決めるデージー・チェーンを形成するために用いられる。このPIOより優先順位の高いデバイスからのIEO信号が“H”レベルであれば、条件が成立した場合に、このデバイス（PIO）から割り込みを発生することができる。（このPIOの直前のデバイスのIEOをこのPIOのIEIに接続しておく。）                                                                                                                                                                                      |
| IEO                            | 割り込みイネーブル出力（出力、アクティブ “H”）<br>このIEO信号もデージー・チェーンを形成するのに必要なものである。<br>IEIが“H”レベルで、CPUがこのPIOからの割り込みのサービスを行っていないときにだけIEOは“H”レベルとなる。このPIOの割り込みサービスが行われているときには、これより優先順位の低いデバイスのIEIがこの信号で“L”レベルにおさえられ、そこからの割り込みは阻止される。（このIEOはこのPIOの直後のデバイスのIEIに接続しておく。）                                                                                                                                                       |
| <u>INT</u>                     | 割り込み要求（出力、オープン・ドレイン、アクティブ “L”）<br>PIOからのCPUに対する割り込み要求はこの信号をアクティブにして行う。この <u>INT</u> （出力）はCPUの <u>INT</u> （入力）に接続する。                                                                                                                                                                                                                                                                                  |
| A <sub>0</sub> ～A <sub>7</sub> | ポートAバス（双方向性、トライ・ステート）<br>この8ビット・バスはZ-80A PIOのポートAと周辺装置との間でデータ、ステータス、制御情報の転送を行うもので、A <sub>0</sub> はポートAデータ・バスの最下位ビットである。                                                                                                                                                                                                                                                                              |
| <u>A STB</u>                   | 周辺装置が与えるポートAストローブ・パルス（入力、アクティブ “L”）<br>この信号の意味は、以下のように、指定されたモードごとに異なる。<br>1) 出力モード：PIOから送り出されたデータを周辺装置が受け取ったことをPIOに対して通知する信号であり、この信号の立ち上がりが有効である。<br>2) 入力モード：周辺装置からポートAの入力レジスタへデータをロードしたとき、その周辺装置から出されるストローブ信号として使用する。この信号がアクティブになったとき、データがPIOにロードされる。<br>3) 双方向モード：この信号がアクティブのとき、ポートAの出力レジスタからのデータがポートAの双方向データ・バス上に乗せられる。<br>ストローブが立ち上がれば、周辺装置がデータを受け取ったとみなされる。<br>4) ビット制御モード：このときのストローブ入力は無効である。 |
| A RDY                          | レジスタAレディ（出力、アクティブ “H”）<br>この信号の意味は、以下のように、指定されたモードによって異なる。<br>1) 出力モード：ポートAの出力レジスタがロードされていて周辺用データ・バスが安定になり、周辺装置へのデータ転送が準備できたことを指示するため、アクティブとなる。<br>2) 入力モード：ポートAの入力レジスタが空となり、周辺装置からのデータ受け入れ準備ができたとき、アクティブとなる。<br>3) 双方向モード：ポートAの出力レジスタに周辺装置へ送るべきデータがロードされたとき、アクティブとなる。<br>4) ビット制御モード：この信号は強制的に“L”状態になる。                                                                                             |
| B <sub>0</sub> ～B <sub>7</sub> | ポートBバス（双方向性、トライ・ステート）<br>この8ビット・バスはデータ、ステータス、制御語などの情報をPIOのポートBと周辺装置間で転送するために用いられる。ポートBのデータ・バスは、ダーリントン・トランジスタを駆動できるよう、1.5V当たり1.5mAの出力能力をもっている。<br>B <sub>0</sub> はバスの最下位ビットである。                                                                                                                                                                                                                       |
| <u>B STB</u>                   | 周辺装置が与えるポートBストローブ・パルス（入力、アクティブ “L”）<br>この信号の意味は、 <u>A STB</u> と同様であるが、次の点が異なる。ポートAの双方向モードでは、周辺装置からポートAの入力レジスタへのデータのストローブ（移し込み）をこのB STBで行う。（ポートAの出力レジスタ内容の出力ストローブは <u>A STB</u> を使用する。）                                                                                                                                                                                                               |

## B RDY

レジスタBレディ（出力、アクティブ“H”）

この信号の意味は、A RDYと同様であるが、次の点が異なる。ポートAの双方向モードでは、ポートAの入力レジスタが空となり、データの受け入れ準備ができたとき、このB RDYがアクティブとなる。（ポートAの出力レジスタ内容の出力準備完了の指示はA RDYによる。）



図3-1 Z-80A PIO 端子配置図

## 4. プログラミング

### 4.1 リセット

Z-80A PIO は、電源投入時、自動的にリセット状態に入る。リセット状態では次のような機能をもっている。

- 1) 両ポートのマスク・レジスタがリセットされ、全データ・ビットが禁止（インヒビット）となる。
- 2) ポートのデータ・バス線は高インピーダンス状態になり、ハンドシェークのレディ信号は非アクティブ（"L"）となる。動作モードは自動的にモード1に設定される。
- 3) ベクトル・アドレス・レジスタはリセットされない。
- 4) 両ポートの割り込みイネーブル・フリップ・フロップがリセットされる。
- 5) 両ポートの出力レジスタもリセットされる。

電源投入時の自動リセットに加え、PIO のリセットは、RD あるいはIORQ 信号を非アクティブにして2クロックのM1を与えても行える。

M1期間にRDかIORQかが検出されなければ、PIOはM1信号が非アクティブになった直後リセット状態になる。

このリセットの目的は、電源を切ってリセットするという手順を省き、簡単な外部ゲートのみでリセットを行うことができるようにするためであり、40ピンのパッケージに収めるまでの処置である。

一度PIOが内部リセット状態になると、CPUから制御語を受けるまでそのままリセット状態を保持する。

### 4.2 割り込みベクトルのローディング

PIOは、モード2の割り込み応答のとき、Z-80A CPU側に情報を返して、CPUがこれを処理・操作できるように設計されている。

このモードでは、割り込みを要求しているデバイスから割り込みベクトルを供給することになるが、このベクトルはCPU内でそのデバイスの割り込みサービス・ルーチンのアドレスを形成するのに使用される。

このベクトルは、その時点で最高位の優先順位をもっているデバイス（PIOなど）から割り込みアクノリッジ・サイクル期間中に、Z-80Aデータ・バス上に乗せられる。（CPUの割り込みサービスの詳細については、第1部Z-80A CPUテクニカル・マニュアルを参照されたい。）

PIOが出す割り込みベクトルは次のようなフォーマットで、CPUから出力命令によって制御語を書き出し、希望するPIOにロードしておく。この場合のポート・アドレスはAまたはBポートの制御語に対応するアドレスである。



ベクトルの書き込みにおいてはD<sub>0</sub>は、フラグ・ビットとして使用され、このビットが0である場合のV<sub>1</sub>からV<sub>7</sub>までが、PIO内のベクトル・レジスタにロードされる。

割り込みアクノリッジ期間に割り込みをかけたポートのベクトルが、Z-80Aデータ・バス上に、上のようなフォーマットで現われる。

### 4.3 動作モードの選択

PIOのポートAは次のような4種の異なったモードで使用できる。

- モード0（出力モード）
- モード1（入力モード）
- モード2（双方向モード）
- モード3（ビット制御モード）

数字は次のような関連で覚えるとよい。

$$0 = \text{OUT}, \quad 1 = \text{IN}, \quad 2 = \text{BI-DIRECTIONAL}$$

(出力)            (入力)            (双方向)

ポートBはモード2を除いたモード0、1、3で動作可能である。動作モードの指定はPIOに次のようなフォーマットの制御語を書き込んで行う。



ビットD<sub>7</sub>、D<sub>6</sub>により、以下のようにモードを指定できる。

| D <sub>7</sub> | D <sub>6</sub> | モード     |
|----------------|----------------|---------|
| 0              | 0              | 0 (出力)  |
| 0              | 1              | 1 (入力)  |
| 1              | 0              | 2 (双方向) |
| 1              | 1              | 3 (制御)  |

ビットD<sub>5</sub>、D<sub>4</sub>は無視される。(0、1いずれでもよい。)

ビットD<sub>3</sub>～D<sub>0</sub>により動作モードを指定し、1111に設定しておかねばならない。

モード0を指定した場合、ポートの出力レジスタ内のデータが対応するポートのデータ・バス上に乗せられる。この出力レジスタの内容は出力命令を用いて新しいデータにいつでも簡単に書き換えられるし、また、ある時点での出力レジスタの内容を入力命令を用いてCPU側へ呼び戻す(出力レジスタの内容は変化しない)こともできる。

モード0では、CPUから出力レジスタに対してデータの書き込みがあった場合、そのポートのハンドシェーク線であるレディ信号はアクティブ("H")となり、周辺装置にデータの転送が可能であるという指示を出す。この信号は周辺装置から受信したというストローブ信号が返されるまで、"H"レベルのままである。その返されたストローブの立ち上がりエッジで、もし割り込みが発生するようにプログラムされているならば、割り込みが発生し、レディ線は非アクティブ("L")となる。この簡単なハンドシェーク方式は多くの周辺装置によく使用されているものと同じ方式である。

モード1を指定した場合、ポートは入力モードとなる。ハンドシェーク動作を始めるためには、まずそのポートに対して読み出しを行ってよい(ダミー・リード)。この動作によってレディ線がアクティブとなり、"周辺装置へ入力レジスタが空になったのでデータをロードせよ"という指示が出される。次に周辺装置はストローブ信号に同期してデータを送出するが、PIOはこのストローブ信号がアクティブになることによって内部入力レジスタにデータを取り込む。この返されたストローブの立ち上がりエッジで可能であれば割り込みが発生し、レディ信号が非アクティブ状態に落される("L"となる)。データがオーバラン状態にならないように注意が行き届いていれば、レディ信号の状態にかかわらず、ストローブをかけてデータを入力レジスタへロードしてもよい。

モード2の双方向データ転送はすべてのハンドシェーク線(A、B各2本)を使用して行う。したがって、モード2では、ポートAだけをデータの入出力用として使用し、ハンドシェーク線はポートAの2本を出力制御用とし、ポートBの2本を入力制御用として使用する。A RDY、B RDYは両方とも、同時にアクティブとなる。モード0とモード2における出力時の動作の違いは、このモード2では双方向にデータ転送を行うのを可能にするためA STBがアクティブになったときにだけポートAの出力レジスタ上のデータがポートAのデータ・バス上に乗せられる、という点のみである。

モード3の動作はステータスを調べるために制御用として応用するためのものであり、この場合ハンドシェーク信号は使用しない。モード3を選択すると次にポート・アドレスに書き込む制御語によって、ポートのデータ・バス線のどれを入力用とし、どれを出力用とするかを指定する必要がある。あるビットを1に設定すれば、そのビットに対応するデータ・バス端子は入力用となり、0に設定したビットに対応するデータ・バス端子は出力用となる。

|                  |                  |                  |                  |                  |                  |                  |                  |
|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|
| D <sub>7</sub>   | D <sub>6</sub>   | D <sub>5</sub>   | D <sub>4</sub>   | D <sub>3</sub>   | D <sub>2</sub>   | D <sub>1</sub>   | D <sub>0</sub>   |
| I/O <sub>7</sub> | I/O <sub>6</sub> | I/O <sub>5</sub> | I/O <sub>4</sub> | I/O <sub>3</sub> | I/O <sub>2</sub> | I/O <sub>1</sub> | I/O <sub>0</sub> |

モード3の動作時、ストローブ信号は無視され、レディ線は"L"レベルに保持される。ポートとCPU間のデータのやりとりは動作中任意の時点で行える。ポートを読む場合、CPUに入るデータは入力として指定されたポートのデータ・バス線からのデータと出力として指定されたポートのデータ・バスからのデータが重なり合っている。

#### 4.4 割り込み制御語の設定

各ポートへの割り込み制御語の設定は次のようなフォーマットで行う。

| D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 割り込み<br>イネーブル  | AND<br>OR      | High/<br>Low   | マスク<br>指定      | 0              | 1              | 1              | 1              |

モード 3 のみで使用

割り込み制御語を指定する。

ビット D<sub>7</sub> = 1 のとき、対応するポートの割り込みイネーブル・フリップ・フロップがセットされ、ポートからの割り込み要求が可能となる。D<sub>7</sub> = 0 のとき、イネーブル・フラグはリセットされ、割り込みを発生できない。イネーブル・フラグがセットされていて、割り込みが保留状態ならば、CPUの割り込み要求信号である INT 線は "L" レベルのままである。ビット D<sub>6</sub>、D<sub>5</sub>、D<sub>4</sub> はモード 3 でのみ使用される。割り込み制御語のビット D<sub>4</sub> がセットされると、どのモードで動作している場合でも、未処理の割り込みはすべてリセットされる。モード 3 で、入出力線群のどれかがある指定状態になったとき、割り込み動作を実行できるようにするための条件設定にこの 3 ビットを用いる。ビット D<sub>6</sub> でモード 3 のデータ一致条件を AND で採るか、OR で採るかを定め、D<sub>6</sub> = 1 ならば AND、D<sub>6</sub> = 0 ならば OR となる。たとえば、AND の場合、入力線の指定ビットがすべてアクティブのときにのみ、割り込み発生の条件となり、OR の場合、指定ビットのいずれかがアクティブならば、割り込み発生の条件となる。

ビット D<sub>5</sub> は入力線のアクティブ状態の極性規定するためのものである。D<sub>5</sub> = 1 ならば、入力線が "H" レベルのときアクティブとみなし、D<sub>5</sub> = 0 ならば、入力線が "L" レベルのときアクティブとみなす。

ビット D<sub>4</sub> = 1 のとき、同一ポートに次に書き込まれた制御語はマスクと解釈される。

| D <sub>7</sub>  | D <sub>6</sub>  | D <sub>5</sub>  | D <sub>4</sub>  | D <sub>3</sub>  | D <sub>2</sub>  | D <sub>1</sub>  | D <sub>0</sub>  |
|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| MB <sub>7</sub> | MB <sub>6</sub> | MB <sub>5</sub> | MB <sub>4</sub> | MB <sub>3</sub> | MB <sub>2</sub> | MB <sub>1</sub> | MB <sub>0</sub> |

このマスクでビット 0 の箇所の入力線のみを調べ、設定条件と一致すれば割り込みを発生させる条件となる。

## 5. タイミング

### 5.1 出力モード（モード0）

図5-1にモード0の動作のタイミングを示す。出力サイクルはつねにCPUの出力命令の実行でスタートする。

CPUから入出力への書き込み動作時にPIO内でWR\*パルスが発生し（これは外部には出ない）、この信号によってCPUデータ・バス上のデータを指定されたポート（AかB）の出力レジスタにとり込む。

WR\*パルスが立ち上がったあと最初のΦの立ち下がりエッジで、周辺装置へのデータ供給が可能であるという指示を出すために、レディ・フラグがセットされる。たいていのシステムではこのレディ信号を周辺装置内のデータ・ラッチ信号として使用することができる。（WR\*は図参照）

レディ信号は次のいずれかの状態になるまでアクティブのままである。

- (1) 周辺装置がデータを受けとったときに返してくるストローブ信号の立ち上がりエッジで非アクティブとなる。
- (2) すでにアクティブであって、さらに続いてポートの出力レジスタに、データを書き込む場合、IORQの立ち下がりエッジの3/2Φ後にレディ信号を強制的に非アクティブ（“L”）にする。次にIORQの立ち上がりエッジのあと最初のΦの立ち下がりエッジで、“H”レベルに戻る。

このことからもわかるように、ポートのデータが変化すればレディ信号は必ず“L”レベルとなるようになっている。レディ信号は、クロックΦの立ち下がりエッジまでは、非アクティブにならない。クロックが立ち下がるまでレディ信号の立ち下がりを遅らせた理由はこれによって非常に簡単にストローブ・パルスを作ることができるようになるからである。

レディ線とストローブ線とを直接結べば、他の回路を使用しなくとも1クロック期間のストローブを作ることができる。IFFがセットされていて、かつ割り込みを要求しているデバイスがその時点での最高位の優先順位をもっていれば、ストローブ・パルスの立ち上がりエッジで自動的にINTが発生する。

もし、PIOがリセット状態になければ、モード0を指定する前に出力レジスタに情報をロードすると、モード0を指定したときに、すでにロードしている出力レジスタの情報がそのポートの出力線から出力する。



図5-1 モード0（出力）のタイミング

### 5.2 入力モード（モード1）

図5-2に入力サイクルのタイミングを示す。

CPUがデータの読み込みを完了したのち、周辺装置はストローブ線を使用してこのサイクルを始める。このストローブ信号が“L”レベルになることにより、ポートの入力レジスタへデータをロードし、条件が満たされているれば、ストローブ信号の立ち上がりエッジで割り込み要求線（INT）がアクティブとなる。入力レジスタが満杯になれば、クロック（Φ）の次の立ち下がりエッジで、レディをリセット（非アクティブ）し、CPUがデータを読み込んでしまうまで、次のデータのロードを禁止する。

そこでCPUは割り込みサービス・ルーチンに入り、そのルーチンで割り込みをかけたポートからのデータを読み込む。読み込み終了後、CPUのRD信号によるRD\*（図5-2参照）の立ち上がりエッジのあとΦの立ち下がりのときにレディが立ち上がり、次の新しいデータをPIOへロードしてもよい状態になる。

すでにリード待ち状態（アクティブ）であって、データがPIOポートからCPUに読み込まれている間、IORQの立ち下がりエッジのあと3/2Φ後にレディは強制的に“L”レベルに落ちる。

ユーザはレディが“H”的ときにのみPIOにデータを送り込むようにすれば、CPUがPIOからデータを読み出す期間はレディが“L”レベルとなっているので、読み出し途中でPIOの入力レジスタの内容が変わってしまうことはない。

レディは、すでに述べたように、IORQの立ち上がりエッジのあとで再び“H”レベルになる。



図5-2 モード 1（入力）のタイミング

### 5.3 双方向モード（モード 2）

このモードはたんにモード 0 とモード 1 の組み合わせであり、4 本のハンドシェーク線をすべて使用する方式である。

このモードでは4 本のハンドシェーク線が必要なので、データ転送にはポート B は使用せずポート A のみを使用する。このとき、ポート B はビット制御モードにセットしておく必要がある。ポート B をモード 3 にした場合の割り込みと、ポート A をモード 2 で動作させかつその入力転送中に生じる割り込みのベクトルは同じものになる。これら 2 つのモードのベクトルの混同はポート B を制御モード（モード 3）で動作させ、かつマスクレジスタの全ビットをインヒビットすることによって回避できる。



図5-3 モード 2（双方向）のタイミング、ポート A

双方向モードでのタイミングを図 5-3 に示す。これはほとんどモード 0、モード 1 で述べたのと同様であり、ポート A のハンドシェーク線を出力制御用に使用し、ポート B の線を入力制御用として動作させると考えればよい。その場合の 2 つのモードの異なる点は、モード 2 では A ストローブが “L” レベル (A STB がアクティブ) になったときにのみ、データがバス上に乗せられることがある。

このストローブの立ち上がりエッジのあとしばらくデータは安定しているので、この立ち上がりエッジを周辺装置へのラッチ信号として使用することができる。

モード 2 の入力動作はモード 1 のそれと同じである。

ポート A、ポート B ともに割り込み駆動で双方向転送が行えるようにするためには、それぞれが割り込み機能をもつようにしておく必要がある。

A STB がアクティブのときには、周辺装置からポート・データ・バス上へデータを乗せてはならない。ちなみに周辺装置からのデータを B STB でゲートしておけば、バス駆動の競合状態は生じない。PIO はこのデータを B STB の “L” レベルで取り込むようになっている。

PIO は、このモードでデータの取り込みを行う際に、取り込みに必要なホールド時間が零であってもよいように設計されているので、上述のような簡単なゲート方式でよい。すなわち上述のストローブ (B STB) の立ち上がりエッジの直後で、バスからのデータは取り込み禁止（ディセーブル）となる。

#### 5.4 ビット制御モード（モード3）

ビット制御モードでは、ハンドシェーク信号は使用しないので、任意の時点で正規のポートの書き込み、読み出しが行える。書き込み時、データはモード0と同じタイミングで出力レジスタにラッチされる。もしポートAがモード3で動作中には、A RDYは“L”レベルに固定される。ポートAをモード2で使用していなければ、ポートBがモード3で動作する場合はいつもB RDYは“L”レベルに固定される。この場合、B RDYの状態は何によっても変化しない。

PIOからの読み出しで、CPUへ返るデータは、出力として指定しているポート・データ線からの（出力レジスタの）データと入力として指定している同じポートのデータ線からの（入力レジスタの）データとの合成になっている。入力レジスタの内容はRDが下がる直前にポート・データ・バス上にあったデータに等しい。（図5-4参照）



図5-4 ビット制御モードのタイミング

ポートからの割り込みが受け付け可能で、ポート・データ線上の入力データが8ビット・マスクと2ビットのマスク制御レジスタで指定される条件に一致すれば（論理式が等しくなる）、割り込みが発生し、条件の一致状態に変化がなければ、新しく割り込みが発生することはない。

モード3の割り込みは、このモードでの論理演算が“偽”から“真”に変わったときにのみ、発生する。たとえば、モード3での論理式が“OR”機能であれば、マスクされないポート・データ線の少なくともいずれかひとつがアクティブになれば割り込み要求が出る。

次に先の状態に続いて他のマスクされないデータ線がアクティブになっても、モード3の論理演算の結果に変化はないので、新たに割り込み要求が出ることはない。

論理演算の結果がM1サイクルの直前かその期間中に“真”になれば、割り込み要求はM1の立ち上がりエッジで発生する。

## 6. 割り込みサービス

PIO から割り込み要求を受け取ったあと、CPU は割り込みアクノリッジを送出する。(このアクノリッジ信号として M1 と IORQ が同時に出る。)

この期間において、PIO 内の割り込み論理回路は割り込み要求を出している最も優先順位の高いポートを決定する。(これは単に IEI が "H" レベルで IEO が "L" レベルのデバイスを求めて決まる。)

デージー・チェーンのイネーブル線の状態を確実にするため、M1 がアクティブになったとき、各デバイスの割り込み要求状態の変更は許されない。

割り込みアクノリッジの期間に、割り込みを出している最も優先順位の高いデバイスが CPU データ・バス上にその割り込みベクトルを乗せる。

図 6-1 に割り込み要求に関するタイミングを示す。M1 期間では、新しい割り込み要求を発生させることができない。これは 4 個までの PIO からの割り込みイネーブル信号を受けるに十分な時間をとる必要があるからである。

INTA の期間で、IEI が "H" レベル、IEO が "L" レベルである PIO がそのポートの 8 ビットの割り込みベクトルをデータ・バス上に送り込むことになる。



図 6-1 割り込みアクノリッジのタイミング

PIO からの割り込み要求が、受け付けられると、要求を出したポートが "サービス" を受ける。IEI が "H" レベルであれば、このポートの IEO は RETI 命令を実行すると "L" レベルから "H" レベルに変化する。

割り込み要求が受け付けられていない PIO は OP コード "ED" (入出力命令などの OP コード) を解読後、次の M1 の 1 サイクル間 IEI を強制的に "H" レベルにする。

この動作により、この 2 バイトの RETI 命令を選ばれた PIO ポートだけが解読することができるようになっている。(図 6-2 参照)



図 6-2 割り込みサイクルからの復帰

4 つのポートをデージー・チェーンで接続してある場合のネスト構造の割り込みシーケンスの例を図 6-3 に示す。

まず、ポート 2 A が要求を出し割り込みが受け付けられるが、このポートがサービスされている途中で、優先順位の高いポート 1 B が要求を出すと、これが受け付けられ、ポート 2 A のサービスは保留される。

優先順位の高いポート 1 B に対するサービス・ルーチンが完了し、RETI 命令を実行して、そのルーチンの終了をポート 2 A に知らせる。次に優先順位の低いポート 2 A のサービス・ルーチンを再開する。



図6-3 デージー・チェーンでの割り込みサービス

## 7. 応用例

### 7.1 割り込みデータ・チェーンの拡張

割り込みの優先順位を付けるためのデータ・チェーンには、Z-80A PIO を外部回路を付加しないで最大 4 個まで接続できる。

この数の制限は、割り込みイネーブル信号 (IEO) が各 PIO を伝播していくときの遅延時間によるもので、この遅れは割り込みアクノリッジ・サイクルにおける M1 の立ち下がりエッジと IORQ の立ち下がりまでの間の時間からはみ出してはいけない。

割り込みイネーブルの状態を M1 期間では変化させることができない。これにより CPU に戻る PIO からのベクトル・アドレスは、割り込みを要求した最高位の優先順位をもつデバイスからのものであると保証できる。

PIO を 4 個以上接続する必要がある場合は、図 7-1 に示すような “ルック・アヘッド” 構成にするとよい。この方法で標準 TTL を使用して 30 個以上の PIO を接続できる。



図 7-1 デージー・チェーンの拡張方法

### 7.2 入出力インターフェース

Z-80A PIO を入出力ターミナル・デバイスと結合して、図 7-2 に示すような 8 ビット並列の双方向データ・バスを介してデータの送受を行う場合、ポート A に次のような制御語を送って、PIO をモード 2 (双方向モード) に設定すればよい。



図 7-2 入出力インターフェースの例

次に、適当な割り込みベクトルをロードする。(割り込みの操作については、A.1 Z-80A CPU テクニカルデータを参照のこと。)

| D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 特殊<br>テスト      | パワー<br>オン      | 電源異常<br>アラーム   | プロセス<br>停止     | 温度<br>アラーム     | ヒータ<br>オン      | 圧力系            | 圧力<br>アラーム     |

M1が割り込みアクノリッジ・サイクル時のものでなければ、割り込みモード語をセットしたあの最初のM1の立ち上がりエッジで割り込みがイネーブル（受け付け可能）となる。

割り込みモード語の後にマスク語が続いて送られたときは、マスクがセットされたあの最初のM1の立ち上がりエッジで割り込みはイネーブルとなる。

こうして、周辺装置とCPUとの間でデータの転送が可能となる。この転送時のタイミングは第5章で述べたことと同様である。

### 7.3 制御用インターフェース

ビット制御モードでの例を図7-3に示す。

工業プロセスでのモニタを考えてみる。異常動作状態の発生をZ-80A CPUを基本とした制御システムに伝達する場合、次のようにフォーマットのプロセス制御語およびステータス語を設定しておくとする。

| D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| V <sub>7</sub> | V <sub>6</sub> | V <sub>5</sub> | V <sub>4</sub> | V <sub>3</sub> | V <sub>2</sub> | V <sub>1</sub> | 0              |



図7-3 制御モードの応用

PIOを次のように使用する。ポートAに次のような制御語を書き込んでモード3に設定する。

| D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 1              | 1              | X              | X              | 1              | 1              | 1              | 1              |

モード3を指定した場合、その次の制御語は入出力選択語でなければならないので、たとえば、ポート・データ線A<sub>5</sub>、A<sub>3</sub>、A<sub>0</sub>を入力とする場合には次のような語を書き込む。

| D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 0              | 0              | 1              | 0              | 1              | 0              | 0              | 1              |

次に必要な割り込みベクトルをロードしておく。

| D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| V <sub>7</sub> | V <sub>6</sub> | V <sub>5</sub> | V <sub>4</sub> | V <sub>3</sub> | V <sub>2</sub> | V <sub>1</sub> | 0              |

割り込み制御語を続いてポートに転送する。

| D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 1              | 0              | 1              | 1              | 0              | 1              | 1              | 1              |

割り込み  
イネーブル OR アクティブ "H" マスク

割り込み制御

割り込みモードを指定したのち、次に書き込むマスク語を以下のように設定する。

| D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 1              | 1              | 0              | 1              | 0              | 1              | 1              | 0              |

モニタ線の指定

以上の準備で、A<sub>5</sub>、A<sub>3</sub>、A<sub>0</sub>いずれかの線の検出器からの信号が "H" レベルになれば、割り込み要求が発生する。

マスク語により入力、出力のどのような組み合わせに対しても割り込みを発生させる条件を選択、指定できる。たとえば、上述のマスク語が次のようにあれば、

| D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 0              | 1              | 0              | 1              | 0              | 1              | 1              | 0              |

割り込み要求は出力レジスタのビット A<sub>7</sub> (特殊テスト) をセットしたときにも発生することになる。

ポートの指定方法については、たとえば次のようにするとよい。

E0<sub>H</sub> = ポート A データ

E1<sub>H</sub> = ポート B データ

E2<sub>H</sub> = ポート A 制御用

E3<sub>H</sub> = ポート B 制御用

(Hは前に置かれた数が16進表現であることを示す。)

ポート番号をこのように指定しておくと、アドレス・バスの A<sub>0</sub> をポート B/A の選択用、アドレス・バスの A<sub>1</sub> を C/D (制御信号/データ) の選択用として使用することができ、便利である。

チップ選択 (CE) には、A<sub>2</sub> から A<sub>7</sub>までのCPUのアドレス・ビットをデコードすればよいが、この場合、A<sub>7</sub>～A<sub>2</sub>が11000になればチップ選択される。

周辺装置が少ない場合には、CEとして特別にデコードする必要はなく、必要に応じて A<sub>2</sub> から A<sub>7</sub> の適当なビットを直接使用することもできることに注意されたい。

## 8. プログラミングのまとめ

### 8.1 割り込みベクトルのロード

|                |                |                |                |                |                |                |   |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|---|
| V <sub>7</sub> | V <sub>6</sub> | V <sub>5</sub> | V <sub>4</sub> | V <sub>3</sub> | V <sub>2</sub> | V <sub>1</sub> | 0 |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|---|

### 8.2 モードの設定

|    |    |   |   |   |   |   |   |
|----|----|---|---|---|---|---|---|
| M1 | M0 | X | X | 1 | 1 | 1 | 1 |
|----|----|---|---|---|---|---|---|

| M1 | M0 | モード      |
|----|----|----------|
| 0  | 0  | 出力(0)    |
| 0  | 1  | 入力(1)    |
| 1  | 0  | 双方向(2)   |
| 1  | 1  | ピット制御(3) |

モード3を指定した場合、次に書き込むデータにより入出力レジスタを設定する。

|                  |                  |                  |                  |                  |                  |                  |                  |
|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|
| I/O <sub>7</sub> | I/O <sub>6</sub> | I/O <sub>5</sub> | I/O <sub>4</sub> | I/O <sub>3</sub> | I/O <sub>2</sub> | I/O <sub>1</sub> | I/O <sub>0</sub> |
|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|

I/O = 1ならば、入力ピットとなる。

I/O = 0ならば、出力ピットとなる。

### 8.3 割り込み制御語の設定

|           |        |          |       |   |   |   |   |
|-----------|--------|----------|-------|---|---|---|---|
| 割り込みイネーブル | AND/OR | High/Low | マスク指定 | 0 | 1 | 1 | 1 |
|-----------|--------|----------|-------|---|---|---|---|

モード3でのみ使用

マスク指定(Mask follows)が“H”レベルならば、次にPIOに書き込むデータはマスクとなる。

|                 |                 |                 |                 |                 |                 |                 |                 |
|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| MB <sub>7</sub> | MB <sub>6</sub> | MB <sub>5</sub> | MB <sub>4</sub> | MB <sub>3</sub> | MB <sub>2</sub> | MB <sub>1</sub> | MB <sub>0</sub> |
|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|

MB = 0ならば、モニタ・ピットとなる。

MB = 1ならば、非モニタ・ピットとなる。

また、ポートの割り込みイネーブル・フリップ・フロップ(IFF)を次のようなコマンドを使用して、割り込み制御語の他の部分を変えずにセットまたはリセットすることもできる。

|           |   |   |   |   |   |   |   |
|-----------|---|---|---|---|---|---|---|
| 割り込みイネーブル | X | X | X | 0 | 0 | 1 | 1 |
|-----------|---|---|---|---|---|---|---|

## A.3 MZ-2000の仕様

### 1. MZ-2000一般仕様

|                 |                                                                                                                                                                                                                                                                                                |        |                                                                          |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------------------------------------------------------|
| C P U           | SHARP LH0080A (Z80A-CPU)                                                                                                                                                                                                                                                                       | サウンド出力 | 最大 400mW (440Hz)                                                         |
| クロック            | 4MHz                                                                                                                                                                                                                                                                                           | キー構成   | キー数 92<br>ASCII標準、10数字キー<br>ファンクションキー、カーソルコントロールキー<br>カセットテープデッキコントロールキー |
| メモリ             | ROM 2Kバイト<br>(IPL: イニシャル・プログラム・ローダ)<br>ROM 2Kバイト<br>(キャラクタ・ジェネレータ)<br>RAM 64Kバイト<br>(ダイナミックRAM)                                                                                                                                                                                                | 編集機能   | カーソルコントロール: 上、下、左、右、<br>ホーム、クリアキー<br>挿入、削除キー                             |
| C R T<br>ディスプレイ | 10型CRT (グリーンフェイス)<br>キャラクタ表示<br>8×8 ドットマトリックス<br>1) 1,000キャラクタ<br>(40キャラクタ×25行)<br>2) 2,000キャラクタ<br>(80キャラクタ×25行)<br>1), 2): ソフトで切り替え<br>グラフィック表示 (オプション)<br>1) 320×200ドット (標準BASIC)<br>2) 640×200ドット (標準BASIC)<br>3) カラーコントロール (拡張BASIC)<br>ページ1、2、3およびキャラクタとの混合<br>表示が可能<br>1), 2): ソフトで切り替え | 時計機能   | 内蔵                                                                       |
|                 |                                                                                                                                                                                                                                                                                                | 電 源    | AC100V±10% 50/60Hz<br>消費電力 約50W                                          |
|                 |                                                                                                                                                                                                                                                                                                | 温 度    | 使用温度 0°C~35°C<br>保存温度 -15°C~60°C                                         |
|                 |                                                                                                                                                                                                                                                                                                | 湿 度    | 使用湿度 80%以下                                                               |
|                 |                                                                                                                                                                                                                                                                                                | 重 量    | 約 13kg                                                                   |
| カセットテー<br>ブ・デッキ | 標準オーディオカセットテープ使用<br>データ転送速度 2,000ビット/秒<br>データ転送方式 SHARP PWM方式<br>マニュアルおよびソフトウェアによりコントロール                                                                                                                                                                                                       | 外形寸法   | 幅 440mm<br>奥行 490mm<br>高さ 262mm                                          |

### 2. CPUボード部仕様

|                 |                                                   |                       |                  |
|-----------------|---------------------------------------------------|-----------------------|------------------|
| C P U           | SHARP LH0080A (Z80A-CPU) 1個                       | メモリー<br>コントローラ        | SHARP LZ90D02 1個 |
| P I O           | SHARP LH0081A (Z80A-PIO) 1個                       | プログラマブル<br>カウンタ       | 8253 1個          |
| R O M           | IPL ROM (2Kバイト) 1個<br>キャラクタジェネレータROM (2Kバイト) 1個   | プログラマブル<br>周辺インターフェイス | 8255 1個          |
| R A M           | 標準装備 64KビットRAM 8個 (64Kバイト)<br>ビデオ RAM 2KバイトRAM 1個 | その他のIC                | 18個              |
| C R T<br>コントローラ | SHARP LZ90D01 1個                                  |                       |                  |

### 3. カラーグラフィックボード部仕様 (オプション……ページ1含む)

|                     |                                |                            |     |
|---------------------|--------------------------------|----------------------------|-----|
| カラーグラフィック<br>コントローラ | SHARP LZ90D03 1個               | その他のIC                     | 21個 |
| R A M               | 16KビットRAM 8個(16Kバイト)* 最大48Kバイト | *ページ2、3はオプション (各8個…16Kバイト) |     |

### 4. 電源部仕様

|     |                    |     |                   |
|-----|--------------------|-----|-------------------|
| 入 効 | AC100V±10% 50/60Hz | 出 効 | 5V、-5V<br>12V、15V |
|-----|--------------------|-----|-------------------|

## 5. ディスプレイ部仕様

|           |                                                      |               |                                                                                                           |
|-----------|------------------------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------|
| サ イ ズ     | 10型                                                  | ビデオアウトプット     | 標準40Vpp (LIMIT35Vpp)                                                                                      |
| 水平垂直周波数   | 垂直 60Hz 水平 15.75kHz                                  | 解像度           | 水平  画面中央部で左の模様が確認できること |
| 電 源       | DC12V 1.1A±10%                                       | 非直線性歪         | 水平 + 8% (±14%MAX)<br>垂直 ± 8% (±12%MAX)                                                                    |
| ピクチャーチューブ | E2728B31 10型 90°偏光防爆型<br>ヒーター 12V 75mA               | 幾何学的歪         | 糸巻歪 1% (2%MAX)<br>樽形歪 1% (2%MAX)<br>台形歪 1% (2%MAX)<br>平行四辺形歪 1° (2.5°MAX)                                 |
| I C       | 2個                                                   | 高 壓           | 0 beam 11.0kV (10.0kV MIN)<br>(12.0kV MAX)                                                                |
| トランジスタ    | 7個                                                   | 電 源           | DC 12.0V 1.05A (1.2A MAX)                                                                                 |
| ダイオード     | 13個                                                  | 電源動作範囲        | 12V±10%                                                                                                   |
| 音 声 出 力   | 最大400mW (440Hz)<br>スピーカ 8cm<br>ラウンドダイナミックタイプ32Ω      | ス キ ャ ン サ イ ズ | 水平 10% (15%MAX)<br>垂直 10% (15%MAX)                                                                        |
| コントロールツマミ | Volume V-Hold<br>Contrast H-Hold<br>Brightness Focus | 水平引込範囲        | ±300Hz (LIMIT ±100Hz)                                                                                     |
| 動 作 温 度   | -10°C ~ 50°C                                         | 垂直引込範囲        | -12Hz (LIMIT -6Hz)                                                                                        |
|           |                                                      | 音声周波数特性       | 440Hz(0dB)<br>-10dB±4dB at 100Hz<br>-12dB±4dB at 10kHz                                                    |

## 6. カセット部仕様

|                 |                                     |                     |                 |
|-----------------|-------------------------------------|---------------------|-----------------|
| シス テ ム          | PWM録音方式                             | ト ラ ッ ク の 数 及 び 用 法 | 2トラックモノラル方式     |
| 定 格 電 源         | 5V±5%<br>12V±5% (安定化)<br>15V (非安定化) | モー タ                | 12V電子ガバナモーター    |
| 使 用 半導体         | トランジスタ 2個<br>I C 12個<br>ダイオード 10個   | バ イ ア ス 方 式         | DC              |
| 使 用 テ ー ピ ー     | C15~C60使用可                          | 消去 方 式              | DC              |
| テ ー ピ ー 定 格 速 度 | 4.75cm/sec                          | 標準再生点               | 667μsec~333μsec |
|                 |                                     | 使 用 温 度 範 囲         | -10°C ~ +40°C   |
|                 |                                     | 保 存 温 度 範 囲         | -25°C ~ +65°C   |

【注意】製品定格および仕様は予告なく変更することがあります。その場合ここに掲げた項目と異なる場合がありますから注意が必要です。

## A.4 取り扱い上の注意

### ■電源コードについて

電源コードを机やイスの下に敷いたり、ものにはさんで傷をつけないようご注意ください。電源コードに傷がついたまま使用すると危険です。また電源コードを抜くときは必ずプラグを持って抜いてください。

### ■電源電圧について

電源電圧はAC100Vでご使用ください。電源電圧が極端に高かったり、低かったりすると故障の原因になり、十分性能が発揮できない場合があります。このようなときはお買い求めの販売店あるいはもよりのシャープお客様ご相談窓口、シャープエンジニアリング・サービスステーションにご相談ください。

### ■風通しについて

本機は温度上昇を防ぐため、キャビネットに通風孔があけてあります。風通しの悪い狭い場所に押し込んだり、布を掛けたり、カーペットやフトンの上に置いたりして、通風孔をふさがないでください。

### ■湿気やほこりについて

本機を湿気の多い場所や、ほこりの多い場所に置かないでください。故障の原因になります。

### ■高温について

本機を直射日光の当る場所や暖房器具のような熱器具の近くに置かないでください。キャビネットや内部の部品をいためる原因になります。

### ■水や異物について

本機の内部に水や液状のもの、針やピン等金属類が入ったまま使用すると危険です。異物が入らないようご注意ください。とくに水や液状の異物が入った場合すぐに電源コードのプラグを抜き、ご販売店あるいはもよりのシャープエンジニアリング・サービスステーションにご連絡ください。

### ■衝撃について

本機は精密な電子部品でできています。落としたり、物を当てたりして衝撃を与えないでください。故障の原因になります。

### ■異常のときは

万一故障した時や異常を感じたら使用を中止し、お買い求めの販売店あるいはもよりのシャープエンジニアリング・サービスステーションにご相談ください。

### ■長期間使用しない場合

長い間ご使用にならない場合は必ず電源コードのプラグをコンセントから抜いてください。

### ■周辺機器の増設

シャープ指定の部品または機器をご使用ください。指定部品または機器以外の使用ならびに改造は故障の原因になる恐れがあります。

### ■汚れ

本機の汚れはやわらかい布に水または洗剤を含ませて軽くふいてください。ベンジン、シンナーなど揮発性のものは使用しないでください。ケースの変色などの原因になります。

### ■雑音対策

雑音の多い環境では電源に混入する雑音をラインフィルター等で除去してください（ラインフィルターについてはもよりのサービスステーションでご相談ください）。信号ケーブルと他の機器や電源コードとは、できるだけ離して配置してください。

### ■雑音電波

ラジオやテレビなどの近くでご使用になるとラジオやテレビに雑音が入ることがあります。なお、テレビなどの強い磁界を発生するものから影響をうけることがありますので、2～3m以上離れた所でご使用ください。

### ■電源の「入り」・「切り」

電源スイッチの入り・切りは10秒以上の間隔をあけて操作してください。マイクロコンピュータの動作を確実にするため必要です。またスイッチの入った状態で電源プラグを差し込むと、故障の原因になります。

### ■カセットの取り扱い

カセット内の録音・再生ヘッドが汚れますと正確なデータの録音・再生ができません。1ヶ月に一度掃除をしてください。一般市販のクリーニングテープを使用すると便利です。

### ■テレビ画面のヤケについて

本機のテレビ画面は、長時間連続して同じ点を表示し続けると、その箇所にヤケを生じことがありますので、注意が必要です（やむを得ず長時間ご使用になる時は、後側のブライト調節ボリュームを充分しほってご使用ください）。

### ■本体上部キャビネットの開き方

本機の上部キャビネットを持ち上げたら支持アームで上部キャビネットを支えます。本機の上部キャビネットを開いた状態での使用及び保管をしないでください。