www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀] 引言 S12X架構(gòu)是飛思卡爾公司推出的16位CPU,占有一定的單片機(jī)應(yīng)用市場(chǎng)。μC/OS—III是.MICrium公司推出的一款實(shí)時(shí)操作系統(tǒng)(RTOS),它的前身——μC/OS—II,由于源碼公開(kāi)、實(shí)時(shí)性好、便于學(xué)習(xí)等優(yōu)

引言
S12X架構(gòu)是飛思卡爾公司推出的16位CPU,占有一定的單片機(jī)應(yīng)用市場(chǎng)。μCOS—III是.MICrium公司推出的一款實(shí)時(shí)操作系統(tǒng)(RTOS),它的前身——μC/OS—II,由于源碼公開(kāi)、實(shí)時(shí)性好、便于學(xué)習(xí)等優(yōu)點(diǎn),應(yīng)用非常廣泛,并被移植到了幾乎所有主流的CPU架構(gòu)上。但是到目前為止,μC/OS—III在S12X架構(gòu)上還沒(méi)有官方的移植版本。
μC/OS-III相比μC/OS—II作了很大的改進(jìn),整個(gè)內(nèi)核基本被重寫(xiě)。任務(wù)的數(shù)量可無(wú)限多,只受限于系統(tǒng)存儲(chǔ)器的大??;由于支持時(shí)間片輪轉(zhuǎn)調(diào)度,任務(wù)的優(yōu)先級(jí)可以相同;采用了延遲中斷處理機(jī)制(deferred post),中斷服務(wù)所要訪問(wèn)的全局變量數(shù)變得很少,使得大部分臨界代碼的保護(hù)只需要關(guān)閉調(diào)度器,而不需要關(guān)閉中斷,大大縮短了系統(tǒng)的中斷延遲;系統(tǒng)時(shí)鐘服務(wù)(tick handling)被移到了任務(wù)級(jí)執(zhí)行,進(jìn)一步縮短了中斷延遲;引入了時(shí)間戳的概念,用32位計(jì)數(shù)器為系統(tǒng)提供了精確的時(shí)標(biāo),用來(lái)計(jì)算每個(gè)任務(wù)的CPU使用率、最長(zhǎng)關(guān)中斷時(shí)間、最長(zhǎng)關(guān)調(diào)度器時(shí)間等;提供了獨(dú)特的、豐富的運(yùn)行時(shí)統(tǒng)計(jì)參數(shù),為更好地應(yīng)用μC/OS—III提供了有力的基礎(chǔ)。更深入地了解μC/OS—III內(nèi)核,讀者可以參見(jiàn)參考文獻(xiàn)。
總之,μC/OS—III是μC/OS—II的全面升級(jí),具有更短的中斷延遲、更豐富的運(yùn)行時(shí)參數(shù)、更豐富的調(diào)試手段、更優(yōu)的代碼組織、更靈活的配置和使用等,但是,μC/OS—III對(duì)于硬件卻沒(méi)有更高的要求:對(duì)于ROM的需求,μC/OS—III為6~24 KB,μC/OS—II為6~26KB;對(duì)于RAM的需求二者均為1 KB左右,可見(jiàn)μC/OS—III同樣適合運(yùn)行在低端的8位、16位單片機(jī)上。由于繼承了μC/OS—II的優(yōu)點(diǎn),μC/OS—III有了這么多新的優(yōu)秀特性,它應(yīng)該會(huì)得到更廣泛的應(yīng)用。本文詳細(xì)地講述了μC/OS—III移植的方法和在S12X架構(gòu)上移植的具體步驟,希望能對(duì)在該方面有需求的讀者提供幫助。

1 μC/OS-III的移植方法
如前所述,μC/OS—III對(duì)于硬件的要求并不比μC/OS—II高多少。事實(shí)上,只要滿足如下幾條,μC/OS—III就能夠被移植到該平臺(tái)上:
①處理器帶有支持標(biāo)準(zhǔn)C的工具鏈,并且需要支持32位數(shù)據(jù)。
②處理器支持中斷,并能夠提供10~1 000Hz的周期中斷作為系統(tǒng)的時(shí)鐘節(jié)拍源。
③中斷能夠被關(guān)閉和打開(kāi)。
④處理器有棧指針寄存器,并且所有其他的寄存器能夠被存儲(chǔ)和恢復(fù)。
⑤處理器能夠支持足夠的尋址空間。
這幾個(gè)條件,現(xiàn)在的處理器架構(gòu)都能夠滿足,S12X顯然也滿足,所以μC/OS—III能夠移植到S12X架構(gòu)上。
μC/OS—III的代碼組織非常利于移植,代碼按照模塊分層次地組織在一起。移植時(shí)需要改動(dòng)的模塊和文件如表1所列。



2 μC/OS-III在S12X架構(gòu)上移植的步驟
2.1 第一步:建立合適的起點(diǎn)
移植之前找一個(gè)合適的起點(diǎn)非常必要。這包括選擇已經(jīng)移植好的可運(yùn)行的版本、工具鏈和開(kāi)發(fā)板。由于不存在飛思卡爾16位CPU的μC/ OS—III的移植版本,這里選擇K60移植版本。該移植版本的IAR示例工程可以從Micrium官方網(wǎng)站下載。工具鏈選擇CodeWarrior Development Studio for S12(X)V5.1(以下簡(jiǎn)稱CW5.1),開(kāi)發(fā)板使用MC9S12XDP512的核心小板即可。K60的處理器基于Cortex—M4架構(gòu),是32位CPU,與S12X 16位處理器存在很大的差異,所以表1中所列的文件基本需要全部重寫(xiě)。
2.2 第二步:新建工程
打開(kāi)CW5.1,新建工程,選擇目標(biāo)為MC9S12XDP512,調(diào)試方式為T(mén)BDML,采用C語(yǔ)言開(kāi)發(fā),選擇小存儲(chǔ)模式(small memory model),其余的選項(xiàng)按照默認(rèn)設(shè)置即可。MC9S12XDP512采用了分頁(yè)內(nèi)存機(jī)制,擴(kuò)展了16位CPU的64 KB尋址空間,它擁有512 KB的Flash,出于簡(jiǎn)單考慮,移植的過(guò)程中忽略這種分頁(yè)機(jī)制,即所謂的小存儲(chǔ)模式,只使用默認(rèn)的64 KB的存儲(chǔ)空間。對(duì)于大多數(shù)的16位單片機(jī)應(yīng)用,這么大的存儲(chǔ)空間應(yīng)該夠用。μC/OS—III的設(shè)計(jì)并沒(méi)有固定代碼和數(shù)據(jù)的位置,也沒(méi)有固定中斷的設(shè)置方法,也沒(méi)有固定自己的啟動(dòng)代碼,將這些都交給了工具鏈或者用戶。μC/OS—III代碼的運(yùn)行開(kāi)始于main函數(shù),對(duì)于之前的C語(yǔ)言環(huán)境初始化、硬件初始化沒(méi)有什么特殊的需求,對(duì)于自己的代碼和數(shù)據(jù)段的放置也沒(méi)有特別的要求,這應(yīng)該說(shuō)是一種靈活性。中斷設(shè)置,需要在前述的prm文件中加入如下幾行:
VECTOR 0_startup
VECTOR 7OS_CPU_SysTickHandler
VECTOR 4OSCtxSw
分別制定好用于任務(wù)切換的軟中斷和時(shí)鐘節(jié)拍的RTI中斷。
2.3 第三步:添加文件
打開(kāi)資源管理器,在工程目錄下新建表2所示目錄,并從官網(wǎng)上下載的IAR示例工程中拷貝相應(yīng)的文件。在CW5.1的工程中添加表2中新建的文件夾,并將上述拷貝的文件加入對(duì)應(yīng)的文件夾。接下來(lái)需要修改路徑設(shè)置:Edit->Standard Setting->Target->ACCess Paths,勾選Always Search Usei Paths。這樣,添加文件的環(huán)節(jié)算是完成了。


2.4 第四步:修改文件
這一步是移植的關(guān)鍵,按照表2的總結(jié),一共需要修改8個(gè)文件,接下來(lái)逐個(gè)說(shuō)明。
(1)os_cpu_a.a(chǎn)sm
該文件包含了OSStartHiglaRdy、OSCtxSw、OSINTCtxSw 三個(gè)實(shí)現(xiàn)任務(wù)切換的代碼片段,將這3個(gè)片段定義到一個(gè)代碼段,比如codesecti on2段,具體就是在文件開(kāi)始處加上語(yǔ)句“codesection2:SECTION”即可。另外,μC/OS—III中這3個(gè)函數(shù)都是在臨界代碼段中訪問(wèn),故不需要考慮共享變量的問(wèn)題。OSCtxSw的代碼如下:

該函數(shù)被設(shè)計(jì)成swi軟中斷的服務(wù)程序,所以1~2行代碼結(jié)合中斷響應(yīng)時(shí)的入棧操作完成了被換出任務(wù)的上下文的保存,3行調(diào)用介入函數(shù),4~7行修改了記錄當(dāng)前任務(wù)TCB和優(yōu)先級(jí)的全局變量,8行將SP換成了換入任務(wù)的棧指針,9行執(zhí)行后CPU會(huì)裝載換入任務(wù)的上下文,從而完成了上下文切換。OSStartHighRdy和OSINTCtxSw的機(jī)制和OSCtxSw類似,代碼分別如下:

應(yīng)該注意到,這3個(gè)函數(shù)的功能僅僅是保存換出任務(wù)的上下文和裝載換入任務(wù)的上下文,之所以這么簡(jiǎn)單,主要是因?yàn)镾12X的寄存器很少,中斷響應(yīng)和返回過(guò)程硬件都自動(dòng)完成了所有寄存器的保存和恢復(fù)。這也從一個(gè)側(cè)面說(shuō)明了為什么需要借助中斷完成任務(wù)切換的一個(gè)原因:借助中斷機(jī)制,可以高效簡(jiǎn)潔地完成上下文切換。
(2)os_cpu_c.c
這個(gè)文件里面至少需要修改兩個(gè)函數(shù),即任務(wù)棧初始化函數(shù)OSTaskStkInit和時(shí)鐘節(jié)拍服務(wù)程序OS_CPU_SysTICkHandler。遵照S12X中斷的棧結(jié)構(gòu),OSTaskStkInit實(shí)現(xiàn)如下:

從棧頂?shù)綏5滓来螢镃CR、D、X、Y、PC,按照S12X的C語(yǔ)言參數(shù)傳遞規(guī)則,任務(wù)函數(shù)的傳入?yún)?shù)被保存在了D寄存器對(duì)應(yīng)的棧位置。

該宏保存被中斷任務(wù)的棧頂指針,在其TCB結(jié)構(gòu)中,之所以需要先遞增SP、保存SP、再遞減,是因?yàn)镃PU_SR_ALLOC()宏定義了一個(gè)局部變量,該變量處在任務(wù)棧上,但是不屬于上下文的一部分。
如果在該移植版本上寫(xiě)中斷服務(wù)子程序,都需要寫(xiě)成上述格式,μC/OS-III才能夠正常運(yùn)行。另外,需要將OSTaskSwHook函數(shù)單獨(dú)定義在os_cpu_a.a(chǎn)sm文件中所定義的那個(gè)段中,這只需在該函數(shù)頭尾加上如下語(yǔ)句:
#pragma CODE_SEG codesection2
void OSTaskSwHook(void){
……
}
#pragma CODE_SEG DEFAULT
這是因?yàn)樵摵瘮?shù)被os_cpu_a.a(chǎn)sm文件中的3個(gè)匯編函數(shù)以bsr指令調(diào)用,而bsr只能夠?qū)崿F(xiàn)-128~+127范圍的相對(duì)轉(zhuǎn)移,故這里只需要將他們放在同一段,即可完成跳轉(zhuǎn)。
os_cpu.h為頭文件,需要定義上述OS_SAVE_SP()宏,其他的可以不更改,也可以刪除那些沒(méi)有被定義的聲明(如原來(lái)的pendSV的服務(wù)子程),注意os_cpu_a.a(chǎn)sm是完全重寫(xiě),os_cpu_c.c只是修改上述兩個(gè)函數(shù)。
(3)cpu.h
編譯器無(wú)關(guān)的數(shù)據(jù)類型定義,可以參考Edit->Standard Setting->Compiler for HC12->type sizes,默認(rèn)情況下char為8位,int和short為16位,long和long long為32位,該編譯器不支持64位。該處理器為大端模式、棧生長(zhǎng)方向?yàn)檫f減,其余的設(shè)置都很容易改動(dòng),這里不一一贅述。
(4)cpu_a.a(chǎn)sm
替代對(duì)應(yīng)的函數(shù)如下所示,其余的函數(shù)可以刪除(μC/OS—III沒(méi)有用到):

這幾個(gè)函數(shù)完成相應(yīng)的使能中斷、關(guān)閉中斷、保存中斷狀態(tài)并關(guān)閉、恢復(fù)中斷狀態(tài)這4個(gè)功能,都比較簡(jiǎn)單,這里不再贅述。
cpu_c.c文件中的函數(shù)其實(shí)都可以刪了,當(dāng)然也可以保留,因?yàn)檫@里面原來(lái)是一些關(guān)于中斷向量操作、位帶操作指令,這些都是特定于Cortex—M3的,S12X并沒(méi)有位操作的對(duì)應(yīng)指令。
最后是bsp.c和bsp.h,簡(jiǎn)單起見(jiàn),bsp.c只定義了如下函數(shù):
void BSP Init(void){
IRQCR=0x00;
RTICTL=0x74;
CRGINT|=0x80;
}
這算得上是最簡(jiǎn)單的“bsp包”了,僅僅設(shè)置并使能了RTI中斷作為系統(tǒng)時(shí)鐘中斷(當(dāng)然還關(guān)閉了IRQ中斷)。該函數(shù)需要在第一個(gè)運(yùn)行的用戶任務(wù)中調(diào)用,開(kāi)始μC/OS—III的心跳。
至此,所有必要的文件修改工作已經(jīng)完成。
2.5 第五步:調(diào)試運(yùn)行
經(jīng)過(guò)上述步驟,如果編譯、鏈接沒(méi)有什么問(wèn)題,寫(xiě)一個(gè)簡(jiǎn)單的應(yīng)用,借助調(diào)試器就可以對(duì)基于μC/OS—III的應(yīng)用進(jìn)行調(diào)試了。其實(shí)在移植的過(guò)程中,第四步的很多細(xì)節(jié)都是在第五步的調(diào)試中發(fā)現(xiàn)問(wèn)題并完善的。值得注意的是,由于MC9S12XDP512沒(méi)有32位的計(jì)數(shù)器,所以bsp.c里面也沒(méi)有初始化該計(jì)數(shù)器的代碼,也沒(méi)有提供系統(tǒng)所需的CPU_TS_TmrRd函數(shù),所以以下幾個(gè)宏應(yīng)該配置如下:
#defineOS_CFG_TS_EN 0u
#define OS_CFG_SCHED_LOCK_TIME_MEAS_EN 0u
不定義CPU_CFG_INT_DIS_MEAS_EN宏,在這種配置下,系統(tǒng)所有依賴于時(shí)間戳的功能都被關(guān)閉。其余的μC/OS—III組件都可以使能。

結(jié)語(yǔ)
使用CW5.1集成開(kāi)發(fā)環(huán)境的讀者,只要按照以上步驟,即可在S12X系列單片機(jī)上完成μC/OS—III的移植和運(yùn)行。本文還融入了筆者對(duì)于μC/OS—III的理解,希望能夠幫助讀者理解和熟悉μC/OS-III的移植工作,進(jìn)一步加深對(duì)于該款優(yōu)秀實(shí)時(shí)內(nèi)核的理解。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(liá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)越多用戶希望企業(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ā)表演講稱,數(shù)字世界的話語(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)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

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