Lock in $30 Savings on PRO—Offer Ends Soon! ⏳
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
簡単な4bitCPUの作成
Search
mikiken
December 12, 2023
Programming
0
1.2k
簡単な4bitCPUの作成
mikiken
December 12, 2023
Tweet
Share
More Decks by mikiken
See All by mikiken
ライフゲームの製作
mikiken
0
220
Webブラウザでページが表示されるまで
mikiken
0
73
Cコンパイラ自作はじめてみた
mikiken
0
250
seccamp2022 成果発表
mikiken
0
41
Other Decks in Programming
See All in Programming
Jetpack XR SDKから紐解くAndroid XR開発と技術選定のヒント / about-androidxr-and-jetpack-xr-sdk
drumath2237
1
190
チームをチームにするEM
hitode909
0
390
モデル駆動設計をやってみようワークショップ開催報告(Modeling Forum2025) / model driven design workshop report
haru860
0
280
The Art of Re-Architecture - Droidcon India 2025
siddroid
0
130
AIコーディングエージェント(Manus)
kondai24
0
220
C-Shared Buildで突破するAI Agent バックテストの壁
po3rin
0
420
Implementation Patterns
denyspoltorak
0
120
「コードは上から下へ読むのが一番」と思った時に、思い出してほしい話
panda728
PRO
39
26k
生成AIを利用するだけでなく、投資できる組織へ
pospome
2
410
Cap'n Webについて
yusukebe
0
150
ELYZA_Findy AI Engineering Summit登壇資料_AIコーディング時代に「ちゃんと」やること_toB LLMプロダクト開発舞台裏_20251216
elyza
2
630
HTTPプロトコル正しく理解していますか? 〜かわいい猫と共に学ぼう。ฅ^•ω•^ฅ ニャ〜
hekuchan
2
460
Featured
See All Featured
Ruling the World: When Life Gets Gamed
codingconduct
0
100
AI in Enterprises - Java and Open Source to the Rescue
ivargrimstad
0
1.1k
My Coaching Mixtape
mlcsv
0
13
Game over? The fight for quality and originality in the time of robots
wayneb77
1
66
Thoughts on Productivity
jonyablonski
73
5k
Art, The Web, and Tiny UX
lynnandtonic
304
21k
The World Runs on Bad Software
bkeepers
PRO
72
12k
KATA
mclloyd
PRO
33
15k
From π to Pie charts
rasagy
0
91
The Straight Up "How To Draw Better" Workshop
denniskardys
239
140k
How to Talk to Developers About Accessibility
jct
1
85
Building Flexible Design Systems
yeseniaperezcruz
330
39k
Transcript
簡単な4bit CPUの作成 電気電子工学実験 テーマS(a) 自由設計 mikiken (@mikikeen) 1
何を作ったか • 書籍「CPUの創りかた」で解説されている4bit CPUを FPGAで実装 • 予めROMに書き込んだプログラムを実行できる • LEDチカチカ •
タイマー (参考: GitHubリポジトリ) https://github.com/mikiken/TD4 2
「CPUの創りかた」―マイナビ出版 (2003) • 汎用ロジックICを用い、簡単な4bit CPU「TD4」†1を作る • アナログ回路の基礎から、丁寧に解説されている • 30刷以上重版 (技術書としては異例)
†1 “とりあえず動作するだけの 4bitCPU” の略 3 https://www.google.co.jp/books/edition/CPU%E3%81%AE% E5%89%B5%E3%82%8A%E3%81%8B%E3%81%9F/2UbaDwA AQBAJ?hl=ja&gbpv=1&printsec=frontcover
動機 • FPGAで何か作るといえばCPU • 自作CPUに関する書籍はいくつかあるが… • 「CPUの創りかた」なら授業時間内で作れそう 4
TD4の仕様 • • • • • • • • •
• • • 5 • 命令長8bit • オペコード4bit, オペランド4bit • 表現できるアドレスの大きさも4bit = プログラムは16 Stepまで • 演算用レジスタは2つ
どのような手順で作ったか • 基本的には本の記述に従って実装 • 具体的には • レジスタ → ALU†2 →
プログラムカウンタ → 命令デコーダ → ROM の順 • ROMは実装方針に迷ったので後回しに †2 Arithmetic Logic Unit (算術論理演算装置). 大層な名前がついているが、今回のCPUの場合、ただの4bitの全加算器 6
7 回路の全体像
8
ROM (メモリ) クロック生成 ← プログラムカウンタ ALU (4bit FA) 命令デコーダ レジスタ
データセレクタ 9 Aレジスタ → Bレジスタ → キャリーフラグ
• リセットがかかると、ROMの0000番地の命令から実行開始 • ROMに入っている機械語命令 • 上位4bit(オペコード)を命令デコーダが読み込む • 下位4bitを(オペランド)をレジスタに読み込む • ALUはレジスタから値を読み込み、演算を行う
• 演算結果をレジスタに書き込む • プログラムカウンタを+1する • このような動作をクロックに合わせて、繰り返し行う 10 回路の全体像
ROMの実現方法 • 書籍では、8bit DIP SW✕16個 でROMを表現 • 評価ボードのDIPスイッチが 足りない •
Verilogで、各アドレスに対し 機械語命令を返す論理素子を 記述することでROMを表現 11
サンプルプログラム1 : LEDチカチカ 12
サンプルプログラム1 : LEDチカチカ 13
サンプルプログラム2 : タイマー • 実演します 14
感想 • ブラックボックスだと思っていたCPUの仕組みを ある程度知ることができ、勉強になった • もう少し大規模なCPUをHDLを用いて実装してみたい 15