mz-700
差分
このページの2つのバージョン間の差分を表示します。
両方とも前のリビジョン前のリビジョン次のリビジョン | 前のリビジョン | ||
mz-700 [2023/12/06 12:24] – [MZ-800をMZ-700のようになるまで初期化する] araki | mz-700 [2023/12/07 07:07] (現在) – [概要] araki | ||
---|---|---|---|
行 2: | 行 2: | ||
===== 概要 ===== | ===== 概要 ===== | ||
+ | |||
+ | {{: | ||
===== MZ-800エミュレータでMZ-700のIPLを使う ===== | ===== MZ-800エミュレータでMZ-700のIPLを使う ===== | ||
行 62: | 行 64: | ||
Applyを押せば、1Z-009Aが起動する。 | Applyを押せば、1Z-009Aが起動する。 | ||
+ | |||
{{:: | {{:: | ||
==== MZ-800の初期化処理について ==== | ==== MZ-800の初期化処理について ==== | ||
+ | |||
+ | MZ-800は電源投入後、またはリセット直後は MZ-800モードで起動するが、その後、MZ-700モードに移行し、CGROMや周辺デバイスの設定を行った後、ディップスイッチの設定を読んで、MZ-800またはMZ-700それぞれのモードに移行する。 | ||
+ | |||
+ | MZ-700のROMを使うのであればディップスイッチの如何に関わらずMZ-700モードへと移行し、本来のモニターに制御を戻すようにしてやればいい。 | ||
+ | |||
+ | この時、MZ-700とは異なるMZ-800のハードウェアを適切に設定して、適切なポイントへ制御を戻す必要がある。 | ||
+ | |||
+ | 具体的に問題となる、MZ-700とMZ-800との違いには以下のものがある。 | ||
+ | |||
+ | * MZ-800モードとMZ-700モード | ||
+ | * CGROMデータのPCGへの転送処理 | ||
+ | * 画面モードの設定と画面クリア | ||
+ | * 8255/ | ||
+ | |||
+ | === MZ-800モードとMZ-700モード === | ||
+ | |||
+ | MZ-800はポート0xceに0x08を出力することで、MZ-700モードへと移行する。 | ||
+ | このポートはディスプレーモードレジスタにつながっていて、画面モードの設定を行うのだが、0x08を渡すと、メモリーマップがMZ-700相当のものになる。 | ||
+ | |||
+ | この時、0x0000~0x0fffと0xe000~0xffffにはROM(0xe000~0x00fはmemory mapped I/ | ||
+ | |||
+ | IPL2.ROMではまずこの処理を行う。 | ||
+ | |||
+ | === CGROMデータのPCGへの転送処理 === | ||
+ | |||
+ | MZ-800はMZ-700とは異なり、CG-ROMにCPUからアクセスができる。 | ||
+ | また表示に使われるデータはPCGのデータが参照されるため、CG-ROMの内容をPCGに設定する必要がある。 | ||
+ | |||
+ | MZ-700モードにあるときに、ポート0xe0から値を読むと、0x1000~0x1fffにCG-ROMが、0xc000~0xcfffにPCGがそれぞれ割り当てられるので、この状態で、CG-ROMの内容をPCGに転送する。 | ||
+ | |||
+ | 転送が終わったら、ポート0xe1から値を読みだせば再び0x1000~0x1fff, | ||
+ | |||
+ | < | ||
+ | in a,(0e0h) | ||
+ | |||
+ | ld hl,01000h | ||
+ | ld de,0c000h | ||
+ | ld bc,01000h | ||
+ | ldir | ||
+ | |||
+ | in a,(0e1h) | ||
+ | </ | ||
+ | |||
+ | これで、MZ-700のCG-ROMデータ((ここでは、エミュレータ用のデータだが。))が表示に使用されるようになった。 | ||
+ | |||
+ | === 画面モードの設定と画面クリア === | ||
+ | |||
+ | MZ-700のROM内にも画面クリアーのコードがあるが、アトリビュートだけを0x71(文字色白、背景青)にするだけで、文字データ自体をクリアしない。 | ||
+ | |||
+ | MZ-700の場合はリセットでおそらくテキストVRAMがクリアされるのだが、MZ-800ではそうではないため、VRAMをクリアするコードを追加してやる必要がある。 | ||
+ | これを行わないとリセット直後に謎の模様が画面に表示されることになる。 | ||
+ | |||
+ | |||
+ | === 8255/ | ||
+ | |||
+ | MZ-700と異なり、MZ-800は8253のポート0の出力がスピーカーに直結せずに、代わりに SN76489ANの Audio INにつながっている。 | ||
+ | また、SN76489ANにクロックの供給も行っている。 | ||
+ | このクロックの供給の制御は 8255が行っている。 | ||
+ | |||
+ | このため、この関係に従って初期化を行わないと、謎のホワイトノイズが出っぱなしになり、8253にコマンドを送っても音を奏でることがなくなってしまう。 | ||
+ | |||
+ | MZ-700の8255の初期化は、8253からSN76489ANへのクロック供給を有効化しないため、これに代わる処理を行い、逆にMZ-700側の初期化ルーチンをバイパスしてやる必要がある。 | ||
+ | |||
+ | 幸い、1Z-009Aの8253/ | ||
+ | |||
+ | ==== 初期化コード ==== | ||
+ | |||
+ | 上記の処理を以下のように実装した。 | ||
+ | |||
+ | < | ||
+ | ; | ||
+ | ; MZ-800 to MZ-700 | ||
+ | ; | ||
+ | .z80 | ||
+ | org | ||
+ | mz700 | ||
+ | stack | ||
+ | cgrom | ||
+ | pcgram | ||
+ | mset53 | ||
+ | |||
+ | entry: | ||
+ | di | ||
+ | im 1 ; set interrupt mode to 1 | ||
+ | |||
+ | ld a,8 ; set MZ-700 mode | ||
+ | out | ||
+ | ld a,1 ; set CRTC to MZ-700 mode | ||
+ | out | ||
+ | out | ||
+ | out | ||
+ | ld sp, | ||
+ | ; init 8255 | ||
+ | ld a,08ah | ||
+ | ld (0e003h), | ||
+ | ld a,1 | ||
+ | ld (0e003h), | ||
+ | ld a,5 | ||
+ | ld (0e003h), | ||
+ | ; init 8253 | ||
+ | ld de,0 | ||
+ | call mset53 | ||
+ | ; init PIO | ||
+ | ld bc,04fch | ||
+ | ld hl,piodat | ||
+ | otir | ||
+ | ld bc,04fdh | ||
+ | otir | ||
+ | ; init SIO | ||
+ | ld a,1 | ||
+ | out | ||
+ | xor a | ||
+ | out | ||
+ | ; init PSG (SN76489AN) | ||
+ | ld b,4 | ||
+ | ld a,09fh | ||
+ | psgset: | ||
+ | out | ||
+ | add | ||
+ | djnz psgset | ||
+ | ; init screen | ||
+ | ld hl,0d800h | ||
+ | ld de,0d000h | ||
+ | ld bc,0400h | ||
+ | cls_loop: | ||
+ | ld (hl), | ||
+ | inc hl | ||
+ | xor a | ||
+ | ld (de), | ||
+ | inc de | ||
+ | |||
+ | dec bc | ||
+ | ld a,b | ||
+ | or c | ||
+ | jr nz,cls_loop | ||
+ | |||
+ | ; copy CGROM to PCG | ||
+ | in a,(0e0h) | ||
+ | ld de,pcgram | ||
+ | ld hl,cgrom | ||
+ | ld bc,1000h | ||
+ | ldir | ||
+ | in a,(0e1h) | ||
+ | |||
+ | jp mz700 | ||
+ | |||
+ | org | ||
+ | piodat | ||
+ | |||
+ | end | ||
+ | </ | ||
mz-700.1701865468.txt.gz · 最終更新: 2023/12/06 12:24 by araki