LoginSignup
45
25

More than 1 year has passed since last update.

NANDで自作CPUを作成する①

Last updated at Posted at 2023-03-24

目次

・1. はじめに
・2. 作成した回路
・3. LEDを光らせてみる
・4. Not,And,Or,Xor作成
・5. And16,Not16,Or16作成
・6. Or8Way作成
・7. Mux,Mux16,Mux4Way16,Mux8Way16作成
・8. DMux,DMux4Way,DMux8Way作成
・9. 今後

1. はじめに

初心者がNANDで自作CPUを作成するまでの記録を書こうと思います。僕と同じような初心者に少しでも参考になったら幸いです。

・始めようと思ったきっかけ
ちぇりーさんという方の投稿を見て、ピカピカ光ってかっけぇなーと思って始めました。
それと純粋にプログラムが動く仕組みを低レイヤから知ってみたいという知的好奇心です。
https://twitter.com/cherry_takuan/status/1633289780581793793?s=20

・僕のTwitterで自作CPUをつくるまでをだらだら投稿してます。
@iGPj10g3JGjodFI

・狂気の沙汰だと思った回路。Mux8Way16(16bit8入力のマルチプレクサ)
6時間ぐらいかかった笑
image.png

・使用したツール
最初はSteamのCRUMBというアプリを使ってましたがTinkercadの方が早くできそうだったので変えました。

・参考にした本
CPUの創りかた
コンピュータシステムの理論と実装

初めて電子回路をいじったので配線が汚いのはすいません。(だんだん上手になっているつもり笑)
間違ってるところや、こうしたほうがいいよ!楽だよ!みたいなのがあったらコメントで教えて下さるととてもうれしいです。☺

2. 作成した回路

・Not
・And
・Or
・Xor
・And16
・Not16
・Or16
・Or8Way
・Mux
・Mux16
・Mux4Way16
・Mux8Way16
・DMux
・DMux4Way
・DMux8Way

LEDを光らせてみる

・ブレッドボードの仕組み
この画像の同じ色の箇所で、既に配線してくれてるらしい。
image.png

・とりあえずLEDと抵抗をつなげてみた。

  1. 左の回路はLEDのさしている箇所が+と-が同じ電位になっているため光らない。
  2. 真ん中の回路はLEDの+と-の接続する場所が逆のため光らない。曲がってる方を+側に接続する(抵抗はどっちでもいいらしい)
  3. 正しい回路
    image.png

最初、左のパターンでやってて光らずに何時間も無駄にしました。。笑
ブレッドボードの使い方がおかしいのかなって調べても正しそうなので最終的にアプリのバグのせいにしてました笑(よくない癖ですね)

3. Not,And,Or,Xor作成

・Nand回路
まずNand回路を根底にこれから様々な回路、最終的にはCPUを作成していきます。

Nand回路の仕様
image.png
入力がA,Bの2つで出力がOutの1つです。値が0の時が電流が流れてない状態(GNDの電位)で1の時が流れている状態になってます。
つまり、入力のA,Bがどちらも電流が流れているときOutが流れず、それ以外の3パターンの時はOutに流れます。

実際に配線してみるとこんな感じです。
[A,B=0]
image.png
[A,B=1]
image.png

AとBが0の時のみLEDが光ってませんね。

ここで赤いスイッチと、黒いゲジゲジみたいなやつを説明します

・赤いスイッチ
Onのとき電流が流れます。

・黒いゲジゲジ
こんな感じでNand回路が4つ入ってます。
74HC00とありますが、NandのICのことで同じようにAndは74HC08,Orは74HC32,Notは74HC04と表記されています。
image.png

3. Not,And,Or,Xor作成

Not,And,Or,Xorの真理値表は調べてください

・Notの作成
1つの入力値をNandの2つの入力ピンに接続することでNot回路を作ることができる。

[回路図]
image.png
[配線図]
image.png

最初作ったときめちゃくちゃ感動しました。Nand回路を組み合わせることで別の機能を持つ回路を作ることができるんだ!!
おそらくこんな感じでAndやOrなどの回路をひとつづつ作っていってCPUまで完成させるんだと思います。(まだ完成してない)

・And
[回路図]
image.png
[配線図]
image.png

Not回路は作ったので実際の配線ではNot回路を直接使いました(全部Nand回路を使うのではなく)

・Or
image.png
image.png

・Xor
image.png
image.png

4. And16,Not16,Or16作成

今まで作成した回路は1bitに対応した回路でした。
普段僕たちが使っているパソコンは64bitだと思います。
今回作成するのは16bitに対応したCPUを作成しようと思ってるので、16bitのNot,And,Orを作成します。

・And16
image.png
image.png
回路図は自分用に作ったのでかなりきもいですが笑、ただ先ほど作成した1bit対応のAndをビットごとに16個使ってるだけです。
配線図をみたらかなり複雑ですが、本当に各ビットに対してAndを使ってるだけです。同じようにNot16,Or16も作っていきます

・Not16
image.png

・Or16
image.png

5. Or8Way作成

今まで1bit対応で入力が2つのOrと、16bit対応の入力が2つのOrを作成しました。
後々使いそうなので1bit対応の8つ入力のOrを作成しておきます。
image.png
image.png

6. Mux,Mux16,Mux4Way16,Mux8Way16作成

次はマルチプレクサを作成していきます
マルチプレクサとは複数の入力に対して、制御ビット(ここではSELと表記)でどれか一つだけ出力させます。

例えば入力がIN1,IN2,SELの時SELが0の時、出力はIN1
SELが1の時、出力はIN2。になります

・Mux
[真理値表]
image.png
[回路図]
image.png
[配線図]
image.png

・Mux16
And16と同じように16bitに対応したMuxを作成します。
同じように16個Muxを使用するだけです。  が!!!TinkercadというツールはMux回路を準備してくれてないので
先ほど作成したMuxを1から16個作りました。。。。ここから地獄のはじまり。。
image.png

・Mux4Way16
入力が4つの16bitに対応したMuxを作成します。
入力が4つのため制御するビットは2bitになります。(2^2)
image.png

・Mux8Way16
最後に入力が8つの16bitに対応したMuxを作成します。
入力が8つのため制御するビットは3bitになります。(2^3)
image.png

朝から始めたのに気が付いたら日が暮れてました笑

7. DMux,DMux4Way,DMux8Way作成

マルチプレクサの逆のデマルチプレクサを作成します。
1つの入力に対して複数の出力をします。制御ビットで1つだけ入力値を出力するのですが残りは0を出力します。

例えば入力がIN1,SELの時SELが0の時、出力1はIN1,出力2は0
SELが1の時、出力1は0,出力2はIN1。になります

・DMux
[真理値表]
image.png
[回路図]
image.png
[配線図]
image.png

・DMux4Way
1つの入力に対して4つの出力を行うDMuxを作成します。
4つの出力のため制御ビットは2ビットになります
image.png

・DMux8Way
1つの入力に対して8つの出力を行うDMuxを作成します。
8つの出力のため制御ビットは3ビットになります
image.png

8. 今後

つぎはALUっていうやつを作成していこうと思います。
Tinkercadでは限界があるので他のいいアプリを見つけて頑張ります。

45
25
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
45
25