嵌入式系統(tǒng)復(fù)習終極版資料_第1頁
嵌入式系統(tǒng)復(fù)習終極版資料_第2頁
嵌入式系統(tǒng)復(fù)習終極版資料_第3頁
嵌入式系統(tǒng)復(fù)習終極版資料_第4頁
嵌入式系統(tǒng)復(fù)習終極版資料_第5頁
已閱讀5頁,還剩18頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、嵌入式系統(tǒng)復(fù)習重點一、題型填空題2'X10單項選擇題2'X 5名詞解釋 2' X 5簡做題5'X 6設(shè)計題 15' X 2二、考點第一章嵌入式系統(tǒng)概述1、 嵌入式系統(tǒng)從技術(shù)角度的定義及其特點見PPT第一章定義:以應(yīng)用為中央、以計算機技術(shù)為根底、軟件硬件可裁剪、適應(yīng)應(yīng)用系統(tǒng)對功能、 可靠性、本錢、體積、功耗嚴格要求的專用計算機系統(tǒng).特點:嵌入性、內(nèi)含計算機、專用性.2、嵌入式系統(tǒng)的未來P3產(chǎn)品市場窗口現(xiàn)在預(yù)計翻番的周期狂熱到69個月;全球重新定義市場的時機和膨脹的應(yīng)用空間;互聯(lián)現(xiàn)在是一個需求而不是輔助性的,包括用有線和剛剛顯露頭角的無線技術(shù);基于電子的產(chǎn)品

2、更復(fù)雜化;互聯(lián)嵌入式系統(tǒng)產(chǎn)生新的依賴網(wǎng)絡(luò)根底設(shè)施的應(yīng)用;微處理器的處理水平按莫爾定律 Moore' s L aw 預(yù)計的速度在增加.該定律認為集 成電路和晶體管個數(shù)每18個月翻一番.3、 什么是嵌入式處理器及嵌入式系統(tǒng)的分類 P5嵌入式處理器:為完成特殊應(yīng)用而設(shè)計的特殊目的的處理器.嵌入式系統(tǒng)可以分為以下幾大類:嵌入式微處理器EMPU嵌入式微限制器MCU嵌入式DSPb理器;嵌入式片上系統(tǒng)SOC4、嵌入式操作系統(tǒng)相關(guān)的根本概念 P7-10 可能考名詞解釋前后臺系統(tǒng):對基于芯片的開發(fā)來說,應(yīng)用程序一般是一個無限的循環(huán),可稱為前后臺系 統(tǒng)或超循環(huán)系統(tǒng).循環(huán)中調(diào)用相應(yīng)的函數(shù)完成相應(yīng)的操作,這局

3、部可以看成后臺行為,后臺也可以叫做任務(wù)級,這種系統(tǒng)在處理的及時性上比實際可以做到的要差.中斷效勞程序處理異步事件,這局部可以看成前臺行為,前臺也叫中斷級,時間相關(guān)性很強的關(guān)鍵操作一定是 靠中斷效勞程序來保證的.操作系統(tǒng):操作系統(tǒng)是計算機中最根本的程序.操作系統(tǒng)負責計算機系統(tǒng)中全部軟硬資源的分配與回收、限制與協(xié)調(diào)等并發(fā)的活動;操作系統(tǒng)提供用戶接口,使用戶獲得良好的工作環(huán)境;操作系統(tǒng)為用戶擴展新的系統(tǒng)功能提供軟件平臺.實時操作系統(tǒng):實時操作系統(tǒng)是一段在嵌入式系統(tǒng)啟動后首先執(zhí)行的背景程序,用戶的應(yīng)用程序是運行于 RTOE上的各個任務(wù),RTOS艮據(jù)各個任務(wù)的要求,進行資源 包括存儲器、 外設(shè)等治理、消

4、息治理、任務(wù)調(diào)度、異常處理等工作.在RTOS持的系統(tǒng)中,每個任務(wù)均有一個優(yōu)先級,RTOS根據(jù)各個任務(wù)的優(yōu)先級,動態(tài)地切換各個任務(wù),保證對實時性的要 求.代碼的臨界區(qū):也稱為臨界區(qū),指處理不可分割的代碼,運行這些代碼不允許被打斷.一旦 這局部代碼開始執(zhí)行, 那么不允許任何中斷打斷 這不是絕對的,如果中斷不調(diào)用任何包含臨 界區(qū)的代碼,也不訪問臨界區(qū)的使用的共享資源,這個中斷可以執(zhí)行.為保證臨界區(qū)代碼的執(zhí)行,在進入臨界區(qū)之前要關(guān)中斷,而臨界區(qū)代碼執(zhí)行完成以后要立即開中斷.資源:程序運行時可使用的軟、硬件環(huán)境統(tǒng)稱為資源.資源可以是輸入、輸出設(shè)備,例如打 印機、鍵盤、顯示器,也可以是一個變量、一個結(jié)構(gòu)或

5、一個數(shù)組等.共享資源:可以被一個以上任務(wù)使用的資源叫做共享資源.為了預(yù)防數(shù)據(jù)被破壞, 每個任務(wù)在與共享資源打交道時,必須獨占該資源,這叫做互斥.任務(wù):一個任務(wù)也叫做一個線程, 是一個簡單的程序, 該程序可以認為 CPlUc全屬于該程序 本身.實時應(yīng)用程序的設(shè)計過程, 包括如何把問題分割成多個任務(wù), 每個任務(wù)都是整個應(yīng)用 的某一局部,被賦予一定的優(yōu)先級,有它自己的一套CPl存放器和自己的??臻g.任務(wù)切換:當多任務(wù)內(nèi)核決定運行另外的任務(wù)時,保存正在運行任務(wù)的當前狀態(tài),即CPl存放器中的全部內(nèi)容. 這些內(nèi)容保存在當前狀態(tài)保存區(qū),也就是任務(wù)自己的棧區(qū)之中. 入棧工作完成以后,就把下一個將要運行的任務(wù)的

6、當前狀態(tài)從任務(wù)的棧中重新裝入CPU存放器,并開始下一個任務(wù)的運行,這個過程就叫任務(wù)的切換.這個過程增加了應(yīng)用程序的額外負擔,CPU的存放器越多,額外負擔就越重.做任務(wù)切換所需要的時間取決于CPUW多少存放器要入棧,實時內(nèi)核的性能不應(yīng)該以每秒鐘能做多少次任務(wù)切換來評價.內(nèi)核:多任務(wù)系統(tǒng)中,內(nèi)核負責治理各個任務(wù),或者說為每個任務(wù)分配CPU寸間,并且負責任務(wù)之間的通信.內(nèi)核提供的根本效勞是任務(wù)切換.使用實時內(nèi)核可以大大簡化應(yīng)用系統(tǒng)的設(shè)計,是由于實時內(nèi)核允許將應(yīng)用分成假設(shè)干個任務(wù),由實時內(nèi)核來治理它們. 內(nèi)核提供必不可少的系統(tǒng)效勞,如信號量、消息隊列、延時等.調(diào)度:調(diào)度是內(nèi)核的主要責任之一. 調(diào)度就是

7、決定該輪到哪個任務(wù)運行了. 多數(shù)實時內(nèi)核是 基于優(yōu)先級調(diào)度法的. 每個任務(wù)根據(jù)其重要程序的不同被賦予一定的優(yōu)先級.基于優(yōu)先級的調(diào)度法指CPU總是讓處在就緒態(tài)的優(yōu)先級最高的任務(wù)先運行. 然而究竟何時讓高優(yōu)先級任務(wù)掌握CPU的使用權(quán),有兩種不同的情況, 這要看用的是什么類型的內(nèi)核,是非占先式的還是占先式的內(nèi)核.非先占式內(nèi)核:非占先式內(nèi)核要求每個任務(wù)自我放棄CPU的所有權(quán).非占先式調(diào)度法也稱作合作型多任務(wù),各個任務(wù)彼此合作共享一個CPU異步事件還是由中斷效勞來處理.中斷效勞可以使一個高優(yōu)先級的任務(wù)由掛起狀態(tài)變?yōu)榫途w狀態(tài).但中斷效勞以后限制權(quán)還是回到原來被中斷了的那個任務(wù),直到該任務(wù)主動放棄 CPU的

8、使用權(quán)時,那個高優(yōu)先級的任務(wù)才能 獲得CPU的使用權(quán).先占式內(nèi)核:當系統(tǒng)響應(yīng)時間很重要時,要使用占先式內(nèi)核. 因此絕大多數(shù)商業(yè)上銷售的實時內(nèi)核都是占先式內(nèi)核.最高優(yōu)先級的任務(wù)一旦就緒,總能得到CPU的限制權(quán).當一個運行著的任務(wù)使一個比它優(yōu)先級高的任務(wù)進入了就緒狀態(tài),當前任務(wù)的CPUt用權(quán)就被剝奪了,或者說被掛起了,那個高優(yōu)先級的任務(wù)馬上得到了CPU的限制權(quán).如果是中斷效勞子程序使一個高優(yōu)先級的任務(wù)進入就緒態(tài),中斷完成時,中斷了的任務(wù)被掛起, 優(yōu)先級高的那個任務(wù)開始運行.任務(wù)優(yōu)先級:任務(wù)的優(yōu)先級是表示任務(wù)被調(diào)度的優(yōu)先程度.每個任務(wù)都具有優(yōu)先級.任務(wù)越重要,賦予的優(yōu)先級應(yīng)越高,越容易被調(diào)度而進入運

9、行態(tài).中斷:中斷是一種硬件機制,用于通知 cpiW個異步事件發(fā)生了.中斷一旦被識別,cpU存局部或全部上下文即局部或全部存放器的值,跳轉(zhuǎn)到專門的子程序,稱為中斷效勞子程序ISR.中斷效勞子程序做事件處理,處理完成后,程序回到:1. 在前后臺系統(tǒng)中,程序回到后臺程序;2. 對非占先式內(nèi)核而言,程序回到被中斷了的任務(wù);3. 對占先式內(nèi)核而言,讓進入就緒態(tài)的優(yōu)先級最高的任務(wù)開始運行.時鐘節(jié)拍:時鐘節(jié)拍是特定的周期性中斷.這個中斷可以看作是系統(tǒng)心臟的脈動.中斷之間的時間間隔取決于不同應(yīng)用,一般在10ms到200ms之間.時鐘的節(jié)拍式中斷使得內(nèi)核可以將任務(wù)延時假設(shè)干個整數(shù)時鐘節(jié)拍,以及當任務(wù)等待事件發(fā)生

10、時,提供等待超時的依據(jù). 時鐘節(jié)拍率越快,系統(tǒng)的額外開銷就越大.5、嵌入式實時操作系統(tǒng)的優(yōu)缺點及常見的嵌入式實時操作系統(tǒng)P11-14優(yōu)點:在嵌入式實時操作系統(tǒng)環(huán)境下開發(fā)實時應(yīng)用程序使程序的設(shè)計和擴展變得容易,不需要大的改動就可以增加新的功能.通過將應(yīng)用程序分割成假設(shè)干獨立的任務(wù)模塊,使應(yīng)用程序的設(shè)計過程大為簡化;而且對實時性要求苛刻的事件都得到了快速、 可靠的處理.通過有效 的系統(tǒng)效勞,嵌入式實時操作系統(tǒng)使得系統(tǒng)資源得到更好的利用.缺點:使用嵌入式實時操作系統(tǒng)還需要額外的ROM/RA研銷,25湖CPU額外負荷,以及內(nèi)核的費用.常見的嵌入式實時操作系統(tǒng):uClinux、Wndows CE、VxW

11、orks、C/OS-II第二章 ARM7體系結(jié)構(gòu)1、ARM勺體系結(jié)構(gòu)及常用的AR僦理器系列P16AR幃核采用RISC系結(jié)構(gòu).RISC是精簡指令集計算機的縮寫,其目標是設(shè)計出在高時鐘頻率下單周期執(zhí)行,簡單而有效的指令集.ARW核采用RIS酬系結(jié)構(gòu),因此具有RISC的結(jié)構(gòu)特點如具有大量的通用存 儲器;獨特的裝載/保存(load-store )結(jié)構(gòu);簡單的尋址模式;統(tǒng)一和固定長度的指令格式.常用的AR就理器系列:ARM淙列、ARM際列、ARM1源列、ARM11系列、Intel的XScale 系列和MPCore系列;還有針對低端 8位MC廊場推出的Cortex-M3系列,其具有32位CPU 性能、8位

12、CPU的價格.2、ARM7TDM®完整意思是什么?ARM7TDMO基于AR冊系結(jié)構(gòu)V4版本的低端AR蜓.其彌補了 ARM伊艮難在低于5V電壓 下穩(wěn)定工作的缺乏,還增加了后綴所對應(yīng)的功能:ARM7TDMI-SARM7TDMI 的可蟀合 fsynthesizableJ|版本,對危用工程處秉說其偏程摸型與ARM7TDM1 一故;支持EmbededlCE觀察硬件;更特64位乘豎;矣持片上調(diào)武;支特 高 密度16張的Thumb指冬推;3、存儲器的字與半字及對齊關(guān)系 P20從偶數(shù)地址開始的連續(xù)2個字節(jié)構(gòu)成一個半字;以能被 4整除的地址開始的連續(xù) 4個字節(jié) 構(gòu)成一個字;ARM旨令的長度剛好是一個字

13、,Thumbs令的長度剛好是一個半字. 如果一個數(shù)據(jù)是從偶地址開始的連續(xù)存儲, 那么它就是半字對齊, 否那么就是非半字對齊; 如 果一個數(shù)據(jù)是以能被4整除的地址開始的連續(xù)存儲, 那么它就是字對齊,否那么就是非字對齊.B式豐爭對齊壽對齊地波0x40020x40040x40040x4008BitO=OBitl=0.BitO=0 其也住為性惹值4、3級流水線P20(可能考大題) 級流水線結(jié)構(gòu)的指令執(zhí)行順序pc-a指令1指令2指令3指令4周期1同期2周周期4周期5周期6史理器說樗一務(wù)取指譯碼執(zhí)行攜令的三個階段 取指譯碼執(zhí)行取指譯碼執(zhí)行|取指譯碼I執(zhí)行I程序存儲器可參考第二章PPT23頁的思考題例子.5

14、、ARMfe理器的兩種狀態(tài)P24ARM7TDM&理器內(nèi)核包含2套指令系統(tǒng),分別為ARIW令集和Thum萌令,并且各自對應(yīng)1種處 理器的狀態(tài):AR瞰態(tài):32位,處理器執(zhí)行字方式的 ARMf令,處理器默認為此狀態(tài);Thum以犬態(tài):16位,處理器執(zhí)行半字方式的 Thumb旨令.注意:兩個狀態(tài)之間的切換并不影響處理器模式或存放器內(nèi)容.具體例子見書上P2砒序清單2.2 .6、ARMfe理器的7種處理模式P26 必考ARM體系結(jié)構(gòu)支持7種處理器模式,分別為:用戶模式、快中斷模式、中斷模式、治理 模式、中止模式、未定義模式和系統(tǒng)模式. 這樣的好處是可以更好的支持操作系統(tǒng)并提升工 作效率,ARM7TD

15、MK全支持這七種模式.處理器模式說明備注用戶usr正常程序運行的工作模式不能直接從用戶模式切換到其他模式特權(quán)模式系統(tǒng)sys用于支持操作系統(tǒng)的特權(quán)任務(wù)等與用戶模式類似,但具有直接切換到其他模式等特權(quán)異 常 模 式治理(svc)供操作系統(tǒng)使用的一種保護模式只有在系統(tǒng)復(fù)位和軟件中斷響應(yīng)時,才進入此模式中止abt用于虛擬內(nèi)存和或存儲器保護在ARM武核中沒有多大用處未正義und支持軟件仿真的硬件協(xié)處理器只有在未定義指令異常響應(yīng)時,才進入此模式中斷(irq )中斷請求處理只有在IRQ異常響應(yīng)時,才進入此模式快速中斷fiq 快速中斷請求處理只有在FIQ異常響應(yīng)時,才進入此模式7、ARM犬態(tài)下的內(nèi)部存放器P2

16、8-36 重點熟記各數(shù)字在ARK理器內(nèi)部共有37個用戶可訪問的存放器,分別為31個通用32位存放器和6個狀態(tài) 存放器.AR祉理器共有7種不同的處理器模式, 每種模式都有一組相應(yīng)的存放器組, 最多可 以18個活動的存放器.如下表所示:ARM狀態(tài)各模式下可以訪問的存放器類別希中的名琮mP背登中止:未定艾中斷快中嘶R0(a1)RDR1網(wǎng)R2a3JR2R3【邳R3R5(v2)存放甥存放器在王名模式下實際訪問的存放器RB(v5Ra_fiqR12_hqR9_fiqR10_fiq麗網(wǎng)R7(v4R13(SPJR13R13_svcR13_abtR13 undR13JrqR13_fiqR14 iR14_svcRH

17、JrqRHJkjR15R1G(5Lpv7)EH(FP 順 R12(IP)CP5RSPSRCP5RR 15( PCI哥存器SPSR_svc SPSR_abt SPSR_undSPSR ria存放器R0R7為未分組的通用存放器,它們在任何處理器模式都對應(yīng)于相同的32位物理存放器.存放器R8R12有兩個分組的物理存放器.一個用于除FIQ模式之外的所有存放器模式,另一 個用于FIQ模式.在發(fā)生FIQ中斷后,處理器不必為保護存放器而浪費時間,從而加速了FIQ的處理速度.存放器R1& R14分別有6個分組的物理存放器.1個用于用戶和系統(tǒng)模式,其余 外分別 用于5種異常模式.存放器R13通常作為堆棧

18、指針SD,用于保存待使用的存放器的內(nèi)容.存放器R14稱為鏈接存放器LR,在結(jié)構(gòu)上有兩個特殊功能: 當使用BL旨令調(diào)用子程序 時,返回地址將自動存入 R1.;當發(fā)生異常時,將R1取寸應(yīng)的異常模式版本設(shè)置為異常返回 地址有些異常有一個小的固定偏移量.存放器R15稱為程序計數(shù)器PQ,它指向正在“取指的指令.存放器CPS曲當前程序狀態(tài)存放器,在異常模式中,另外一個存放器“程序狀態(tài)保存寄 存器SPSR可以被訪問.每種異常都有自己的 SPSR在進入異常時它保存 CPSR勺當前值, 異常退出時可通過它恢復(fù) CPSRThum猷態(tài)存放器集是AR嗷態(tài)集的子集,程序員可以直接訪問的存放器為:8個通用存放器R0R7,

19、在匯編語言中存放器 R0R7為通用存放器,對于任何處理器模 式,它們中的每一個都對應(yīng)于相同的32為物理存放器.程序計數(shù)器P.;堆棧指針SP,堆棧指針SP寸應(yīng)AR嗷態(tài)的存放器R13.每個異常模式都有其自身的 SP 分組版本,SP®常指向各異常模式所專用的堆棧. 注意:在發(fā)生異常時,處理器自動進入ARM 狀態(tài).鏈接存放器LR,鏈接存放器LRM應(yīng)ARK態(tài)存放器R14.注意:在發(fā)生異常時,處理 器自動進入AR嗷態(tài).當前程序狀態(tài)存放器CPSRR.在兩種狀態(tài)中,存放器R0-R7是低端存放器,R8-R12是高端存放器,在Thum砒態(tài)中,高 端存放器的訪問是受到限制的,只有MOV CM和ADD旨令可

20、以對其訪問,可以用于數(shù)據(jù)的快速暫存.8、當前程序狀態(tài)存放器的用法 P36-39AR函核包含1個CPS前5個僅供異常處理程序使用的SPSR CPS阪映當前處理器的狀態(tài),其包含:4個條件代碼標志負標志N、零標志Z、進位標志胡日溢出標志V ;2個中斷禁止位IRQ禁止與FIQ禁止;5個對當前處理器模式進行編碼的位M4:0;1個用于指示當前執(zhí)行指令的位ARM旨令還是Thumb旨令.其格式如下:茶件代碼榕志保存限制住負標志N:運算結(jié)果的第31位值,記錄標志設(shè)置操作的結(jié)果;零標志Z:如果標志設(shè)置的操作為 0,那么置位;進位標志C:記錄無符號加法溢出,減法無借位,循環(huán)移位;溢出標志V:記錄標志設(shè)置操作的有符號

21、溢出.中斷禁止限制位I和F:當限制位I置位時,IRQ中斷被禁止;當限制位F置位時,FIQ中斷被禁止.處理器狀態(tài)位T:當限制位T置位時,處理器正在Thumb犬態(tài)下運行;當限制位T清零時,處理器正在AR瞰態(tài)下運行.警告:絕對不要強制改變CPSfW存器中的限制位T.如果這樣做,處理器將進入一個無 法預(yù)測的狀態(tài).處理器模式位MA M4AE式可見的可見的ARM狀者存放器1000G用戶R0-R7, SPr LR. PC, CPSRROR14rPC, CPSR10001快速中斷SP fiq.LR fig. PC, cpsr spsr naROR7. R8jtqRl4_fiq; PC.CPSR, SPSRJi

22、q1001.中斷ROR7, SPJrq; LR_irq. PChCPSR, SPSRJtqROR12, Rl3_irqr R14Jrq; FC, CPSR, SPSR_irq10011治理RdR乙 SP_SK. LR_S;'C. PC:CPSR, SPSR_svcR0R12, R13_S ;C; R14_svch PC, CPSR. SPSR_svc10111中止R(WR7, SP_abt. LR_abL PC, CPSR, SPSR.abtRCWR12, R13_abt, R14_abt FC, CPSR, SPSR_abt11011未定義R(WR7, SP_und LR_und.

23、PCr CPSR, SPSR_undRCWR12, R13,und. R14_und. PCh CPSR, SPSR_und11111 R(WR7, SP, LR一 PC, CPSRR(WR14rPC, CPSR注意:不是所有模式位的組合都定義了有效的處理器模式,如果將非法值寫入M4:0中,處理器將進入一個無法恢復(fù)的模式.保存位:CPS呻的保存位被保存將來使用. 當改變CPS標志和限制位時, 請確認沒有改變這 些保存位.另外,請保證您的程序不依賴于包含特定值的保存位,由于將來的處理器可能會將這些位設(shè)置為1或者0.9、AR咻系的異常、中斷及其向量表 P39 異常中斷的進入與退出是重中之重 當多個

24、異常同時發(fā)生時,一個固定的優(yōu)先級決定系統(tǒng)處理它們的順序:優(yōu)先級由高到低優(yōu)先級異常1復(fù)伺數(shù)據(jù)中止311FIQLk4IRQ5預(yù)取指中止6未定義指令中止6 L軟件中斷異常當一個異常導(dǎo)致模式切換時,內(nèi)核自動的做如下處理:即異常的進入將異常處理程序的返回地址加固定的偏移量保存到相應(yīng)異常模式下的LR;將CPSR勺當前值保存到相應(yīng)異常模式下的SPSR設(shè)置CPS的相應(yīng)的異常模式;設(shè)置PC相應(yīng)異常處理程序的中斷入口向量地址,跳轉(zhuǎn)到相應(yīng)的異常中斷處理程序執(zhí)行;當異常處理程序結(jié)束時,異常處理程序必須:即異常的退出返回到發(fā)生異常中斷的指令的下一條指令處執(zhí)行,即就是說將LR中的值減去偏移量后移入PC將SPSR勺值復(fù)制回

25、CPSR清零在入口處置位的中斷禁止標志.10、ARM#系的存儲系統(tǒng)P48 了解“大端與“小端存儲器系統(tǒng)有兩種映射機制:小端存儲器系統(tǒng):在小端格式中,數(shù)據(jù)的高字節(jié)存放在高地址中.大端存儲器系統(tǒng):在大端格式中,數(shù)據(jù)的高字節(jié)存放在低地址中.存儲器格式O小瑞存儲 模扎下. 0x12345676 在A地址開始 的一個學(xué)空 問的存在'.火耕存儲A+3模扎下A+2 0x12345678A*在A也址開始的一個字安間 A的存鈾:第三章 ARM7TDMI-S指令系統(tǒng)1、ARM#理器的8種尋址方式P52 可能考名詞解釋存放器尋址:操作數(shù)的值在存放器中,指令中的地址碼字段指出的是存放器編號,指令執(zhí) 行時直接取

26、出存放器值來操作.存放器尋址指令舉例如下:MOV R1,R2; 將R2勺值存入 R1SUB R0,R1,R2; 將R1的值減去 R2的值,結(jié)果保存到 R0立即尋址:立即尋址指令中的操作碼字段后面的地址碼局部即是操作數(shù)本身,也就是說,數(shù)據(jù)就包含在指令當中,取出指令也就取出了可以立即使用的操作數(shù)這樣的數(shù)稱為立即數(shù).立即尋址指令舉例如下:SUBS R0,R0,#1;R0 減1,結(jié)果放入 R0,并且影響標志位MOV R0,#0xFF000 ;將立即數(shù) 0XFF000裝入 R0W存器存放器移位尋址:存放器移位尋址是ARM旨令集特有的尋址方式.當?shù)?個操作數(shù)是存放器移 位方式時,第2個存放器操作數(shù)在與第1

27、個操作數(shù)結(jié)合之前, 選擇進行移位操作. 存放器移位 尋址指令舉例如下:MOV R0,R2,LSL #3;R2的值左移3位,結(jié)果放入 R0;即是R0=R 8ANDS R1,R1,R2,LSL R3 ;R2的值左移R3,然后和R1相;“與操作,結(jié)果放入 R1存放器間接尋址:存放器間接尋址指令中的地址碼給出的是一個通用存放器的編號,所需的操作數(shù)保存在存放器指定地址的存儲單元中,即存放器為操作數(shù)的地址指針. 存放器間接尋址指令舉例如下:LDR R1,R2;將R2旨向的存儲單元的數(shù)據(jù)讀出;保存在R1中SWP R1,R1,R2;將存放器R1的值和R2旨定的存儲;單元的內(nèi)容交換基址尋址:基址尋址就是將基址存

28、放器的內(nèi)容與指令中給出的偏移量相加,形成操作數(shù)的有效地址.基址尋址用于訪問基址附近的存儲單元,常用于查表、數(shù)組操作、 功能部件存放器訪問等.基址尋址指令舉例如下:LDR R2,R3,#0x0C;讀取R3+0X0CM址上的存儲單元;的內(nèi)容,放入 R2STR R1,R0,#-4!;先R0=R0-4,然后把R1的值存放;到保存到R0旨定的存儲單元多存放器尋址:多存放器尋址一次可傳送幾個存放器值,允許一條指令傳送16個存放器的任何子集或所有存放器.多存放器尋址指令舉例如下:LDMIA R1!,R2-R7,R12;將R1指向的單元中的數(shù)據(jù)讀出到;R2R7、R12中R1自動加1STMIA R0!,R2-R

29、7,R12;將存放器R2R7、R12的值保;存到R0旨向的存儲;單元中;R0自動加1堆棧尋址:堆棧指針指向最后壓入的堆棧的有效數(shù)據(jù)項,稱為滿堆棧;堆棧指針指向下一個待壓入數(shù)據(jù)的空位置,稱為空堆棧.0x12345678 一 .盡我棧底所以可以組合出四種類型的堆棧方式:滿遞增:堆棧向上增長,等;空遞增:堆棧向上增長,滿遞減:堆棧向下增長,等;空遞減:堆棧向下增長,堆棧指針指向內(nèi)含有效數(shù)據(jù)項的最高地址.指令如堆棧指針指向堆棧上的第一個空位置.指令如 堆棧指針指向內(nèi)含有效數(shù)據(jù)項的最低地址.指令如堆棧指針向堆棧下的第一個空位置.指令如LDMFA STMFALDMEA STME俸;LDMFD STMFDL

30、DMED STME弟.相對尋址:相對尋址是基址尋址的一種變通.由程序計數(shù)器?既供基準地址,指令中的地址碼字段作為偏移量,兩者相加后得到的地址即為操作數(shù)的有效地址.相對尋址指令舉例如下:BL SUBR1;調(diào)用至ij SUBR作程序BEQ LOOP;條件跳轉(zhuǎn)到LOO標號處LOOP MOV R6,#1SUBR12、ARM旨令集中各典型指令的用途P58 小例子:可能考選擇或填空思考與練習.1 .以下8位圖立即教是否合埃?0X0103C000 Xr0x12800000可以由0x4A循球主祥10伐捋利2 ,靖列舉2個8位圖立即數(shù)?0X4000003B fOxEDZ宣望不右移2伐OxOOIGCOOO rOx

31、$B循玨右移 18住加載指令:LDR/ST -一加載/存儲指令LDM/ST冊一多存放器加載/存儲指令SWP一存放器和存儲器交換指令數(shù)據(jù)處理指令:見書上P70-71 乘法指令: ARNI指令集乘法指令助ie符說明操作條ft碼位置MUL Rd Rm.Rs32位乘沌才冷Rd-Rn*Rs (RdRm)1WL cond SMLA Rd Rm Rs Rn3捻剜時盼Ed<-RB*Rs+Rn (RdRm)mUcon日格UXfULL RdLoRdHIRm:史64位無符號乘法指令(RdLa, RdHi) <-Rm*RsUIULL cond SUXfLAL RdLo;RdHi:Rm:Rs艦位無符號乘加指

32、令(RdLEdHp£RiuRs+(R 此RdHi)SIL AL cand SjSMITLL RdLodHi.Rm.RiS4位有符號乘法指令(RdLo, RdHi)Rm*KsSKILL cond ISSMLAL RdLo;RdHi;Rm:Rs翩位有符號乘加指令.(KdLoRdHijeftntRs+tR dLo,RdHi)SMLALcond S3、AR而支指令和雜項指令P72-77分支指令:B指令為簡單的跳轉(zhuǎn)指令,不附帶其它功能.跳轉(zhuǎn)范圍限制在當前指令的土32"節(jié)地址內(nèi)ARM旨令為字對齊,最低2位地址固定為0.BL指令除了具有跳轉(zhuǎn)功能,還能在跳轉(zhuǎn)之前將下一條指令的地址拷貝到R1

33、4即LR鏈接存放器中,它適用于子程序調(diào)用.跳轉(zhuǎn)范圍限制在當前指令的土32M字節(jié)地址內(nèi).BX指令除了具有跳轉(zhuǎn)功能,還能在跳轉(zhuǎn)的同時切換處理器狀態(tài).其跳轉(zhuǎn)范圍不受限制.雜項指令:在ARM旨令集中雜項指令共有3條,它們非常重要,特別是與操作系統(tǒng)的使用息息相關(guān):1. 軟件中斷產(chǎn)生指令:SWI,主要用于用戶程序調(diào)用操作系統(tǒng)的系統(tǒng)效勞.2. 程序狀態(tài)存放器讀指令:MRS對狀態(tài)存放器CPSR日SPSRJ行讀操作.3. 程序狀態(tài)存放器寫指令:MSR對狀態(tài)存放器CPSR日SPSRJ行寫操作.4、AR佩指令P78ARM/指令有四條:1. 小范圍地址讀取指令: ADR,將基于PCW對偏移的地址值或基于存放器相對偏移

34、的地 址值讀取到存放器中.2. 中等范圍地址讀取指令:ADRL,將基于PCW對偏移的地址值或基于存放器相對偏移的 地址值讀取到存放器中,比 ADRJ指令可以讀取更大范圍的地址.3. 大等范圍地址讀取指令:LDR,用于加載32位的立即數(shù)或一個地址值到指定存放器.4. 空操作指令:NP,在匯編時將會被代替成 AR"的空操作,比方可能是“MOV R0,R0 指令等.NOPT用于延時操作.5、ARM旨令集和Thumb®令集的異同 同:Thumb旨令的格式與使用方式與 ARMH令集類似,它也具有以下種類的指令:存儲器訪問指令數(shù)據(jù)處理指令分支指令雜項指令偽指令異:Thumb旨令集較AR

35、M!令集有如下限制:只有B旨令可以條件執(zhí)行,其它指令都不能條件執(zhí)行;分支指令的跳轉(zhuǎn)范圍有更多限制;數(shù)據(jù)處理指令的操作結(jié)果必須放入其中一個;單存放器訪問指令,只能操作 R0R7;LD睇日STM旨令可以對R0R7的任何子集進行操作;第四章 LPC2000系列ARMM件結(jié)構(gòu)1、了解硬件結(jié)構(gòu)P90芯片內(nèi)部結(jié)構(gòu)LPC2000S劃祗旋制崟包舍 4大局部:O艾垮仿真的ARM7TDMI-SCPU烏片內(nèi)存儲舞限制思埃口的ARMF,導(dǎo)都總線中既限制器痍口的AMB A焉岐能總焦(AHB)逐琵冷內(nèi)外設(shè)功能的VLSI 外叔總成.(VPB)2、 存儲器重映射的概念及其作用 P106給物理存儲器分配邏輯地址的過程稱為存儲器

36、映射.將已經(jīng)過映射的存儲器再次映射的過程稱為存儲器重映射,它使同一物理存儲單元出現(xiàn)多個不同的邏輯地址(增加了代碼的可移植性和可通用性).這些存儲單元主要包括引導(dǎo)塊“Boot Block 和用于保存異常向量表的少量存儲單元.弓I導(dǎo)塊(Boot Block )是芯片設(shè)計廠家在 LPC200曜列ARW部固化的一段代碼,用戶無 法修改或刪除.這段代碼在芯片復(fù)位后被首先運行,其功能主要是:判斷運行哪個存儲器上的程序;檢查用戶代碼是否有效;判斷芯片是否被加密;芯片的在應(yīng)用編程(IAP)以及在系統(tǒng)編程功能(ISP)3、時鐘部件一一鎖相環(huán)PLL (可能考大題)P126LPC2000系列芯片內(nèi)部均具有PLL電路

37、,娠蕩寇產(chǎn)生的時鐘Fosc通過PLL升瀕,可以獲得更高的條統(tǒng)時鐘CCLKPCLK(Fcclk)PLL頻率計算:可以得出以下幾個等式:Fosc = Fcco/(2x px M) a Fcco = Fosc x (2 x px M)Fcclk = Fcco/(2 x p) a Fcco = Fcclk x (2 x p)最后得出PLL的輸出頻率(當PLL激活并連接時)為:Fcclk = M x Fosc 或 Fcclk = Fcco / (2 x P)CC函出頻率為:Fcco = Fcclk x 2 x P 或 Fcco = Fosc x MX 2 x PPL成置舉例:系統(tǒng)要求 Fosc= 10M

38、Hz Fcclk = 60MHz根據(jù)這些要求:確定 Fcclk = 60MHz;選擇 Fosc = 10MHz計算 M= Fcclk/Fosc = 60MHz/10MH卒 6.M-1 = 5,所以寫入 PLLCFG4:0 = 00101;計算 P=Fcco/( Fcclk*2),其中 Fcco為 156320 MHz 當 Fcco= 156MHz寸,P=156MHz/(2*60MHz) =1.3 當 Fcco = 320MHz寸,P=2.67 P取整數(shù)2,所以寫入PLLCFG6:5=01. PLL設(shè)置舉例uint8 PLLSet(uint32 Fcclk.uint32Fo9C. uint32F

39、cco) uint 町ulnt32glldati = (Fccd f Fcclk):swltcnti)case 2:刨域=(盡妙既照-1)I卬"歟break;case 4:break:C3iS 8蜒=(E 見知 f M2break;case 1 &:plldat=(Fcdk/ Fosc) -1)|3 « 5);break;defaultreturn(FALSE): break:PLLCON = 1:PLLCFG =plldat:PLLFEED = Oxaa.PLLFEED = 0x55:whlle(PLLSIAT&(1 « 1.)= 0);PLLC

40、ON = 3:PLLFEED = Oxaa;PLLFEED = 0x55:retum(TRUE):PLL配置過程】4、外部存儲器限制器EMCX引腳連接模塊P152-1785、GPIO P1796、向量中斷限制器P1887、定時器0和定時器1的作用P2228、I 2 C接口的操作模式 P2719、UARTCft UART1 勺用法和區(qū)別P276UART0只提供TXD和RXD言號引腳,而 UART1增加了一個調(diào)制解調(diào)器Modem接口,其余 二者都是完全相同的:16字節(jié)接收FIFO和16字節(jié)發(fā)送FIFO;存放器位置符合16C550工業(yè)標準;接收FIFO觸發(fā)點可設(shè)置為1、4、8或14字節(jié);內(nèi)置波特率發(fā)

41、生器;UART官有標準調(diào)制解調(diào)器接口信號.10、A/D轉(zhuǎn)換器、脈寬調(diào)制器PWM日實時時鐘RTC第六章 pC/OS-II程序設(shè)計根底1、任務(wù)的分類、劃分和優(yōu)先級安排 P395按執(zhí)行方式可將任務(wù)分類以下三類:任務(wù)的分類void MyTaskvoid *pdata三務(wù)實體代碼;調(diào)用任務(wù)刪除函數(shù);1. 單次尬符類任務(wù)/ 單次執(zhí)每奕任務(wù)創(chuàng)a、 廠、,陳J一4定義和初始化變量及硬件設(shè)備、完成該任務(wù)的具體皂能 將自己摒蛛,操作系統(tǒng)將不再承閔任務(wù)的分類2. 周期執(zhí)行類任務(wù)任密備卷局void MyTask(voiid *pdata) 二三自任工:攔:王;while (1) 件務(wù)突仔弋駕;.調(diào)用系統(tǒng)延時函數(shù):)任

42、務(wù)的分類3.事件觸發(fā)執(zhí)符類任務(wù)運行狀態(tài)void MyTask (void *pdata)消息就緒狀態(tài)運行狀態(tài)任務(wù)優(yōu)先級足夠高進行準備工作的代碼;while (1)(謂用表氧事件的函數(shù): 任務(wù)實體代碼;等侍信號量或消息 完成具體易能任務(wù)的劃分:目標1. 首要目標是滿足“實時性指標:即使在最壞的情況下,系統(tǒng)中所有對實時性有要求的功能都能夠正常實現(xiàn);2. 任務(wù)數(shù)目合理:對于同一個應(yīng)用系統(tǒng), 合理的合并一些任務(wù), 使任務(wù)數(shù)目適當少一些還是 比擬有利;3. 簡化軟件系統(tǒng):一個任務(wù)要實現(xiàn)其功能,除了需要操作系統(tǒng)的調(diào)度功能支持外, 還需要操 作系統(tǒng)的其它效勞功能支持,合理劃分任務(wù),可以減少對操作系統(tǒng)的效勞要

43、求, 簡化軟件系 統(tǒng);4. 降低資源需求:合理劃分任務(wù),減少或簡化任務(wù)之間的同步和通信需求,就可以減少相應(yīng) 數(shù)據(jù)結(jié)構(gòu)的內(nèi)存規(guī)模,從而降低對系統(tǒng)資源的需求.任務(wù)的優(yōu)先級的安排原那么中斷關(guān)聯(lián)性:與中斷效勞程序ISR有關(guān)聯(lián)的任務(wù)應(yīng)該安排盡可能高的優(yōu)先級,以便及時處理異步事件,提升系統(tǒng)的實時性.如果優(yōu)先級安排得比擬低,CPIW可能被優(yōu)先級比擬高的任務(wù)長期占用,以致于在第二次中斷發(fā)生時連第一次中斷還沒有處理,產(chǎn)生信號喪失現(xiàn)象;緊迫性:由于緊迫任務(wù)對響應(yīng)時間有嚴格要求,在所有緊迫任務(wù)中,按響應(yīng)時間要求排序, 越緊迫的任務(wù)安排的優(yōu)先級越高.緊迫任務(wù)通常與ISR關(guān)聯(lián);關(guān)鍵性:任務(wù)越關(guān)鍵安排的優(yōu)先級越高,以保證其執(zhí)行時機;頻繁性:對于周期性任務(wù),執(zhí)行越頻繁,那么周期越短,允許耽誤的時間也越短,故應(yīng)該安排 的優(yōu)先級也越高,以保證及時得到執(zhí)行;快捷性:在前面各項條件相近時,越快捷耗時短的任務(wù)安排的優(yōu)先級越高,以使其它就 緒任務(wù)的延時縮短

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論