uefi原理與編程下載 最新軟件|熱門排行|軟件分類|軟件專題|廠商大全

您的位置: 首頁教育教學(xué)電子圖書 → UEFI原理與編程pdf 完整版

UEFI原理與編程pdf

完整版 UEFI原理與編程pdf 網(wǎng)友評分:8

同類相關(guān)軟件

軟件介紹

軟件標(biāo)簽: 編程圖書 編程書籍

UEFI原理與編程pdf是由戴正華編寫的UEFI操作系統(tǒng)遠(yuǎn)離和開發(fā)配置的編程教程,幫助初學(xué)者更好的掌握UEFI的基礎(chǔ)和理論學(xué)習(xí),綠色資源網(wǎng)誠意推薦!

UEFI原理與編程電子書介紹

《UEFI原理與編程》以實(shí)戰(zhàn)為導(dǎo)向,面向UEFI的使用者和開發(fā)者,首先細(xì)致地介紹了UEFI的系統(tǒng)組成、啟動過程、優(yōu)點(diǎn),以及各種系統(tǒng)中的開發(fā)環(huán)境搭建;然后深入剖析了UEFI的工作原理,包括UEFI工程模塊、各種協(xié)議、基礎(chǔ)服務(wù)、事件、硬盤和文件系統(tǒng)等內(nèi)容;最后講解了UEFI的開發(fā),涉及UEFI服務(wù)的開發(fā)、UEFI驅(qū)動的開發(fā)、多任務(wù)應(yīng)用的開發(fā)、網(wǎng)絡(luò)應(yīng)用的開發(fā)、GUI應(yīng)用的開發(fā),以及如何用C++和C標(biāo)準(zhǔn)庫開發(fā)UEFI應(yīng)用,等等。

UEFI原理與編程

UEFI原理與編程完整版目錄

前 言

第1章 UEFI概述 1

1.1 BIOS的前世今生 1

1.1.1 BIOS在計(jì)算機(jī)系統(tǒng)中的作用 1

1.1.2 BIOS缺點(diǎn) 2

1.2 初識UEFI 2

1.2.1 UEFI系統(tǒng)組成 3

1.2.2 UEFI的優(yōu)點(diǎn) 4

1.2.3 UEFI系統(tǒng)的啟動過程 5

1.3 本章小結(jié) 12

第2章 UEFI 開發(fā)環(huán)境搭建 14

2.1 配置Windows開發(fā)環(huán)境 14

2.1.1 安裝所需開發(fā)工具 15

2.1.2 配置EDK2開發(fā)環(huán)境 15

2.1.3 編譯UEFI模擬器和UEFI工程 17

2.1.4 運(yùn)行模擬器 19

2.2 配置Linux 開發(fā)環(huán)境 21

2.2.1 安裝所需開發(fā)工具 22

2.2.2 配置EDK2開發(fā)環(huán)境 22

2.2.3 編譯UEFI模擬器和UEFI工程 23

2.2.4 運(yùn)行模擬器 24

2.3 OVMF的制作和使用 25

2.4 UEFI的啟動 27

2.5 本章小結(jié) 28

第3章 UEFI工程模塊文件 29

3.1 標(biāo)準(zhǔn)應(yīng)用程序工程模塊 30

3.1.1 入口函數(shù) 30

3.1.2 工程文件 31

3.1.3 編譯和運(yùn)行 37

3.1.4 標(biāo)準(zhǔn)應(yīng)用程序的加載過程 37

3.2 其他類型工程模塊 43

3.2.1 Shell應(yīng)用程序工程模塊 43

3.2.2 使用main函數(shù)的應(yīng)用程序工程模塊 46

3.2.3 庫模塊 47

3.2.4 UEFI驅(qū)動模塊 49

3.2.5 模塊工程文件小結(jié) 50

3.3 包及.dsc、.dec、.fdf文件 51

3.3.1 .dsc文件 51

3.3.2 .dec文件 56

3.4 調(diào)試UEFI 59

3.5 本章小結(jié) 61

第4章 UEFI中的Protocol 62

4.1 Protocol 在UEFI內(nèi)核中的表示 64

4.2 如何使用Protocol服務(wù) 65

4.2.1 OpenProtocol服務(wù) 66

4.2.2 HandleProtocol服務(wù) 67

4.2.3 LocateProtocol服務(wù) 69

4.2.4 LocateHandleBuffer服務(wù) 69

4.2.5 其他一些使用Protocol的服務(wù) 71

4.2.6 CloseProtocol服務(wù) 72

4.3 Protocol服務(wù)示例 73

4.4 本章小結(jié) 75

第5章 UEFI的基礎(chǔ)服務(wù) 76

5.1 系統(tǒng)表 76

5.1.1 系統(tǒng)表的構(gòu)成 77

5.1.2 使用系統(tǒng)表 79

5.2 啟動服務(wù) 82

5.2.1 啟動服務(wù)的構(gòu)成 82

5.2.2 啟動服務(wù)的生存期 91

5.3 運(yùn)行時服務(wù) 93

5.4 本章小結(jié) 102

第6章 事件 103

6.1 事件函數(shù) 104

6.1.1 等待事件的服務(wù)WaitForEvent 105

6.1.2 生成事件的服務(wù)CreateEvent 106

6.1.3 CreateEventEx服務(wù) 110

6.1.4 事件相關(guān)的其他函數(shù) 112

6.2 定時器事件 113

6.3 任務(wù)優(yōu)先級 114

6.3.1 提升和恢復(fù)任務(wù)優(yōu)先級 115

6.3.2 UEFI中的時鐘中斷 116

6.3.3 UEFI事件Notif?ication函數(shù)的派發(fā) 126

6.4 鼠標(biāo)和鍵盤事件示例 127

6.5 本章小結(jié) 128

第7章 硬盤和文件系統(tǒng) 129

7.1 GPT硬盤 129

7.1.1 基于MBR分區(qū)的傳統(tǒng)硬盤 129

7.1.2 GPT硬盤詳解 130

7.2 設(shè)備路徑 134

7.3 硬盤相關(guān)的Protocol 139

7.3.1 BlockIo解析 140

7.3.2 BlockIo2解析 142

UEFI原理與編程下載

7.3.3 DiskIo解析 146

7.3.4 DiskIo2解析 147

7.3.5 PassThrough解析 150

7.4 文件系統(tǒng) 152

7.5 文件操作 153

7.5.1 打開文件 154

7.5.2 讀文件 156

7.5.3 寫文件 159

7.5.4 關(guān)閉文件(句柄) 160

7.5.5 其他文件操作 160

7.5.6 異步文件操作 162

7.5.7 EFI_SHELL_PROTOCOL中的文件操作 166

7.6 本章小結(jié) 170

第8章 開發(fā)UEFI服務(wù) 171

8.1 Protocol服務(wù)接口設(shè)計(jì) 172

8.2 Protocol服務(wù)的實(shí)現(xiàn) 174

8.3 服務(wù)型驅(qū)動的框架 178

8.4 ffmpeg的移植與編譯 179

8.4.1 libavcodec的建立和移植 181

8.4.2 其他庫的建立與移植 182

8.4.3 在驅(qū)動型服務(wù)中使用StdLib 186

8.5 使用Protocol服務(wù) 188

8.6 本章小結(jié) 190

第9章 開發(fā)UEFI驅(qū)動 191

9.1 UEFI驅(qū)動模型 192

9.1.1 EFI Driver Binding Protocol的構(gòu)成 192

9.1.2 EFI Component Name Protocol的作用和構(gòu)成 196

9.2 編寫設(shè)備驅(qū)動的步驟 197

9.3 PCI設(shè)備驅(qū)動基礎(chǔ) 199

9.4 AC97控制器芯片的控制接口 202

9.5 AC97驅(qū)動 206

9.5.1 AC97驅(qū)動的驅(qū)動服務(wù)EFI_AUDIO_PROTOCOL 206

9.5.2 AC97驅(qū)動的框架部分 213

9.5.3 AC97驅(qū)動實(shí)驗(yàn) 220

9.6 本章小結(jié) 221

第10章 用C++開發(fā)UEFI應(yīng)用 222

10.1 從編譯器角度看C與C++的差異 222

10.2 在EDK2中支持C++ 224

10.2.1 使EDK2支持C++基本特性 224

10.2.2 在Windows系統(tǒng)下的程序啟動過程 226

10.2.3 在Windows系統(tǒng)下支持全局構(gòu)造和析構(gòu) 229

10.2.4 在Linux系統(tǒng)下的程序啟動過程 231

10.2.5 在Linux系統(tǒng)下支持全局構(gòu)造和析構(gòu) 240

10.2.6 支持new和delete 242

10.2.7 支持STL 243

10.3 GcppPkg概覽 243

10.4 測試GcppPkg 246

10.5 本章小結(jié) 248

第11章 GUI基礎(chǔ) 249

11.1 字符串 249

11.1.1 字符串函數(shù) 249

11.1.2 字符串資源 251

11.1.3 管理字符串資源 255

11.2 管理語言 260

11.3 包列表 262

11.4 圖形界面顯示 263

11.4.1 顯示模式 264

11.4.2 Block Transfer(Blt)傳輸圖像 267

11.4.3 在圖形界面下顯示字符串 269

11.5 用SimpleFont顯示中文 272

11.5.1  SimpleFont 格式 273

11.5.2 如何生成字體文件 275

11.5.3 如何注冊字體文件 276

11.6 開發(fā)SimpleFont字庫程序 277

11.7 字體Font 278

11.7.1 Font的格式 279

11.7.2 字體包的格式 279

11.7.3 為什么Font性能高于SimpleFont 281

11.8 本章小結(jié) 284

第12章 GUI應(yīng)用程序 285

12.1 UEFI事件處理 285

12.1.1 鍵盤事件 285

12.1.2 鼠標(biāo)事件 292

12.1.3 定時器事件 293

12.1.4 UI事件服務(wù)類 294

12.2 事件處理框架 297

12.3 鼠標(biāo)與控件的繪制 302

12.3.1 鼠標(biāo)的繪制 303

12.3.2 控件的繪制 305

12.4 控件系統(tǒng)包GUIPkg 306

12.5 簡單視頻播放器的實(shí)現(xiàn) 309

12.6 本章小結(jié) 315

第13章 深入了解多任務(wù) 317

13.1 多處理器服務(wù) 317

13.1.1 EFI_MP_SERVICES_PROTOCOL功能及用法 317

13.1.2 啟動AP的過程 324

13.2 內(nèi)聯(lián)匯編基礎(chǔ)和寄存器上下文的保存與恢復(fù) 333

13.2.1 內(nèi)聯(lián)匯編基礎(chǔ) 333

13.2.2 寄存器上下文的保存與恢復(fù) 335

13.3 多線程 336

13.3.1 生成線程 337

13.3.2 調(diào)度線程 340

13.3.3 等待線程結(jié)束 341

13.3.4 SimpleThread服務(wù) 341

13.4 本章小結(jié) 345

第14章 網(wǎng)絡(luò)應(yīng)用開發(fā) 346

14.1 在UEFI中使用網(wǎng)絡(luò) 348

14.2 使用EFI_TCP4_PROTOCOL 350

14.2.1 生成Socket對象 352

14.2.2 連接 356

14.2.3 傳輸數(shù)據(jù) 358

14.2.4 關(guān)閉Socket 361

14.2.5 測試Socket 362

14.3 本章小結(jié) 363

第15章 使用C標(biāo)準(zhǔn)庫 364

15.1 為什么使用C標(biāo)準(zhǔn)庫函數(shù) 364

15.2 實(shí)現(xiàn)簡單的Std函數(shù) 365

15.2.1 簡單標(biāo)準(zhǔn)庫函數(shù)包sstdPkg 366

15.2.2 使用sstdPkg 368

15.3 使用EDK2的StdLib 369

15.3.1 main函數(shù)工程 369

15.3.2 非main函數(shù)工程 374

15.4 本章小結(jié) 376

第16章 Shell及常用Shell命令 377

16.1 Shell的編譯與執(zhí)行 377

16.2 Shell服務(wù) 379

16.3 Shell腳本 385

16.3.1 Shell腳本語法簡介 385

16.3.2 自動運(yùn)行指定應(yīng)用程序 388

16.4 Shell內(nèi)置命令 388

16.4.1 調(diào)試設(shè)備的相關(guān)命令 388

16.4.2 驅(qū)動相關(guān)命令 390

16.4.3 網(wǎng)絡(luò)相關(guān)命令 392

16.5 本章小結(jié) 394

附錄A UEFI常用術(shù)語及簡略語 395

附錄B RFC 4646常用語言列表 397

附錄C 狀態(tài)值 398

附錄D 參考資料 400

軟件截圖

下載地址 電腦版

用戶評論

熱門評論

最新評論

發(fā)表評論 查看所有評論(0)

昵稱:
請不要評論無意義或臟話,我們所有評論會有人工審核.
字?jǐn)?shù): 0/500 (您的評論需要經(jīng)過審核才能顯示)