You are here

マイコン

マイコン

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

Intel 80960SA

テーマ:

カテゴリー:

また変わったCPUを買ってしまいました。動かせそうもない代物ではありませんが、膨大な積みプロセッサが溜まっている中いつになったら着手できるものやら。


これはIntelのi960ファミリ、N80960SA16です。

i960ファミリはIntelが1980年代後半から1990年代中頃まで生産していた32ビットのRISCマイクロプロセッサです。

組み込み用途のあまり知名度のないプロセッサですが、このファミリの一員i960RDはPCに使われたこともあります。ATXに移行する直前ごろ、PCI×7+ISA×3といった巨大なATマザーボードがありI/Oプロセッサとして搭載されていました。これはI2O(Intelligent I/O)と呼ばれていました。

これまで触ったことのないアーキテクチャなのでデータシートから特徴を拾ってみます。

半透明なICパッケージ

テーマ:

カテゴリー:

Twitter(現X)で旧ソ連の変わったICパッケージを見かけ、そういえば似たの持ってたなと探したらこんなものが出てきました。


このロゴはいつものサイトにも見当たらないので不明ですが……

このКР1816ВЕ35はIntel 8035のクローンのようです。製造は1988年1月かな。

8035自体は以前MCS-48 2種でNEC製のを取り上げていますし大量に使われた一般的なものですが、面白いのはそのパッケージというか色(材質)です。

プラスチックパッケージの色といえばほぼ黒、それ以外は無いといってもいいほどなのですが、これは茶色でしかもうっすら透けています。

TMP68HC11A1T

テーマ:

カテゴリー:

前に書いたMC68HC11の予備として買ったんだったかな。


東芝のTMP68HC11A1Tです。

ところで東芝のマイコンというと何を連想しますか?

某氏が愛用していた4ビットのTLCS-47、以前試したこともある8ビットのTLCS-90、珍しい12ビットのTLCS-12、などの独自アーキテクチャがいろいろありました。

セカンドソースとしてはZ80ファミリがもっとも有名でしょう。MC68000ファミリも種類は多くありませんが作っていました。TRONチップも作っていたはずです。

そんな中でMC6800ファミリって印象はないんですよね。

NS32032

テーマ:

カテゴリー:

これも何かのついでに買ったまま忘れていたものですね。


ナショセミのNS32032E-6、1985年製のFマスク品です。

このNS32032というのはNS32016の外部バスを32ビット化したものです。MC68020がアドレスバスも32ビットになったのに対し、これはデータバスは32ビットになったもののアドレスバスは24ビットのままなのでアドレス空間は16MBです。

バス幅以外の機能面ではほぼ同等のようですが、データシートをパラパラ見ただけですので細部は不明です。

DCJ11

テーマ:

カテゴリー:

以前HD3-6402のコメントでもちょっと触れたので予想していた方もいるかもしれませんが、こんなものを入手できました。


さまざまな番号が記されていて正式な型番というのがよくわかりませんが、DEC J-11あるいはDCJ11などと呼ばれることが多いですね。

これは何かというと、PDP-11互換のプロセッサです。というかLSI-11(PDP-11をLSI化したもの)に使われたプロセッサです。

Iskra EMZ1001

テーマ:

カテゴリー:

しばらく前にTwitter(現 X)でこのEMZ1001を購入された方がおりまして、それでどんな石なのだろうと調べているうちに欲しくなってしまい、遂にポチってしまったのでした。


Iskra社のEMZ1001、末尾「E」は動作温度範囲0~85℃のもののようです。

聞き慣れないプロセッサですが、これはAMI S2000の互換品です。というかIskraとAMIの共同開発らしいのですが、この辺り情報が少なく詳しくはわかりません。それでもEMZ1001とS2000が互換だというのは確かなようなのでS2000のデータシートを元にして書いていきます。

S2000ファミリは命令幅が8ビット、データ幅が4ビットのプロセッサです。

NS32081を追加してみた

テーマ:

カテゴリー:

NS32016ボードのコメントにちょっと書いたようにNS32081 FPUを搭載してみました。


空きエリアに24ピンソケットを置いてNS32081D-10を載せます。

このFPUはたったの24ピンしかないのにバスは16ビットあります。接続は簡単でデータシートの通りにNS32016の同名の信号と接続するのみ、CPU空間のデコードを必要とするMC68881などよりシンプルです。あ、クロックだけはNS32201から引っ張ってきます。

MC68881/68882と異なり複数搭載はできません。いや、外部にセレクタ置けば出来なくはないのかな?

ハードウェア的に接続出来たら次はソフトウェアですが......

NS32016ボード(ソフトウェア編)

カテゴリー:

前回プログラムが動き始めたので、例によってUniversal Monitorの移植を行なっています。似ているプロセッサとしてMC68000をベースに、HEXファイル関係については長いアドレスに対応したH8/300Hが元にしています。

現時点でD(ump), G(o), S(et), L(oad), P(unch)の各コマンドが動作するようになっており、引き続きR(egister)の実装を進めているところです。

ということで気付いたことを書いてみようかと思います。

バイトオーダー

NS32000のバイトオーダーはリトルエンディアンなのですが、命令語に含まれる即値やディスプレースメントなどはビッグエンディアンで格納されます。

面白いのはディスプレースメント(絶対アドレッシングのアドレスも含む)は可変長で、最初のバイトの最上位ビットが"0"なら符号付7ビット、上位2ビットが"10"なら符号付14ビット、"11"なら符号付30ビットになることです。

NS32016ボード(動作確認編)

テーマ:

カテゴリー:

今回はNS32016ボードの組み立て終わってからUniversal Monitorの移植を始めるまでの動作確認編をお送りします。

まずは発振器とTCUのみで動かしてみます。CPU→TCUの信号が数本あるので仮にプルアップしておきます。これでPHI1, PHI2が出ていることを確認します。

リンギングが酷いですが、とりあえずTCUは動作してそうですね。

NS32016ボード(ハードウェア編)

テーマ:

カテゴリー:

約半年ぶりにマイコンボードを作ってみました。


今度のはNS32016のボードです。もちろんEMILY Boardを使っています。

8ビットバスのNS32008を使った方が配線が少し楽になりますが、こちらは入手しずらいのと、NS32016はいくつも持っているからです。

Pages