嵌入式計算機系統(tǒng)簡稱為嵌入式系統(tǒng),其概念初源于傳統(tǒng)測控系統(tǒng)對計算機的需求。隨著以微處理器(MPU)為內(nèi)核的微控制器(MCU)制造技術的不斷進步,計算機領域在通用計算機系統(tǒng)與嵌入式計算機系統(tǒng)這兩大分支分別得以發(fā)展。通用計算機已經(jīng)在科學計算、通信、日常生活等各個領域產(chǎn)生重要影響。在后PC時代,嵌入式系統(tǒng)的廣闊應用是計算機發(fā)展的重要特征。一般來說,嵌入式系統(tǒng)的應用范圍可以粗略分為兩大類: 一類是電子系統(tǒng)的智能化(如工業(yè)控制、汽車電子、數(shù)據(jù)采集、測控系統(tǒng)、家用電器、現(xiàn)代農(nóng)業(yè)、嵌入式人工智能及物聯(lián)網(wǎng)應用等),這類應用也被稱為微控制器(MCU)領域; 另一類是計算機應用的延伸(如平板電腦、手機、電子圖書等),這類應用也被稱為應用處理器(MAP)領域。在ARM產(chǎn)品系列中,ARM CortexM系列與ARM CortexR系列適用于電子系統(tǒng)的智能化類應用,即微控制器領域; ARM CortexA系列適用于計算機應用的延伸,即應用處理器領域。不論如何分類,嵌入式系統(tǒng)的技術基礎是不變的,即要完成一個嵌入式系統(tǒng)產(chǎn)品的設計,需要有硬件、軟件及行業(yè)領域相關知識。但是,隨著嵌入式系統(tǒng)中軟件規(guī)模的日益增大,業(yè)界對嵌入式底層驅(qū)動軟件的封裝提出了更高的要求,因此嵌入式底層驅(qū)動軟件的可復用性與可移植性受到特別的關注,嵌入式軟硬件構(gòu)件化開發(fā)方法逐步被業(yè)界重視。
本書1~5版先后獲得蘇州大學精品教材、江蘇省高等學校重點教材、十一五十二五普通高等教育本科規(guī)劃教材、國家精品在線開放課程等。本版是在2019年出版的第5版基礎上重新撰寫的,樣本芯片使用意法半導體ARM CortexM4內(nèi)核的STM32L431微控制器。同時,在意法半導體、南京沁恒微電子及清華大學出版社的支持下,配備了可以直接實踐的硬件系統(tǒng),具備簡捷、便利、邊學邊實踐等優(yōu)點,克服了實驗箱模式的冗余、不方便帶出實驗室、不易升級等缺點,為探索嵌入式教學模式提供了一種新的嘗試。
書中以嵌入式硬件構(gòu)件及底層軟件構(gòu)件設計為主線,基于嵌入式軟件工程的思想,按照通用知識驅(qū)動構(gòu)件使用方法測試實例構(gòu)件制作過程的線條,逐步闡述電子系統(tǒng)智能化嵌入式應用的軟件與硬件設計。需要特別說明的是,雖然書籍撰寫與教學必須以某一特定芯片為藍本,但作為嵌入式技術基礎,本書試圖闡述嵌入式通用知識要素。因此,本書以知識要素為基本立足點設計芯片底層驅(qū)動,使得應用程序與芯片無關,具有通用嵌入式計算機(GEC)的性質(zhì)。書中將大部分驅(qū)動的使用方法提前闡述,而驅(qū)動構(gòu)件的設計方法后置,
目的是先學會使用構(gòu)件進行實際編程,后理解構(gòu)件的設計方法。因構(gòu)件設計方法部分有一定難度,對于不同要求的教學場景,也可不要求學生理解全部構(gòu)件的設計方法,講解一兩個即可。
本書具有以下特點。
(1) 把握通用知識與芯片相關知識之間的平衡。書中對于嵌入式通用知識的基本原理,以應用為立足點,進行語言簡潔、邏輯清晰的闡述,同時注意與芯片相關知識之間的銜接,使讀者在更好地理解基本原理的基礎上,學習芯片應用的設計,進而加深對通用知識的理解。
(2) 把握硬件與軟件的關系。嵌入式系統(tǒng)是軟件與硬件的綜合體,嵌入式系統(tǒng)設計是一個軟件、硬件協(xié)同設計的工程,不能像通用計算機那樣把軟件、硬件完全分開來看。特別是對電子系統(tǒng)智能化嵌入式應用來說,沒有對硬件的理解就不可能寫好嵌入式軟件,同樣沒有對軟件的理解也不可能設計好嵌入式硬件。因此,本書注重把握硬件知識與軟件知識之間的關系。
(3) 對底層驅(qū)動進行構(gòu)件化封裝。書中根據(jù)嵌入式軟件工程基本原則并按照構(gòu)件化封裝要求,給出每個模塊的底層驅(qū)動程序,同時給出詳細、規(guī)范的注釋及對外接口,為實際應用提供底層構(gòu)件,方便移植與復用,為讀者進行實際項目開發(fā)節(jié)省大量時間。
(4) 設計合理的測試用例。書中所有源程序均經(jīng)測試通過,并保留測試用例在本書的網(wǎng)上教學資源,避免了因例程的書寫或固有錯誤給讀者帶來煩惱。這些測試用例,也為讀者驗證與理解帶來方便。
(5) 網(wǎng)上教學資源提供了所有模塊完整的底層驅(qū)動構(gòu)件化封裝程序與測試用例,包括需要使用PC的程序測試用例,提供了PC的C#源程序、芯片資料、使用文檔、硬件說明等,還制作了課件及微課視頻,網(wǎng)上教學資源的版本將會適時更新。
本書由蘇州大學王宜懷教授擔任主編,李躍華、徐文彬、施連敏擔任副主編。蘇州大學嵌入式人工智能與物聯(lián)網(wǎng)實驗室的博士研究生、碩士研究生參與程序開發(fā)、書稿整理及有關資源建設,他們卓有成效的工作使得本書更加充實。ST 大學計劃的丁曉磊女士,ARM中國教育生態(tài)部的王夢馨女士、南京沁恒微電子的楊勇先生及劉帥先生等為本書提供了許多幫助。劉純平教授、趙雷教授、章曉芳副教授、劉曉升博士等老師參與本書撰寫的討論,提出了不少建設性建議,在此一并表示誠摯的感謝。
由于作者水平有限,書中難免存在不妥之處,懇望讀者提出寶貴意見和建議,以便再版時改進。
蘇州大學王宜懷
2021年6月
嵌入式技術基礎與實踐(第6版)(微課視頻版)
硬件資源及網(wǎng)上教學資源
硬件資源(AHLSTM32L431)
網(wǎng)上教學資源: AHLMCU6
文件夾內(nèi)容
01Information
內(nèi)核及芯片文檔
02Document
補充閱讀材料、硬件使用說明等
03Hardware
硬件文檔
04Software
CH01
硬件測試程序(含MCU方及PC方程序)
CH02
認識匯編語句生成的機器碼
CH04
直接地址方式干預發(fā)光二極管; 構(gòu)件方式干預發(fā)光二極管; 匯編編程方式干預發(fā)光二極管
CH06
直接地址方式串口發(fā)送數(shù)據(jù),構(gòu)件方式串口發(fā)送數(shù)據(jù),利用串口接收中斷進行數(shù)據(jù)接收
CH07
內(nèi)核SysTick定時器; 帶日歷功能實時時鐘RTC; Timer模塊基本定時器; 脈寬調(diào)制PWM、輸入捕捉、輸出比較; PC方配套測試程序
CH08
Flash、ADC、DAC; PC方配套測試程序
CH09
SPI、I2C、TSC; GPIO模擬TSC
CH10
CAN、DMA、位帶操作
CH11
系統(tǒng)時鐘程序的注解、看門狗、CRC
CH12\RTOS
實時操作系統(tǒng)的延時函數(shù)、事件、消息隊列、信號量、互斥量
CH12\EORS
嵌入式人工智能: 物體認知系統(tǒng)
CH12\NBIoT
窄帶物聯(lián)網(wǎng)NBIoT
CH12\IoT
物聯(lián)網(wǎng)的4G、Cat1、WiFi、WSN通信方式
05Tool
AHLSTM32L431板載TTLUSB芯片驅(qū)動程序
06Other
C#2019串口測試程序; C#快速應用指南下載導引
該網(wǎng)上教學資源適時更新,可通過百度搜索蘇州大學嵌入式學習社區(qū)官網(wǎng)金葫蘆專區(qū)嵌入式書6版下載; 也可通過清華大學出版社官網(wǎng)下載。
第1章概述
1.1初識嵌入式系統(tǒng)
1.1.1運行硬件系統(tǒng)
1.1.2實踐體系簡介
1.1.3編譯、下載與運行個嵌入式程序
1.2嵌入式系統(tǒng)的定義、發(fā)展簡史、分類及特點
1.2.1嵌入式系統(tǒng)的定義
1.2.2嵌入式系統(tǒng)的由來及發(fā)展簡史
1.2.3嵌入式系統(tǒng)的分類
1.2.4嵌入式系統(tǒng)的特點
1.3嵌入式系統(tǒng)的學習困惑、知識體系及學習建議
1.3.1嵌入式系統(tǒng)的學習困惑
1.3.2嵌入式系統(tǒng)的知識體系
1.3.3基礎階段的學習建議
1.4微控制器與應用處理器簡介
1.4.1MCU簡介
1.4.2以MCU為核心的嵌入式測控產(chǎn)品的基本組成
1.4.3MAP簡介
1.5嵌入式系統(tǒng)常用術語
1.5.1與硬件相關的術語
1.5.2與通信相關的術語
1.5.3與功能模塊相關的術語
本章小結(jié)
習題
第2章ARM CortexM4微處理器
2.1ARM CortexM4微處理器簡介
2.1.1ARM CortexM4微處理器內(nèi)部結(jié)構(gòu)概要
2.1.2ARM CortexM4微處理器的內(nèi)部寄存器
2.2尋址方式與機器碼獲取方法
嵌入式技術基礎與實踐(第6版)(微課視頻版)
2.2.1指令保留字簡表與尋址方式
2.2.2指令的機器碼
2.3基本指令分類解析
2.3.1數(shù)據(jù)傳送類指令
2.3.2數(shù)據(jù)操作類指令
2.3.3跳轉(zhuǎn)控制類指令
2.3.4其他指令
2.4匯編語言的基本語法
2.4.1匯編語言的格式
2.4.2常用偽指令簡介
本章小結(jié)
習題
第3章存儲器映像、中斷源與硬件小系統(tǒng)
3.1STM32L4系列MCU概述
3.1.1STM32L4系列MCU命名規(guī)則
3.1.2STM32L4存儲器映像
3.1.3STM32L4中斷源
3.2STM32L4芯片的引腳圖與硬件小系統(tǒng)
3.2.1STM32L4芯片的引腳圖
3.2.2STM32L4硬件小系統(tǒng)原理圖
3.3由MCU構(gòu)建通用嵌入式計算機
3.3.1嵌入式終端開發(fā)方式存在的問題與解決辦法
3.3.2提出GEC概念的時機、GEC定義與特點
3.3.3由STM32L431芯片構(gòu)成的GEC
本章小結(jié)
習題
第4章GPIO及程序框架
4.1GPIO通用基礎知識
4.1.1GPIO概念
4.1.2輸出引腳的基本接法
4.1.3上拉、下拉電阻與輸入引腳的基本接法
4.2軟件干預硬件的方法
4.2.1GPIO構(gòu)件API
4.2.2GPIO構(gòu)件的輸出測試方法
4.3認識工程框架
4.3.1工程框架及所含文件簡介
4.3.2了解機器碼文件及芯片執(zhí)行流程簡析
4.4GPIO構(gòu)件的制作過程
4.4.1端口與GPIO模塊
4.4.2GPIO基本編程步驟并點亮一盞小燈
4.4.3GPIO構(gòu)件的設計
4.5個匯編語言工程: 控制小燈閃爍
4.5.1匯編工程文件的組織
4.5.2匯編語言小燈測試工程主程序
4.6實驗一熟悉實驗開發(fā)環(huán)境及GPIO編程
本章小結(jié)
習題
第5章嵌入式硬件構(gòu)件與底層驅(qū)動構(gòu)件基本規(guī)范
5.1嵌入式硬件構(gòu)件
5.1.1嵌入式硬件構(gòu)件概念及其分類
5.1.2基于嵌入式硬件構(gòu)件的電路原理圖設計簡明規(guī)則
5.2嵌入式底層驅(qū)動構(gòu)件的概念與層次模型
5.2.1嵌入式底層驅(qū)動構(gòu)件的概念
5.2.2嵌入式硬件構(gòu)件與軟件構(gòu)件結(jié)合的層次模型
5.2.3嵌入式軟件構(gòu)件分類
5.3底層驅(qū)動構(gòu)件的封裝規(guī)范
5.3.1構(gòu)件設計的基本思想與基本原則
5.3.2編碼風格基本規(guī)范
5.3.3頭文件的設計規(guī)范
5.3.4源程序文件的設計規(guī)范
5.4硬件構(gòu)件及其驅(qū)動構(gòu)件的復用與移植方法
5.4.1硬件構(gòu)件的復用與移植
5.4.2驅(qū)動構(gòu)件的移植
本章小結(jié)
習題
第6章串行通信模塊及個中斷程序結(jié)構(gòu)
6.1異步串行通信的通用基礎知識
6.1.1串行通信的基本概念
6.1.2RS232和RS485總線標準
6.1.3TTLUSB串口
6.1.4串行通信編程模型
6.2基于構(gòu)件的串行通信編程方法
6.2.1STM32L431芯片UART對外引腳
6.2.2UART構(gòu)件API
6.2.3UART構(gòu)件API的發(fā)送測試方法
6.2.4printf函數(shù)的設置方法與使用
6.3UART構(gòu)件的制作過程
6.3.1UART寄存器概述
6.3.2利用直接地址操作的串口發(fā)送打通程序
6.3.3UART構(gòu)件設計
6.4中斷機制及中斷編程步驟
6.4.1關于中斷的通用基礎知識
6.4.2ARM CortexM4非內(nèi)核模塊中斷編程結(jié)構(gòu)
6.4.3STM32L431中斷編程步驟以串口接收中斷為例
6.5實驗二串口通信及中斷實驗
本章小結(jié)
習題
第7章定時器相關模塊
7.1定時器通用基礎知識
7.2STM32L431中的定時器
7.2.1ARM CortexM內(nèi)核定時器SysTick
7.2.2實時時鐘模塊
7.2.3Timer模塊的基本定時功能
7.3脈寬調(diào)制
7.3.1脈寬調(diào)制通用基礎知識
7.3.2基于構(gòu)件的PWM編程方法
7.3.3脈寬調(diào)制構(gòu)件的制作過程
7.4輸入捕捉與輸出比較
7.4.1輸入捕捉與輸出比較通用基礎知識
7.4.2基于構(gòu)件的輸入捕捉和輸出比較編程方法
7.4.3輸入捕捉和輸出比較構(gòu)件的制作過程
7.5實驗三定時器及PWM實驗
本章小結(jié)
習題
第8章Flash在線編程、ADC與DAC
8.1Flash在線編程
8.1.1Flash在線編程的通用基礎知識
8.1.2基于構(gòu)件的Flash在線編程方法
8.1.3Flash構(gòu)件的制作過程
8.2ADC
8.2.1ADC的通用基礎知識
8.2.2基于構(gòu)件的ADC編程方法
8.2.3ADC構(gòu)件的制作過程
8.3DAC
8.3.1DAC的通用基礎知識
8.3.2基于構(gòu)件的DAC編程方法
8.4實驗四ADC實驗
本章小結(jié)
習題
第9章SPI、I2C與TSC模塊
9.1串行外設接口SPI模塊
9.1.1串行外設接口SPI的通用基礎知識
9.1.2基于構(gòu)件的SPI通信編程方法
9.1.3SPI構(gòu)件的制作過程
9.2集成電路互聯(lián)總線模塊
9.2.1集成電路互聯(lián)總線的通用基礎知識
9.2.2基于構(gòu)件的I2C通信編程方法
9.2.3I2C構(gòu)件的制作過程
9.3觸摸感應控制器模塊
9.3.1觸摸感應控制器的基本原理
9.3.2基于構(gòu)件的TSC編程方法
9.3.3TSC構(gòu)件的制作過程
9.3.4模擬觸摸感應輸入功能
9.4實驗五SPI通信實驗
本章小結(jié)
習題
第10章CAN總線、DMA與位帶操作
10.1CAN總線
10.1.1CAN總線的通用基礎知識
10.1.2基于構(gòu)件的CAN編程方法
10.1.3CAN構(gòu)件的制作過程
10.2DMA
10.2.1DMA的通用基礎知識
10.2.2基于構(gòu)件的DMA編程方法
10.2.3DMA構(gòu)件的制作過程
10.3位帶操作
10.3.1位帶操作的基本含義
10.3.2使用位帶操作的緣由及編程方法
本章小結(jié)
習題
第11章系統(tǒng)時鐘與其他功能模塊
11.1時鐘系統(tǒng)
11.1.1時鐘系統(tǒng)概述
11.1.2時鐘模塊寄存器及編程實例
11.2復位模塊與看門狗模塊
11.2.1復位模塊
11.2.2看門狗
11.3電源控制模塊與CRC校驗模塊
11.3.1電源控制模塊
11.3.2校驗模塊
11.4實驗六綜合實驗
本章小結(jié)
習題
第12章應用案例
12.1嵌入式系統(tǒng)的穩(wěn)定性問題
12.2外接傳感器及執(zhí)行部件的編程方法
12.2.1開關量輸出類驅(qū)動構(gòu)件
12.2.2開關量輸入類驅(qū)動構(gòu)件
12.2.3聲音與加速度傳感器驅(qū)動構(gòu)件
12.3實時操作系統(tǒng)的簡明實例
12.3.1無操作系統(tǒng)與實時操作系統(tǒng)
12.3.2RTOS中的常用基本概念
12.3.3線程的三要素、4種狀態(tài)及3種基本形式
12.3.4RTOS下的編程實例
12.4嵌入式人工智能的簡明實例
12.4.1EORS簡介
12.4.2AHLEORS的數(shù)據(jù)采集與訓練過程
12.4.3在通用嵌入式計算機GEC上進行的推理過程
12.5NBIoT的應用簡介
12.5.1NBIoT應用架構(gòu)
12.5.2AHLNBIoT開發(fā)套件簡介
12.5.3NBIoT的數(shù)據(jù)傳輸
12.64G、Cat1、WiFi及WSN的應用
12.6.14G通信
12.6.2Cat1通信
12.6.3WiFi通信
12.6.4WSN
12.6.5WiFi 與WSN相結(jié)合系統(tǒng)
參考文獻