HD64180は、 日立製作所(現ルネサス エレクトロニクス)が開発したZ80バイナリ互換の8ビットCPUである。MMUやDMAコントローラなどを集積し、アドレス空間は512KB~1MBとZ80よりも拡張された。Z80にはない乗算、除算命令を備えている。レジスタセットはZ80と同等のものを採用している。HD64180は、アナウンスされた当初はZ80互換をうたわず、カタログ等でもCP/M-80ソフトウェア互換と説明され、そうでありながらマニュアルに掲載されている命令一覧はZ80と同等であったため、マイコンマニアの間では多少の混乱があった。1命令の実行に必要なクロック数はZ80とは異なっており、制御信号やバスのタイミングは、Z80のそれを改良した非同期バスである。オペコードフェッチサイクルのタイミングが改善されていたおかげで同一クロックのZ80よりもメモリーアクセスタイミングに余裕があったが、その相違のためにZ80系の周辺デバイスを直接接続すると割り込み制御機能を使用することができなかった。後にこの問題を解消したHD64180Zが開発された。また、ザイログよりHD64180ZのセカンドソースとしてZ64180が、その改良版としてZ180(Z80180, Z8S180)が製造された。Z180は動作モードコントロールレジスタの機能(バス切り換え)が異なっているので、多少のソフトウェアの変更が必要である。信頼性強化のため、仕様にない未定義命令を実行するとトラップがかかるようになっているので、Z80ユーザーの間でよく知られていた未定義命令である、IXおよびIYレジスタの8ビット分割(IXL/IXH・IYL/IYH)には対応していない(それ以外のもの、例えばビットシフトに関する未定義命令でも同じ)。そのため、これらの命令を使用しているソフトウェアをそのまま実行することはできない。なお、トラップ発生後にセットされるフラグをチェックすることでリセットかトラップかを区別できるので、理屈としては、必要に応じてエミュレーションプログラムに処理を移し、スタックポインタの値から、不正命令によるトラップを起こしたコードを読み取って同等な処理を実行するサブルーチンを呼び出すことは可能である。しかしながら、それを実現するためのクロック数は、未定義命令を直接実行できる従来のZ80よりもはるかに増える。この種の、Z80においても動作保証が一切されていなかった未定義命令(後継チップでは公式に仕様化された)をあえて使用するのは、ゲームソフトなどで、IX, IYレジスタを、HLレジスタの代用として8ビット単位で流用しRAMへのアクセス頻度を減らし極限まで実行速度を稼ぐ場合であり、そのようなプログラムは、未定義命令以外の部分でも実行環境とするハードウェア(特定のゲーム機器やパソコンなど)に依存したコードになっているため、命令だけエミュレーションできても、そのままではバイナリ互換性がないことに変わりはない。移植のためにソースコードを修正するのであれば、その作業の一環として未定義命令の部分も書きなおせばよく、HD64180によるZ80未定義命令のエミュレーションは、実用的とは言えない。ビクターのMSX2、HC-90, HC-95に搭載されたほか、富士通のFM TOWNS HRなどのCD-ROMコントローラや、KAWAI Q-80といった電子楽器、組み込み機器制御などに使用された。また、NTTの電話番号検索システムであるエンジェルラインの専用端末(ANGEL NOTE)に採用されたことでも知られている。
出典:wikipedia
LINEスタンプ制作に興味がある場合は、
下記よりスタンプファクトリーのホームページをご覧ください。