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

當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]從Keil C51的內(nèi)存空間管理方式入手,著重討論實(shí)時(shí)操作系統(tǒng)在任務(wù)調(diào)度時(shí)的重入問(wèn)題,分析一些解決重入的基本方式與方法:分析實(shí)時(shí)操作系統(tǒng)任務(wù)調(diào)度的占先性,提出非占先的任務(wù)調(diào)度是能更適合于Keil C51的一種調(diào)度方式。

摘  要:從Keil C51的內(nèi)存空間管理方式入手,著重討論實(shí)時(shí)操作系統(tǒng)在任務(wù)調(diào)度時(shí)的重入問(wèn)題,分析一些解決重入的基本方式與方法:分析實(shí)時(shí)操作系統(tǒng)任務(wù)調(diào)度的占先性,提出非占先的任務(wù)調(diào)度是能更適合于Keil C51的一種調(diào)度方式。為此,構(gòu)造這一實(shí)時(shí)操作系統(tǒng),并有針對(duì)性地介紹此系統(tǒng)的堆管理方法、任務(wù)的建立以廈任務(wù)的切換等。
關(guān)鍵詞51單片機(jī) 實(shí)時(shí)操作系統(tǒng) 任務(wù)重八調(diào)度

    目前,大多數(shù)的產(chǎn)品開發(fā)是在基于一些小容量的單片機(jī)上進(jìn)行的。51系列單片機(jī),是我國(guó)目前使用最多的單片機(jī)系列之一,有非常廣大的應(yīng)用環(huán)境與前景,多年來(lái)的資源積累,使51系列單片機(jī)仍是許多開發(fā)者的首選。針對(duì)這種情況,近幾年涌現(xiàn)出許多基于51內(nèi)核的擴(kuò)展芯片,功能越來(lái)越齊全,速度越來(lái)越快,也從一個(gè)側(cè)面說(shuō)明了51系列單片機(jī)在國(guó)內(nèi)的生命力。

    多年來(lái)我們一直想找一個(gè)合適的實(shí)時(shí)操作系統(tǒng),作為自己的開發(fā)基礎(chǔ)。根據(jù)開發(fā)需求,整合一些常用的嵌入式構(gòu)件,以節(jié)約開發(fā)時(shí)間,盡最大可能地減少開發(fā)工作量;另外,要求這個(gè)實(shí)時(shí)操作系統(tǒng)能非常容易地嵌入到小容量的芯片中。畢竟,大系統(tǒng)是少數(shù)的,而小應(yīng)用是多數(shù)而廣泛的。顯而易見(jiàn),μC/OS—II是不太適合于以上要求的,而Keil C所帶的RTX Tiny不帶源代碼,不具透明性,至于其FULL版本就更不用說(shuō)了。

1 KeiI C51與重入問(wèn)題
    說(shuō)到實(shí)時(shí)操作系統(tǒng),就不能不考慮重入問(wèn)題。對(duì)于PC機(jī)這樣的大內(nèi)存處理器而言,這似乎并不是一個(gè)很麻煩的問(wèn)題,借用μC/OS—II RTOS的說(shuō)法,即要求在重入的函數(shù)內(nèi),使用局部變量。但5l系列單片機(jī)堆??臻g很小,僅局限在256字節(jié)之內(nèi),無(wú)法為每個(gè)函數(shù)都分配一個(gè)局部堆空間。正是由于這個(gè)原因,Keil C51使用了所謂的可覆蓋技術(shù):
    ①局部變量存儲(chǔ)在全局RAM空間(不考慮擴(kuò)展外部存儲(chǔ)器的情況);
    ②在編譯鏈接時(shí),即已經(jīng)完成局部變量的定位;
    ③如果各函數(shù)之間沒(méi)有直接或間接的調(diào)用關(guān)系,則其局部變量空間便可覆蓋。

    正是由于以上的原因,在Keil C51環(huán)境下,純粹的函數(shù)如果不加處理(如增加一個(gè)模擬棧),是無(wú)法重人的。那么在Keil C5l環(huán)境下,如何使其函數(shù)具有可重人性呢?下面分析在實(shí)時(shí)操作系統(tǒng)下面,任務(wù)的基本結(jié)構(gòu)與模式:
vold TaskA(void*ptr){
UINT8 vaL_a;
//其他一些變量定義
do{
//實(shí)際的用戶任務(wù)處理代碼
}while(1);
}
void TaskB(void*ptr){
UINT8 vaLb;
//其他一些變量定義
do{
Funcl();
//其他實(shí)際的用戶任務(wù)處理代碼
)while(1);
void Funcl(){
UlNT8 v al_fa;
//其他變量的定義
//函數(shù)的處理代碼
}

    在上面的代碼中,TaskA與TaskB并不存在直接或間接的調(diào)用關(guān)系,因而其局部變量val_a與val_b便是可以被互相覆蓋的,即其可能都被定位于某一個(gè)相同的RAM空間。這樣,當(dāng)TaskA運(yùn)行一段時(shí)間,改變了val_a后,TaskB取得CPU控制權(quán)并運(yùn)行時(shí),便可能會(huì)改變val_b。由于其指向相同的RAM空間,導(dǎo)致TaskA重新取得CPU控制權(quán)時(shí),val—a的值已經(jīng)改變,從而導(dǎo)致程序運(yùn)行不正確,反過(guò)來(lái)亦然。另一方面,F(xiàn)uncl()與TaskB有直接的調(diào)用關(guān)系,因而其局部變量val_fa與val_b不會(huì)被互相覆蓋,但也不能保證其局部變量val_fa不會(huì)與TaskA或其他任務(wù)的局部變量形成可覆蓋關(guān)系。

    將val_a、val_b以及val_fa等局部變量定義為靜態(tài)變量(加上static指示符)可以解決這一問(wèn)題。但問(wèn)題是,定義大量的static類型變量,將導(dǎo)致RAM空間的大量占用,有可能直接導(dǎo)致RAM空間不夠用。尤其是在一些小容量的單片機(jī)內(nèi),一般只有128或256字節(jié),大量的靜態(tài)變量定義,在如此小的RAM資源狀況下顯然就不太合適了。由此而有了另一種的解決方法,如下代碼所示:
void TaskC(void){
UINT8 x,v;
whlk(1){
OS_ENTER_CRITICAL();
x=GetX(); (1)
y=GetY(); (2)
//任務(wù)的其他代碼
OS_EXIT_CRITICAL(); (3)
0SSleep(100); (4)
}
}

    以上代碼TaskC中使用了臨界保護(hù)的方法來(lái)保護(hù)代碼不被中斷占先,確實(shí)有效地解決了RAM空間太小,不宜大量定義靜態(tài)變量的問(wèn)題。然而如果每個(gè)任務(wù)都采用此種結(jié)構(gòu),任務(wù)一開始,就關(guān)閉中斷,將使實(shí)時(shí)性得不到保證。事實(shí)證明,這種延時(shí)是相當(dāng)可觀的。用一個(gè)實(shí)例來(lái)說(shuō)明,如果想在系統(tǒng)中使用一個(gè)動(dòng)態(tài)刷新的LED顯示器,就難以保證顯示的穩(wěn)定與連續(xù),哪怕在系統(tǒng)中是使用一個(gè)單獨(dú)的定時(shí)器來(lái)做這一工作(進(jìn)入臨界區(qū)后,EA=0)。其次,這種結(jié)構(gòu)事實(shí)上將占先的任務(wù)調(diào)度轉(zhuǎn)化為非占先的任務(wù)調(diào)度。實(shí)際上如果在(3)與(4)之間沒(méi)有碰巧發(fā)生中斷并導(dǎo)致一個(gè)任務(wù)調(diào)度,那就可以理解為是任務(wù)主動(dòng)放棄CPU的控制。如果在(3)和(4)之間碰巧產(chǎn)生了一個(gè)中斷并導(dǎo)致了一個(gè)任務(wù)調(diào)度,只是執(zhí)行了一次多余的任務(wù)調(diào)度而已,而且并不希望在(3)之后發(fā)生2次甚至多次的任務(wù)調(diào)度,相信讀者也有這一愿望。

    除此之外,還可以發(fā)現(xiàn)任務(wù)的一個(gè)特點(diǎn):當(dāng)任務(wù)從(1)重新開始時(shí),局部變量x和y是一個(gè)什么值并不在乎,即x和y即使在(3)之后改變了,也已經(jīng)不再重要,不會(huì)影響程序的正確性。其實(shí)這一特點(diǎn)也是大部分任務(wù),至少是太部分任務(wù)的大部分局部變量的一個(gè)共性——如果任務(wù)在整個(gè)執(zhí)行過(guò)程中,不會(huì)(被占先)放棄CPU控制權(quán),則其局部變量大多數(shù)并不需要進(jìn)行特別的保護(hù),即其作用域只是任務(wù)的當(dāng)次執(zhí)行,針對(duì)上面的代碼,就是臨界保護(hù)區(qū)內(nèi)的代碼區(qū)域。

2 實(shí)時(shí)操作系統(tǒng)要不要占先
    由上面的分析,如果要保持一個(gè)函數(shù)可重人,就得使用靜態(tài)變量,系統(tǒng)的RAM資源將是一個(gè)嚴(yán)峻的考驗(yàn);如果使用臨界區(qū)來(lái)保護(hù)運(yùn)行環(huán)境,系統(tǒng)的實(shí)時(shí)性又得不到保證,而且有將占先式任務(wù)調(diào)度轉(zhuǎn)為非占先任務(wù)調(diào)度之虞。顯然,使用靜態(tài)變量簡(jiǎn)單,但有更多的不適用性,對(duì)將來(lái)功能的調(diào)整也是一個(gè)阻礙,一般不被采用。那么,就只能從環(huán)境保護(hù)上來(lái)下功夫了,但是果真只能以進(jìn)入臨界區(qū)犧牲系統(tǒng)的實(shí)時(shí)性來(lái)保證任務(wù)不被占先?下面看看臨界保護(hù)這一方法的基本思路:
    ①在一個(gè)任務(wù)中,如果局部變量在其作用域內(nèi)不被占先切換,則這些變量在任務(wù)被剝奪了CPU控制權(quán)后,不關(guān)心其值也不會(huì)影響任務(wù)的正確執(zhí)行;
    ②使用臨界區(qū)保護(hù),可以達(dá)到上面所提到的要求;
    ③由此導(dǎo)致的實(shí)時(shí)性能與占先切換的減弱可以接受。由此可知,不被占先是任務(wù)保護(hù)局部變量的關(guān)鍵。既然如此,何不舍棄占先式的任務(wù)調(diào)度?這不失為一個(gè)好的出發(fā)點(diǎn)。針對(duì)Keil C51,非占先式任務(wù)調(diào)度,可能是一種更好的方法,更能協(xié)調(diào)51系列單片機(jī)的既定資源。下面編寫這樣一個(gè)系統(tǒng):
    ①使用非占先式任務(wù)調(diào)度;
    ②可以在小容量的芯片中使用,開發(fā)目標(biāo)是,即使是8051這樣小的芯片,也可使用這個(gè)實(shí)時(shí)操作系統(tǒng);
    ③支持優(yōu)先級(jí)調(diào)度,盡可能保證其實(shí)時(shí)性。

3 實(shí)時(shí)操作系統(tǒng)的實(shí)現(xiàn)
    基于以上的分析與目的,近日完成了這個(gè)操作系統(tǒng)。在堆棧上借用RTx的管理方法,即當(dāng)前任務(wù)使用全部的堆空間,如圖1所示。

3.1 堆棧的初始化與任務(wù)的創(chuàng)建
    堆棧的初始化實(shí)際是初始化0STaskStackBotton數(shù)組,并將當(dāng)前任務(wù)指定為空閑任務(wù),下一個(gè)運(yùn)行任務(wù)指定為最高優(yōu)先級(jí)任務(wù),即優(yōu)先級(jí)為零的任務(wù)。初始化時(shí),將SP的值存人OSTaslkStackBotton[O],SP+2的值存入OSTaskStacKBotton[1],依此類推。而任務(wù)是調(diào)用0STa-skCreate函數(shù)建立的。實(shí)際上只是將任務(wù)(假設(shè)為n號(hào)任務(wù))的地址填人到對(duì)應(yīng)OSTaskStackBotton[n]所指向的位置,并將SP向后移動(dòng)2個(gè)字節(jié),如圖2所示。


    為什么要以這樣一種規(guī)律而不是其他的方式呢?這是由于在任務(wù)建立后,還未進(jìn)行任務(wù)調(diào)度之前,各任務(wù)的堆棧實(shí)際上是它們自身的地址,因而其堆棧深度為2,為了程序的簡(jiǎn)便而直接填入。
void main(void){
OSInit(); /*初始化OSTaskStackBcBotton隊(duì)列*/
TMOD=(TMOD&0XFO)│ 0XOl;
TL0=0xBF;
TH0=0xFC;
TRO=1;
ETO=1;
TFO=O:
OSTaskCreate(TaskA,NULL,0);
OSTaskCreate(TaskB.NULL,1);
OSTaskCreate(TaskC,NULL,2);
OSStart();

    上面這段代碼中,所有任務(wù)建立后,便調(diào)用OSStart()開始任務(wù)調(diào)度。OSStart()是一個(gè)宏定義,如下所示:
#deflne OSStart() d0{\
OSTaskCreate(TaskIdle,NULL,OS_MAX_TASKS);\
EA=l:\
return;\
}while(O)

    首先,它創(chuàng)建了一個(gè)空閑任務(wù)并打開中斷,然后便返回。返回到哪里了呢?我們知道,空閑任務(wù)是優(yōu)先級(jí)最低的任務(wù),當(dāng)調(diào)OSTaskCreate建立時(shí),會(huì)將其地址填人到SP的位置,并把SP向后移動(dòng)2個(gè)字節(jié)(見(jiàn)圖2及說(shuō)明),因而此時(shí)處在堆棧頂端的,一定是空閑任務(wù)Taslddle。這就使得這里的return一定會(huì)返回到空閑任務(wù)。至此,系統(tǒng)進(jìn)入正常運(yùn)行狀態(tài)。

3.2 任務(wù)的切換

    任務(wù)的切換分兩種情況,在當(dāng)前任務(wù)優(yōu)先級(jí)低于下一個(gè)取得CPU控制權(quán)的任務(wù)時(shí),將下一個(gè)取得CPU控制權(quán)的任務(wù)的棧頂?shù)疆?dāng)前任務(wù)的棧頂之間的內(nèi)容向RAM空間的高端搬移,以空出全部的RAM空間作下一個(gè)任務(wù)的堆空間,同時(shí)更新對(duì)應(yīng)的OSTaskStackBotton,使其指向新的正確任務(wù)的堆棧棧底。如果當(dāng)前任務(wù)的優(yōu)先級(jí)高于下一個(gè)任務(wù)的優(yōu)先級(jí),則作相反的搬移,如圖3與圖4所示。

    所有任務(wù)必須主動(dòng)調(diào)用OSSleep,放棄CPU的控制權(quán)。任務(wù)調(diào)用OSSleep后,將選擇優(yōu)先級(jí)最高的就緒任務(wù)運(yùn)行。

結(jié) 語(yǔ)
    系統(tǒng)完成后,內(nèi)核的代碼量在400多個(gè)字節(jié)左右,占用1個(gè)定時(shí)器中斷及小量的內(nèi)存空間。系統(tǒng)設(shè)置容量為8個(gè)任務(wù),用戶實(shí)際可用任務(wù)為7個(gè),能夠滿足一般需求,也達(dá)到了在小容量芯片中應(yīng)用的開發(fā)要求。由于沒(méi)有采用占先式的任務(wù)調(diào)度,除開全程相關(guān)的個(gè)別任務(wù)的一些局部變量外,其他局部變量已經(jīng)不存在覆蓋關(guān)系,由于是任務(wù)主動(dòng)放棄CPU控制權(quán),對(duì)于個(gè)別需要保護(hù)的變量單獨(dú)進(jìn)行處理也變得容易。在系統(tǒng)中,全程不需要反復(fù)地開關(guān)中斷,實(shí)時(shí)性能也很好。對(duì)個(gè)別時(shí)序要求嚴(yán)格的外設(shè)(如DSl8820)除外。

本站聲明: 本文章由作者或相關(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)系本站刪除。
換一批
延伸閱讀

舍弗勒以"專注驅(qū)動(dòng)技術(shù)的科技公司"為主題亮相IAA MOBILITY 2025(B3館B40展臺(tái)) 合并緯湃科技后首次亮相IAA MOBILITY,展示拓展后的汽車產(chǎn)品組合 憑借在軟件、...

關(guān)鍵字: 電氣 軟件 驅(qū)動(dòng)技術(shù) BSP

香港2025年 9月12日 /美通社/ -- 全球領(lǐng)先的互聯(lián)網(wǎng)社區(qū)創(chuàng)建者 - 網(wǎng)龍網(wǎng)絡(luò)控股有限公司 ("網(wǎng)龍"或"本公司",香港交易所股票代碼:777)欣然宣布,其子公司My...

關(guān)鍵字: AI 遠(yuǎn)程控制 控制技術(shù) BSP

深圳2025年9月11日 /美通社/ -- 2025 年 9 月 10 日,第 26 屆中國(guó)國(guó)際光電博覽會(huì)(簡(jiǎn)稱 "CIOE 中國(guó)光博會(huì)")在深圳盛大開幕。本屆展會(huì)吸引力再創(chuàng)新高,全球超3800家優(yōu)質(zhì)...

關(guān)鍵字: 自動(dòng)化 光電 CIO BSP

天津2025年9月11日 /美通社/ -- 國(guó)際能源署(IEA)數(shù)據(jù)顯示,2024 年全球數(shù)據(jù)中心電力消耗達(dá) 415 太瓦時(shí),占全球總用電量的 1.5%,預(yù)計(jì)到 2030 年,這一數(shù)字將飆升至 945 太瓦時(shí),近乎翻番,...

關(guān)鍵字: 模型 AI 數(shù)據(jù)中心 BSP

北京2025年9月11日 /美通社/ -- 國(guó)際9月11日上午,2025年中國(guó)國(guó)際服務(wù)貿(mào)易交易會(huì)(以下簡(jiǎn)稱"服貿(mào)會(huì)")—體育賽事經(jīng)濟(jì)高質(zhì)量發(fā)展大會(huì)現(xiàn)場(chǎng),北京經(jīng)濟(jì)技術(shù)開發(fā)區(qū)工委委員、管委會(huì)副主...

關(guān)鍵字: 5G BSP GROUP MOTOR

柏林2025年9月9日 /美通社/ -- 2025年9月5日,納斯達(dá)克上市公司優(yōu)克聯(lián)集團(tuán)(NASDAQ: UCL)旗下全球互聯(lián)品牌GlocalMe,正式亮相柏林國(guó)際消費(fèi)電子展(IFA 2025),重磅推出融合企...

關(guān)鍵字: LOCAL LM BSP 移動(dòng)網(wǎng)絡(luò)

深圳2025年9月9日 /美通社/ -- PART 01活動(dòng)背景 當(dāng)技術(shù)的鋒芒刺穿行業(yè)壁壘,萬(wàn)物互聯(lián)的生態(tài)正重塑產(chǎn)業(yè)疆域。2025年,物聯(lián)網(wǎng)產(chǎn)業(yè)邁入?"破界創(chuàng)造"與"共生進(jìn)化"?的裂變時(shí)代——AI大模型消融感知邊界,...

關(guān)鍵字: BSP 模型 微信 AIOT

"出海無(wú)界 商機(jī)無(wú)限"助力企業(yè)構(gòu)建全球競(jìng)爭(zhēng)力 深圳2025年9月9日 /美通社/ -- 2025年8月28日, 由領(lǐng)先商業(yè)管理媒體世界經(jīng)理人攜手環(huán)球資源聯(lián)合主辦、深圳?前海出海e站通協(xié)辦的...

關(guān)鍵字: 解碼 供應(yīng)鏈 AI BSP

柏林2025年9月9日 /美通社/ -- 柏林當(dāng)?shù)貢r(shí)間9月6日,在2025德國(guó)柏林國(guó)際電子消費(fèi)品展覽會(huì)(International Funkausstellung...

關(guān)鍵字: 掃地機(jī)器人 耳機(jī) PEN BSP

武漢2025年9月9日 /美通社/ -- 7月24日,2025慧聰跨業(yè)品牌巡展——湖北?武漢站在武漢中南花園酒店隆重舉辦!本次巡展由慧聰安防網(wǎng)、慧聰物聯(lián)網(wǎng)、慧聰音響燈光網(wǎng)、慧聰LED屏網(wǎng)、慧聰教育網(wǎng)聯(lián)合主辦,吸引了安防、...

關(guān)鍵字: AI 希捷 BSP 平板
關(guān)閉