女人被狂躁到高潮视频免费无遮挡,内射人妻骚骚骚,免费人成小说在线观看网站,九九影院午夜理论片少妇,免费av永久免费网址

當前位置:首頁 > 工業(yè)控制 > 工業(yè)控制
[導讀]引 言 ARM公司于2008年11月12日發(fā)布了ARM Cortex微控制器軟件接口標準(CMSIS:Cortex Microcon-troller Software Interface Standard)。CMSIS是獨立于供應商的Cortex-M處理器系列硬件抽象層,為芯片廠商和中間


引 言
    ARM公司于2008年11月12日發(fā)布了ARM Cortex微控制器軟件接口標準(CMSIS:Cortex Microcon-troller Software Interface Standard)。CMSIS是獨立于供應商的Cortex-M處理器系列硬件抽象層,為芯片廠商和中間件供應商提供了連續(xù)的、簡單的處理器軟件接口,簡化了軟件復用,降低了Cortex-M3上操作系統(tǒng)的移植難度,并縮短了新入門的微控制器開發(fā)者的學習時間和新產品的上市時間。
    根據(jù)近期的調查研究,軟件開發(fā)已經被嵌入式行業(yè)公認為最主要的開發(fā)成本。圖1為近年來軟件開發(fā)與硬件開發(fā)成本對比圖。因此,ARM與Atmel、IAR、Keil、hami-nary Micro、Micrium、NXP、SEGGER和ST等諸多芯片和軟件廠商合作,將所有Cortex芯片廠商產品的軟件接口標準化,制定了CMSIS標準。此舉意在降低軟件開發(fā)成本,尤其針對新設備項目開發(fā),或者將已有軟件移植到其他芯片廠商提供的基于Cortex處理器的微控制器的情況。有了該標準,芯片廠商就能夠將他們的資源專注于產品外設特性的差異化,并且消除對微控制器進行編程時需要維持的不同的、互相不兼容的標準的需求,從而達到降低開發(fā)成本的目的。


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

    CMSIS層主要分為3部分。
    ①核內外設訪問層(CPAL):由ARM負責實現(xiàn)。包括對寄存器地址的定義,對核寄存器、NVIC、調試子系統(tǒng)的訪問接口定義以及對特殊用途寄存器的訪問接口(如CONTROL和xPSR)定義。由于對特殊寄存器的訪問以內聯(lián)方式定義,所以ARM針對不同的編譯器統(tǒng)一用_INLINE來屏蔽差異。該層定義的接口函數(shù)均是可重入的。
    ②中間件訪問層(MWAL):由ARM負責實現(xiàn),但芯片廠商需要針對所生產的設備特性對該層進行更新。該層主要負責定義一些中間件訪問的API函數(shù),例如為TCP/IP協(xié)議棧、SD/MMC、USB協(xié)議以及實時操作系統(tǒng)的訪問與調試提供標準軟件接口。該層在1.1標準中尚未實現(xiàn)。
    ③設備外設訪問層(DPAL):由芯片廠商負責實現(xiàn)。該層的實現(xiàn)與CPAL類似,負責對硬件寄存器地址以及外設訪問接口進行定義。該層可調用CPAL層提供的接口函數(shù),同時根據(jù)設備特性對異常向量表進行擴展,以處理相應外設的中斷請求。


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

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

   
    這樣,CPAL中的功能函數(shù)就可以被定義成靜態(tài)內聯(lián)類型(static_INLINE),實現(xiàn)編譯優(yōu)化。
    (3)中斷異常
    CMSIS對異常和中斷標識符、中斷處理函數(shù)名以及中斷向量異常號都有嚴格的要求。異常和中斷標識符需加后綴_IRQn,系統(tǒng)異常向量號必須為負值,而設備的中斷向量號是從0開始遞增,具體的定義如下所示(以STM32為例):


    CMSIS對系統(tǒng)異常處理函數(shù)以及普通的中斷處理函數(shù)名的定義也有所不同。系統(tǒng)異常處理函數(shù)名需加后綴_Handler,而普通中斷處理函數(shù)名則加后綴_IRQHandler。這些異常中斷處理函數(shù)被定義為weak屬性,以便在其他的文件中重新實現(xiàn)時不出現(xiàn)重復定義的錯誤。這些處理函數(shù)的地址用來填充中斷異常向量表,并在啟動代碼中給以聲明,例如:NMI_Handler、MemManage_Handler、SysTick_Handler、WWDG_IRQHandler等。
    (4)數(shù)據(jù)類型
    CMSIS對數(shù)據(jù)類型的定義是在stdint.h中完成的,對核寄存器結構體的定義是在core_cm3.h中完成的,寄存器的訪問權限是通過相應的標識來指示的。CMSIS定義以下3種標識符來指定訪問權限:_I(volatile const)、_O(volatile)和_IO(volatile)。其中_I用來指定只讀權限,_O指定只寫權限,_IO指定讀寫權限。
    (5)調 試
    嵌入式軟件開發(fā)中的一個基本需求就是能通過終端來輸出調試信息,一般可通過2種方式實現(xiàn):一種是使用串口線連接板上的UART和PC上的COM口,通過PC上的超級終端來查看調試信息;另一種則是采用半主機機制,但有可能不被所用的工具鏈支持?;贑ortex-M3核的軟件調試突破了這樣的限制,Cortex-M3內核提供了一個ITM(Instrumentation Trace Macrocell)接口,通過SWV(Serial Wire Viewer)可調試由SWO引腳接收到的ITM數(shù)據(jù)。ITM實現(xiàn)了32個通用的數(shù)據(jù)通道,基于這樣的實現(xiàn),CMSIS規(guī)定用通道0作為終端來輸出調試信息,通道31用于操作系統(tǒng)的輸出調試(特權模式訪問)。在core_cm3.h中定義了ITM_SendChar()函數(shù),因此可通過調用該函數(shù)來重寫fputc,以在應用程序中通過printf打印調試信息,并可通過ITM Viewer查看這些調試信息。有了這樣的實現(xiàn),嵌入式軟件開發(fā)者就可以在不配置串口和使用終端調試軟件的情況下輸出調試信息,在一定程度上減少了工作量。
    (6)安全機制
    在嵌入式軟件開發(fā)過程中,代碼的安全性和健壯性一直是開發(fā)人員所關注的,因此CMSIS在這方面也作出了努力,所有的CMSIS代碼都基于MISRA-C2004(Motor Industry Software Reliability Association forthe C programming language)標準。MIRSA-C 2004制定了一系列安全機制用來保證驅動層軟件的安全性,是嵌入式行業(yè)都應遵循的標準。對于不符合MISRA標準的,編譯器會提示錯誤或警告,這主要取決于開發(fā)者所使用的工具鏈。


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

   

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

結 語
    本文闡述了基于CMSIS標準的軟件架構、規(guī)范,并通過一個實例更加清晰地解讀了CMSIS作為一個新的基于Cortex-M核處理器系列的軟件開發(fā)標準所具有的巨大潛力。它不僅降低了軟件開發(fā)的難度,更減少了軟件開發(fā)的成本。因此,工程師盡早掌握CMSIS標準,對進行基于Cortex-M3處理器的軟件開發(fā)會大有幫助。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

美國紐約州阿蒙克2022年10月20日 /美通社/ -- IBM(NYSE: IBM)發(fā)布 2022 年第三季度業(yè)績報告。 IBM 董事長兼首席執(zhí)行官 Arvind Kri...

關鍵字: IBM 軟件 BSP 云平臺

成都2022年10月19日 /美通社/ -- 近期,平安養(yǎng)老險積極籌備個人養(yǎng)老金的產品設計和系統(tǒng)開發(fā)工作,發(fā)展多樣化的養(yǎng)老金融產品,推動商業(yè)養(yǎng)老保險、個人養(yǎng)老金、專屬商業(yè)養(yǎng)老保險等產品供給。 搭養(yǎng)老政策東風 ...

關鍵字: 溫度 BSP 東風 大眾

廣東佛山2022年10月19日 /美通社/ -- 空間是人居生活的基礎單元,承載著生存與活動的最基本功能。而對于理想空間的解構意義卻在物理性容器之外,體現(xiàn)出人們對于空間和生活深層關系的思考,同時也塑造著人與空間的新型連接...

關鍵字: 溫度 BSP 智能化 進程

上海2022年10月19日 /美通社/ -- 10月17日晚間,安集科技披露業(yè)績預告。今年前三季度,公司預計實現(xiàn)營業(yè)收入7.54億元至8.33億元,同比增長60.24%至77.03%;歸母凈利潤預計為1.73億...

關鍵字: 電子 安集科技 BSP EPS

北京2022年10月19日 /美通社/ -- 10月18日,北京市經濟和信息化局發(fā)布2022年度第一批北京市市級企業(yè)技術中心創(chuàng)建名單的通知,諾誠健華正式獲得"北京市企業(yè)技術中心"認定。 北京市企業(yè)技...

關鍵字: BSP ARMA COM 代碼

北京2022年10月18日 /美通社/ -- 10月14日,國際數(shù)據(jù)公司(IDC)發(fā)布《2022Q2中國軟件定義存儲及超融合市場研究報告》,報告顯示:2022年上半年浪潮超融合銷售額同比增長59.4%,近5倍于...

關鍵字: IDC BSP 數(shù)字化 數(shù)據(jù)中心

上海2022年10月18日 /美通社/ -- 2022年9月5日,是首都銀行集團成立60周年的紀念日。趁著首都銀行集團成立60周年與首都銀行(中國)在華深耕經營12年的“大日子”,圍繞作為外資金融機構對在華戰(zhàn)略的構想和業(yè)...

關鍵字: 數(shù)字化 BSP 供應鏈 控制

東京2022年10月18日  /美通社/ -- NIPPON EXPRESS HOLDINGS株式會社(NIPPON EXPRESS HOLDINGS, INC.)旗下集團公司上海通運國際物流有限公司(Nipp...

關鍵字: 溫控 精密儀器 半導體制造 BSP

廣州2022年10月18日 /美通社/ -- 10月15日,第 132 屆中國進出口商品交易會("廣交會")于"云端"開幕。本屆廣交會上高新技術企業(yè)云集,展出的智能產品超過140,...

關鍵字: 中國智造 BSP 手機 CAN

要問機器人公司哪家強,波士頓動力絕對是其中的佼佼者。近來年該公司在機器人研發(fā)方面獲得的一些成果令人印象深刻,比如其開發(fā)的機器人會后空翻,自主爬樓梯等。這不,波士頓動力又發(fā)布了其機器人組團跳男團舞的新視頻,表演的機器人包括...

關鍵字: 機器人 BSP 工業(yè)機器人 現(xiàn)代汽車

工業(yè)控制

13472 篇文章

關注

發(fā)布文章

編輯精選

技術子站

關閉