基于CMSIS標(biāo)準(zhǔn)的Cortex-M3應(yīng)用軟件開發(fā)-基礎(chǔ)電子_第1頁
基于CMSIS標(biāo)準(zhǔn)的Cortex-M3應(yīng)用軟件開發(fā)-基礎(chǔ)電子_第2頁
基于CMSIS標(biāo)準(zhǔn)的Cortex-M3應(yīng)用軟件開發(fā)-基礎(chǔ)電子_第3頁
基于CMSIS標(biāo)準(zhǔn)的Cortex-M3應(yīng)用軟件開發(fā)-基礎(chǔ)電子_第4頁
基于CMSIS標(biāo)準(zhǔn)的Cortex-M3應(yīng)用軟件開發(fā)-基礎(chǔ)電子_第5頁
已閱讀5頁,還剩4頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

精品文檔-下載后可編輯基于CMSIS標(biāo)準(zhǔn)的Cortex-M3應(yīng)用軟件開發(fā)-基礎(chǔ)電子引言

ARM公司于2022年11月12日發(fā)布了ARMCortex微控制器軟件接口標(biāo)準(zhǔn)(CMSIS:CortexMicrocon-trollerSoftwareInterfaceStandard)。CMSIS是獨立于供應(yīng)商的Cortex-M處理器系列硬件抽象層,為芯片廠商和中間件供應(yīng)商提供了連續(xù)的、簡單的處理器軟件接口,簡化了軟件復(fù)用,降低了Cortex-M3上操作系統(tǒng)的移植難度,并縮短了新入門的微控制器開發(fā)者的學(xué)習(xí)時間和新產(chǎn)品的上市時間。

根據(jù)近期的調(diào)查研究,軟件開發(fā)已經(jīng)被嵌入式行業(yè)公認(rèn)為主要的開發(fā)成本。圖1為近年來軟件開發(fā)與硬件開發(fā)成本對比圖。因此,ARM與Atmel、IAR、Keil、hami-naryMicro、Micrium、NXP、SEGGER和ST等諸多芯片和軟件廠商合作,將所有Cortex芯片廠商產(chǎn)品的軟件接口標(biāo)準(zhǔn)化,制定了CMSIS標(biāo)準(zhǔn)。此舉意在降低軟件開發(fā)成本,尤其針對新設(shè)備項目開發(fā),或者將已有軟件移植到其他芯片廠商提供的基于Cortex處理器的微控制器的情況。有了該標(biāo)準(zhǔn),芯片廠商就能夠?qū)⑺麄兊馁Y源專注于產(chǎn)品外設(shè)特性的差異化,并且消除對微控制器進行編程時需要維持的不同的、互相不兼容的標(biāo)準(zhǔn)的需求,從而達到降低開發(fā)成本的目的。

1基于CMSIS標(biāo)準(zhǔn)的軟件架構(gòu)

如圖2所示,基于CMSIS標(biāo)準(zhǔn)的軟件架構(gòu)主要分為以下4層:用戶應(yīng)用層、操作系統(tǒng)及中間件接口層、CMSIS層、硬件寄存器層。其中CMSIS層起著承上啟下的作用:一方面該層對硬件寄存器層進行統(tǒng)一實現(xiàn),屏蔽了不同廠商對Cortex-M系列微處理器核內(nèi)外設(shè)寄存器的不同定義;另一方面又向上層的操作系統(tǒng)及中間件接口層和應(yīng)用層提供接口,簡化了應(yīng)用程序開發(fā)難度,使開發(fā)人員能夠在完全透明的情況下進行應(yīng)用程序開發(fā)。也正是如此,CMSIS層的實現(xiàn)相對復(fù)雜。

CMSIS層主要分為3部分。

①核內(nèi)外設(shè)訪問層(CPAL):由ARM負(fù)責(zé)實現(xiàn)。包括對寄存器地址的定義,對核寄存器、NVIC、調(diào)試子系統(tǒng)的訪問接口定義以及對特殊用途寄存器的訪問接口(如CONTROL和xPSR)定義。由于對特殊寄存器的訪問以內(nèi)聯(lián)方式定義,所以ARM針對不同的編譯器統(tǒng)一用_INLINE來屏蔽差異。該層定義的接口函數(shù)均是可重入的。

②中間件訪問層(MWAL):由ARM負(fù)責(zé)實現(xiàn),但芯片廠商需要針對所生產(chǎn)的設(shè)備特性對該層進行更新。該層主要負(fù)責(zé)定義一些中間件訪問的API函數(shù),例如為TCP/IP協(xié)議棧、SD/MMC、USB協(xié)議以及實時操作系統(tǒng)的訪問與調(diào)試提供標(biāo)準(zhǔn)軟件接口。該層在1.1標(biāo)準(zhǔn)中尚未實現(xiàn)。

③設(shè)備外設(shè)訪問層(DPAL):由芯片廠商負(fù)責(zé)實現(xiàn)。該層的實現(xiàn)與CPAL類似,負(fù)責(zé)對硬件寄存器地址以及外設(shè)訪問接口進行定義。該層可調(diào)用CPAL層提供的接口函數(shù),同時根據(jù)設(shè)備特性對異常向量表進行擴展,以處理相應(yīng)外設(shè)的中斷請求。

2CMSIS規(guī)范

(1)文件結(jié)構(gòu)

CMSIS的文件結(jié)構(gòu)如圖3所示(以STM32為例)。其中stdint.h包括對8位、16位、32位等類型指示符的定義,主要用來屏蔽不同編譯器之前的差異。core_cm3.h和core_cm3.C中包括Cortex_M3核的全局變量聲明和定義,并定義一些靜態(tài)功能函數(shù)。system_.h和system_.c(即圖3中的system_stm32.h和system_stm32.c)是不同芯片廠商定義的系統(tǒng)初始化函數(shù)SystemInit(),以及一些指示時鐘的變量(如SystemFre-quency)。.h(即圖3中的stm32.h)是提供給應(yīng)用程序的頭文件,它包含core_cm3.h和system_.h,定義了與特定芯片廠商相關(guān)的寄存器以及各中斷異常號,并可定制M3核中的特殊設(shè)備,如MCU、中斷優(yōu)先級位數(shù)以及SysTick時鐘配置。雖然CMSIS提供的文件很多,但在應(yīng)用程序中只需包含h。

(2)工具鏈

CMSIS支持目前嵌入式開發(fā)的三大主流工具鏈,即ARMReakView(armcc)、IAREWARM(iccarm)以及GNU工具鏈(gcc)。通過在core_cm3.C中的如下定義,來屏蔽一些編譯器內(nèi)置關(guān)鍵字的差異。

這樣,CPAL中的功能函數(shù)就可以被定義成靜態(tài)內(nèi)聯(lián)類型(static_INLINE),實現(xiàn)編譯優(yōu)化。

(3)中斷異常

CMSIS對異常和中斷標(biāo)識符、中斷處理函數(shù)名以及中斷向量異常號都有嚴(yán)格的要求。異常和中斷標(biāo)識符需加后綴_IRQn,系統(tǒng)異常向量號必須為負(fù)值,而設(shè)備的中斷向量號是從0開始遞增,具體的定義如下所示(以STM32為例):

CMSIS對系統(tǒng)異常處理函數(shù)以及普通的中斷處理函數(shù)名的定義也有所不同。系統(tǒng)異常處理函數(shù)名需加后綴_Handler,而普通中斷處理函數(shù)名則加后綴_IRQHandler。這些異常中斷處理函數(shù)被定義為weak屬性,以便在其他的文件中重新實現(xiàn)時不出現(xiàn)重復(fù)定義的錯誤。這些處理函數(shù)的地址用來填充中斷異常向量表,并在啟動代碼中給以聲明,例如:NMI_Handler、MemManage_Handler、SysTick_Handler、WWDG_IRQHandler等。

(4)數(shù)據(jù)類型

CMSIS對數(shù)據(jù)類型的定義是在stdint.h中完成的,對核寄存器結(jié)構(gòu)體的定義是在core_cm3.h中完成的,寄存器的訪問權(quán)限是通過相應(yīng)的標(biāo)識來指示的。CMSIS定義以下3種標(biāo)識符來指定訪問權(quán)限:_I(volatileconst)、_O(volatile)和_IO(volatile)。其中_I用來指定只讀權(quán)限,_O指定只寫權(quán)限,_IO指定讀寫權(quán)限。

(5)調(diào)試

嵌入式軟件開發(fā)中的一個基本需求就是能通過終端來輸出調(diào)試信息,一般可通過2種方式實現(xiàn):一種是使用串口線連接板上的UART和PC上的COM口,通過PC上的超級終端來查看調(diào)試信息;另一種則是采用半主機機制,但有可能不被所用的工具鏈支持?;贑ortex-M3核的軟件調(diào)試突破了這樣的限制,Cortex-M3內(nèi)核提供了一個ITM(InstrumentationTraceMacrocell)接口,通過SWV(SerialWireViewer)可調(diào)試由SWO引腳接收到的ITM數(shù)據(jù)。ITM實現(xiàn)了32個通用的數(shù)據(jù)通道,基于這樣的實現(xiàn),CMSIS規(guī)定用通道0作為終端來輸出調(diào)試信息,通道31用于操作系統(tǒng)的輸出調(diào)試(特權(quán)模式訪問)。在core_cm3.h中定義了ITM_SendChar()函數(shù),因此可通過調(diào)用該函數(shù)來重寫fputc,以在應(yīng)用程序中通過printf打印調(diào)試信息,并可通過ITMViewer查看這些調(diào)試信息。有了這樣的實現(xiàn),嵌入式軟件開發(fā)者就可以在不配置串口和使用終端調(diào)試軟件的情況下輸出調(diào)試信息,在一定程度上減少了工作量。

(6)安全機制

在嵌入式軟件開發(fā)過程中,代碼的安全性和健壯性一直是開發(fā)人員所關(guān)注的,因此CMSIS在這方面也作出了努力,所有的CMSIS代碼都基于MISRA-C2022(MotorIndustrySoftwareReliabilityAssociationfortheCprogramminglanguage)標(biāo)準(zhǔn)。MIRSA-C2022制定了一系列安全機制用來保證驅(qū)動層軟件的安全性,是嵌入式行業(yè)都應(yīng)遵循的標(biāo)準(zhǔn)。對于不符合MISRA標(biāo)準(zhǔn)的,編譯器會提示錯誤或警告,這主要取決于開發(fā)者所使用的工具鏈。

3基于CMSIS標(biāo)準(zhǔn)的代碼實現(xiàn)

CMSIS降低了代碼開發(fā)的難度,為了更好地詮釋這一點,下面以一個基于STM32微處理器的簡單例子來說明。代碼實現(xiàn)如下:

可以看到用戶程序中僅需短短的幾行代碼就實現(xiàn)了定時器的功能,每隔1S報數(shù)1次,并可通過ITM窗口查看輸出的調(diào)試信息。其中SystemInit()用來初始化時鐘,SysTick_Config()用來配置系統(tǒng)定時器,而SysTick_Han-dler()用來處理系統(tǒng)時鐘異常,該異常每1ms發(fā)生1次。由于重寫了fputc(),所以可通過printf()函數(shù)將調(diào)試信息打印到ITM窗口上,輸出結(jié)果如圖4所示。

結(jié)語

本文闡述了基于CMSIS標(biāo)準(zhǔn)的軟件架構(gòu)、

溫馨提示

  • 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)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論