国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

uCOS-II系統(tǒng)開(kāi)發(fā)的6條重要總結(jié)

發(fā)布時(shí)間:2018-4-20 15:58    發(fā)布者:嵌入式之家666
uC/OS-II是一個(gè)簡(jiǎn)潔、易用的基于優(yōu)先級(jí)的嵌入式搶占式多任務(wù)實(shí)時(shí)內(nèi)核。盡管它非常簡(jiǎn)單,但是它的確在很大程度上解放了我的嵌入式開(kāi)發(fā)工作。既然是一個(gè)操作系統(tǒng)內(nèi)核,那么一旦使用它,就會(huì)涉及到如何基于操作系統(tǒng)設(shè)計(jì)應(yīng)用軟件的問(wèn)題。
1. uC/OS-II的任務(wù)框架
void  task_xxx(void *pArg)

{

/* 該任務(wù)的初始化工作 */

……   

/* 進(jìn)入該任務(wù)的死循環(huán) */

while(1)

{

……

}

}

每個(gè)用戶的任務(wù)都必須符合事件驅(qū)動(dòng)的編程模型,即uC/OS-II的應(yīng)用程序都必須是“事件驅(qū)動(dòng)的編程模型”。一個(gè)任務(wù)首先等待一個(gè)事件的發(fā)生,事件可以是系統(tǒng)中斷發(fā)出的,也可以是其它任務(wù)發(fā)出的,又可以是任務(wù)自身等待的時(shí)間片。當(dāng)一個(gè)事件發(fā)生了,任務(wù)再作相應(yīng)處理,處理結(jié)束后又開(kāi)始等待下一個(gè)事件的發(fā)生。如此周而復(fù)始的任務(wù)處理模型就是“事件驅(qū)動(dòng)的編程模型”。事件驅(qū)動(dòng)模型也涵蓋了中斷驅(qū)動(dòng)模型,uC/OS-II事件歸根結(jié)底來(lái)自三個(gè)方面:

(1)中斷服務(wù)函數(shù)發(fā)送的事件

(2)系統(tǒng)延時(shí)時(shí)間到所引起的

(3)其它任務(wù)發(fā)送的事件。

其中“中斷服務(wù)函數(shù)發(fā)送的事件”就是指每當(dāng)有硬件中斷發(fā)生,那么中斷服務(wù)程序就會(huì)以事件的形式告訴任務(wù),而等待該事件的最高優(yōu)先級(jí)任務(wù)就會(huì)馬上得以運(yùn)行;“系統(tǒng)延時(shí)時(shí)間到所引起的”事件其實(shí)也是硬件中斷導(dǎo)致的,那就是系統(tǒng)定時(shí)器中斷。而“其它任務(wù)發(fā)送的事件”則是由任務(wù)代碼自身決定的,這是完全的“軟事件”。不管“軟事件”還是“硬事件”,反正引起uC/OS-II任務(wù)切換的原因就是“事件”,所以用戶編寫(xiě)應(yīng)用代碼的時(shí)候一定要體現(xiàn)出“事件驅(qū)動(dòng)的編程模型”。

2.uC/OS-II的任務(wù)優(yōu)先級(jí)分配

uC/OS-II的任務(wù)優(yōu)先級(jí)分配需要按照不同的系統(tǒng)設(shè)計(jì)具體分析。比如,對(duì)實(shí)時(shí)性要求越高的任務(wù),則優(yōu)先級(jí)要越高。

3.uC/OS-II的軟件層次

uC/OS-II會(huì)直接操縱硬件,比如:任務(wù)切換代碼必然要保存和恢復(fù)CPU及協(xié)處理器的寄存器;uC/OS-II的內(nèi)核時(shí)基時(shí)鐘就需要硬件定時(shí)器的中斷。

BSP就是“板極支持包”,它包括基于uC/OS-II而開(kāi)發(fā)的事件驅(qū)動(dòng)模型、支持多任務(wù)的驅(qū)動(dòng)程序,這些驅(qū)動(dòng)程序直接控制各個(gè)硬件模塊并利用uC/OS-II的系統(tǒng)函數(shù)來(lái)實(shí)現(xiàn)多任務(wù)功能,它們應(yīng)該盡量避免應(yīng)用程序直接操縱硬件和uC/OS-II內(nèi)核。BSP還應(yīng)該為應(yīng)用程序提供標(biāo)準(zhǔn)、統(tǒng)一的API,以達(dá)到軟件層次分明、應(yīng)用軟件代碼可復(fù)用的目的。

應(yīng)用程序就是用戶為具體應(yīng)用需要而開(kāi)發(fā)的軟件,它必須符合uC/OS-II的編程模型,即“事件驅(qū)動(dòng)的編程模型”。應(yīng)用程序還應(yīng)該盡量避免直接控制硬件和直接調(diào)用uC/OS-II系統(tǒng)函數(shù)、變量,一個(gè)完善的uC/OS-II系統(tǒng)是不需要應(yīng)用程序來(lái)針對(duì)具體硬件而設(shè)計(jì)的。也就是說(shuō),uC/OS-II必須擁有完備的設(shè)備驅(qū)動(dòng)程序,而驅(qū)動(dòng)程序和BSP共同提供完備、標(biāo)準(zhǔn)的API。

4.uC/OS-II中使用互斥信號(hào)對(duì)象應(yīng)該注意

互斥信號(hào)對(duì)象(Mutual Exclusion Semaphore)簡(jiǎn)稱Mutex,是uC/OS-II的內(nèi)核對(duì)象之一,用于管理那些需要獨(dú)占訪問(wèn)的資源,并使其適應(yīng)多任務(wù)環(huán)境。

創(chuàng)建每一個(gè)Mutex,都需要指定一個(gè)空閑的優(yōu)先級(jí)號(hào),這個(gè)優(yōu)先級(jí)號(hào)的優(yōu)先級(jí)必須比所有可能使用此Mutex的任務(wù)的優(yōu)先級(jí)都高!

uC/OS-II的Mutex實(shí)現(xiàn)原理大致如下:

當(dāng)一個(gè)低優(yōu)先級(jí)的任務(wù)A申請(qǐng)并得到了Mutex,于是它獲得資源訪問(wèn)權(quán)。如果此后有一個(gè)高優(yōu)先級(jí)的任務(wù)B開(kāi)始運(yùn)行(此時(shí)任務(wù)A已經(jīng)被剝奪),而且也要求得到Mutex,系統(tǒng)就會(huì)把任務(wù)A的優(yōu)先級(jí)提高到Mutex所指定的優(yōu)先級(jí)。由于此優(yōu)先級(jí)高于任何可能使用此Mutex的任務(wù)的優(yōu)先級(jí),所以任務(wù)A會(huì)馬上獲得CPU控制權(quán)。一直到任務(wù)A釋放Mutex,任務(wù)A才回到它原有的優(yōu)先級(jí),這時(shí)任務(wù)B就可以擁有該Mutex了。

應(yīng)該注意的是:當(dāng)任務(wù)A得到Mutex后,就不要再等待其它內(nèi)核對(duì)象(諸如:信號(hào)量、郵箱、隊(duì)列、事件標(biāo)志等等)了,而應(yīng)該盡量快速的完成工作,釋放Mutex。否則,這樣的Mutex就失去了作用,而且效果比直接使用信號(hào)量(Sem)更糟糕!

雖然普通的信號(hào)量(Sem)也可以用于互斥訪問(wèn)某獨(dú)占資源,但是它可能引起“優(yōu)先級(jí)反轉(zhuǎn)”的問(wèn)題。假設(shè)上面的例子使用的是Sem,當(dāng)任務(wù)A得到Sem后,那么任務(wù)C(假設(shè)任務(wù)C的優(yōu)先級(jí)比A高,但比B低)就緒的話將獲得CPU控制權(quán),于是任務(wù)A和任務(wù)B都被剝奪CPU控制權(quán)。任務(wù)C的優(yōu)先級(jí)比B低,卻優(yōu)先得到了CPU!而如果任務(wù)A是優(yōu)先級(jí)最低的任務(wù),那么它就要等到所有比它優(yōu)先級(jí)高的任務(wù)都掛起之后才會(huì)擁有CPU,那么任務(wù)B(優(yōu)先級(jí)最高的任務(wù))跟著它一起倒霉!這就是優(yōu)先級(jí)反轉(zhuǎn)問(wèn)題,這是違背“基于優(yōu)先級(jí)的搶占式多任務(wù)實(shí)時(shí)操作系統(tǒng)”原則的!

綜上所述,uC/OS-II中多個(gè)任務(wù)訪問(wèn)獨(dú)占資源時(shí),最好使用Mutex,但是Mutex是比較消耗CPU時(shí)間和內(nèi)存的。如果某高優(yōu)先級(jí)的任務(wù)要使用獨(dú)占資源,但是不在乎久等的情況下,就可以使用Sem,因?yàn)镾em是最高效最省內(nèi)存的內(nèi)核對(duì)象。

5.uC/OS-II應(yīng)用程序調(diào)用OSSchedLock()和OSSchedUnlock()函數(shù)應(yīng)注意

uC/OS-II的OSSchedLock()和OSSchedUnlock()函數(shù)允許應(yīng)用程序鎖定當(dāng)前任務(wù)不被其它任務(wù)搶占。使用時(shí)應(yīng)當(dāng)注意的是:當(dāng)你調(diào)用了OSSchedLock()之后,而在調(diào)用OSSchedUnlock()之前,千萬(wàn)不要再調(diào)用諸如OSFlagPend()、OSMboxPend()、OSMutexPend()、OSQPend()、OSSemPend()之類的事件等待函數(shù)!而且應(yīng)當(dāng)確保OSSchedLock()和OSSchedUnlock()函數(shù)成對(duì)出現(xiàn),特別是在有些分支條件語(yǔ)句中,要考慮各種分支情況,不要有遺漏!

需要一并提醒用戶的是:當(dāng)您調(diào)用開(kāi)關(guān)中斷函數(shù)OS_ENTER_CRITICAL()和OS_EXIT_CRITICAL()時(shí)也要確保成對(duì)出現(xiàn),否則系統(tǒng)將可能崩潰!不過(guò),在OS_ENTER_CRITICAL()和OS_EXIT_CRITICAL()函數(shù)之間調(diào)用OSFlagPend()、OSMboxPend()、OSMutexPend()、OSQPend()、OSSemPend()之類的事件等待函數(shù)是允許的。

6.uC/OS-II驅(qū)動(dòng)程序編寫(xiě)規(guī)范,特別推薦

首先應(yīng)該闡明的是,我們這里討論的是“驅(qū)動(dòng)程序”,而不是“中斷服務(wù)程序”,這兩個(gè)詞語(yǔ)往往被用戶混淆。

(1)中斷服務(wù)程序指那種硬件中斷一旦發(fā)生,就會(huì)立即被硬件中斷控制器調(diào)用的一小段程序,它的操作追求簡(jiǎn)單明了,越快速越精簡(jiǎn)就越好。

(2)驅(qū)動(dòng)程序是指封裝了某種硬件操作細(xì)節(jié)的函數(shù)集,它提供給應(yīng)用程序的是統(tǒng)一、標(biāo)準(zhǔn)、清晰、易用的API。

對(duì)于中斷服務(wù)程序的編寫(xiě),往往與驅(qū)動(dòng)程序的設(shè)計(jì)相關(guān)聯(lián)。比如驅(qū)動(dòng)程序提供異步操作的功能,那么就需要中斷服務(wù)程序?yàn)樗鼫?zhǔn)備緩沖區(qū)和一個(gè)結(jié)構(gòu)體,并且中斷服務(wù)程序會(huì)依照這個(gè)結(jié)構(gòu)體的成員參數(shù)自動(dòng)完成所要求的操作。又如,串口(UART)中斷服務(wù)程序的設(shè)計(jì)有兩種:基于數(shù)據(jù)包傳輸和基于單字節(jié)傳輸,前者適用于以數(shù)據(jù)包為單位的通信程序,而后者適用于如超級(jí)終端這樣的應(yīng)用程序。

如果在一個(gè)系統(tǒng)中,要求使用同一個(gè)硬件設(shè)備完成幾種不同的操作方式,就需要設(shè)計(jì)一個(gè)通用的驅(qū)動(dòng)程序,而該驅(qū)動(dòng)程序可以根據(jù)需要安裝各種針對(duì)性很強(qiáng)的中斷服務(wù)程序。

在設(shè)計(jì)驅(qū)動(dòng)程序時(shí),特別需要注意的是,某些外設(shè)的操作往往以一個(gè)連續(xù)而嚴(yán)格的時(shí)序作為原子操作,比如用I/O端口來(lái)訪問(wèn)DS1302、24C01、LM75A等等。在這類設(shè)備的操作過(guò)程中,不允許有其它任務(wù)來(lái)控制對(duì)應(yīng)的I/O端口,否則會(huì)引起數(shù)據(jù)錯(cuò)誤甚至器件損壞。所以,這種設(shè)備的驅(qū)動(dòng)程序都應(yīng)該仔細(xì)設(shè)計(jì)“原子操作”,把必須連貫操作的時(shí)序控制代碼用互斥對(duì)象封裝成一個(gè)“原子操作”,以適應(yīng)多任務(wù)環(huán)境。其實(shí),大部分設(shè)備都是這樣,需要確定“原子操作”,如LCD、RTL8019AS、Flash等等也是如此。

1.AI時(shí)代FPGA廠商與FPGA工程師該如何轉(zhuǎn)型?
2.介紹幾款嵌入式開(kāi)發(fā)工具,或許能用上!
3.牛人已經(jīng)總結(jié)了單片機(jī)應(yīng)用程序架構(gòu),去看即可!
4.4 月編程語(yǔ)言排行榜:萬(wàn)年不變的前三
5.通過(guò)這 9 本開(kāi)源好書(shū)學(xué)習(xí) C 語(yǔ)言
6.ARM寄存器與匯編指令詳解
更多嵌入式學(xué)習(xí),歡迎咨詢余工Q 二八五九七八零二零三

本文地址:http://www.qingdxww.cn/thread-524756-1-1.html     【打印本頁(yè)】

本站部分文章為轉(zhuǎn)載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀點(diǎn)和對(duì)其真實(shí)性負(fù)責(zé);文章版權(quán)歸原作者及原出處所有,如涉及作品內(nèi)容、版權(quán)和其它問(wèn)題,我們將根據(jù)著作權(quán)人的要求,第一時(shí)間更正或刪除。
您需要登錄后才可以發(fā)表評(píng)論 登錄 | 立即注冊(cè)

廠商推薦

  • Microchip視頻專區(qū)
  • 5分鐘詳解定時(shí)器/計(jì)數(shù)器E和波形擴(kuò)展!
  • 想要避免發(fā)生災(zāi)難,就用MPLAB® SiC電源仿真器!
  • PIC18-Q71系列MCU概述
  • 為何選擇集成電平轉(zhuǎn)換?
  • 貿(mào)澤電子(Mouser)專區(qū)
關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點(diǎn)地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權(quán)所有   京ICP備16069177號(hào) | 京公網(wǎng)安備11010502021702
快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 亚洲性爰视频 | 青青草华人在线视频 | 日色网站 | a爱爱视频 | 久久精品国产一区二区三区不卡 | 色噜噜色偷偷 | 久久精品视频网站 | 成人性毛片 | 久久99精品久久久久久首页 | 国产91视频观看 | 成年女人免费毛片视频永久 | 无毒不卡| 欧美人与动交tv | 亚洲一区二区免费看 | 在线观看黄日本高清视频 | 免费中文字幕一级毛片 | 久久国产乱子伦精品免费不卡 | 高清成年美女黄网站色大 | 国产91网站在线观看免费 | 香蕉社区 | 草莓香蕉绿巨人丝瓜榴莲18 | 亚洲成人网在线播放 | 欧美多人三级级视频播放 | 日韩字幕一中文在线综合 | 欧美国产精品不卡在线观看 | 在线免费观看亚洲 | 日韩精品视频在线免费观看 | 精品久久久久久久一区二区伦理 | 成年人视频免费在线观看 | 一区二区欧美视频 | 欧美v亚洲 | 精品欧美一区二区三区精品久久 | 婷婷七月丁香 | 一级一级女人18毛片 | 精品日韩一区二区三区 | 国产又粗又爽又大又长免费视 | 欧美亚洲综合另类 | 自拍视频一区二区 | 国产大片中文字幕在线观看 | 国产一卡二卡3卡4卡无卡下载 | 家庭教师动漫在线观看 |