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
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
HASEGAWA Tomoki
March 15, 2026
Technology
0
4
PHPer Book Revue: CPUの創りかた / How to Build a CPU
PHPerKaigi 2026
PHPer Book Revueの資料です
HASEGAWA Tomoki
March 15, 2026
Tweet
Share
More Decks by HASEGAWA Tomoki
See All by HASEGAWA Tomoki
超入門3Dプリンタ: 生活を便利にするモノを作ろう / Getting Started with 3D Printing: Making small things that quietly improve your daily life.
tomzoh
0
60
最新ハードウェアの中の8ビットCPU / The Hidden Power of 8-Bit CPUs in Modern Hardware
tomzoh
0
87
PHPからはじめるコンピュータアーキテクチャ / From Scripts to Silicon: A Journey Through the Layers of Computing Hiroshima 2025 Edition
tomzoh
0
350
PHPからはじめるコンピュータアーキテクチャ / From Scripts to Silicon: A Journey Through the Layers of Computing
tomzoh
5
790
低レイヤを知りたいPHPerのためのCコンパイラ作成入門 完全版 / Building a C Compiler for PHPers Who Want to Dive into Low-Level Programming - Expanded
tomzoh
6
4.5k
カンファレンスのつくりかた / The Conference Code: What Makes It All Work
tomzoh
10
2.2k
低レイヤを知りたいPHPerのためのCコンパイラ作成入門 / Building a C Compiler for PHPers Who Want to Dive into Low-Level Programming
tomzoh
1
1.5k
PHPで印刷所に入稿できる名札データを作る / Generating Print-Ready Name Tag Data with PHP
tomzoh
0
980
asumikamというカンファレンスオーガナイザの凄さを語る / The Brilliance of Asumikam
tomzoh
1
630
Other Decks in Technology
See All in Technology
Claude Code のコード品質がばらつくので AI に品質保証させる仕組みを作った話 / A story about building a mechanism to have AI ensure quality, because the code quality from Claude Code was inconsistent
nrslib
13
7.1k
us-east-1 に障害が起きた時に、 ap-northeast-1 にどんな影響があるか 説明できるようになろう!
miu_crescent
PRO
13
4.2k
Yahoo!ショッピングのレコメンデーション・システムにおけるML実践の一例
lycorptech_jp
PRO
1
200
IBM Bobを使って、PostgreSQLのToDoアプリをDb2へ変換してみよう/202603_Dojo_Bob
mayumihirano
1
320
Go標準パッケージのI/O処理をながめる
matumoto
0
160
[JAWS DAYS 2026]私の AWS DevOps Agent 推しポイント
furuton
0
150
元エンジニアPdM、IDEが恋しすぎてCursorに全業務を集約したら、スライド作成まで爆速になった話
doiko123
1
600
新職業『オーケストレーター』誕生 — エージェント10体を同時に回すAgentOps
gunta
4
1.8k
ナレッジワークのご紹介(第88回情報処理学会 )
kworkdev
PRO
0
190
AWSの資格って役に立つの?
tk3fftk
1
220
実践 Datadog MCP Server
nulabinc
PRO
1
100
タスク管理も1on1も、もう「管理」じゃない ― KiroとBedrock AgentCoreで変わった"判断の仕事"
yusukeshimizu
5
2.6k
Featured
See All Featured
Heart Work Chapter 1 - Part 1
lfama
PRO
5
35k
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
38
2.8k
Measuring Dark Social's Impact On Conversion and Attribution
stephenakadiri
1
150
The AI Search Optimization Roadmap by Aleyda Solis
aleyda
1
5.4k
Agile Leadership in an Agile Organization
kimpetersen
PRO
0
110
Building Applications with DynamoDB
mza
96
7k
Claude Code どこまでも/ Claude Code Everywhere
nwiizo
64
53k
Stop Working from a Prison Cell
hatefulcrawdad
274
21k
Building an army of robots
kneath
306
46k
How to build an LLM SEO readiness audit: a practical framework
nmsamuel
1
670
A designer walks into a library…
pauljervisheath
210
24k
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
31
10k
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が返した 機械語が… 演算器に 演算の種類を… セレクタに どれとどれを演算するかを… 演算結果を どこに保存するかを… プログラムカウンタが 示すアドレスのデータ が出てくる