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
PHPer Book Revue: CPUの創りかた / How to Build a CPU
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
HASEGAWA Tomoki
March 15, 2026
Technology
72
0
Share
PHPer Book Revue: CPUの創りかた / How to Build a CPU
PHPerKaigi 2026
PHPer Book Revueの資料です
HASEGAWA Tomoki
March 15, 2026
More Decks by HASEGAWA Tomoki
See All by HASEGAWA Tomoki
3Dプリンタでコレはこう作る! - マルチディスプレイ用モニタアームマウンタの作り方 / Made with a 3D Printer: DIY Multi-Display Monitor Arm Mount
tomzoh
0
75
デシリアライゼーションを理解する / Inside Deserialization
tomzoh
0
500
超入門3Dプリンタ: 生活を便利にするモノを作ろう / Getting Started with 3D Printing: Making small things that quietly improve your daily life.
tomzoh
0
86
最新ハードウェアの中の8ビットCPU / The Hidden Power of 8-Bit CPUs in Modern Hardware
tomzoh
0
130
PHPからはじめるコンピュータアーキテクチャ / From Scripts to Silicon: A Journey Through the Layers of Computing Hiroshima 2025 Edition
tomzoh
0
390
PHPからはじめるコンピュータアーキテクチャ / From Scripts to Silicon: A Journey Through the Layers of Computing
tomzoh
5
860
低レイヤを知りたいPHPerのためのCコンパイラ作成入門 完全版 / Building a C Compiler for PHPers Who Want to Dive into Low-Level Programming - Expanded
tomzoh
6
4.7k
カンファレンスのつくりかた / The Conference Code: What Makes It All Work
tomzoh
11
2.3k
低レイヤを知りたいPHPerのためのCコンパイラ作成入門 / Building a C Compiler for PHPers Who Want to Dive into Low-Level Programming
tomzoh
1
1.8k
Other Decks in Technology
See All in Technology
PdM・Eng・QAで進めるAI駆動開発の現在地/aidd-with-pdm-eng-qa
shota_kusaba
0
200
AI時代の品質はテストプロセスの作り直し #scrumniigata
kyonmm
PRO
4
1.5k
多角的な視点から見たAGI
terisuke
0
130
20260507-ACL-seminar
satoshi5884
0
110
「背中を見て育て」からの卒業 〜専門技術としてのテスト設計を軸に、品質保証のバトンを繋ぐ〜 #genda_tech_talk
nihonbuson
PRO
3
1.2k
マンション備え付けのネットワークとLTE回線を組み合わせた ネットワークの安定化の考案
harutiro
1
120
Forget technical debt
ufried
0
180
Every Conversation Counts
kawaguti
PRO
0
210
サービスの信頼性を高めるため、形骸化した「プロダクションミーティング」を立て直すまでの取り組み
stefafafan
1
260
2026年春のAgentCoreアプデ 細かいやつ全部まとめ
minorun365
3
220
フロントエンドの相手が変わった - AIが加わったWebの新しいインターフェース設計
azukiazusa1
33
11k
全社統制を維持しながら現場負担をどう減らすか〜プラットフォームチームとセキュリティチームで進めたSecurity Hub活用によるAWS統制の見直し〜/secjaws-security-hub-custom-insights
mhrtech
1
390
Featured
See All Featured
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
25
1.9k
Side Projects
sachag
455
43k
XXLCSS - How to scale CSS and keep your sanity
sugarenia
250
1.3M
Reality Check: Gamification 10 Years Later
codingconduct
0
2.1k
Intergalactic Javascript Robots from Outer Space
tanoku
273
27k
We Analyzed 250 Million AI Search Results: Here's What I Found
joshbly
1
1.3k
Bootstrapping a Software Product
garrettdimon
PRO
307
120k
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
38
2.8k
HDC tutorial
michielstock
2
650
DBのスキルで生き残る技術 - AI時代におけるテーブル設計の勘所
soudai
PRO
65
54k
We Are The Robots
honzajavorek
0
220
Code Review Best Practice
trishagee
74
20k
Transcript
長谷川智希 𝕏 @tomzoh 2026/03/21 PHPerKaigi 2026 PHPer Book Revue CPUの創りかた
୩ஐر ͕ͤΘ ͱ͖ @tomzoh http://www.dgcircus.com デジタルサーカス株式会社 ॴଐ ٕज़ΧϯϑΝϨϯεओ࠻ دߘɾஶॻ 来たれ!PHPer!We
are hiring! 𝕏
୩ஐر ͕ͤΘ ͱ͖ @tomzoh ٕज़ΧϯϑΝϨϯεӡӦࢀՃ ֤छϓϩάϥϜ։ൃ $16 ϨτϩήʔϜػ
ిࢠ࡞ Ϗʔϧ αοΧʔ؍ઓ ϨϯλϧΧʔτϨʔε ΩϟϯϐϯάΧʔ ๅ௩؍ܶʜ ϥΠϑϫʔΫ 𝕏 今日ご紹介する本が ライフワークに…
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた 4 PHPer Book Revue
CPUの創りかた
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた CPUの創りかた • 個人でも比較的簡単に買える汎用ICだけを使って CPU(物理)を作る本
• 1冊で完結する「CPU作る本」 • CPU特有の解説だけでなく、 電子回路の基礎から解説されている • この1冊と部品があればCPUを作れる • 多少の手先技術と根気も… 5
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた CPUでのプログラム実行 • 我々が作ったプログラムは(最終的には)CPUで実行されている •
これはなんとなくわかる • 速いCPUに変えればプログラムも速く動くし • 一方、PHPみたいなVM型の言語だとPHPプログラムはVMで実行される • PHPのVMはCで書かれてる • パーサとかASTとかオペコードとか • パーサがプログラムの上から順にパースしてASTにしてASTを解決していく • プログラム実行、と言われるとこういうのを想像しがち • CPUはそれとは大きく違う方法でプログラムを「実行」している 6
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた CPUでのプログラム実行 • ピタゴラスイッチ的な仕組み •
玉が経路を転がっていって、玉自身が経路にも影 響を与えるやつ • CPUが実行できる唯一の言語 機械語 • 玉が通る経路を切り替える方向を決める • CPUの動作クロック • クロックのタイミングにあわせて玉が通る経路が 切り替わる • この話は過去にしているので興味ある方は… • Speaker Deck の @tomzoh にあります 7 https://www.mouse-jp.co.jp/store/g/ggtune-fzi7g80g8bfdw102dec/
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた 話の流れ Chapter1, 2 •
電子工作の基礎の話から • IC以外の電子部品 • LEDを光らせる方法 8
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた 話の流れ Chapter 3, 4
• 電子回路で1と0を表現する方法 • 電子回路で論理演算する方法 • NOT, AND, OR, NAND (NOT + AND) • PHPで言えば ! A, A && B, A || B, !(A && B) • アナログ回路とデジタル回路の境界 • 電気回路でスイッチを扱う時に必ず直面する チャタリング • キーボードとかマウスでも故障するとなる • クロックの作り方 • 01010101って規則的な信号を作る装置 9
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた 話の流れ Chapter 5, 6
• ROMとは何か • メモリーセル • CPUの設計 • 何を決めればCPUが作れるか • 機械語の基礎知識 10
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた 話の流れ Chapter 7, 8
• フリップフロップ • CPUを実現する上での最重要コンポネント • ピタゴラ装置実現のコア • ALU (Arithmetic and Logic Unit / 算術論理演算装置) • 二進数の演算(ここでは足し算)をする装置 • 演算に必須なフラグの概念 • プログラムカウンタ • 「いまメモリ上のここを実行しているよ」 を指しているレジスタ • I/Oポート • 文字通り入出力: キーボードとかディスプレイとか 11
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた 話の流れ Chapter 9, 10
• 命令デコーダ • 一番興奮するところ • 順次実行されるプログラムをピタゴラ装置に落とし 込むキモ • 全体の回路図 • これを見ながら1本1本配線していけばCPUになる 12
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた 13
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた 話の流れ Chapter 11 •
動作確認 • コンポネントごとに正しく動いているか確認 • 仕様を知りそれをベースにした検証方法 • 自作CPUでのプログラム実行 • ついに…! • 高機能化 14
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた この本を読んで変わったこと • コンピュータを上から下まで理解できた •
NANDがあればコンピュータを作れる(気がする)ようになった • CPUのアーキテクチャのメリット/デメリットを少し深く理解できる様になった • 例えば: Cとかで int の値を long int の変数に入れる処理 • 符号拡張 or ゼロ拡張 • 「ゼロ拡張はそこらへんにあるゼロを使えば良いが、符号拡張は配線負荷が高い」 • CPUが好きになった 15
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた おすすめ書籍: CPUの創りかた • 1冊で完結する「CPU作る本」
• この1冊と部品があればCPUを作れる • 自分で作らないまでも読むだけでも楽しめる • 作るCPUが高度なものでないので手軽 • CPUからテトリスまでの nand2tetris とか、自 作OSを動かすことを目的とすると難しくなる • 「汎用ICだけで作る」が良い制約になっている • ハマると人生変わる(変わった) • 読んでみて! 16 長谷川 智希 @tomzoh
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた おまけ 17
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた 18 その他しばらく積んで 2019年に読みました
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた 19
長谷川智希 @tomzoh PHPer Book Revue: CPUの創りかた 本書で作るCPU TD4の構成 電子回路のピタゴラスイッチ 20
命令 デコーダ 演算器 セレクタ IN ポート レジスタ OUT ポート プログラム カウンタ ROM ROMが返した 機械語が… 演算器に 演算の種類を… セレクタに どれとどれを演算するかを… 演算結果を どこに保存するかを… プログラムカウンタが 示すアドレスのデータ が出てくる