Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
マイクロプログラム制御方式のCPUを自作した話
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Kenta
June 02, 2024
Technology
470
0
Share
マイクロプログラム制御方式のCPUを自作した話
Kenta
June 02, 2024
More Decks by Kenta
See All by Kenta
『Verylで作るCPU』を読んでいる
kenta11
0
190
Elixirで作る将棋ソフト
kenta11
0
150
失くしたリモコンを作る2
kenta11
0
100
失くしたリモコンを作る
kenta11
0
53
Other Decks in Technology
See All in Technology
Databricks における 生成AIガバナンスの実践
taka_aki
1
270
Javaで学ぶSOLID原則
negima
1
270
ITエンジニアを取り巻く環境とキャリアパス / A career path for Japanese IT engineers
takatama
4
1.8k
OpenID Connectによるサービス間連携
takesection
0
150
さきさん文庫の書籍ができるまで
sakiengineer
0
330
APIテストとは?
nagix
0
170
運用を見据えたAIエージェント設計実践
amacbee
0
2.2k
インフラが苦手でも大丈夫! 紙芝居 Kubernetes -WWGT 10周年編-
aoi1
1
330
チームで実践する AI-DLC 思考の軌跡を残すチェックポイント設計
belongadmin
0
2k
ChatworkとBPaaS 異なる特性で学んだAI機能開発の ベストプラクティス
kubell_hr
2
2.1k
AI フレンドリーなエラー監視を TypeScript で実現する
shinyaigeek
2
240
Claude Codeを組織で使いこなす— サーバサイドAIエージェント運用の実践知
techtekt
PRO
0
180
Featured
See All Featured
Done Done
chrislema
186
16k
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
49
3.5k
AI Search: Where Are We & What Can We Do About It?
aleyda
0
7.5k
Connecting the Dots Between Site Speed, User Experience & Your Business [WebExpo 2025]
tammyeverts
11
930
SEOcharity - Dark patterns in SEO and UX: How to avoid them and build a more ethical web
sarafernandez
0
190
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
3.3k
WCS-LA-2024
lcolladotor
0
610
The Curse of the Amulet
leimatthew05
1
13k
Ecommerce SEO: The Keys for Success Now & Beyond - #SERPConf2024
aleyda
1
2k
The Language of Interfaces
destraynor
162
27k
From π to Pie charts
rasagy
0
200
Leveraging LLMs for student feedback in introductory data science courses - posit::conf(2025)
minecr
1
270
Transcript
マイクロプログラム制御方式 のCPUを自作した話 Kenta Arai 2024/06/02 ぬるぽ 1
自己紹介 • 名前:Kenta Arai • Twitter: @isKenta14 • Qiita: Kenta11
• 仕事:組込みソフトウェア開発 • 趣味で作ったもの • micro-alpha ☜今日はこれの話です • 簡素なマイクロプログラム制御方式CPU • Xilinx FPGA 上で実際に動かせました • simple_uart:UART の SystemVerilog 実装 • elixir_shogi:投了だけできる Elixir 製将棋エンジン 2024/06/02 ぬるぽ 2
背景 • マイクロプログラム制御方式:計算機の制御装置を構成する方式の 一つ • 特徴:制御装置が簡素、ISAの変更が容易等 • 結線論理方式と対比される • 黎明期の計算機でよく使われていた
• KT-Pilot(1961年、京都大学、東芝) • MELCOM 1530(1963年、三菱電機) • 自作CPUで採用されることは少ない(気がする) • 自作してマイクロプログラム制御方式について理解を深めたい 2024/06/02 ぬるぽ 3
目的 • マイクロプログラム制御方式で自作CPUをする 2024/06/02 ぬるぽ 4
CISC と RISC [1] • 典型的な定義 • CISC (Complex Instruction
Set Computer) • 命令の種類:多い • 制御部の構成:マイクロプログラム制御方式 • RISC (Reduced Instruction Set Computer) • 命令の種類:少ない • 制御部の構成:結線論理方式 • 旧来の命令セットが複雑化した(CISC)反省から 命令セットを単純化することで、パイプライン処理を高速化(RISC) 2024/06/02 ぬるぽ 5 [1] 馬場敬信:コンピュータアーキテクチャ改訂4版, オーム社, p. 8, 66, 2019
マイクロプログラム制御方式 2024/06/02 ぬるぽ 6 0000 制御記憶 アドレス レジスタ CPU 主記憶装置
制御記憶 制御記憶アドレス マイクロオーダ 0000 制御記憶 データ レジスタ 汎用レジスタ 0000 0000 0000 0000 算術論理演算装置 IO装置 プログラム カウンタ 0000 命令レジスタ 0000 被制御部 デコーダ 命令フェッチ XXX0 XXX1 XXX2 ロード命令 XXX3 XXX4 ストア命令 XXX5 XXX6 加算命令 XXX7 制御部
MICRO-1[2] • 簡素なマイクロプログラム制御方式のモデル • 制御部 • 制御記憶:1語40ビット、最大4K語の容量 • アドレス長:12ビット •
被制御部 • 主記憶:1語16ビット、最大64K語の容量 • 汎用レジスタ:16ビット×8 • フラグ:ZER, NEG, CRY, OV等 2024/06/02 ぬるぽ 7 [2] 馬場敬信:ソフトウェア講座(23)マイクロプログラミング, 昭晃堂, pp. 31-107, 1985 図:書籍の表紙
MICRO-1を実装 • 開発環境等 • 言語:SystemVerilog • シミュレータ:ModelSim • テストフレームワーク:VUnit •
実践FPGAテスト自動化が とても役に立ちました 2024/06/02 ぬるぽ 8 図:テストの様子 ソ ー ス コ ー ド を コ ン パ イ ル テ ス ト 結 果 が レ ポ ー ト さ れ る
アセンブラとマイクロアセンブラも自作 • Windows版しかなかったので、Linux版を自作しました • Rust 実装なので、cargo コマンドでインストールできます • cargo install
rm1asm; cargo install rm1masm 2024/06/02 ぬるぽ 9
Xilinx FPGA 上に実装 • Arty A7-100 と Basys 3 で動作検証
• 逆ポーランド電卓が動いた! 2024/06/02 ぬるぽ 10
結果 • マイクロプログラム制御方式で自作CPUができた • MICRO-1 を基に簡素な CISC プロセッサを実装 • ついでにアセンブラとマイクロアセンブラも自作
• FPGA 上で逆ポーランド電卓を動作させることに成功 2024/06/02 ぬるぽ 11
考察っぽいなにか • マイクロプログラム制御方式 • 前評判通り、制御装置は簡素かも • オープンな設計が無さそうなので、本格的なものを作るとなると大変だろう • アセンブラとマイクロアセンブラを両方作るのが面倒 •
MICRO-1 • 関数呼び出しで飛べるアドレス範囲が狭すぎる • 現在アドレス+8ビット2の補数表現、までしか飛べません • これに気が付かず大きなプログラムを書いたときに、大変な思いをしました • スタックが狭すぎる(0x0040-0x013F) • これに気が付かず(以下略) • 1人で作るにはちょうどいい規模の計算機かも 2024/06/02 ぬるぽ 12
成果 • ブログ • https://kenta11.github.io/posts/2022-09-23-micro1/ • https://kenta11.github.io/posts/2023-03-18-micro-alpha/ • リポジトリ •
https://github.com/Kenta11/micro-alpha • https://github.com/Kenta11/rm1asm • https://github.com/Kenta11/rm1masm 2024/06/02 ぬるぽ 13