TK-80サブボード基板の製作(基板設計編)

2019/02/14

 次は基板設計です。今回初めてですが、トランジスタ技術等で紹介されている内容を参考に進めました。まず、CADの選定ですが、①無償であること、②10x12センチメートルの基板設計ができることより、KiCadを採用しました。


初めての基板設計ですので、勝手がわかりにくいところもありましたが、これまで色々な基板を見てきた経験から、それなりの基板ができそうです。


①回路図入力


今回、SBC8080/SBC8085切替対応とするため、下記の対応を行いました。


・SBC8080用のステップ動作割込み信号の生成部をSBC8085と類似した回路に変更する

・SBC8080/SBC8085切替は、ジャンパーヘッダー切替と、ロジックICの追加で行う

・SBC8080の12Vライン誤接続の保護回路を追加する


これが<a href="/jr2xzy/doc/TK-80-SUB_pcb_sch.pdf" target="_blank">回路図(PDF)</a>です。


②基板レイアウト


まず、特殊部品(LEDディスプレイとトグルSW)の類似フットプリントをRSコンポーネンツから入手し、編集後、使用しました。


トランジスタ技術の記事(DVD)を参考にしながら、スイッチサイエンスのSeeedプロジェクトに対応した基板設計ルールでレイアウトを行いました。部品がつめこみ気味になったので、配線の引き回しと、ベタアースの配置バランスに手間がかかりました。


下記が、概略の基板レイアウトです。



下記は、基板の3D表示です。



ガーバーデータを抽出し、これから、発注する予定です。

基板到着には、春節の関係で、1ヶ月以上必要なようですので、気長に待ちたいと思います。

ただ、そのまま組み立ててうまく動作するか、寸法のミスや部品同士が当たらないかなど、どきどきです。

(再クロール更新:2022/12/22)

TK-80サブボード基板の製作(SBC8085ルーズキット対応編)

2019/02/12

 積み残しになっていたTK-80サブボード基板の製作にチャレンジすることにしました。

その前段階として、バス互換のSBC8085ルーズキットに対応してみました。8085を採用したTK-85がありますが、マニュアルが入手できませんでしたので、紹介しているホームページを参考に仕様の確認をしましたが、


・2.4576MHzクロックで8085を使用している

・ROM:2Kバイト、RAM:1Kバイトに拡張されている

・CMTインタフェースが含まれている

・LED表示の「0」が縦長表示になっている

・モニタコマンドが拡張されているようであるが、詳細は不明である


そこで、無理してTK-85を目指すのではなく、SBC8085でTK-80を実現することにしました。


①SBC8085ルーズキットの製作とTK-80サブボードの動作確認


SBC8085がバス互換であるので、大半は、SBC8080対応のTK-80サブボードを流用できそうでしたので、まず、SBC8085の組み立て後、機械語モード付きタイニーBASICを動作させましたが、問題なく動作しました。


次にTK-80サブボードを接続して、TK-80モニタを動作させると、困ったことにLEDの表示が消えたり、キーボードを接続しなくてもキー入力動作になったり、誤動作しているようですが、暴走まではしていないような感じでした。


8255の動作がおかしくなっていると思われるので、オシロで信号波形を確認しましたが、異常な波形やグリッジなどは、発見できませんでした。そこで、LEDが消える瞬間(8255のPC7信号がhighからlow遷移)を確認したところ、-IOW信号の立ち上がりが非常に鈍っていることを見つけました。この現象は、HOLDA信号直前で起こっていましたので、74HCT257の-IOW信号出力がhighになりきらないうちにHOLDA信号で3stateになったようでした。


SBC8080では、8288が何らかの対策をおこなっているかもしれません。8085のスペック上、-WR信号と同時にHOLDA信号が出ているはずですが、74HCT257の遅延との関係でうまくいかない可能性があります。TK-85でどのようにな回路になっているのか定かではありませんが、本来、HOLDA信号は、DMA遷移のため早めに出力されて、DMAコントローラ(例えば8257)で最適な遅延でバス切替を行うように使用するようです。従って、HOLDA信号を適度な遅延をおこなえば、問題を回避できるかもしれません。


そこで、20nS程度遅延させるため、HOLDA信号に47pFを追加してみました。問題なくTK-80サブボードが動き出しました。下記は、HOLDA信号を遅延させ、-IOW信号の問題が回避できた時の波形です。HOLDA信号の遅延によって、-IOW信号(上側)の立ち上がりがHOLDA信号(下側)の立ち上がり開始に対して約16nS遅延していてもしっかり立ち上がっています。




また、8085の-RD信号、-WR信号、M/IO信号は、HOLD期間中に3stateとなるので、今回は74LS257ではなく74HCT257を使用したため、フロート回避のプルアップ抵抗(4.7K)を追加しました。



②SBC8085用ステップ動作割込み信号生成部の試作


SBC8080とSBC8085では、CPUからの信号が異なるため、ステップ動作を行うための割込み信号の生成部を変更する必要があります。


SBC8080の場合、INTE信号がhighになった後、2命令目のフェッチでINT信号をhighにして、INTE信号がlowでリセットしています。SBC8085の場合、INTE信号がありませんので、EI命令のフェッチを検出した後、2命令目のフェッチでINT信号をhighにして、-INTA信号がlowまたは、RES信号がhighでリセットすることにします。これでソフトウェア完全互換性が保てます。


下記がSBC8085用ステップ動作割込み信号の生成部回路です。




下記は、HOLDA問題対応とステップ動作割込み信号のためのS0、S1信号取り出しを行った、SBC8085ボード裏側と表側です。





下記は、TK-80サブボードにステップ動作割込み信号ドーターボードを追加して、SBC8085でステップ動作ができるようにしたようすです。


(再クロール更新:2022/12/22)

SBC8080ルーズキット+TK-80サブボードの製作(TK-80サブボード製作編)

2019/01/11

 今回は、蛇の目基板に手配線で製作しますので、秋月電子の「両面スルホール・ガラス・ユニバーサル基板Aタイプ」から、幅はSBCサイズ、奥行きは、118mmに切り出すことにします。位置決めは、スタッキングコネクタをSBCボードと串刺しにし、切り出し線、取り付け穴決めを行い、加工をしました。


次にキーボードですが、ラベルキャップ付タクトスイッチの値段が25個そろえると結構高く、大きなピン穴が必要で、取り付け基板も作成が大変そうでしたので、割り切ってZK-80を購入して、キーボード部のみを流用しました。(残りは、何かに使いたいと思います)


①TK-80サブボードの配線


例のごとく、ソケットを配置・仮止めを行い、GNDと5Vラインを先にスズめっき線で配線し、パスコンも取り付けます。各ICに近くのCRを取り付け、ローカルな配線から接続していきます。最後に広域の配線を行うと、配線がしやすくなります。


一通りの配線チェックを行った後、TK-80サブボードのICを指さずに、SBC8080の上にTK-80 SUBボードを積み、SBC8080 CPUボードとSUBボードからTK-80サブボードへ必要な追加信号を接続し、正常に立ち上がることを確かめます。これで、ショート系の誤配線が無いことを確認できます。


次に、DMAアドレスを83F8、モードスイッチをAUTOにし、データバスに接続されている8255、74ACT573以外のICを差し込み、正常に立ち上がることを確かめます。最後は、8255、74ACT573を差し込み、正常に立ち上がることを確かめます。


下記は、配線済みのTK-80サブボードです。





機械語モード付きタイニーBASICからMONコマンドでモニターに入り、下記のプログラムで、LED表示をONします。


8000
MVI A,92
OUT FB
MVI A,80
OUT FA
RET
EXEC 8000


次に、下記により、指定されたLEDのセグメントが表示されればOKです。


83F8
DEFINE 01,02,04,08,10,20,40,80


以上のように問題なければ、CMT用の発振回路、DMA用NE555の出力波形を確認し、問題ないことを確かめます。この時点で、LEDが結構明るく、LEDセグメントドライバの電流が点灯時32mA程度となっており、気になるならR30~R37の電流制限抵抗値を増やすと良いかもしれません。


②TK-80モニタの動作確認


「TK-80ユーザーマニュアル」の「モニタ・アセンブル・リスト」からバイナリを抜出すと、「0」が「O」になっている部分が見つかりました。とりあえず修正後、ROMに書き込み立ち上げると、LEDの表示が「0000 0004」と表示はするものの、暴走しているようでした。


配線ミスを再度行ったところ、未配線が見つかり、修正しましたが、表示は変わりませんでした。このマニュアルの誤植について、指摘があったホームページをみつけましたので、全て反映しましたが、まだ駄目でした。そこで、「機械語モード付きタイニーBASIC」に戻し、TK-80モニタを逆アセンブルして、ソースコードとの比較をせっせと行うと、出てきました。すべてを修正すると、「0000 0000」の表示がされ、キーボードが動作するようになりました。


誤植ヵ所は、


0012	000A	D3F8		OUT	OFBH	; PROGRAM TO 8255
0057 006E C9 DAD B
0271 01CD E6FO0 ANI OFOH ; MASK 'F0'
0274 01D1 OF RRC
0275 01D2 OF RRC ; SHIFT RIGHT 4 BITS
0296 01E9 5C06 SEGD: DB 5CH,06H,5EH,4FH,66H,6DH
  5B4F
  666D
0360 024E D8F8 IN 0F8H ; KEY SCAN 0--->7
0426 02BC OF RRC ; DATA SHIFT


下記が、動作中のSBC8080+TK-80サブボードです。コンパクトに実現できました。



SBC8080 CPUボードのREADYヘッダーをTK-80接続、同様にSBC8080 SUBボードのINTヘッダーを切断すると、STEP動作も問題なく動作しました。CMT出力も問題なさそうでした。


最後に、下記のような内容を書き込み集合ROMを作成します。


0000-3FFF PTBEXSA

4000-5FFF MSBAS80

6000-7FFF TK-80 MONITOR


これで、ジャンパ切替のみで、SBC8080、TK-80両方が楽しめます。参考にしていただければと思います。

(再クロール更新:2022/12/22)