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

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

16、8-36 重點熟記各數(shù)字在ARK理器內部共有37個用戶可訪問的存放器,分別為31個通用32位存放器和6個狀態(tài) 存放器.AR祉理器共有7種不同的處理器模式, 每種模式都有一組相應的存放器組, 最多可 以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為未分組的通用存放器,它們在任何處理器模式都對應于相同的32位物理存放器.存放器R8R12有兩個分組的物理存放器.一個用于除FIQ模式之外的所有存放器模式,另一 個用于FIQ模式.在發(fā)生FIQ中斷后,處理器不必為保護存放器而浪費時間,從而加速了FIQ的處理速度.存放器R1& R14分別有6個分組的物理存放器.1個用于用戶和系統(tǒng)模式,其余 外分別 用于5種異常模式.存放器R13通常作為堆棧

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

19、在匯編語言中存放器 R0R7為通用存放器,對于任何處理器模 式,它們中的每一個都對應于相同的32為物理存放器.程序計數(shù)器P.;堆棧指針SP,堆棧指針SP寸應AR嗷態(tài)的存放器R13.每個異常模式都有其自身的 SP 分組版本,SP®常指向各異常模式所專用的堆棧. 注意:在發(fā)生異常時,處理器自動進入ARM 狀態(tài).鏈接存放器LR,鏈接存放器LRM應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:運算結果的第31位值,記錄標志設置操作的結果;零標志Z:如果標志設置的操作為 0,那么置位;進位標志C:記錄無符號加法溢出,減法無借位,循環(huán)移位;溢出標志V:記錄標志設置操作的有符號

21、溢出.中斷禁止限制位I和F:當限制位I置位時,IRQ中斷被禁止;當限制位F置位時,FIQ中斷被禁止.處理器狀態(tài)位T:當限制位T置位時,處理器正在Thumb犬態(tài)下運行;當限制位T清零時,處理器正在AR瞰態(tài)下運行.警告:絕對不要強制改變CPSfW存器中的限制位T.如果這樣做,處理器將進入一個無 法預測的狀態(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中,處理器將進入一個無法恢復的模式.保存位:CPS呻的保存位被保存將來使用. 當改變CPS標志和限制位時, 請確認沒有改變這 些保存位.另外,請保證您的程序不依賴于包含特定值的保存位,由于將來的處理器可能會將這些位設置為1或者0.9、AR咻系的異常、中斷及其向量表 P39 異常中斷的進入與退出是重中之重 當多個

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

25、CPSR清零在入口處置位的中斷禁止標志.10、ARM#系的存儲系統(tǒng)P48 了解“大端與“小端存儲器系統(tǒng)有兩種映射機制:小端存儲器系統(tǒng):在小端格式中,數(shù)據(jù)的高字節(jié)存放在高地址中.大端存儲器系統(tǒng):在大端格式中,數(shù)據(jù)的高字節(jié)存放在低地址中.存儲器格式O小瑞存儲 模扎下. 0x12345676 在A地址開始 的一個學空 問的存在'.火耕存儲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的值,結果保存到 R0立即尋址:立即尋址指令中的操作碼字段后面的地址碼局部即是操作數(shù)本身,也就是說,數(shù)據(jù)就包含在指令當中,取出指令也就取出了可以立即使用的操作數(shù)這樣的數(shù)稱為立即數(shù).立即尋址指令舉例如下:SUBS R0,R0,#1;R0 減1,結果放入 R0,并且影響標志位MOV R0,#0xFF000 ;將立即數(shù) 0XFF000裝入 R0W存器存放器移位尋址:存放器移位尋址是ARM旨令集特有的尋址方式.當?shù)?個操作數(shù)是存放器移 位方式時,第2個存放器操作數(shù)在與第1

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

28、放器的內容與指令中給出的偏移量相加,形成操作數(shù)的有效地址.基址尋址用于訪問基址附近的存儲單元,常用于查表、數(shù)組操作、 功能部件存放器訪問等.基址尋址指令舉例如下:LDR R2,R3,#0x0C;讀取R3+0X0CM址上的存儲單元;的內容,放入 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 一 .盡我棧底所以可以組合出四種類型的堆棧方式:滿遞增:堆棧向上增長,等;空遞增:堆棧向上增長,滿遞減:堆棧向下增長,等;空遞減:堆棧向下增長,堆棧指針指向內含有效數(shù)據(jù)項的最高地址.指令如堆棧指針指向堆棧上的第一個空位置.指令如 堆棧指針指向內含有效數(shù)據(jù)項的最低地址.指令如堆棧指針向堆棧下的第一個空位置.指令如LDMFA STMFALDMEA STME俸;LDMFD STMFDL

30、DMED STME弟.相對尋址:相對尋址是基址尋址的一種變通.由程序計數(shù)器?既供基準地址,指令中的地址碼字段作為偏移量,兩者相加后得到的地址即為操作數(shù)的有效地址.相對尋址指令舉例如下:BL SUBR1;調用至ij SUBR作程序BEQ LOOP;條件跳轉到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指令為簡單的跳轉指令,不附帶其它功能.跳轉范圍限制在當前指令的土32"節(jié)地址內ARM旨令為字對齊,最低2位地址固定為0.BL指令除了具有跳轉功能,還能在跳轉之前將下一條指令的地址拷貝到R1

33、4即LR鏈接存放器中,它適用于子程序調用.跳轉范圍限制在當前指令的土32M字節(jié)地址內.BX指令除了具有跳轉功能,還能在跳轉的同時切換處理器狀態(tài).其跳轉范圍不受限制.雜項指令:在ARM旨令集中雜項指令共有3條,它們非常重要,特別是與操作系統(tǒng)的使用息息相關:1. 軟件中斷產(chǎn)生指令:SWI,主要用于用戶程序調用操作系統(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í)行;分支指令的跳轉范圍有更多限制;數(shù)據(jù)處理指令的操作結果必須放入其中一個;單存放器訪問指令,只能操作 R0R7;LD睇日STM旨令可以對R0R7的任何子集進行操作;第四章 LPC2000系列ARMM件結構1、了解硬件結構P90芯片內部結構LPC2000S劃祗旋制崟包舍 4大局部:O艾垮仿真的ARM7TDMI-SCPU烏片內存儲舞限制思??诘腁RMF,導都總線中既限制器痍口的AMB A焉岐能總焦(AHB)逐琵冷內外設功能的VLSI 外叔總成.(VPB)2、 存儲器重映射的概念及其作用 P106給物理存儲器分配邏輯地址的過程稱為存儲器

36、映射.將已經(jīng)過映射的存儲器再次映射的過程稱為存儲器重映射,它使同一物理存儲單元出現(xiàn)多個不同的邏輯地址(增加了代碼的可移植性和可通用性).這些存儲單元主要包括引導塊“Boot Block 和用于保存異常向量表的少量存儲單元.弓I導塊(Boot Block )是芯片設計廠家在 LPC200曜列ARW部固化的一段代碼,用戶無 法修改或刪除.這段代碼在芯片復位后被首先運行,其功能主要是:判斷運行哪個存儲器上的程序;檢查用戶代碼是否有效;判斷芯片是否被加密;芯片的在應用編程(IAP)以及在系統(tǒng)編程功能(ISP)3、時鐘部件一一鎖相環(huán)PLL (可能考大題)P126LPC2000系列芯片內部均具有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設置舉例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增加了一個調制解調器Modem接口,其余 二者都是完全相同的:16字節(jié)接收FIFO和16字節(jié)發(fā)送FIFO;存放器位置符合16C550工業(yè)標準;接收FIFO觸發(fā)點可設置為1、4、8或14字節(jié);內置波特率發(fā)

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

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

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

溫馨提示

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

評論

0/150

提交評論