嵌入式Linux與物聯網軟件開發:ARM處理器開發自學教程( 簡體 字) | |
作者:朱有鵬 韓霆 | 類別:1. -> 電腦組織與體系結構 -> 嵌入式系統 -> Cortex |
出版社:人民郵電出版社 | 3dWoo書號: 56373 詢問書籍請說出此書號! 有庫存 NT售價: 450 元 |
出版日:12/1/2023 | |
頁數:364 | |
光碟數:0 | |
站長推薦: | |
印刷:黑白印刷 | 語系: ( 簡體 字 ) |
ISBN:9787115617088 | 加入購物車 │加到我的最愛 (請先登入會員) |
(簡體書上所述之下載連結耗時費功, 恕不適用在台灣, 若讀者需要請自行嘗試, 恕不保證, 繁體書的下載亦請直接連絡出版社) | |
ARM那些你需要知道的事 01
1.1 ARM公司大事記 01 1.2 ARM公司的商業模式和生態系統 02 1.3 ARM處理器版本命名解析 03 1.3.1 如何描述ARM處理器的版本號 03 1.3.2 ARM處理器版本的發展歷程 04 1.4 CPU和SoC的區別及外圍設備的概念 05 1.4.1 CPU和SoC的區別 05 1.4.2 外圍設備 06 1.5 學習平臺的選擇 06 1.5.1 學習平臺的選擇要求 06 1.5.2 為什么選擇三星S5PV210 06 1.6 X210開發板介紹 07 1.7 基于單片機的嵌入式系統和基于復雜操作系統的 嵌入式系統的區別 07 1.7.1 芯片平臺對比 08 1.7.2 片上資源、價格、應用領域上的對比 08 1.7.3 開發模式對比 08 1.7.4 技術特征對比 08 1.7.5 職業發展對比 09 1.8 嵌入式開發學習和編程語言、英語水平等的 關系 09 1.8.1 嵌入式開發學習和編程語言的關系 09 1.8.2 嵌入式開發學習和英語水平的關系 09 1.8.3 嵌入式開發學習和數電、模電的關系 09 1.8.4 嵌入式開發學習和專業的關系 09 1.8.5 嵌入式開發學習和個人性格的關系 10 1.9 嵌入式系統的構成、特點和發展方向 10 1.9.1 嵌入式系統的構成 10 1.9.2 嵌入式系統的特點 10 1.9.3 嵌入式系統的發展方向 11 1.10 交叉編譯 12 1.10.1 軟件開發的兩種模式 12 1.10.2 交叉編譯的特點 12 1.11 CPU的設計原理、地址總線/數據總線/控制 總線 13 1.11.1 CPU的設計原理 13 1.11.2 地址總線、數據總線和控制總線 13 1.12 嵌入式輔助開發工具 14 1.13 習題 14 ARM CPU的體系結構與匯編指令 15 2.1 可編程器件的編程原理 15 2.2 指令集對CPU的意義 16 2.3 CISC和RISC 16 2.4 統一編址和獨立編址、馮·諾依曼結構和哈佛 結構 17 2.4.1 I/O與內存的統一編址和獨立編址 17 2.4.2 馮·諾依曼結構和哈佛結構 18 2.5 軟件編程控制硬件的關鍵——寄存器 19 2.5.1 寄存器的含義及查看方法 19 2.5.2 寄存器的分類 21 2.6 S5PV210的地址映射詳解 21 2.7 CPU的外存儲器和接口方式 24 2.7.1 SoC外存儲器分類與介紹 25 2.7.2 S5PV210支持的外存儲器 26 2.8 S5PV210的啟動過程詳解 27 2.8.1 不同計算機系統內存和外存配置的區別 27 2.8.2 S5PV210啟動方式詳解 28 2.8.3 X210開發板啟動方式選擇 30 2.9 ARM CPU的編程模式和7種工作模式 32 2.9.1 ARM CPU的編程模式 32 2.9.2 ARM CPU的7種工作模式 33 2.10 ARM CPU的37個寄存器詳解 34 2.11 ARM CPU的異常處理方式簡介 37 2.12 ARM匯編指令集詳解 38 2.12.1 ARM匯編指令集總述 38 2.12.2 ARM匯編指令集中指令的分類及詳細講解 40 2.12.3 ARM匯編指令中的偽指令 46 2.13 習題 48 開發板、原理圖和數據手冊 49 3.1 開發板配置簡介 49 3.2 資料導讀 50 3.2.1 開發板硬件手冊導讀 50 3.2.2 X210核心板、底板原理圖導讀 51 3.2.3 S5PV210數據手冊 55 3.3 開發板刷系統 56 3.3.1 刷機工具簡介 56 3.3.2 開發板刷系統方法介紹 58 3.4 新開發板X210BV3S 65 3.5 習題 66 GPIO和LED 67 4.1 交叉編譯工具鏈 67 4.2 Makefile 70 4.3 mkv210_image.c 73 4.3.1 mkv210_image.c的作用 73 4.3.2 mkv210_image.c代碼解析 74 4.4 編寫點亮LED程序前的相關準備工作 77 4.5 點亮LED 81 4.6 擴展:反匯編工具objdump 87 4.7 習題 89 SDRAM和重定位 90 5.1 關閉看門狗 90 5.2 設置棧和調用C程序 92 5.3 用匯編語言編寫啟動代碼之開/關iCache 95 5.4 重定位引入與編程實現 96 5.4.1 重定位引入和鏈接腳本 96 5.4.2 重定位代碼實現 99 5.5 SDRAM初始化 102 5.5.1 原理圖中SDRAM相關部分分析 103 5.5.2 數據手冊中SDRAM相關部分分析 104 5.5.3 代碼實戰 111 5.6 習題 117 時鐘系統 118 6.1 SoC時鐘系統簡介 118 6.2 S5PV210的時鐘系統 119 6.3 時鐘設置的關鍵寄存器分析 126 6.4 實現時鐘設置代碼詳解 126 6.4.1 S5PV210時鐘設置的步驟分析 126 6.4.2 S5PV210時鐘設置匯編語言代碼分析 127 6.4.3 S5PV210時鐘設置C語言代碼分析 132 6.5 習題 134 串口通信 135 7.1 通信發展史及電子通信涉及的基礎概念 135 7.1.1 通信發展史 135 7.1.2 電子通信中涉及的概念 136 7.2 串口通信的基本概念 138 7.3 串口通信的基本原理 140 7.4 S5PV210串口通信詳解 142 7.4.1 原理框圖與自動流控 142 7.4.2 3種擴展模式 144 7.4.3 串口通信中的中斷與時鐘 145 7.5 S5PV210串口通信編程實戰 146 7.6 uart stdio的移植介紹 156 7.7 習題 164 按鍵和CPU中斷系統 165 8.1 按鍵 165 8.2 S5PV210的中斷體系介紹 167 8.3 異常向量表的編程處理 168 8.3.1 訪問異常向量表 169 8.3.2 中斷處理過程中匯編代碼的使用 169 8.4 S5PV210中斷處理的主要寄存器 170 8.5 中斷處理的代碼實現步驟 172 8.6 按鍵與外部中斷 175 8.6.1 外部中斷寄存器配置 175 8.6.2 外部中斷實現按鍵 175 8.7 習題 176 定時器、看門狗和實時時鐘等 177 9.1 定時器 177 9.2 S5PV210中的PWM定時器介紹 178 9.2.1 S5PV210的PWM定時器原理圖簡介 179 9.2.2 預分頻器與分頻器 180 9.2.3 TCNT、TCNTB、TCON和TCNTO寄存器 功能介紹 181 9.2.4 自動重載和雙緩沖 183 9.3 PWM波形介紹 183 9.3.1 什么是PWM 183 9.3.2 PWM波形的生成原理 184 9.3.3 輸出電平翻轉器 185 9.3.4 死區生成器 185 9.4 蜂鳴器和PWM定時器編程實戰 186 9.4.1 蜂鳴器的工作原理 186 9.4.2 原理圖和硬件信息 187 9.4.3 驅動蜂鳴器的PWM定時器代碼編寫 188 9.4.4 編寫C語言主函數、子函數 190 9.4.5 修改Makefile 191 9.5 看門狗 192 9.5.1 什么是看門狗及看門狗的作用 193 9.5.2 S5PV210看門狗的結構原理圖 193 9.5.3 看門狗的主要寄存器 193 9.6 看門狗的編程實戰 194 9.6.1 看門狗產生中斷信號功能代碼編寫 194 9.6.2 看門狗產生復位信號功能代碼編寫 198 9.7 實時時鐘介紹 200 9.7.1 S5PV210實時時鐘的結構框圖 200 9.7.2 S5PV210 RTC的主要寄存器 201 9.7.3 BCD碼介紹 201 9.8 RTC編程實戰 201 9.8.1 編程注意事項 201 9.8.2 實戰步驟詳解 202 9.8.3 示例程序詳解 204 9.9 習題 208 SD卡啟動 209 10.1 SD卡的特點和背景知識 209 10.2 SD卡的編程接口 210 10.2.1 物理接口 210 10.2.2 SD協議與SPI協議 210 10.3 S5PV210的SD卡啟動詳解 211 10.3.1 SoC為何要支持SD卡啟動 211 10.3.2 SD卡啟動的難點在哪里 211 10.3.3 SD卡啟動流程 212 10.3.4 SoC支持SD卡啟動的秘密 212 10.3.5 扇區和塊的概念 213 10.3.6 用函數指針方式調用device copy function 213 10.4 S5PV210的SD卡啟動實戰 214 10.4.1 任務:大于16KB的.bin文件使用SD卡 啟動 214 10.4.2 代碼劃分為兩部分(BL1和BL2)編寫 214 10.4.3 BL1中的重定位 216 10.4.4 BL2遠跳轉 217 10.5 區別于將代碼分為兩部分的另一種啟動方式 217 10.5.1 代碼分為兩部分啟動的缺陷 217 10.5.2 U-Boot的SD卡啟動 218 10.5.3 分析U-Boot的SD卡啟動細節 218 10.6 習題 218 外存芯片NAND Flash和iNAND 219 11.1 NAND Flash的型號和命名 219 11.1.1 NAND Flash的數據位 219 11.1.2 NAND Flash的功能框圖 219 11.2 NAND Flash的單元組織:Block和Page 221 11.2.1 帶內數據和帶外數據 221 11.2.2 NAND Flash的地址時序和命令碼 222 11.3 NAND Flash的壞塊檢查 222 11.3.1 NAND Flash的頁寫操作 223 11.3.2 NAND Flash的擦除和頁讀操作 224 11.4 SoC的NAND Flash控制器 224 11.5 NAND Flash操作代碼解析 225 11.6 iNAND介紹 228 11.7 SD卡/iNAND硬件接口 228 11.7.1 SD卡命令相應的操作模式 229 11.7.2 SD卡體系結構、內部寄存器 229 11.8 SD/iNAND代碼分析 230 11.8.1 Hsmmc.h頭文件CMD×和ACMD×命令碼 分析 230 11.8.2 Hsmmc.c文件分析 233 I2C通信 238 12.1 I2C通信介紹 238 12.2 I2C通信的時序 239 12.2.1 I2C的空閑態/忙態、起始位/結束位 239 12.2.2 I2C數據傳輸格式(數據位和ACK) 240 12.2.3 數據在總線上的傳輸協議 240 12.3 S5PV210的I2C控制器 241 12.4 X210開發板的板載重力傳感器介紹 243 12.4.1 原理圖 243 12.4.2 重力傳感器簡介 244 12.4.3 I2C從設備地址 244 12.4.4 I2C從設備的通信速率 245 12.5 I2C的通信流程 245 12.5.1 I2C的通信流程寄存器分析 245 12.5.2 重力傳感器讀/寫寄存器流程分析 247 12.6 I2C通信代碼分析 248 12.7 習題 250 A/D轉換器 251 13.1 A/D轉換器的引入 251 13.1.1 模擬量和數字量 251 13.1.2 什么是A/D轉換器 252 13.1.3 有A/D轉換器自然就有D/A轉換器 252 13.2 A/D轉換器的主要相關概念 252 13.2.1 量程 252 13.2.2 精度 252 13.2.3 轉換速率 253 13.2.4 A/D轉換器的工作時鐘框圖 253 13.2.5 A/D轉換器的通道數 254 13.2.6 A/D轉換器和電阻式觸摸屏的關系 255 13.3 S5PV210的A/D轉換控制器 255 13.4 硬件設計分析 258 13.5 軟件設計 258 13.6 程序燒錄與調試 260 13.7 習題 262 LCD屏 263 14.1 LCD簡介 263 14.1.1 什么是LCD 263 14.1.2 LCD的顯示原理和特點 263 14.1.3 LCD屏的種類 264 14.1.4 其他類型的顯示屏 264 14.2 LCD設備的接口技術 265 14.2.1 LCD設備通信接口中的電平轉換 265 14.2.2 RGB接口詳解 266 14.3 LCD的顯像原理和相關概念 267 14.3.1 像素及相關概念 267 14.3.2 掃描 268 14.3.3 驅動器和控制器 269 14.3.4 顯示內存(顯存) 269 14.3.5 LCD屏的6個主要時序參數 270 14.4 顏色在計算機中的表示 272 14.4.1 計算機中的顏色是離散的 272 14.4.2 常見像素深度 272 14.5 S5PV210的LCD控制器 273 14.5.1 虛擬屏幕疊加 274 14.5.2 虛擬顯示 275 14.6 LCD編程實戰 276 14.6.1 LCD控制器初始化 276 14.6.2 顯示像素、刷背景、橫線豎線和畫圓功能的 實現 287 14.6.3 寫英文和中文字符 290 14.6.4 畫圖 292 14.7 習題 295 觸摸屏 296 15.1 輸入設備簡介及觸摸屏介紹 296 15.1.1 觸摸屏的特點 296 15.1.2 觸摸屏和顯示屏的聯系與區別 296 15.2 電阻式觸摸屏的原理 297 15.3 S5PV210的電阻式觸摸屏控制器 298 15.3.1 控制器框圖介紹 298 15.3.2 控制器部件的工作模式選擇 299 15.3.3 控制器的主要寄存器 300 15.4 電容式觸摸屏的原理 301 15.4.1 人體感知電流 301 15.4.2 專用電路計算坐標 301 15.4.3 多個區塊支持多點觸摸 302 15.4.4 對外提供I2C的訪問接口 302 15.5 FT5x06電容觸摸IC簡介 302 15.6 習題 303 Shell原理和問答機制引入 304 16.1 理解Shell 304 16.1.1 什么是Shell 304 16.1.2 Shell的運行原理 305 16.1.3 Shell應用舉例 305 16.2 從零寫最簡單的Shell 306 16.2.1 使用printf和scanf函數做輸入回顯 306 16.2.2 定義簡單命令集 306 16.3 將簡易Shell移植到開發板中 308 16.3.1 工程選定、文件復制、Makefile編寫 308 16.3.2 printf和scanf函數的移植 314 16.3.3 main.c和其余文件 317 16.3.4 編譯下載和調試驗證 319 16.4 定義標準命令集及解析 320 16.4.1 添加cmd_parser和cmd_exec函數 321 16.4.2 自己動手寫strcmp和strcpy函數 322 16.4.3 定義命令集、添加shell.h頭文件 322 16.4.4 修改代碼 323 16.4.5 燒錄與測試 324 16.5 添加第 一個命令 326 16.5.1 命令任務分析 326 16.5.2 命令解析與命令執行 327 16.5.3 修改代碼 330 16.5.4 第 一個命令的測試 331 16.6 添加其他命令 332 16.6.1 添加pwm.c文件 332 16.6.2 添加adc.c命令文件 333 16.6.3 移植printf函數 334 16.6.4 添加lcd.c文件 335 16.6.5 修改代碼 339 16.6.6 編譯測試 345 16.7 實現開機倒計時自動執行命令 346 16.7.1 添加計時功能 347 16.7.2 修改代碼 349 16.7.3 測試運行 352 16.7.4 構建BL1和BL2燒錄 352 16.8 初步實現環境變量 354 16.8.1 添加env.c文件對環境變量進行設置、 修改 355 16.8.2 修改代碼 357 16.8.3 測試代碼 363 16.9 習題 364 本書基于ARM Cortex-A8 內核的三星 S5PV210 CPU,主要講解 ARM CPU 開發的全套相關技術,包括ARM體系的背景知識、常規開發方式、ARM 體系結構和匯編指令集。本書還基于 X210 開發板講解了開發板的原理圖、芯片的數據手冊,以及開發板的刷機流程等,講解了 GPIO、LED、DDR、串口、定時器、看門狗、SD 卡、NAND Flash、iNAND、I2C 總線、LCD 屏、A/D 轉換器、電阻式和電容式觸摸屏等 ARM CPU 常見外設的原
理,并使用匯編和 C 語言編程進行了外設及代碼重定位、時鐘體系等的原理和功能的編程實踐。本書最后還利用X210 平臺結合部分外設寫了一個裸機串口的 Shell 作為小項目,幫助讀者理解什么是交互式 Shell,為下一階段U-Boot 及 Linux 內核的學習打好基礎。在具體講解過程中,本書引用了產品的一部分原始英文圖表,并有針對性地進行了適當的說明。 本書適合從事 CPU 開發等相關工作的人員和相關專業的學生閱讀參考。 |