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
系統程式 第 4 章 -- 組譯器
Search
陳鍾誠
April 14, 2022
Education
610
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
系統程式 第 4 章 -- 組譯器
陳鍾誠
April 14, 2022
More Decks by 陳鍾誠
See All by 陳鍾誠
第 6 章、巨集處理器
ccckmit
0
140
第 7 章、高階語言
ccckmit
0
220
第 9 章、虛擬機器
ccckmit
0
150
第 8 章、編譯器
ccckmit
0
270
數學、程式和機器
ccckmit
2
850
語言處理技術
ccckmit
0
230
微積分
ccckmit
1
540
系統程式 第 1 章 -- 系統軟體
ccckmit
0
610
系統程式 第 2 章 -- 電腦的硬體結構
ccckmit
0
580
Other Decks in Education
See All in Education
Dashboards - Lecture 11 - Information Visualisation (4019538FNR)
signer
PRO
1
2.7k
吉祥寺.pmは1つじゃない — 複数イベント並走運営の12年 —
magnolia
0
1.3k
生成AI時代の情報発信
molmolken
0
130
From Days to Minutes: How We Taught an AI to Onboard 50+ Tenants on our AI Features
mfcabrera
0
180
Visionary Initiative: Future Intelligence 「未来の知性と社会の礎を築く」|Science Tokyo(東京科学大学)
sciencetokyo
PRO
0
420
Throw Yourself In! - How I've learned English and What I'm Facing
georgeorge
1
140
Virtual and Augmented Reality - Lecture 8 - Next Generation User Interfaces (4018166FNR)
signer
PRO
0
2.3k
AI進化史:LLMからAIエージェントへ
mickey_kubo
0
200
アラムコSTEAMチャレンジ 実践報告書
codeforeveryone
0
140
Implicit and Cross-Device Interaction - Lecture 10 - Next Generation User Interfaces (4018166FNR)
signer
PRO
2
2.3k
[2026前期火5] 論理学(京都大学文学部 前期 第3回)「形式言語と四つのキーワード:メタ・構成・意味論・ハーモニー」
yatabe
0
550
Visualisation Techniques - Lecture 8 - Information Visualisation (4019538FNR)
signer
PRO
1
3.1k
Featured
See All Featured
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
659
62k
Believing is Seeing
oripsolob
1
150
Kristin Tynski - Automating Marketing Tasks With AI
techseoconnect
PRO
0
270
jQuery: Nuts, Bolts and Bling
dougneiner
66
8.5k
SEO for Brand Visibility & Recognition
aleyda
0
4.6k
Data-driven link building: lessons from a $708K investment (BrightonSEO talk)
szymonslowik
1
1.1k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.8k
Testing 201, or: Great Expectations
jmmastey
46
8.2k
A Guide to Academic Writing Using Generative AI - A Workshop
ks91
PRO
1
330
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
3.5k
We Are The Robots
honzajavorek
0
250
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
1
1.7k
Transcript
第 4 章、組譯器 作者:陳鍾誠 旗標出版社
第 4 章、組譯器 4.1 組譯器簡介 4.2 組譯器的演算法
4.3 完整的組譯範例 4.4 實務案例:處理器 IA32 上的 GNU 組譯器
4.1 組譯器簡介 組譯器乃是將組合語言轉換為機器碼的工具。 組合語言 (組譯器) 目的檔
(或執行檔) 組譯器是組合語言程式師所使用的主要工具。
組譯器的過程示意圖 MUL R5, R2, R2 ADD R1, R2, R5 ADD
R2, R4, R2 15 52 20 00 13 12 50 00 13 24 20 00 組譯器 Assembler 組合語言 目的檔 圖 4.1 組譯器的過程示意圖
簡單的組合語言程式
組譯:將組合語言轉譯成目的碼
組譯的原理 (絕對定址)
組譯的原理 (相對於 PC 定址)
二階段的組譯方式 (1). 運算元轉換: 將指令名稱轉換為機器語言 例如 LD 轉為00,
ST 轉為01等 (2). 參數轉換: 將暫存器轉為代號,符號轉換成機器位址 例如 R1 轉為 1, A 轉為 000C,B 轉為 0010 等。 (3). 資料轉換: 將原始程式當中的資料常數轉換為內部的機器碼 例如 29 轉換為 001D。 (4). 目的碼產生: 根據指令格式, 轉換成目的碼, 輸出到目的檔中。 (1) (2) (3) (2)
映像檔 映像檔:最簡單的目的碼 組合語言 (組譯器) 映像檔
as0 組譯器
4.2 組譯器的演算法 第一階段 計算符號位址 第二階段 組譯指令與資料
資料結構:符號表
第一階段 (計算符號位址) 1. 決定每一個指令所佔記憶空間 的大小 例如 決定
WORD、RESW 等指令所定 義的資料長度 決定 LD、ST 等指令所佔空間的大 小 2. 計算出程式當中每一行的位址。 3. 儲存每一個標籤與變數的位址 例如 變數 A 為 0x000C 變數 B 為 0x0010
第二階段 (組譯指令與資料) (1). 轉換指令OP欄位為機器碼 例如 LD 轉換為
00 ST 轉換為 01 (2). 轉換指令參數為機器碼 例如 R1轉換為 1 B 轉換為 000C (3). 轉換資料定義指令為位元值 例如 WORD B 29 轉為 0000001D (4). 產生目的碼並輸出到目的檔當 中 (1) (2) (2) (3)
組譯器的資料結構 運算碼表 (Op Table) 儲存指令與代碼的配對表 通常使用雜湊表格
符號表 (Symbol Table) 儲存符號與位址的配對表 通常使用雜湊表格
第一階段 (PASS1) 計算位址
第二階段 (PASS2) – 主程式 指令轉為機器碼
第二階段 (PASS2) – 指令轉換函數 根據指令類型 L 型
A 型 J 型 轉換成該型編碼
4.3 完整的組譯範例 範例:陣列加總功能 功能 如右圖 C 語言所示
原始程式 如範例 4.7 所示 組譯結果 如範例 4.8 所示
原始程式
組譯結果 組譯報表 範例 4.8 符號表 圖
4.6 目的檔 範例 4.9
4.4 實務案例: 處理器 IA32 上的 GNU 組譯器 as :
GNU 的組譯器 -a 參數 讓 GNU 的 as 組譯器 產生組譯報表檔
GNU 的 組譯報表 指令長度不固定 範例 addl %eax, sum 010500000000
addl $1, %eax 83C001 符號表
結語 對 IA32 的編碼方式有興趣的讀者,可以參考 Kip Irvine 的組合語言一書
習題 1. 請說明組譯器的輸入、輸出與功能為何? 2. 請說明組譯器第一階段 (PASS1) 的功能為何? 3. 請說明組譯器第二階段 (PASS2)
的功能為何? 4. 請說明組譯器當中的符號表之用途為何? 5. 請說明組譯器當中的指令表之用途為何? 6. 請仿照範例 4.4,使用本書第12章所實作的 as0 組譯器,組譯 Ex4_1.asm0 組合語 言檔,並仔細觀察其輸出結果。 7. 請閱讀本書第12章所附的 Assembler.c 與 Assembler.h 等C語言程式,並且對照本 章的演算法,以學習 CPU0 組譯器的實作方式。 8. 請按照4.4節的方法,操作 GNU 工具對組合語言進行組譯動作,並檢視組譯報表, 找出各個符號的位址。 9. 請於 http://kipirvine.com/asm/ 網站下載Kip Irvine 書籍組合語言程式範例,並以 Visual Studio 進行組譯與執行。