0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

單片機(jī)資源少但是不能拒絕RTOS

5RJg_mcuworld ? 來源:smallrtos源碼 陳明計(jì) ? 作者:smallrtos源碼 陳明 ? 2018-03-19 15:10 ? 次閱讀

對于搞單片機(jī)的特別用8051系列工程師來說,談到單片機(jī)的RTOS,很多時(shí)候會(huì)問一句:“為什么要用RTOS?單片機(jī)就這一點(diǎn)資源,使用RTOS能保證效率嗎?”

對于這個(gè)問題,我會(huì)反問:“你用單片機(jī)的目的是什么?是為了用單片機(jī)的C編程,單片機(jī)的匯編編程甚至于用單片機(jī)的二進(jìn)制指令編程?”上個(gè)世紀(jì)80年代,工程師用二進(jìn)制指令給Z80編程,現(xiàn)在還有誰在用?現(xiàn)在還有人死抱著匯編不放,但越來越多的人工程師使用C編程(我起初也是使用匯編的),為什么?因?yàn)槲覀兊哪康氖窃谟邢薜臅r(shí)間甚至是不充足的時(shí)間內(nèi)把項(xiàng)目保質(zhì)保量的完成!使用什么工具和方法是次要的(如果你的項(xiàng)目以成本放在第一位,則另當(dāng)別論,這時(shí),也是要考慮開發(fā)時(shí)間的)。時(shí)間就是金錢啊,一個(gè)產(chǎn)品在單片機(jī)上增加些許成本是可以接受的。況且,使用8051系列單片機(jī)時(shí),單片機(jī)資源也常有富余,CPU一般情況也只是空轉(zhuǎn),這就為它使用RTOS創(chuàng)造了條件。

那么,使用RTOS的好處呢?我舉一個(gè)例子吧。假設(shè)我們編一個(gè)串行通訊程序,通訊協(xié)議如下:

數(shù)據(jù)包長度為NBYTE,起始字節(jié)為STARTBYTE1,STARTBYTE2,最后一個(gè)字節(jié)為檢驗(yàn)和,中間字節(jié)不可能出現(xiàn)連續(xù)出現(xiàn)STARTBYTE1,STARTBYTE2。

第一種方法,在中斷中處理協(xié)議:

unsigned char Buf[NBYTE-2];bit GetRight=0;

void comm(void) interrupt 4//"串行口中斷"{

static unsigned char Sum,Flag=0,i;

unsigned char temp;

if(RI==1)

{

RI=0;

temp=SBUF;

switch(Flag)

{

case 0:

if(temp==STARTBYTE1)

{

Flag=1;

}

break;

case 1:

if(temp==STARTBYTE2)

{

Sum=STARTBYTE1+STARTBYTE2;

i=0;

Flag=2;

break;

}

if(temp==STARTBYTE1) break;

Flag=0;

break;

case 2:

if(temp==STARTBYTE1)

{

Flag=3;

break;

}

Sum+=temp;

if((i>=(NBYTE-3))&&Sum==0)

{

GetRight=1;

Flag=0;

break;

}

Buf[i++]=temp;

break;

case 3:

if(temp==STARTBYTE2)

{

Sum=STARTBYTE1+STARTBYTE2;

Flag=2;

i=0;

break;

}

Sum+=STARTBYTE1;

if((i>=(NBYTE-3))&&Sum==0)

{

GetRight=1;

Flag=0;

break;

}

Buf[i++]=STARTBYTE1;

if(temp==STARTBYTE1)

{

break;

}

Sum+=temp;

if((i>=(NBYTE-3))&&Sum==0)

{

GetRight=1;

Flag=0;

break;

}

Buf[i++]=temp;

Flag=2;

break;

}

}}

第二種方法,使用隊(duì)列中斷函數(shù):

void comm(void) interrupt 4//"串行口中斷"{

if(RI==1)

{

RI=0;

SBUF 入隊(duì);

}}

主程序不斷調(diào)用的函數(shù):

unsigned char Buf[NBYTE-2];

unsigned char ReadSerial(unsigned char *cp){

unsigned char i;

unsigned char temp,Sum;

temp=隊(duì)列中數(shù)據(jù)個(gè)數(shù);

if(temp<(NBYTE)) return 0;

出隊(duì) temp;

if(temp!=STARTBYTE1) return 0;

temp=隊(duì)列首字節(jié);

if(temp!=STARTBYTE2) return 0;

出隊(duì) temp;

sum=STARTBYTE1+STARTBYTE2;

for(i=0;i

{

temp=隊(duì)列首字節(jié);

if(temp==STARTBYTE1)

{

temp=隊(duì)列次首字節(jié);

if(temp==STARTBYTE2) return 0;

}

出隊(duì) temp;

*cp++=temp;

Sum+=temp;

}

temp=隊(duì)列首字節(jié);

Sum+=temp;

if(Sum!=0) return 0;

出隊(duì) temp;

return 1;}

第三種方法,使用RTOS中斷函數(shù):

void comm(void) interrupt 4//"串行口中斷"{

OS_INT_ENTER();

if(RI==1)

{

RI=0;

OSIntSendSignal(RECIVE_TASK_ID);

}

OSIntExit();}

ID為RECIVE_TASK_ID的任務(wù)

void Recuve(void){

unsigned char temp,temp1,Sum,i;

OSWait(K_SIG,0);

temp=SBUF;

while(1)

{

while(1)

{

OSWait(K_SIG,0);

temp1=SBUF;

if((temp==STARTBYTE1)&&(temp1==STARTBYTE2)) break;

temp=temp1;

}

Sum=STARTBYTE1+STARTBYTE2;

OSWait(K_SIG,0);

temp=SBUF;

for(i=0;i

{

OSWait(K_SIG,0);

temp1=SBUF;

if((temp==STARTBYTE1)&&(temp1==STARTBYTE2))

{

OSWait(K_SIG,0);

temp=SBUF;

i=-1;

Sum=STARTBYTE1+STARTBYTE2;

continue;

}

Buf[i]=temp;

Sum+=temp;

temp=temp1;

}

Sum+=temp1;

if(Sum==0) OSSendSignal(命令解釋任務(wù) ID);

}}

以下為這幾種方法的比較:

可讀性和編程容易性方面,第三鐘方法最好(如果允許使用goto語句,程序更加簡單易讀),第二種次之(因?yàn)橐庩?duì)列程序),第一種最差。如果協(xié)議更加復(fù)雜,這方面更加明顯。程序簡單易讀,自然出錯(cuò)機(jī)會(huì)小了。

RAM占用方面,第三種方法較少,第二種最多(因?yàn)殛?duì)列占用大量空間),第一種最少。

中斷執(zhí)行時(shí)間方面,第三種方法最長,第二種最短,第一種較長。

從功能方面,第三種方法最強(qiáng),它還可以進(jìn)行超時(shí)處理(雖然例子程序沒有),其它方法均不行。

如果數(shù)據(jù)來的太快,命令處理程序來不及處理,三種方法處理方式不太一樣,第一種和第三種方法類似:丟棄以前數(shù)據(jù),第二種則是丟棄后到的數(shù)據(jù)。而且,第二種方法必須等命令處理程序完成后才處理下一個(gè)數(shù)據(jù)包,而第一種和第三種方只需命令處理程序?qū)?shù)據(jù)收取后就可處理下一個(gè)數(shù)據(jù)包。也就是說,第一種和第三種與命令處理程序并行處理,第二種方法為串行處理。

現(xiàn)在,一般情況下,開發(fā)的效率第一,執(zhí)行的效率(包括執(zhí)行時(shí)間和資源占用)第二。在這種情況下,降低些許效率換取開發(fā)的效率的較大提高,何樂而不為?何況,單個(gè)模塊的執(zhí)行的效率高不等于整個(gè)程序執(zhí)行效率高。例如,如果程序需要等待一段時(shí)間,一般用程序延時(shí)或定時(shí)器延時(shí)。無論何種方法,CPU不再處理其它工作,效率很低。而用RTOS,等待的時(shí)候CPU可以處理其它工作,效率得到提高。

以下摘自《uC/OS-II--源碼公開的實(shí)時(shí)嵌入式操作系統(tǒng)

“實(shí)時(shí)內(nèi)核也稱為實(shí)時(shí)操作系統(tǒng)或RTOS。使用它使得實(shí)時(shí)應(yīng)用程序的設(shè)計(jì)和擴(kuò)展變得容易。不需要大的改動(dòng)就可以增加新的功能。通過應(yīng)用程序分割為若干獨(dú)立的任務(wù),RTOS使得應(yīng)用程序的設(shè)計(jì)過程大為簡化。使用可剝奪性的內(nèi)核時(shí),所有時(shí)間要求苛刻的事件都得到了盡可能快捷、有效的處理。通過有效的服務(wù);如信號量、郵箱、隊(duì)列、延時(shí)、超時(shí)等;RTOS使得資源得到更好的利用。

“如果應(yīng)用項(xiàng)目對額外的需求可以承受,應(yīng)該考慮使用實(shí)時(shí)內(nèi)核。這些額外的需求是:內(nèi)核的價(jià)格,額外ROM/RAM開銷,2至4百分點(diǎn)的CPU額外負(fù)擔(dān)。

“還有沒提到的一個(gè)因素是使用實(shí)時(shí)內(nèi)核增加的價(jià)格成本。在一些應(yīng)用中,價(jià)格就是一切,以至于對使用RTOS連想都不敢想?!?/p>

總而言之,適用的就是最好的,不要拒絕RTOS,在它適用的情況下,它工作得很好。(來源:smallrtos源碼 陳明計(jì)


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 單片機(jī)
    +關(guān)注

    關(guān)注

    6023

    文章

    44376

    瀏覽量

    628402
  • RTOS
    +關(guān)注

    關(guān)注

    20

    文章

    804

    瀏覽量

    119115
  • 匯編
    +關(guān)注

    關(guān)注

    2

    文章

    214

    瀏覽量

    25834

原文標(biāo)題:單片機(jī)就那點(diǎn)資源,為啥還要用RTOS?

文章出處:【微信號:mcuworld,微信公眾號:嵌入式資訊精選】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    單片機(jī)資源這么小,還要用RTOS干啥子?

    轉(zhuǎn)自《嵌入式咨詢精選》對于搞單片機(jī)的特別用8051系列工程師來說,談到單片機(jī)RTOS,很多時(shí)候會(huì)問一句:“為什么要用RTOS?單片機(jī)就這一
    發(fā)表于 03-02 15:21

    單片機(jī)為什么要用RTOS

    對于搞單片機(jī)的特別用8051系列工程師來說,談到單片機(jī)RTOS,很多時(shí)候會(huì)問一句:“為什么要用RTOS?單片機(jī)就這一點(diǎn)
    發(fā)表于 12-09 08:29

    單片機(jī)應(yīng)用系統(tǒng)資源擴(kuò)展_從零開始學(xué)習(xí)單片機(jī)系列

    【從零開始學(xué)習(xí)單片機(jī)系列】第09章單片機(jī)應(yīng)用系統(tǒng)資源擴(kuò)展
    發(fā)表于 01-06 17:36 ?0次下載

    單片機(jī)外部擴(kuò)展資源與應(yīng)用

    單片機(jī)外部擴(kuò)展資源與應(yīng)用,單片機(jī)學(xué)習(xí)資料,新手可以下載學(xué)習(xí),適用于初學(xué)者
    發(fā)表于 07-15 17:21 ?6次下載

    開源RTOS在STM32單片機(jī)中的應(yīng)用

    開源RTOS在STM32單片機(jī)中的應(yīng)用
    發(fā)表于 09-25 09:50 ?20次下載
    開源<b class='flag-5'>RTOS</b>在STM32<b class='flag-5'>單片機(jī)</b>中的應(yīng)用

    單片機(jī)資源這么為什么還要用RTOS

    對于搞單片機(jī)的特別用8051系列工程師來說,談到單片機(jī)RTOS,很多時(shí)候會(huì)問一句:“為什么要用RTOS?單片機(jī)就這一點(diǎn)
    發(fā)表于 07-11 17:39 ?1次下載
    <b class='flag-5'>單片機(jī)</b><b class='flag-5'>資源</b>這么<b class='flag-5'>少</b>為什么還要用<b class='flag-5'>RTOS</b>

    如何設(shè)計(jì)一個(gè)節(jié)約單片機(jī)端口資源的鍵盤電路

    鍵盤電路是單片機(jī)應(yīng)用系統(tǒng)最常用的人機(jī)接口,往往要占用較多的I/O端口,利用本文介紹的電路,可以最大限度地減少鍵盤電路對I/O端口的點(diǎn)用。本電路特別適合一些引腳、結(jié)構(gòu)緊湊的單片機(jī),可為其節(jié)省寶貴的I/O
    的頭像 發(fā)表于 05-05 12:08 ?4096次閱讀
    如何設(shè)計(jì)一個(gè)節(jié)約<b class='flag-5'>單片機(jī)</b>端口<b class='flag-5'>資源</b>的鍵盤電路

    51單片機(jī)上跑RTOS會(huì)有意義嗎?

    最近看見我的一個(gè)技術(shù)交流群在討論一個(gè)問題:在51單片機(jī)上跑RTOS有沒有意義? 今天就來圍繞51和RTOS展開講講。 1關(guān)于51單片機(jī)及性能和資源
    的頭像 發(fā)表于 05-27 17:34 ?2219次閱讀

    基于STM32單片機(jī)的串口通信資源

    基于STM32單片機(jī)的串口通信資源
    發(fā)表于 07-05 09:13 ?21次下載

    單片機(jī):內(nèi)部資源

    1.1 單片機(jī)的內(nèi)部資源在這里我所講到的單片機(jī)內(nèi)部資源,和傳統(tǒng)單片機(jī)書籍講單片機(jī)內(nèi)部結(jié)構(gòu)不同,我
    發(fā)表于 11-18 10:21 ?40次下載
    <b class='flag-5'>單片機(jī)</b>:內(nèi)部<b class='flag-5'>資源</b>

    單片機(jī)就那點(diǎn)資源,為啥還要用RTOS

    對于搞單片機(jī)的特別用8051系列工程師來說,談到單片機(jī)RTOS,很多時(shí)候會(huì)問一句:“為什么要用RTOS?單片機(jī)就這一點(diǎn)
    發(fā)表于 11-26 14:36 ?1次下載
    <b class='flag-5'>單片機(jī)</b>就那點(diǎn)<b class='flag-5'>資源</b>,為啥還要用<b class='flag-5'>RTOS</b>?

    單片機(jī)不能正常工作的原因

    電壓范圍是否正常:若電壓不在單片機(jī)的正常工作范圍內(nèi),單片機(jī)肯定就不能正常工作。此時(shí)需要檢查電源部分的電路,排查電源輸出電壓不正確的原因;
    的頭像 發(fā)表于 06-20 09:47 ?1.3w次閱讀

    ?單片機(jī)外部擴(kuò)展資源分類及解析(上)

    隨著大規(guī)模集成電路技術(shù)的發(fā)展,單片微型計(jì)算機(jī)(簡稱:單片機(jī))也隨之大發(fā)展,各種新穎單片機(jī)層出不窮,廣泛應(yīng)用在人類生活的哥哥領(lǐng)域,成為當(dāng)今科學(xué)技術(shù)現(xiàn)代化必不可的重要工具。
    的頭像 發(fā)表于 05-18 11:23 ?1921次閱讀

    51單片機(jī)可以移植RTOS嗎?

    說起RTOS移植,我們首先會(huì)想到32位單片機(jī)。
    發(fā)表于 05-23 17:09 ?1916次閱讀

    如何學(xué)習(xí)單片機(jī)步驟的知識梳理

    單片機(jī)的學(xué)習(xí)實(shí)踐 單片機(jī)提高重在實(shí)踐,想要學(xué)好單片機(jī),軟件編程必不可但是熟悉硬件對于學(xué)好單片機(jī)
    發(fā)表于 10-07 09:55 ?588次閱讀