《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > μC/OS優先級調度機制在PowerPC上的優化
μC/OS優先級調度機制在PowerPC上的優化
單片機與嵌入式系統
龔光華,車惠軍 清華大學
摘要: RTOS實時內核μC/OS和μC/OSII中,任務調度算法巧妙,性能優異,在嵌入式應用領域很有影響力,被移植到各種CPU上。然而由于是為8位CPU設計的,對于那些具有優先級硬件算法指令的16/32/64位CPU,μC/OSII的軟件算法就完全失去了優勢。應該利用這類CPU的特有指令,優化任務調度算法,使RTOS的實時性達到最佳。對于這類處理器,僅移植μC/OSII軟件算法是很不夠的,應該利用相關硬件算法指令。
Abstract:
Key words :

摘要: μC/OSII實時操作系統被移植到幾乎所有CPU上,在我國嵌入式領域頗具影響力。μC/OS和μC/OSII是為8位CPU設計的,對于具有優先級算法硬件指令的32位中高端CPU,則應該對其任務調度算法做進一步優化,以得到更好的系統實時響應。本文以一款PowerPC系列中的中低端單片機為例,說明如何使用優先級算法硬件指令改進任務調度算法。

關鍵詞: μC/OS;PowerPC;優先級調度;前導零計算

Optimization of μC/OS Task Switching Scheme in PowerPC Architecture
Gong Guanghua1,Che Huijun2
(1. Dept. of Engineering Physics, Tsinghua Univ.,Beijing 100084,China;2. Beijing National Railway Research&Design Institute of Signal&Communication)
Abstract: Realtime multitask kernel μC/OS and μC/OSII are ported to almost all popular processors and are widely used in China. As originally designed for 8 bit microcontroller, the kernel is not aware of nor utilizes the hardware priority calculation instruction that exists in some highperformance 32 bit microcontroller families. Based on MPC5554 from Freescale PowerPC embedded microcontroller, this article shows how the hardware priority calculation instruction is used to improve the system response latency.
Key words: μC/OS; PowerPC; task switching; count leading zero instruction

  μC/OS是Jean J.Labrosse開發的實時多任務內核,最初是為Motorola 8位處理器68HC11寫的。在后來的相關著作中,作者將代碼移植到了PC上,以便于更多的讀者學習。μC/OSII繼承了μC/OS的算法,有執行效率高、占用空間小、實時性強和可擴展性好等特點,被移植到幾乎所有類型的CPU上,成為在嵌入式領域非常有影響力的RTOS。然而,由于該實時內核是為8位CPU設計的,對于那些具有優先級算法硬件指令的CPU,僅做移植是很不夠的。

1  基于優先級的任務調度

  一個基于優先級的實時多任務內核的任務調度機制需要實現下面三個核心的處理功能:

◆ 將任務置于就緒態;
◆ 將任務取消就緒態;
◆ 找出最高優先級的就緒態任務。

  在32位機上運行64個任務,可使用兩個32位的整型變量數組OSRdyTbl [2],建立一個64位的任務就緒態向量;每一位表示對應優先級的任務是否處于就緒態,例如OSRdyTbl [0]的第4位為1表示優先級為4的任務處于就緒態。構造如下的三個函數,用來完成設置任務就緒、取消任務就緒和尋找當前最高優先級的就緒任務。

void SetTaskRdyBit(INT8U Prio){/*設置任務就緒態*/
  if(Prio>32) OSRdyTbl [1] |= (1 << (63Prio) );
  else OSRdyTbl [0] |= (1 << (31Prio) );
}
void ClrTaskRdyBit(INT8U Prio){ /*取消任務就緒態*/
  if(Prio>32) OSRdyTbl[1] &= ~(1 << (63Prio) );
  else OSRdyTbl[0] &= ~(1 << (31Prio) );
}
INT8U FindHighestRdyTask(void){ /*尋找最高優先級的就緒態任務*/
  INT32U temp;//中間變量
  INT8Uprio=0;
  if(OSRdyTbl[0] != 0){
    temp = OSRdyTbl[0];//就緒態任務中優先級最高者在OSRdyTbl[0]中
  }
  else{
    temp = OSRdyTbl[1]; //就緒態任務中優先級最高者在OSRdyTbl[1]中
    prio +=32;
  }
  while(temp <0x80000000){//逐位查找就緒態任務中優先級最高者
    temp <<=1;
    prio ++;
  }
  return(prio);
}

  上述代碼可在任何處理器上實現所需的功能,沒有考慮任何的優化和改進。通過這樣的原理性函數,可以更好地理解多任務內核的任務調度。

  尋找最高優先級就緒態任務的函數調用頻率高,其執行時間直接影響內核的任務切換延遲時間,影響系統實時性。上述尋找最高優先級的就緒態任務的代碼,隨當前就緒任務的優先級不同,其循環次數也不同,導致其運行時間不確定。

2  μC/OS的任務調度實現方法

  μC/OS和μC/OSII是為8位CPU寫的,采用8位機算法,支持64個任務。使用8個字節的OSRdyTbl全局數組,表示所有任務的就緒態信息:1為任務就緒,0為非就緒。數組第一個字節的b0位代表64個任務中優先級最高的任務,最后一個字節的b7位代表優先級最低的空閑任務,永遠為1。當OSRdyTbl 數組的數據不為0時(表示對應的8個任務中至少有1個進入就緒態),另一個單字節全局變量OSRdyGrp 中的相應位要置1。當任務狀態發生變化時,需更新OSRdyGrp和OSRdyTbl中對應的位。

  尋找最高優先級的就緒任務時,μC/OS使用了預先固化的256字節的對照表OSUnMapTbl,給出特定字節值的最低位1所在位的信息。查表算法避免了逐位檢測各優先級位引起的執行時間的不確定性,程序簡單,執行速度快,與就緒任務多少和優先級無關。

  對于取值0~63的任務優先級,μC/OS將其劃分成高3位的Y和低3位的X,并保存在其任務控制塊TCB的OSTCBX和OSTCBY中,其對應的OSUnMapTbl的值保存在OSTCBBitY和OSTCBBitX變量中,以提高運算速度。為了避免函數調用所帶來的額外開銷,μC/OS直接用語句實現如下的三部分功能。

① 設置任務進入就緒態

OSRdyGrp |= ptcb>OSTCBBitY;
OSRdyTbl[ptcb﹥OSTCBY] |= ptcb>OSTCBBitX;

② 設置任務退出就緒態。

y = OSTCBCur>OSTCBY;
OSRdyTbl[y] &= ~OSTCBCur>OSTCBBitX;
if (OSRdyTbl[y] == 0) {
  OSRdyGrp &= ~OSTCBCur>OSTCBBitY;
}

③ 尋找最高優先級的就緒態任務。以OSRdyGrp的值做偏移量,查OSUnMapTbl表,得到1個0到7的數Y,作為優先級高3位,再根據Y的值,找出OSRdyTbl中對應的字節,并且再次查OSUnMapTbl表,得到1個0到7的數X,作為優先級低3位的值,通過將Y左移3位再加上X的值,得到就緒任務中優先級最高的那個。

y = OSUnMapTbl[OSRdyGrp];
OSPrioHighRdy = (INT8U)((y << 3) + OSUnMapTbl[OSRdyTbl[y]]);

  μC/OS的任務調度算法采用了以空間換時間的策略,將特定字節值的最低位1所在位的信息預先計算并保存到表中,運行時通過查表快速得到;每個任務的TCB中除了保存優先級信息本身外,還使用額外的4個字節保存優先級的高低3位和對應的OSUnMapTbl值,以避免運行時實時計算這幾個值所帶來的延遲。這些措施增加了系統ROM和RAM的開銷。

3  利用PowerPC“數出前導零數目”指令實現任務調度

  PowerPC是Motorola 、IBM和Apple三家公司于20世紀90年代初期聯合設計的32位CPU。Freescale(其前身是Motorola半導體部)發展了針對汽車電子的MPC5xx系列單片機及后續基于e200內核的MPC5xxx系列單片機;更高端的e500、e600內核是用于通信領域的MPC6xxx、7xxx和8xxx系列。

  下面對μC/OS任務優先級調度算法的改進和優化是在MPC5554單片機上實現的。

  PowerPC處理器具有一條“數出前導零數目” 的指令cntlzw(count leading zero word),可以以硬件指令方式實現優先級的多任務調度算法。這條指令也可用于圖像處理和算法加密的場合。該指令數出一個32位寄存器中前置零的數目,例如,返回0表示b0不為零,即沒有前導零;返回3表示b3不為零,b3位的前面從b0到b2共有3個零;返回32表示RS寄存器中所有的位都為零。(在PowerPC架構中,最高位MSB表示為b0,低位MSB根據位寬表示為b7、b15或b31。)

  利用這條指令,用匯編語言改寫尋找最高優先級的就緒任務的函數,則不需要進行循環移位判斷,可以直接從64個任務中找出優先級最高的那個任務。代碼如下:

asm INT8U FindHighestRdyTask(void){
  lisr5,OSRdyTbl@ha//讓r5寄存器指向OSRdyTbl[]
  orir5,r5,OSRdyTbl@l
  lwzr3,0(r5)//將OSRdyTbl[0]的值載入r3寄存器
  cntlzwr3,r3//計算OSRdyTbl[0]中前導零數目
  cmpi0,0,r3,32//判斷前32個任務是否就緒
  bne __FindEnd//如果前導零數目為32,說明前32個任務均未就緒,需要從后32個任務中尋找
  lwzr4,4(r5)//將OSRdyTbl[1]的值載入r4寄存器
  cntlzwr4,r4//計算OSRdyTbl[1]的前導零數目
  addir3,r4,32//后32個任務需要加上偏移量
  __FindEnd:
  blr //返回值保存在r3寄存器中
}

  在這段代碼中,首先判斷前32個任務是否有處于就緒態的,如果沒有的話,再對后32個任務進行判斷。由于優先級最低的空閑任務總是處于就緒態,所以后32個任務總能返回一個有效值。該代碼在前32個任務有就緒態時運行7條指令,在前32個任務均沒有就緒時需要執行10條指令;而μC/OS原有的代碼編譯出來的匯編程序,則需要運行15條指令。

  使用這個方法的另一個好處是不再需要使用256字節的OSUnMapTbl表,任務控制塊TCB也不需要使用OSTCBX、OSTCBY和OSTCBBitY、OSTCBBitX變量,每個ECB中也不再需要OSRdyGrp,這也減少了對ROM和RAM的占用。

4  改進擴展任務數的優先級調度性能

  當對μC/OSII支持的任務數進行擴展時,按照μC/OSII原有的做法,需要按照高低字節分別查找OSUnMapTbl對照表。任務數為256時,尋找最高優先級就緒任務的函數將需要運行約35條指令。數出前導零數目的指令在這種情況下的作用將更加顯著,對于32位PowerPC處理器,精心設計的代碼可以做到僅需10條指令就將任務數擴展到1024個。

  此時OSRdyGrp擴展為32位,OSrdyTbl擴展成32個32位的數組。從OSRdyGrp得到的前導零數目,就是任務優先級高5位的值,乘以4可以得到該字的相對偏移地址;在OSRdyTbl中,定義高位對應高優先級任務,低位對應低優先級任務,則其前導零數目就是任務優先級低5位的值,和高5位的值移位相加就得到完整的任務優先級。通過將OSRdyGrp和OSRdyTbl定義成結構體,利用結構體首地址的相對尋址來分別讀取其數值,可以減少一次取地址的操作。

  尋找最高優先級就緒態的最終代碼如下:

typedef struct {//定義結構體
  INT32U Tbl[32];
  INT32U Grp;
} OSTaskRdyBlock;
OSTaskRdyBlock  OSRdy;//定義全局變量OSRdy
asm INT16U FindHighestRdyTask(void){
  lisr5,OSRdy@ha//將OSRdy結構體指針載入r5寄存器
  orir5,r5,OSRdy@l
  lwzr3,128(r5)//OSRdy.Grp在結構體中具有固定偏移量
  cntlzwr3,r3//數出OSRdyGrp的前導零數目
  slwir6,r3,2//得到OSRdyTbl的地址偏移量
  lwzxr4,r6,r5//通過結構體指針,讀取OSRdy.Tbl的對應字
  cntlzwr4,r4//計算OSRdyTbl對應字的前導零數目
  slwir3,r3,5//任務優先級高5位移位
  addr3,r4,r3//和優先級低5位相加,得到完整優先級
  blr//返回
}

  在64位的PowerPC 更有cntlzd(Count Leading Zero Double word)指令,一次就可以找出64個任務中優先級最高的那個,就更沒有必要使用μC/OSII中的算法了。

5  總結

  RTOS實時內核μC/OS和μC/OSII中,任務調度算法巧妙,性能優異,在嵌入式應用領域很有影響力,被移植到各種CPU上。然而由于是為8位CPU設計的,對于那些具有優先級硬件算法指令的16/32/64位CPU,μC/OSII的軟件算法就完全失去了優勢。應該利用這類CPU的特有指令,優化任務調度算法,使RTOS的實時性達到最佳。對于這類處理器,僅移植μC/OSII軟件算法是很不夠的,應該利用相關硬件算法指令。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
久久天堂精品| 欧美日韩久久不卡| 亚洲免费激情| 亚洲福利视频网| 午夜视频一区| 亚洲一区在线播放| 亚洲视频在线观看免费| 亚洲精品在线电影| 91久久夜色精品国产九色| 一区免费观看| 在线观看一区二区视频| 禁断一区二区三区在线| 狠狠狠色丁香婷婷综合激情| 国产日韩亚洲欧美综合| 国产精品一区二区三区四区五区| 欧美xx69| 欧美黄色视屏| 欧美精品网站| 欧美日韩亚洲视频一区| 欧美日韩国产影院| 欧美日韩免费观看一区| 欧美成人精品激情在线观看| 理论片一区二区在线| 久久噜噜噜精品国产亚洲综合| 久久精品国产91精品亚洲| 欧美在线观看一区二区| 久久av红桃一区二区小说| 欧美在线黄色| 久久久久.com| 美女福利精品视频| 欧美激情影音先锋| 欧美日本不卡高清| 欧美日韩一区三区| 亚洲国产婷婷香蕉久久久久久| 亚洲一区二区三区四区中文| 亚洲少妇诱惑| 亚洲一区二区在线免费观看视频| 亚洲一区在线免费| 国产麻豆日韩欧美久久| 国产一区二区在线免费观看 | 亚洲一区二区四区| 日韩午夜精品| 亚洲午夜久久久久久尤物| 狠狠色丁香婷婷综合久久片| 亚洲第一偷拍| 99精品视频免费观看| 亚洲制服欧美中文字幕中文字幕| 欧美一级视频一区二区| 亚洲国产精品成人综合| 999亚洲国产精| 亚洲欧美在线免费| 久久一区中文字幕| 欧美日韩mp4| 国产精品资源在线观看| 伊人久久大香线蕉综合热线 | 亚洲一区二区三区四区五区黄 | 欧美极品在线视频| 国产精品久久久久天堂| 国产亚洲欧美色| 亚洲黄色成人| 亚洲欧美视频在线观看| 亚洲最新色图| 香蕉久久国产| 日韩一区二区久久| 欧美一区二区视频观看视频| 久热re这里精品视频在线6| 欧美人与性动交a欧美精品| 国产精品午夜春色av| 在线不卡中文字幕播放| 一区二区三区视频在线观看| 欧美在线观看www| 一区二区三区你懂的| 欧美在线免费看| 欧美乱妇高清无乱码| 国产毛片一区| 日韩小视频在线观看| 久久激情五月婷婷| 日韩一区二区久久| 久久久av毛片精品| 欧美视频一区二区| 在线观看视频一区二区| 亚洲综合精品自拍| 99精品福利视频| 久久久久久久波多野高潮日日 | 国内一区二区三区| 亚洲天堂av综合网| 亚洲丶国产丶欧美一区二区三区| 亚洲视频图片小说| 免费成人av在线| 国产精品欧美在线| 亚洲欧洲中文日韩久久av乱码| 欧美亚洲一级片| 久久精品卡一| 欧美自拍偷拍| 国产精品久久午夜| 亚洲伦伦在线| 欧美午夜精品理论片a级大开眼界 欧美午夜精品理论片a级按摩 | 麻豆国产精品一区二区三区| 欧美午夜视频在线| 亚洲茄子视频| 亚洲国产视频直播| 久久久久久久久一区二区| 国产精品美女久久久久久2018 | 国产精品盗摄久久久| 亚洲国产欧美精品| 亚洲电影有码| 久久亚裔精品欧美| 国内伊人久久久久久网站视频| 亚洲欧美日韩精品在线| 亚洲欧美在线高清| 国产精品系列在线播放| 亚洲美女电影在线| 日韩亚洲精品电影| 欧美精品日韩一本| 亚洲精品乱码| 艳妇臀荡乳欲伦亚洲一区| 欧美黄色aaaa| 亚洲精品欧美激情| 在线视频精品一区| 欧美日韩免费观看一区二区三区| 亚洲精品三级| 亚洲视频一区在线观看| 欧美日韩另类视频| 99热精品在线观看| 亚洲在线视频观看| 国产精品入口麻豆原神| 亚洲综合成人在线| 欧美在线观看视频一区二区三区| 国产精品视频专区| 亚洲欧美国产视频| 欧美一级一区| 国产欧美一区二区在线观看| 红桃视频亚洲| 亚洲国产另类久久久精品极度| 久久久久九九视频| 欧美日韩在线一区二区三区| 亚洲精选成人| 亚洲美女少妇无套啪啪呻吟| 猫咪成人在线观看| 永久久久久久| 性色av一区二区怡红| 久久久久久久久综合| 国产区欧美区日韩区| 亚洲欧美日韩在线播放| 欧美在线日韩精品| 欧美日韩1234| 亚洲午夜日本在线观看| 亚洲一区在线看| 国产精品欧美日韩| 亚洲欧美国产高清| 久久精品亚洲一区| 亚洲高清视频在线| 中文精品视频| 欧美午夜不卡在线观看免费| 国产日韩亚洲欧美综合| 午夜精品福利视频| 久久精品午夜| 亚洲精品久久久久久下一站 | 亚洲男女自偷自拍图片另类| 国产精品成av人在线视午夜片| 99国产精品国产精品久久| 亚洲视频在线视频| 国产精品久久精品日日| 久久国产精品久久精品国产 | 欧美一区二区三区四区夜夜大片| 欧美欧美天天天天操| 亚洲影视中文字幕| 久久久91精品国产一区二区三区| 激情成人av在线| 亚洲黄网站在线观看| 欧美激情影音先锋| 亚洲男人av电影| 久久天堂国产精品| 91久久黄色| 亚洲免费一区二区| 免费h精品视频在线播放| 在线一区二区三区做爰视频网站| 欧美一区午夜视频在线观看| 国内久久视频| 99视频一区二区三区| 国产午夜精品全部视频在线播放| 久久精品一区| 欧美另类视频在线| 亚洲一区二区三区精品在线观看 | 亚洲视频每日更新| 久久精品国产亚洲高清剧情介绍| 一区二区在线视频| 这里只有精品视频在线| 欧美日韩综合视频| 欧美亚洲综合在线| 欧美黄色成人网| 亚洲自拍偷拍一区| 欧美日韩1234| 欧美亚洲三区| 欧美人与性动交cc0o| 亚洲欧美自拍偷拍| 欧美激情按摩在线| 亚洲欧美中文字幕| 噜噜爱69成人精品| 亚洲视频视频在线|