當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式教程
[導(dǎo)讀]μC/OS-III在Cortex-M3處理器上的移植

摘要:為了將μC/OS-III移植Cortex-M3處理器上,選用RealView MDK作為軟件開(kāi)發(fā)平臺(tái),針對(duì)Cortex-M3處理器特性編寫(xiě)了移植所需的C語(yǔ)言和匯編語(yǔ)言源代碼,并驗(yàn)證了移植的正確性。移植后的μC/OS-III能夠穩(wěn)定運(yùn)行于Cortex-M3處理器上。該移植對(duì)大部分Cortex-M3處理器具有通用性,對(duì)其他架構(gòu)處理器的μC/OS-III移植具有參考作用。
關(guān)鍵詞:μC/OS-III;嵌入式操作系統(tǒng);ARM;Cortex-M3;移植

引言
    μC/OS-III是一款基于優(yōu)先級(jí)調(diào)度的搶占式實(shí)時(shí)內(nèi)核,Micrium公司于2011年8月公開(kāi)了μC/OS-III的源碼,其源碼遵循ANSIC標(biāo)準(zhǔn),因而具有良好的移植性,相信其將會(huì)被移植到越來(lái)越多的處理器體系上。本文主要完成基于Cortex-M3處理器的μC/OS-III移植,通過(guò)本次移植,加深對(duì)嵌入式操作系統(tǒng)原理的理解。此外,在μC/OS-III移植成功的基礎(chǔ)上進(jìn)行嵌入式應(yīng)用程序開(kāi)發(fā),可以把主要精力集中到應(yīng)用程序上,而硬件資源交由μC/OS-III管理,從而使得嵌入式應(yīng)用程序更易開(kāi)發(fā)和維護(hù),在嵌入式軟硬件結(jié)構(gòu)變得越來(lái)越復(fù)雜的今天具有現(xiàn)實(shí)意義。

1 μC/OS-III和Cortex-M3特點(diǎn)
    相對(duì)以前的版本,μC/OS-III最大改進(jìn)之處在于允許多個(gè)任務(wù)運(yùn)行于同一優(yōu)先級(jí)上,相同優(yōu)先級(jí)的任務(wù)按時(shí)間片輪轉(zhuǎn)調(diào)度,內(nèi)核對(duì)象的數(shù)量不受限制,以及接近于零的中斷禁用時(shí)鐘周期。
    Cortex-M3是ARM公司推出的基于ARMv7-M架構(gòu)的內(nèi)核,主要針對(duì)高性能、低成本和低功耗的嵌入式應(yīng)用。Cortex-M3擁有固定的存儲(chǔ)器映射,采用更高效的NVIC(Nested Vectored Interrupt Controller)、更簡(jiǎn)單的堆棧以及更高性能的指令集,且NVIC(包括SysTick)的寄存器位置固定,極大地方便了μC/OS-III的移植及在基丁Cortex-M3內(nèi)核的處理器之間的遷移。

2 移植
2.1 移植方案
    本文移植μC/OS-III內(nèi)核的版本為V3.02.00,其源代碼下載地址見(jiàn)參考文獻(xiàn)。選用意法半導(dǎo)體(ST)公司生產(chǎn)的基于Cortex-M3內(nèi)核的STM32F103RBT6微控制器作為硬件實(shí)驗(yàn)平臺(tái),而編譯環(huán)境采用RealViewMDK V3.5。
    Cortex-M3支持兩種特權(quán)級(jí)別:特權(quán)級(jí)和用戶(hù)級(jí),μC/OS-III內(nèi)核和用戶(hù)代碼都運(yùn)行于特權(quán)級(jí)下。Cortex-M3還支持兩個(gè)棧指針MSP和PSP,μC/OS-III內(nèi)核和ISR(Interrupt Service Routine)使用MSP,μC/OS-III的任務(wù)則使用PSP。
    首先針對(duì)Conex-M3處理器的特性編寫(xiě)與內(nèi)核、CPU和BSP(Board Support Package)相關(guān)的源代碼,然后創(chuàng)建若干個(gè)簡(jiǎn)單的用戶(hù)任務(wù),在具體的硬件平臺(tái)上測(cè)試移植后的μC/OS-III。
2.2 內(nèi)核相關(guān)
2.2.1 編寫(xiě)os_cpu.h
    os_cpu.h頭文件主要是對(duì)上下文切換函數(shù)和時(shí)間戳獲取函數(shù)進(jìn)行宏定義。μC/OS-III的上下文切換包括兩種類(lèi)型:任務(wù)級(jí)上下文切換OS_TASK_SW()和中斷級(jí)上下文切換OSIntCtxSw()。它們使用相同的代碼置位ICSR.PENDSVSET以懸起PendSV異常,由PendSV的ISR“緩期執(zhí)行”上下文切換。
    OS_TS_GET()的作用是獲取當(dāng)前時(shí)間戳,若使能μC/OS-III的時(shí)間戳功能,則將OS_TS_GET()宏定義為CPU_TS_TmrRd(),否則簡(jiǎn)單地宏定義為0。
2.2.2 編寫(xiě)os_cpu_a.a(chǎn)sm
    在os_cpu_a.a(chǎn)sm文件中需要用匯編指令實(shí)現(xiàn)OSStartHighRdy()函數(shù)和PendSV的ISR。OSStartHighRdy()函數(shù)被內(nèi)核用于調(diào)度第一個(gè)最高優(yōu)先級(jí)的就緒任務(wù),以開(kāi)始多任務(wù)運(yùn)行環(huán)境,匯編代碼實(shí)現(xiàn)如下:
   
    Cortex-M3支持PendSV異常,而PendSV異常的典型應(yīng)用場(chǎng)合就是上下文切換。得益于Cortex-M3的中斷機(jī)制,μC/OS-III上下文切換只需保存和恢復(fù)R11~R4、PSP,而PSR、PC、LR、R12、R3~R0由硬件自動(dòng)保存和恢復(fù)。PendSV的ISR匯編代碼如下:
    [!--empirenews.page--]
      
2.2.3 編寫(xiě)os_cpu_c.c
    os_cpu_c.c文件包含了OSTaskStkInit()函數(shù)和若干鉤子函數(shù)。OSTaskStkInit()函數(shù)的作用是在創(chuàng)建任務(wù)時(shí)初始化任務(wù)棧,并返回新的棧頂位置。μC/OS-III基于Cortex-M3的任務(wù)棧結(jié)構(gòu)如圖1所示。其中PSR、PC、LR、R1、R0五個(gè)寄存器應(yīng)賦予正確的初值,而其他11個(gè)寄存器的初值無(wú)關(guān)重要。


    os_cpu_c.c文件中的鉤子函數(shù)是μC/OS-III為了擴(kuò)展用戶(hù)功能而定義的。進(jìn)行μC/OS-III移植時(shí)至少需要定義OSTaskSwHook()、OSIn itHook()、OSTimeTickHook()、OSIdleTaskHook()、OSStatTaskHook()、OSTaskCreateHook()、OSTaskDelHook()、OSTaskReturnHook()
八個(gè)鉤子函數(shù)。為了簡(jiǎn)單起見(jiàn),本次移植不塒鉤子函數(shù)作功能擴(kuò)展。
2.3 CPU相關(guān)
2.3.1 編寫(xiě)cpu. h
    cpu.h頭文件主要包括對(duì)標(biāo)準(zhǔn)數(shù)據(jù)類(lèi)型、字長(zhǎng)、棧、臨界區(qū)的相關(guān)定義。標(biāo)準(zhǔn)數(shù)據(jù)類(lèi)型與具體的編譯器相關(guān),需要查閱相應(yīng)的編譯器手冊(cè)。Cortex-M3字長(zhǎng)是32位,則CPU_DATA和CPU_ADDR皆定義為CPU_INT32U類(lèi)型。Cortex-M3使用滿(mǎn)降序棧,棧增長(zhǎng)方向應(yīng)為從高地址到低地址。臨界區(qū)方法選用CPU_CRITICAL_METHOD_STATUS_LOCAL。
2.3.2 編寫(xiě)cpu_a.a(chǎn)sm
    cpu_a.a(chǎn)sm文件的最主要部分是臨界區(qū)函數(shù)的實(shí)現(xiàn)。根據(jù)所選用的臨界區(qū)方法,中斷使能函數(shù)CPU_SR_Save()和中斷禁用函數(shù)CPU_SR_Res tore()代碼實(shí)現(xiàn)如下:
   
    Cortex_M3的指令集提供了CLZ指令,則可選地使用匯編指令實(shí)現(xiàn)CPU_CntLeadZeros()函數(shù),以加快μC/OS-III調(diào)度器查找最高優(yōu)先級(jí)的就緒任務(wù)的速度,CPU_CntLeadZeros()函數(shù)匯編代碼實(shí)現(xiàn)如下:
    CPU_CntLeadZeros
        CLZ R0,R0
        BX LR[!--empirenews.page--]
2.4 BSP
    Cortex-M3內(nèi)核包含了一個(gè)SysTick定時(shí)器,可以用來(lái)給μC/OS-III提供系統(tǒng)時(shí)鐘節(jié)拍。SysTick初始化和ISR的源代碼實(shí)現(xiàn)分別如下:
   
  
    μC/OS-III新增了時(shí)間戳功能,用于測(cè)量中斷禁用時(shí)長(zhǎng)、代碼執(zhí)行時(shí)長(zhǎng)和確定事件發(fā)生時(shí)間等。時(shí)間戳定時(shí)器可以由DWT(Data Watchpo int and Tracc)的時(shí)鐘周期計(jì)數(shù)器CYCCNT充當(dāng),該計(jì)數(shù)器是一個(gè)自由運(yùn)行的32位遞增計(jì)數(shù)器,溢出時(shí)自動(dòng)重載為0,周而復(fù)始。時(shí)間戳定時(shí)器初始化和讀取函數(shù)源代碼實(shí)現(xiàn)分別如下:
   
    此外,本移植過(guò)程的BSP還涉及RCC、GPIO、NVIC和LED/LCD等硬件的初始化函數(shù)和驅(qū)動(dòng)程序。

3 測(cè)試
    首先不加任何用戶(hù)任務(wù)來(lái)測(cè)試移植好的μC/OS-III內(nèi)核自身運(yùn)行情況,待驗(yàn)證內(nèi)核正常運(yùn)行之后,編寫(xiě)TaskLed1、TaskLed2、TaskLe d3、TaskProfile四個(gè)任務(wù),其中前3個(gè)任務(wù)被賦予相同的優(yōu)先級(jí)(本移植是假設(shè)使能了μC/OS-III的輪轉(zhuǎn)調(diào)度功能),實(shí)現(xiàn)對(duì)3盞LED燈不停地
閃爍;而TaskProfile的功能是在液晶屏上顯示上下文切換次數(shù)。


    運(yùn)行結(jié)果如圖2所示。圖中3盞LED燈不停地閃爍,驗(yàn)證了μC/OS-III的相同優(yōu)先級(jí)任務(wù)輪轉(zhuǎn)調(diào)度的特征;LCD上顯示CtxSwCtr的值一直在增加,指示不斷發(fā)生上下文切換。系統(tǒng)連續(xù)穩(wěn)定運(yùn)行5個(gè)小時(shí)以上沒(méi)出現(xiàn)任何問(wèn)題,可見(jiàn)本移植是成功的。

結(jié)語(yǔ)
    本文主要論述了基于Cortex-M3內(nèi)核處理器上μC/OS-III的移植過(guò)程并給出關(guān)鍵代碼,移植后的μC/OS-III能夠穩(wěn)定運(yùn)行于STM32F103RB T6處理器上。本移植能通用于大部分Cortex-M3內(nèi)核的處理器,并對(duì)于將μC/OS-III移植到其他體系結(jié)構(gòu)的處理器上具有參考價(jià)值。

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

9月2日消息,不造車(chē)的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車(chē)技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車(chē)工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車(chē)。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車(chē) 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶(hù)希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱(chēng),數(shù)字世界的話(huà)語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱(chēng)"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉