TK-80サブボード基板の製作(モニターアップデート編)
2019.05.09
TK-80サブボード用モニターV0.90の不具合修正・新機能追加を行いましたので、改めてベータ2版V0.91(ZIPファイル)を公開します。

修正点:
①サブルーチンSRIOT(027CH)、SRIIN(02A0H)、INPUT(0223H)に問題がある。
②アセンブラがPOP, CPE、STAXを生成できない。
③アセンブラが正しいレジスタオペランドを生成できないケースがある。
④相対アドレス入力のための {READ INCR}key、{READ DECR}keyの設定が誤っていた。

新機能:
プログラムを簡易アセンブラで入力してみると、プログラムの移動ができないため、プログラム修正が結構大変でした。
①MOVEアセンブラコマンドの追加(現在のアドレスがdestination)
 MOVE{sp}{source address}{sp}{length}{sp}
②FILLアセンブラコマンドの追加(現在のアドレスがdestination)
 FILL{sp}{byte data}{sp}{length}{sp}
③オペランド入力状態がわかりにくいため、3桁目の少数点を点灯するようにした。

お試しください。
TK-80サブボード基板の製作(モニター公開編)
2019.05.03
少し手間取りましたが、TK-80サブボード用モニターの動作確認がとれましたので、公開します。
非商用の範囲で自己責任でご使用ください。なお、オリジナル・改訂版を含め、再配布される場合は、ソースコード・ライセンス条件を同梱していただけるようお願いします。

今回のモニターは、C言語(Small-C)で作成しましたので、サイズが約8KBとオリジナルに比べると大きくなりましたが、下記の特徴を備えています。

①SBC8080 2・3MHz、SBC8085 2・3・4・5MHzに対応(4・5MHz動作には高速メモリが必要)
②簡易アセンブラを搭載
③ブレーク時にレジスタ内容の参照・修正が簡単
④自動トレース機能(0.5秒/命令で自動実行)

①SBC8080 2・3MHz、SBC8085 2・3・4・5MHzに対応

電源立ち上げ時のLED表示
8080 2.0MHz 1-Wait "8080" "2.0-1" (TK-80オリジナル設定)
8080 2.0MHz 0-Wait "8080" "2.0-0" (SBC8080標準設定)
8080 3.0MHz "8085" "3.0 "
8085 2.0MHz "8085" "2.0 "
8085 3.0MHz "8085" "3.0 " (SBC8085標準設定)
8085 4.0MHz "8085" "4.0 "
8085 5.0MHz "8085" "5.0 "

CPUが変わってもモニター内のタイマーの待ち時間が変わらないように自動切り替えします。

②簡易アセンブラを搭載

下記のようにキーボードにアルファベット文字をオーバーレイさせることで、

C D E F {ADRS SET} --> V W X Y Z
8 9 A B {READ INCR} --> Q R S T U
4 5 6 7 {READ DECR} --> L M N O P
0 1 2 3 {WRITE INCR} --> G H I J K

{LOAD DATA} --> {sp}(区切り記号)

下記は、キーボードにオーバーレイシールを貼った例です。


8080/8085のプログラムをニーモニックで入力できるようになります。
下記が基本入力フォーマットです。
1) {opcode}{sp}
2) {opcode}{sp}{register operand}
3) {opcode}{sp}{data address perand}{sp}
ここで、オペランド部の区切り記号","は、入力不要です。

なお、オペランドの種類は、

{dd} 8 bit data
{rp}{dddd} regiter pair, 16 bit data
{d}{dd} distination register, 8 bit data
{dddd} 16 bit data
{aaaa} 16 bit address({READ INCR},{READ DECR}keyで相対指定)
{s} source register
{d} destination register
{d}{s} source, distination register
{rp} register pair
{rp} register pair for PUSH/POP
{rp} B or D register
{n} 0-7 number
none no operand

また、16ビットアドレスは、命令アドレスに近い範囲であれば、相対入力が可能にしています。誤った入力を検出するとLEDに「....」が表示されます。

③ブレーク時にレジスタ内容の参照・修正が簡単

TK-80は、ブレーク機能でデバックやプログラム動作を学習できる機能がありますが、命令実行前後のレジスタの設定・確認は、絶対メモリアドレスしか使えないので手間がかかり、使い勝手が良くありません。そこで、この領域は、アドレス表示ではなく16bitレジスタ名表示で、設定・確認ができるようにしました。併せてブレークアドレス・回数も簡単に設定できるようにしてみました。

具体的には、ブレーク停止直後に下記のように、{READ INCR}key,{READ DECR}keyで表示できます。さらに、{READ INCR}key,{READ DECR}keyで、アップ・ダウンできます。内容を変更する場合は、{WRITE INCR}keyで可能です。

Program Counter "PC"
Stack Pointer "SP"
HL register "HL" <-- {READ INCR} keyで表示
DE register "DE"
BC register "BC"
Processor Status word "PS"
Break Address "BA"
break Address Counter "AC" <-- {READ DECR} keyで表示

④自動トレース機能(0.5秒/命令で自動実行)

一旦、ステップ状態でブレークさせ、上記のbreak Address Counter=FFと設定後、{RET}keyで、0.5秒/命令で実行中のアドレスを表示しながら動作を確認できます。実行中に適当なキーを押し続けると、break Address Counter=0となり、再ブレークします。

現在、ベータ版として、V0.90(ZIPファイル)を公開します。
不具合があれば、随時修正していきたいと思います。

併せて、Twitter(jr2xzy)を始めましたので、必要な方は、フォローしていただけます。

- CafeNote -