現在地

マイコン

マイコン

マイクロプロセッサ・マイクロコントローラ等です。

INS8070ボード(その2)

テーマ:

カテゴリー:

手持ちのINS8073/Nを仮に載せていたINS8070ボードですが、INS8070も到着したことですし、INS8073でやろうとしていたことも一通りできたので、本来のINS8070に載せ替えました。


INS8073とINS8070の違いは内蔵ROMの有無だけですのでそのまま載せ替えられますが、メモリ配置は変更が必要です。

0x0000番地から起動用のメモリが必要なので0x1000~0x1FFFに配置していたものを0x0000~0x0FFFに移動しました。0xF000以降をRead Onlyにしておく理由もなくなったので書き込み可能にしました。

INS8073のBASICで独自のコンソールを使う

カテゴリー:

前にBASICの持つコンソールルーチンをモニタから使用する方法を書きましたが、今度は逆に独自に用意したコンソールルーチンをBASICに使用させる方法です。

こちらは一応マニュアルにも載っている公認の機能です。

マニュアルの情報不足と誤りのせいでROMを読むまでは動かせませんでしたが...

ということでINS8073のコンソールの設定方法についてまとめておきます。

INS8070

テーマ:

カテゴリー:

INS8073のBASICでユーザが用意したコンソール入出力ルーチンを使う方法を予定していましたが、到着を待っていたCPUが届いたので先に取りあげることにします。


National SemiconductorのINS8070、そもそもINS8070ボードを製作した目的のデバイスです。

製造は1983年の26週のようですね。

INS807xにモニタを移植

前回書き始めていたモニタですが、いつものようにD(ump)コマンドが動くころには慣れてしまって残りはサクサク進み基本的なD,G,S,Lコマンドはすぐにできました。今回はちょっとわけあってP(unch)コマンドも追加しています。

SC/MP(I と II)とは以下のような相違点があります。

  1. 16ビット演算命令
    これ自体は便利でありがたいのですが、キャリ/ボロー込みの加減算命令がなくなってしまいました。モニタには必要ありませんでしたが、16ビットを超える演算は相当面倒になると思われます。条件分岐がAレジスタ(下位8ビット)でしかできないのも意外に不便です。
    SC/MPでは16ビットの値をメモリとやり取りすることがなかったのでエンディアンの概念がありませんでしたが、SC/MP IIIはリトルエンディアンです。
  2. スタックとサブルーチン
    サブルーチン呼び出しの機能が追加されたのは助かります。同時に長距離ジャンプも追加され、4kBページの制約も解消されています。

INS8070ボード

テーマ:

カテゴリー:

CDP1802ボードの次は何にしよう、と考えていて選んだのがこれです。実は先日eBayを眺めていてついINS8070をポチってしまったので...


いつものようにEMILY Boardで動かします。

私は普段ボードを作るときは少なくともメインのチップを手に入れて(ヘタをすると何年も寝かせて)からなのですが、今回は珍しく到着前に作り始めてしまいました。

作っているうちに着くかなと思っていたのですが... 海外からなので時間がかかっているようです。

COSMACのI/O

カテゴリー:

このところCOSMAC関係が続いておりますが、今回をもって一旦終わる予定です。

ソフトウェアUARTも動いたことですし今更感もあるのですが、せっかく準備したUSARTも動かしてみました。

基板 表側
新たに追加したのはμPD71051CとEXO-3です。

当初8251を考えていましたが、せっかく他がCMOSなのでそれに合わせるためと、クロックを5MHzにしてしまったので分周しなくても使えるという理由からμPD71051Cを使うことにしました。

ソフトウェアUART

カテゴリー:

前々回前回書いたような厄介な点はありましたが、CDP1802ボードUniversal Monitorを動かすのは思っていたより簡単でD(ump), G(o), S(et), L(oad)の各コマンドは動作するようになりました。

そうなると今度はSBC1802でも動かしてみたくなります。

ところがこれにはUART相当のハードウェアは無く、CPU内蔵のQ, EF3をシリアルポートとして使うようになっています。UARTの機能をソフトウェアで実現しなくてはなりません。

COSMACでサブルーチン

カテゴリー:

前回書いたようにCOSMACにはサブルーチン呼び出しの仕組みがありません。

それではどうするかというとSEP命令を使います。

COSMACはメモリをポイントできるレジスタを16個 R(0)R(F)と、4ビットのレジスタPを持っています。R(0)R(F)の内Pで選ばれたR(P)がプログラムカウンタとして使用されます。

SEP命令でPに新たな値を設定することでサブルーチンを呼び出し、Pに元の値を設定することで戻ることができます。

COSMACのソフトウェア

カテゴリー:

CDP1802のハードウェアができたのでいつものようにUniversal Monitorを移植していきます。

以前SC/MP使いの憂鬱で書いたようにSC/MPはかなり癖の強いアーキテクチャでしたが、このCOSMACも負けず劣らずですね。

  1. PCがない
    プログラムカウンタに相当するものが無いわけではありません。複数あるレジスタのどれをプログラムカウンタとして使うか選択できるようになっています。専用のものがないという点でだいぶ変わっています。

CDP1802ボード

テーマ:

カテゴリー:

今日2度目のワクチン接種に行ってきまして、ついでに秋月によって不足していた(持ってるはずなんだけど行方不明)パーツを調達してきました。


CDP1802(とCDP1806も)のボード、いつものようにEMILY Boardと組み合わせるボードです。

CDP1802動かすだけならSBC1802でいいのですが、新CPUでいきなりソフトウェアUARTは敷居が高いかなと思って作ってみました。

ページ