版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1ARM處理器綜述、開發(fā)及仿真(二)嵌入式電子系統(tǒng)學(xué)術(shù)沙龍內(nèi)容提要1.本次課目標(biāo)內(nèi)核分類程序設(shè)計(jì)基礎(chǔ)4.RealViewMDK簡介系列ARM芯片GPIO簡介6.RealViewMDK開發(fā)流程7.其他常見ARM開發(fā)環(huán)境及工具8.小結(jié)21.本次課目標(biāo)了解ARM內(nèi)核分類、ARM開發(fā)流程及開發(fā)環(huán)境基礎(chǔ)知識(shí)。3學(xué)術(shù)沙龍內(nèi)容提要1.本次課目標(biāo)內(nèi)核分類程序設(shè)計(jì)基礎(chǔ)4.RealViewMDK簡介系列ARM芯片GPIO簡介6.RealViewMDK開發(fā)流程7.其他常見ARM開發(fā)環(huán)境及工具8.小結(jié)42.
ARM內(nèi)核分類2.1ARM內(nèi)核的發(fā)展2.2ARM72.3ARM92.4ARM102.5ARM1152.1ARM內(nèi)核的發(fā)展6性能ARM處理器的性能及工作速度發(fā)展概況72.2ARM7
ARM7處理器核采用了3級流水線結(jié)構(gòu),指令執(zhí)行分為取指、譯碼和執(zhí)行等3個(gè)階段。8ARM7TDMI
ARM7TDMI-S
ARM7EJARM720TARM7核ARMv4TThumb指令集嵌入式ICE-RTETM7接口ARM7核ARMv4TThumb指令集嵌入式ICE-RTETM7接口ARM7核ARMv5TEJThumb指令集嵌入式ICE-RTETM9接口Jazelle擴(kuò)充DSP擴(kuò)充ARM7核ARMv4TThumb指令集嵌入式ICE-RTETM7接口MMU8KBCacheAHB接口T具有16位壓縮指令集Thumb。在ARMv4中采用Thumbv1版,在ARMv5中采用Thumbv2版;D支持在片上調(diào)試(OnChipDebug);M增強(qiáng)型乘法器,可以執(zhí)行32bit×32bit得到64bit乘積的乘法運(yùn)算和32bit×32bit+64bit得到64bit結(jié)果的累加乘運(yùn)算;S可綜合的(Synthesizable)核;10
I嵌入式ICE(InCircuitEmulating)硬件邏輯,支持嵌入式軟件調(diào)試時(shí)的軟硬件斷點(diǎn)的設(shè)置;E增強(qiáng)型DSP指令。在這類處理器的指令集中,擴(kuò)展了典型的數(shù)字信號處理所需的DSP指令;JJazeller功能,增強(qiáng)了執(zhí)行Java代碼的功能。11片上調(diào)試片上調(diào)試,又稱為OCD,是CPU芯片提供的程序調(diào)試功能,該方式的主要優(yōu)點(diǎn)是不占用目標(biāo)機(jī)的資源,調(diào)試環(huán)境和最終程序運(yùn)行環(huán)境基本一致,支持軟硬件斷點(diǎn)和跟蹤。目前常用的OCD有BDM(BackgroundDebuggingMode)方式,JTAG(JointTeseActionGroup)方式和OnCE(OnChipEmuiation,其實(shí)質(zhì)是BDM和JTAG的一種融合方式),其中JTAG是主流的OCD方式,ARM、MIPS和PowerPC等嵌入式處理器都采用不同種類的增強(qiáng)JTAG方式。12 ARM720T是將ARM7TDMI與8KB混合數(shù)據(jù)指令Cache、寫緩沖器和存儲(chǔ)器管理單元MMU(MemoryManagementUnit)集成在一個(gè)單片上的32位通用處理器。13
ARM7T和ARM7EFamilyUnifiedCache內(nèi)存管理流水線級別ThumbDSPJazelleARM7TDMI無無3有無無ARM7TDMI-S無無3有無無ARM710T/720T8kMMU3有無無ARM740T8k或4kProtectionUnit3有無無ARM7EJ-S無無3有有有2.3ARM9
ARM9內(nèi)核采用了五級流水線、提供的哈佛結(jié)構(gòu)、全性能的MMU單元、可配置的數(shù)據(jù)Cache和可分立和指令和數(shù)據(jù)高速AHB接口。1617五級流水線 ARM920T處理器使用流水線來增加處理器指令流的速度。這樣可以使幾個(gè)操作同時(shí)進(jìn)行,并使處理和存儲(chǔ)器系統(tǒng)連續(xù)操作,能提供的指令執(zhí)行速度。流水線使用5個(gè)階段,因此指令分5個(gè)階段執(zhí)行:取址→譯碼→執(zhí)行→存儲(chǔ)→寫。1819下一個(gè)pc指令Cache+4指令譯碼寄存器堆乘+1ALUMUX字節(jié)復(fù)制數(shù)據(jù)Cache移位/符號擴(kuò)展寄存器寫移位pc+4pc+8后變址前變址Load/Store取指譯碼寄存器移位執(zhí)行緩沖數(shù)據(jù)回寫ARM9FamilyCache內(nèi)存管理流水線級別ThumbDSPJazelleARM9TDMI無無5有無無ARM920T16K/16kMMU5有無無ARM922T8k/8kMMU5有無無ARM940T4k/4kProtectionUnit5有無無 ARM10處理器核采用哈佛結(jié)構(gòu)和六級流水線,處理器核內(nèi)部數(shù)據(jù)總線為64位,以及雙64位的AHB總線接口、并行的Load/Store單元,極大地提高了ARM10數(shù)據(jù)處理能力和工作速度。ARM10的指令執(zhí)行速度為。21ARM10Family22Cache內(nèi)存管理流水線級別ThumbDSPJazelleARM10E無無6有有無ARM1020E32k/32kMMU6有有無ARM1022E16k/16kMMU6有有無ARM10EJ-S無無6有有有ARM1026EJ-S0,4-128k/0,4-128kMMU6有有有ARM10TDMI無無6有無無ARM1020T32k/32kMMU6有無無
ARM11系列采用8級流水線操作,個(gè)別處理器采用9級流水線(例如ARM1156T2(F)-S),Load-Store單元和算術(shù)運(yùn)算單元分別具有獨(dú)立的流水線,并具有轉(zhuǎn)移預(yù)測和前向數(shù)據(jù)通道,可以有效地提高流水線操作的效率。23ARM11支持多處理器系統(tǒng),個(gè)別產(chǎn)品還集成了浮點(diǎn)處理器(以后綴F表示)。ARM11系列包括ARM1136J(F)-S、ARM1156T2(F)-S和ARM1176JZ(F)-S。后綴T2表示Thumb-2指令集。24ARM11Family25Cache內(nèi)存管理流水線級別ThumbDSPJazelle浮點(diǎn)運(yùn)算ARM1136J-S4-64kMMU8有有有無ARM1136JF-S4-64kMMU8有有有有ARM1156T2-S可配置9Thumb-2有無無ARM1156T2F-S可配置9Thumb-2有無有學(xué)術(shù)沙龍內(nèi)容提要1.本次課目標(biāo)2.
ARM內(nèi)核分類3.ARM程序設(shè)計(jì)基礎(chǔ)4.RealViewMDK簡介系列ARM芯片GPIO簡介6.RealViewMDK開發(fā)流程7.其他常見ARM開發(fā)環(huán)境及工具8.小結(jié)263.ARM程序設(shè)計(jì)基礎(chǔ)ARM體系結(jié)構(gòu)支持C/C++及其與匯編語言的混合編程。初始化部分用匯編語言完成;主要編程任務(wù)一般用C/C++完成。程序執(zhí)行時(shí)首先完成初始化過程再跳轉(zhuǎn)到C/C++程序代碼中兩者一般沒有參數(shù)的傳遞,也沒有頻繁的相互調(diào)用27系統(tǒng)的初始化過程定義程序入口點(diǎn)設(shè)置異常向量初始化存儲(chǔ)器系統(tǒng)初始化堆棧指針寄存器28初始化臨界IO設(shè)備初始化C代碼的運(yùn)行環(huán)境改變處理器的運(yùn)行模式和狀態(tài)使能中斷進(jìn)入C代碼運(yùn)行29系統(tǒng)的初始化過程基于ARM微處理器的系統(tǒng)一般比較復(fù)雜,多數(shù)硬件模塊是可以配置的(Configurable),需要明確設(shè)置為特定的工作狀態(tài)。在用戶主程序運(yùn)行之前,需要一段專門的代碼來完成對系統(tǒng)的初始化工作,這段代碼一般稱為Bootloader。30初始化代碼直接對ARM微處理器內(nèi)核及硬件控制器編程,多采用匯編語言,初始化代碼一般包含如下典型任務(wù):定義程序入口點(diǎn)設(shè)置異常向量31初始化存儲(chǔ)器系統(tǒng)初始化堆棧指針寄存器初始化臨界IO設(shè)備初始化C代碼的運(yùn)行環(huán)境改變處理器的運(yùn)行模式和狀態(tài)使能中斷進(jìn)入C代碼運(yùn)行32定義程序入口點(diǎn)初始化代碼必須定義整個(gè)程序的入口點(diǎn)(EntryPoint)采用匯編偽指令Entry指定33設(shè)置異常向量ARM微處理器架構(gòu)要求異常向量表必須位于從0X0地址開始的連續(xù)32(8×4)個(gè)字節(jié)的空間內(nèi)。34異常向量表35地址異常類型進(jìn)入時(shí)的模式進(jìn)入時(shí)I的狀態(tài)進(jìn)入時(shí)F的狀態(tài)0x00000000復(fù)位管理禁止禁止0x00000004未定義指令未定義IF0x00000008軟件中斷管理禁止F0x0000000C中止(預(yù)?。┲兄笽F0x00000010中止(數(shù)據(jù))中止IF0x00000014保留保留——0x00000018IRQ中斷禁止F0x0000001CFIQ快中斷禁止禁止注:表中的I和F表示不對該位有影響,保留原來的值
當(dāng)一個(gè)異常發(fā)生時(shí),ARM微處理器強(qiáng)制把PC指針置為異常向量表中相應(yīng)的位置。異常向量表中每個(gè)異常只占用一個(gè)字的存儲(chǔ)空間,剛好放一條ARM指令,這條指令通常是跳轉(zhuǎn)指令,使程序從異常向量表中跳轉(zhuǎn)到真正的異常處理程序。36AREAInit,CODE,READONLYENTRYBReset_HandlerBUndef_HandlerBSWI_HandlerBPreAbort_HandlerBDataAbort_HandlerB.BIRQ_HandlerBFIQ_HandlerReset_Handler …37初始化存儲(chǔ)器系統(tǒng)初始化存儲(chǔ)器系統(tǒng)主要包括對系統(tǒng)存儲(chǔ)控制器的初始化MMU初始化ARM微處理器的理論尋址能力位4GB,一般需要外接大容量存儲(chǔ)器,需要采用專門的存儲(chǔ)控制器來控制其讀寫操作。38存儲(chǔ)器控制器不是ARM微處理器架構(gòu)的一部分,不同的ARM芯片其設(shè)計(jì)各不相同,初始化代碼也存在差異。但一般都包含兩個(gè)方面:存儲(chǔ)器類型時(shí)序的配置基于ARM的微處理器系統(tǒng)常采用的存儲(chǔ)器FlashSRAMDRAM39Flash、SRAM均為靜態(tài)存儲(chǔ)器,可以共用存儲(chǔ)器控制器端口;DRAM需要?jiǎng)討B(tài)刷新、地址復(fù)用等,需要專門的存儲(chǔ)器控制器端口。(某些ARM芯片內(nèi)部沒有DRAM控制邏輯,不能直接與DRAM接口,如AT9140800系列);一般采用片內(nèi)特殊功能寄存器控制。40存儲(chǔ)器的地址分配地址分配:將物理存儲(chǔ)器定位在4GB尋址空間的哪個(gè)具體位置;ARM微處理器系統(tǒng)采用兩種方式來完成地址分配:固定方式,如S3C2410,相對簡單;重映射(Remap),物理存儲(chǔ)器的地址不固定,如S3C4510B,較復(fù)雜。41重映射(Remap)
系統(tǒng)復(fù)位后,PC指針初始化為0x0,因此要求Flash(或其他類型ROM)起始地址為0x0,但由于Flash的訪問速度大大低于RAM,每次產(chǎn)生異常后,都要從Flash的異常向量表跳轉(zhuǎn)到響應(yīng)的處理程序,會(huì)影響異常的響應(yīng)速度,因此,系統(tǒng)采用重映射方法,在系統(tǒng)完成初始化后,將RAM地址置為0x0,而將ROM置為其他地址。42初始化堆棧指針寄存器由于ARM微處理器支持7種處理器模式,每種模式下的堆棧指針寄存器都是獨(dú)立的(System和User模式使用同一個(gè)SP),根據(jù)系統(tǒng)使用的中斷和異常的情況,需要初始化需要的堆棧指針寄存器SP。由于上電復(fù)位后,系統(tǒng)進(jìn)入管理模式,因此管理模式下的SP必須初始化。4344寄存器類別寄存器在匯編中的名稱各模式下實(shí)際訪問的寄存器用戶系統(tǒng)管理中止未定義中斷快中斷通用寄存器和程序計(jì)數(shù)器R0(a1)R0R1(a2)R1R2(a3)R2R3(a4)R3R4(v1)R4R5(v2)R5R6(v3)R6R7(v4)R7R8(v5)R8R8_fiqR9(SB,v6)R9R9_fiqR10(SL,v7)R10R10_fiqR11(FP,v8)R11R11_fiqR12(IP)R12R12_fiqR13(SP)R13R13_svcR13_abtR13_undR13_irqR13_fiqR14(LR)R14R14_svcR14_abtR14_undR14_irqR14_fiqR15(PC)R15狀態(tài)寄存器CPSRCPSRSPSR無SPSR_abtSPSR_abtSPSR_undSPSR_irqSPSR_fiq無CPSRR15R14R13R12R11R10R9R8R7R6R5R4R3R2R1R0用戶無CPSRR15R14R13R12R11R10R9R8R7R6R5R4R3R2R1R0系統(tǒng)SPSR_abtCPSRR15R14_svcR13_svcR12R11R10R9R8R7R6R5R4R3R2R1R0管理SPSR_abtCPSRR15R14_abtR13_abtR12R11R10R9R8R7R6R5R4R3R2R1R0中止SPSR_undCPSRR15R14_undR13_undR12R11R10R9R8R7R6R5R4R3R2R1R0未定義SPSR_irqCPSRR15R14_irqR13_irqR12R11R10R9R8R7R6R5R4R3R2R1R0中斷SPSR_fiqCPSRR15R14_fiqR13_fiqR12_fiqR11_fiqR10_fiqR9_fiqR8_fiqR7R6R5R4R3R2R1R0快中斷ARM狀態(tài)各模式下可以訪問的寄存器sp_IRQ,sp_FIQ,sp_ABT,sp_UND,根據(jù)系統(tǒng)需要進(jìn)行初始化;sp_USR可以在進(jìn)入用戶模式后,準(zhǔn)備開始執(zhí)行應(yīng)用程序時(shí)對其初始化。45初始化即給SP寄存器定義一個(gè)堆棧地址方法:改變CPSR的狀態(tài)位,使處理器進(jìn)入不同的運(yùn)行模式,然后給SP賦值;sp_USR最后初始化,因?yàn)檫M(jìn)入用戶模式后,不能通過改變CPSR的狀態(tài)位進(jìn)入其他模式。4647NZCV——IM0M1M2M3M4TF—...313029282726876543210條件代碼標(biāo)志保留控制位溢出標(biāo)志進(jìn)位或借位擴(kuò)展零負(fù)或小于IRQ禁止FIQ禁止?fàn)顟B(tài)位模式位NZCVIM0M1M2M3M4TF48M[4:0]模式可見的Thumb狀態(tài)寄存器可見的ARM狀態(tài)寄存器10000用戶R0~R7,SP,LR,PC,CPSRR0~R14,PC,CPSR10001快中斷R0~R7,SP_fiq,LR_fiq,PC,CPSR,SPSR_fiqR0~R7,R8_fiq~R14_fiq,PC,CPSR,SPSR_fiq10010中斷R0~R7,SP_irq,LR_irq,PC,CPSR,SPSR_fiqR0~R12,R13_irq,R14_irq,PC,CPSR,SPSR_irq10011管理R0~R7,SP_svc,LR_svc,PC,CPSR,SPSR_svcR0~R12,R13_svc,R14_svc,PC,CPSR,SPSR_svc10111中止R0~R7,SP_abt,LR_abt,PC,CPSR,SPSR_abtR0~R12,R13_abt,R14_abt,PC,CPSR,SPSR_abt11011未定義R0~R7,SP_und,LR_und,PC,CPSR,SPSR_undR0~R12,R13_und,R14_und,PC,CPSR,SPSR_und11111系統(tǒng)R0~R7,SP,LR,PC,CPSRR0~R14,PC,CPSRCPSR模式位設(shè)置表MODEMASKEQU0x1FSVCMODEEQU0x13IRQMODEEQU0x12…MRS
R0,CPSR ;將CPSR讀到R0中BICR0,R0,#MODEMASK;將CPSR中的模式位清零ORRR1,R0,#SVCMODE;設(shè)置R0到管理模式MSRCPSR_cxsf,R1;切換到管理模式LDRSP,=SVCStack;設(shè)置該模式下的堆棧49初始化臨界IO設(shè)備臨界(Critical)IO設(shè)備是指那些在使能中斷前必須進(jìn)行初始化的設(shè)備。如果不對其進(jìn)行初始化,它們可能在中斷使能后產(chǎn)生一些沒有意義的中斷請求。50初始化C代碼的運(yùn)行環(huán)境程序代碼通過編譯、鏈接后生成可執(zhí)行映像文件映像文件通常包括三部分:RO、RW、ZIRO:包含程序代碼和只讀數(shù)據(jù)RW:包含定義并初始化的全局變量ZI:包含定義但未初始化的全局變量51可執(zhí)行映像文件最初總是放在Flash或其他類型的ROM中RO部分既可以在Flash中運(yùn)行,也可以在高速RAM中運(yùn)行;RW和ZI部分必須復(fù)制到RAM中。初始化C代碼的運(yùn)行環(huán)境,就是將以上部分從Flash中復(fù)制到RAM的過程。52改變處理器的運(yùn)行模式和狀態(tài)ARM微處理器上電復(fù)位后,默認(rèn)模式為管理模式(SupervisorMode),而在初始化代碼中需要切換到其他模式進(jìn)行諸如堆棧設(shè)置之類的操作。53系統(tǒng)初始化過程中處理器模式的變化如下:54管理模式多種特權(quán)模式切換應(yīng)用程序運(yùn)行模式由于ARM微處理器復(fù)位后總是處于ARM狀態(tài),如果應(yīng)用程序?yàn)門humb指令,必須將微處理器切換到Thumb狀態(tài)。55使能中斷如果系統(tǒng)需要使用中斷,初始化代碼應(yīng)該使能中斷??赏ㄟ^清除CPSR中的中斷禁止位來完成。56進(jìn)入C代碼運(yùn)行系統(tǒng)初始化后,就可以進(jìn)入C代碼運(yùn)行。方法一:IMPORTC_Entry;定義一個(gè)外部標(biāo)號,一般不用mainBC_Entry;跳轉(zhuǎn)到C代碼另一種方法IMPORT_mainB_main57_main是編譯器提供的一個(gè)函數(shù),完成庫函數(shù)的初始化和對C代碼運(yùn)行環(huán)境的初始化,最后自動(dòng)跳轉(zhuǎn)到main()函數(shù)執(zhí)行,此時(shí),應(yīng)用程序的主函數(shù)名必須是main()。可以根據(jù)需要選擇兩種之一,如果想讓系統(tǒng)自動(dòng)完成初始化過程,可以使用main()函數(shù),如果所有初始化都由自己編寫程序完成,可以自定義主函數(shù)名。58學(xué)術(shù)沙龍內(nèi)容提要1.本次課目標(biāo)2.
ARM內(nèi)核分類3.ARM程序設(shè)計(jì)基礎(chǔ)4.RealViewMDK簡介系列ARM芯片GPIO簡介6.RealViewMDK開發(fā)流程7.其他常見ARM開發(fā)環(huán)境及工具8.小結(jié)594RealViewMDK簡介4.1RealViewMDK概述4.2RealViewMDK特性產(chǎn)品模塊介紹仿真器60注意:進(jìn)行ARM開發(fā)的Keil(RealViewMDK)與進(jìn)行單片機(jī)開發(fā)的Keil(KeilC)有不同的安裝程序。614.1RealViewMDK概述
RealViewMDK開發(fā)套件源自德國Keil公司,是ARM公司目前最新推出的針對各種嵌入式處理器的軟件開發(fā)工具。RealViewMDK集成了業(yè)內(nèi)最領(lǐng)先的技術(shù),包括μVision3集成開發(fā)環(huán)境與RealView編譯器。支持ARM7、ARM9和最新的Cortex-M3處理器,自動(dòng)配置啟動(dòng)代碼,集成Flash燒寫模塊,強(qiáng)大的Simulation設(shè)備模擬,性能分析等功能。624.2RealViewMDK特性啟動(dòng)代碼生成向?qū)?,自?dòng)引導(dǎo)啟動(dòng)代碼和系統(tǒng)硬件結(jié)合緊密,必須用匯編語言編寫,因而成為許多工程師難以跨越的門檻。RealViewMDK的μVision3工具可以自動(dòng)生成完善的啟動(dòng)代碼,并提供圖形化的窗口,可以輕松修改。能大大節(jié)省時(shí)間,提高開發(fā)效率。63軟件模擬器,完全脫離硬件的軟件開發(fā)過程RealViewMDK的設(shè)備模擬器可以仿真整個(gè)目標(biāo)硬件,包括快速指令集仿真、外部信號和I/O仿真、中斷過程仿真、片內(nèi)所有外圍設(shè)備仿真等。開發(fā)工程師在無硬件的情況下即可開始軟件開發(fā)和調(diào)試,使軟硬件開發(fā)同步進(jìn)行,大大縮短開發(fā)周期。而一般的ARM開發(fā)工具僅提供指令集模擬器,只能支持ARM內(nèi)核模擬調(diào)試。64
性能分析器看得更遠(yuǎn)、看得更細(xì)、看得更清RealViewMDK的性能分析器用于輔助查看代碼覆蓋情況,程序運(yùn)行時(shí)間,函數(shù)調(diào)用次數(shù)等高端控制功能,指導(dǎo)進(jìn)行代碼優(yōu)化。通常這些功能只有價(jià)值數(shù)千美元的昂貴的Trace工具才能提供。65
Cortex-M3支持RealViewMDK支持的Cortex-M3核是ARM公司最新推出的針對微控制器應(yīng)用的內(nèi)核,它提供業(yè)界領(lǐng)先的高性能和低成本的解決方案,未來幾年將成為嵌入式系統(tǒng)應(yīng)用的熱點(diǎn)和主流。66業(yè)界優(yōu)秀的ARM編譯器RealView編譯器,代碼更小,性能更高RealViewMDK的RealView編譯器與比較:代碼密度:比編譯的代碼尺寸小10%;代碼性能:比編譯的代碼性能高20%。67配備ULINK2仿真器+Flash編程模塊,輕松實(shí)現(xiàn)Flash燒寫RealViewMDK無需尋求第三方編程軟件與硬件支持,通過配套的ULINK2仿真器與Flash編程工具,輕松實(shí)現(xiàn)CPU片內(nèi)Flash、外擴(kuò)Flash燒寫,并支持用戶自行添加Flash編程算法;而且能支持Flash整片刪除、扇區(qū)刪除、編程前自動(dòng)刪除以及編程后自動(dòng)校驗(yàn)等功能,輕松方便。68高性價(jià)比RealViewMDK保留了RealViewMDK國際版的所有卓越性能,而產(chǎn)品價(jià)格和國內(nèi)普通開發(fā)工具的價(jià)格相差無幾。更貼身的服務(wù)RealViewMDK用戶將享受到專業(yè)的本地化的技術(shù)支持和服務(wù),包括、Email、論壇、中文技術(shù)文檔等,這將為國內(nèi)工程師們開發(fā)出更有競爭力的產(chǎn)品提供更多的助力。69產(chǎn)品模塊介紹μVision3IDEμVisionIDE在全球擁有龐大的用戶群,超過10萬開發(fā)工程師在使用Keil開發(fā)工具。不管以前是用8位、16位MCU,還是現(xiàn)在改用ARM32位處理器,μVisionIDE簡單易用,容易立馬上手。7071μVision3IDE主要特性:功能強(qiáng)大的源代碼編輯器;可根據(jù)開發(fā)工具配置的設(shè)備數(shù)據(jù)庫;用于創(chuàng)建和維護(hù)工程的工程管理器;集匯編、編譯和鏈接過程于一體的編譯工具;用于設(shè)置開發(fā)工具配置的對話框;72真正集成高速CPU及片上外設(shè)模擬器的源碼級調(diào)試器;高級GDI接口,可用于目標(biāo)硬件的軟件調(diào)試和ULINK2仿真器的連接;用于下載應(yīng)用程序到FlashROM中的Flash編程器;完善的開發(fā)工具手冊、設(shè)備數(shù)據(jù)手冊和用戶向?qū)А?3啟動(dòng)代碼配置向?qū)Е蘓ision3IDE的啟動(dòng)代碼配置向?qū)⒏鱾€(gè)所需配置的功能模塊以對話框方式展示,附加的提示說明,可以快速輕松地做出選擇,生成完善的啟動(dòng)代碼,免除手工寫幾百行匯編程序的痛苦。7475μVision3設(shè)備模擬器μVision3設(shè)備模擬器的功能強(qiáng)大,能模擬整個(gè)MCU的行為。在沒有硬件或?qū)δ繕?biāo)MCU沒有更深的了解的情況下,仍然可以立即開始開發(fā)軟件。高效指令集仿真中斷仿真片內(nèi)外圍設(shè)備仿真
ADC,DAC,TimersUART,CAN,I2C…
外部信號和I/O仿真76性能分析器性能分析器可給所有的MCU實(shí)現(xiàn)如程序運(yùn)行時(shí)間統(tǒng)計(jì)、被調(diào)用次數(shù)統(tǒng)計(jì)、代碼覆蓋率統(tǒng)計(jì)等高端功能,而這些功能對于快速定位死區(qū)代碼,幫助優(yōu)化分析等起了關(guān)鍵的作用。7778RealView編譯器(RVCT)
RealViewMDK集成的RealView編譯器(跟RVDS使用一樣的編譯器),是業(yè)界最優(yōu)秀的編譯器,它能使代碼容量更小、執(zhí)行效率更高;使應(yīng)用程序運(yùn)行更快、系統(tǒng)成本更低。7980MicroLib為進(jìn)一步改進(jìn)基于ARM處理器的應(yīng)用代碼密度,RealViewMDK采用了新型microlibC庫(用于C的ISO標(biāo)準(zhǔn)運(yùn)行時(shí)庫的一個(gè)子集),并將其代碼映像降低最小以滿足嵌入式系統(tǒng)應(yīng)用的需求。MicrolibC庫可將運(yùn)行時(shí)庫代碼大大降低。8182仿真器ULINK2是ARM公司最新推出的配套R(shí)ealViewMDK使用的仿真器,是ULink仿真器的升級版本。ULINK2不僅具有ULINK仿真器的所有功能,還增加了串行調(diào)試(SWD)支持,返回時(shí)鐘支持和實(shí)時(shí)代理等功能。開發(fā)工程師通過結(jié)合使用RealViewMDK的調(diào)試器和ULINK2,可以方便的在目標(biāo)硬件上進(jìn)行片上調(diào)試(使用on-chipJTAG,SWD和OCDS)、Flash編程…8384ULINK2新特點(diǎn)標(biāo)準(zhǔn)WindowsUSB驅(qū)動(dòng)支持ULINK2即插即用;支持基于ARMCortex-M3的串行調(diào)試;支持程序運(yùn)行期間的存儲(chǔ)器讀寫、終端仿真和串行調(diào)試輸出;支持10-pin連接線(也支持20-pin連接線)。85ULINK2主要功能:
USB通訊接口高速下載用戶代碼存儲(chǔ)區(qū)域/寄存器查看快速單步程序運(yùn)行多種程序斷點(diǎn)片內(nèi)Flash編程86ULINK2技術(shù)參數(shù)87特性
RAM斷點(diǎn)
UnlimitedROM斷點(diǎn)(ARM7/9)2maxROM斷點(diǎn)(Cortex-M3)6maxExecution斷點(diǎn)(SetWhileExecuting)√Access斷點(diǎn)(ARM7/9)2max(R/WOnly,WithValue)Access斷點(diǎn)(Cortex-M3)4max(WithValue)TraceHistory×Real-TimeAgent√JTAG時(shí)鐘
<=10MHzJTAGRTCK支持(ReturnClock)√MemoryR/W(Bytes/sec)≈28KFlashR/W(Bytes/sec)≈25KSingle-Step(Fast)(Instructions/sec)≈50ULINK2支持的處理器88ARM7/ARM9/Cortex-M3學(xué)術(shù)沙龍內(nèi)容提要1.本次課目標(biāo)2.
ARM內(nèi)核分類3.ARM程序設(shè)計(jì)基礎(chǔ)4.RealViewMDK簡介系列ARM芯片GPIO簡介6.RealViewMDK開發(fā)流程7.其他常見ARM開發(fā)環(huán)境及工具8.小結(jié)89系列ARM芯片GPIO簡介5.1GPIO(通用I/O口)簡介5.2IO口連接模塊簡介5.3GPIO基本控制寄存器原理圖如何控制LED?如何編程?905.1GPIO(通用I/O口)簡介LPC2000有多個(gè)通用I/O口,分別為P0[31:0]和P1[31:16]。由于IO口和其他功能復(fù)用,需要進(jìn)行相關(guān)的管腳連接模塊(PINSEL0、PINSEL1、PINSEL2)選擇連接GPIO,然后通過IODIR進(jìn)行輸入/輸出屬性設(shè)置后才能操作。當(dāng)管腳選擇GPIO功能時(shí),有三個(gè)寄存器用于控制GPIO的使用,IOSET、IOCLR和IOPIN。915.2IO口連接模塊簡介有些管口除了作為普通IO口以外,還具有復(fù)用功能。比如串行口功能、PWM功能等等。要使用這些功能必須正確的設(shè)置IO連接模塊PINSEL0、PINSEL1、PINSEL2。92PINSEL0、PINSEL1、PINSEL2選擇引腳功能PINSEL0寄存器(位0—位31),分別對應(yīng)于引腳引腳PINSEL1寄存器(位0—位31),分別對應(yīng)于引腳引腳每兩位對應(yīng)一個(gè)引腳,因?yàn)橐粋€(gè)引腳有4種功能,所以要兩位對應(yīng)一個(gè)引腳。9394PINSEL0中所有的位與PINSEL1其它位的復(fù)位值均為00,它們均默認(rèn)為首選功能,即就是通常的GPIO。所有I/O口在復(fù)位后均默認(rèn)為輸入狀態(tài),IODIR寄存器中的方向控制位只有在引腳選擇為GPIO功能時(shí)才有效。對于其它功能,方向是自動(dòng)控制的。955.3GPIO基本控制寄存器LPC2100系列的ARM用四個(gè)寄存器控制IO口。引腳值寄存器IO0PIN和IO1PIN方向寄存器IO0DIR和IO1DIR輸出置位寄存器IO0SET和IO1SET輸出清零寄存器IO0CLR和IO1CLR96引腳值寄存器(輸入寄存器)IO0PIN(32位)對應(yīng)~(32個(gè)IO口)的引腳狀態(tài)。無論IO口處于輸入、輸出或特殊功能狀態(tài),IO0PIN都能讀回IO口引腳上的電平。IO1PIN[31:0]:存儲(chǔ)的當(dāng)前值(forread)97方向寄存器IO0DIR(IO1DIR)32位設(shè)置IO口方向的寄存器對應(yīng)~(32個(gè)IO口)0:輸入1:輸出98輸出置位寄存器(輸出1)IO0SET(IO1SET)32位輸出狀態(tài)時(shí),置1可輸出高電平。置0無效。對應(yīng)~(32個(gè)IO口)99輸出清零寄存器(輸出0)IO0CLR(IO1CLR)
32位輸出狀態(tài)時(shí),置1可輸出低電平。置0無效。對應(yīng)~(32個(gè)IO口)
100原理圖101如何控制LED?102PINSEL0=0; /*設(shè)置引腳為GPIO*/IO0DIR=0x00000001; /*將設(shè)置為輸出*/IO0SET=0x00000001; /*將置1,也就是讓led滅*/IO0CLR=0x00000001;/*將清0,也就是讓led亮*/103如何編程intmain(void){PINSEL0=0; /*設(shè)置引腳為GPIO*/IO0DIR=0x00000001; /*將設(shè)置為輸出*/IO0SET=0x00000001; /*將置1,也就是讓led滅*/while(1){ IO0CLR=0x00000001; delay(); IO0SET=0x00000001; delay();}}104voiddelay(void){unsignedvolatilelongi,j;for(i=0;i<60000;i++)for(j=0;j<5;j++);}105學(xué)術(shù)沙龍內(nèi)容提要1.本次課目標(biāo)2.
ARM內(nèi)核分類3.ARM程序設(shè)計(jì)基礎(chǔ)4.RealViewMDK簡介系列ARM芯片GPIO簡介6.RealViewMDK開發(fā)流程7.其他常見ARM開發(fā)環(huán)境及工具8.小結(jié)1066RealViewMDK開發(fā)流程Step1.新建工程Step2.選擇ARM芯片型號Step3.為工程添加文件Step4.新建main函數(shù)文件Step5.添加C文件到工程Step6.設(shè)置工程選項(xiàng)Step7.編譯生成Hex文件Step8.修改生成的Hex文件Step9.驗(yàn)證Proteus的仿真效果107Step1.新建工程108Step2.選擇ARM芯片型號109Step3.為工程添加文件110Step4.新建main函數(shù)文件111Step5.添加C文件到工程112Step6.設(shè)置工程選項(xiàng)113Step7.編譯生成Hex文件114Step8.修改生成的Hex文件115Step9.驗(yàn)證Proteus的仿真效果116學(xué)術(shù)沙龍內(nèi)容提要1.本次課目標(biāo)2.
ARM內(nèi)核分類3.ARM程序設(shè)計(jì)基礎(chǔ)4.RealViewMDK簡介系列ARM芯片GPIO簡介6.RealViewMDK開發(fā)流程7.其他常見ARM開發(fā)環(huán)境及工具8.小結(jié)1177.其他常見ARM開發(fā)環(huán)境及工具7.2ARMREALVIEWDEVELOPERSUITE7.3IAREWARM7.4WINARM
7.5H-JTAG調(diào)試代理7.6J-LINK7.7U-LINK
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度電商合同電子數(shù)據(jù)證據(jù)收集與保全操作規(guī)范3篇
- 2025-2031年中國網(wǎng)絡(luò)購物行業(yè)市場深度研究及投資策略研究報(bào)告
- 2025年度智慧城市安防系統(tǒng)承包清工勞務(wù)合同4篇
- 2025年中國醫(yī)用空氣凈化器行業(yè)發(fā)展監(jiān)測及投資規(guī)劃建議報(bào)告
- 2025年度教育資源共享平臺(tái)建設(shè)與運(yùn)營合同范本4篇
- 2025年度個(gè)人二手房交易合同模板物業(yè)費(fèi)繳納優(yōu)化版4篇
- 2025年貴州仁懷市供銷社股金公司招聘筆試參考題庫含答案解析
- 2025年江西有為生物技術(shù)有限公司招聘筆試參考題庫含答案解析
- 2025年四川宇客旅游開發(fā)有限公司招聘筆試參考題庫含答案解析
- 2025年江西贛州市會(huì)昌縣發(fā)展集團(tuán)招聘筆試參考題庫含答案解析
- 《請柬及邀請函》課件
- 中小銀行上云趨勢研究分析報(bào)告
- 機(jī)電安裝工程安全培訓(xùn)
- 遼寧省普通高中2024-2025學(xué)年高一上學(xué)期12月聯(lián)合考試語文試題(含答案)
- 青海原子城的課程設(shè)計(jì)
- 常州大學(xué)《新媒體文案創(chuàng)作與傳播》2023-2024學(xué)年第一學(xué)期期末試卷
- 麻醉蘇醒期躁動(dòng)患者護(hù)理
- 英語雅思8000詞匯表
- 小學(xué)好詞好句好段摘抄(8篇)
- JT-T-1059.1-2016交通一卡通移動(dòng)支付技術(shù)規(guī)范第1部分:總則
- 《茶藝文化初探》(教學(xué)設(shè)計(jì))-六年級勞動(dòng)北師大版
評論
0/150
提交評論