CでLEDディスプレイコントローラMAX7219のドライバ部分を記述してみました。
3線シリアルのDIN、CLK、LOADにつながった各ピンをパタパタON/OFFするだけなのでCで書くまでもないのですが。しかも少しでも速くなるかと思ってインラインアセンブラにしてみました。高級言語には役不足的な処理です。
これをコンパイルすると、ほぼそのまま無駄のないコードを吐きます。ちょっといいところはビット操作SET/RESのディストネーションに直接アドレスを指定できるところでオリジナルのZ80ではできなかったアドレッシングのはずです。さらに符号拡張して1バイトで指定する「0ページアドレッシング」になってました。
これらを使ってMAX7219に制御ワードをおくるルーチンを作成。ボード上で正常動作しました。