《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > μc/Os-Ⅱ就緒表算法在ARM架構上的改動
μc/Os-Ⅱ就緒表算法在ARM架構上的改動
摘要: μc/Os-Ⅱ的就緒表設置、清除、查找算法,是高效的、跨平臺的程序。它使用了兩個查找數組OSMapTbl[8]和OSUnMapTbl[256],以提高查找就緒表的速度,盡快獲取就緒任務的最高優先級。Cortex-M3是ARM公司較新的一種架構版本,主要應用在單片機領域。基于它生產的32位芯片日益增多;cortex-M3只支持Thumb-2指令集,在效能和代碼密度間能取得更佳的表現。
Abstract:
Key words :

    μc/Os-Ⅱ的就緒表設置、清除、查找算法,是高效的、跨平臺的程序。它使用了兩個查找數組OSMapTbl[8]和OSUnMapTbl[256],以提高查找就緒表的速度,盡快獲取就緒任務的最高優先級。

  Cortex-M3ARM公司較新的一種架構版本,主要應用在單片機領域。基于它生產的32位芯片日益增多;cortex-M3只支持Thumb-2指令集,在效能和代碼密度間能取得更佳的表現。
  1  在ARM上改動算法的因由利弊
  由于就緒表操作是在關中斷狀態下運行的,其執行影響到系統的中斷響應時間,因此就緒表操作算法的效率是衡量實時操作系統優劣的基準之一。
  在Cortex-M3所用的指令集中,一些指令功能不可小覷,如前導零計數clz、字內位反轉rbit、位清除bic。其中的clz和bic為μc/Os就緒表的高優先級獲取算法指出了另一條道路。
  (1)改動后的優勢
  ①節省存儲空間。不再使用查找數組OSMapTbl[8]和OSUnMapTbl[256]。設立這兩個數組的目的,是為了提高查找就緒表的效率。
  ②提升查找效率。clz是單周期指令,使用帶移位的加法指令,大幅縮短運算時間。
  ③增加了μc/Os-Ⅱ支持的任務數量,從64提升到了1 024(2.84版支持的任務數量已經到了256,不過效率有所下降)。
  (2)存在的不足
  ①Realview MDK(這里使用的是3.20版及其指令模擬器)尚不支持在C語言程序中使用Thumb-2指令內聯匯編。使用內嵌匯編函數時,函數的調用(跳轉返回)降低了執行效率。
  ②C語言對clz指令的支持尚有不足,故新算法跨平臺性差。但鑒于ARM芯片應用廣泛,指令又被ARM9之后的芯片廣泛兼容,所以應用空間還算廣闊。
  2  μc/Os-Ⅱ就緒表算法介紹與具體改動
  μc/Os-Ⅱ就緒表是一個數組,數組元素一位的值(1或0)對應了一個任務就緒與否,該位在數組中的位置表示任務的優先級。當需要調度已就緒的最高優先級任務運行時,就在就緒表中查找該任務。
  2.1  μc/Os-Ⅱ就緒表算法簡介
  一種解決方法是,對數組各項依次判斷是否為0:若>O,進入該項查找最小權的置1位位置;若=0,優先級加一個基數,查下一項,直至查到該優先級。
  μc/Os-Ⅱ技高一籌,設置了一個對就緒表各項判斷是否為0的變量,稱之為就緒表組。就緒表組一位為0或1,對應就緒表一項的值是否為0。通過查找就緒表組最小權位的置1位位置,就確定了對應首個>0的就緒表項的下標,從而避免了循環,大幅度提高了效率。
  2.2改動方式與源碼
  clz算法接受了μc/Os-Ⅱ的思路,再通過使用clz指令來進行優化。不同的是,clz是從右往左查,二進制的高權位對應高優先級,而μc/Os-Ⅱ優先級以值小為高。
  考慮到有時用不到很多任務,這時用數組作就緒表不免浪費。因此當任務總數小于32時,就用32位無符號整數變量作就緒表。注意,此時就緒表組變量OSRdyGrp被當作就緒表使用。
  常量OS_LES_TSK表示是否使用較小任務數,0表示使用最多32個任務,1表示使用最多1 024個任務。
  常量RdySt是將32位整數的最高權位置1,以便移位使用。
  2.3  C語言實現
  以下算法利用內嵌clz指令的函數編寫,實現了指定優先級任務在就緒表的設置、清除,在就緒表中查找就緒任務的最高優先級。
 
  程序中的bx r14,有些資料上要求必須寫,不過查看反匯編代碼,編譯程序已經給加上了。看來是編譯程序已升級,會不會出錯要看使用的編譯器,建議還是按規范寫上。由于內嵌函數調用返回耗時,查找算法未能充分發揮,需改進編譯后的匯編代碼以實現更高的效率,或使用匯編代碼重寫這部分程序。
 
  2.4  THUMB-2匯編指令實現
  用匯編語言寫程序時的技巧:在最高優先級任務的設置、清除函數中,C語言運算符“︱=”對等匯編指令“orr”,“&=~”對等匯編指令“bic。這兩條指令都可以進行預移位操作,大幅提高執行效率。可以查看反匯編源碼,看C編譯器是否利用了這一便利。
  在查找函數中,可以省去C語言程序中的內嵌匯編調用,減少冗余指令。示意偽代碼如下:
  ldr rO,  =OsRdyGrp;加載就緒表組變量OSRdyGrp地址
 
  可以看出,除了數據加載指令外,查找的核心算法僅3條指令(使用<32個任務時,僅1條指令)。不過在實際設計算法的時候,還需要考慮指令流水線停頓,方能達到最佳的效果。
 
  2.5  μC/OS-Ⅱ2.84版相關源碼介紹
  以下是翻譯整理后的μC/OS-Ⅱ優先級查找算法源碼(2.84版),較長的注釋是添加的算法說明。
  clz最高優先級查找算法,與μC/OS-Ⅱ的新算法有所不同:返回的結果分別是8位、16位整數。這是因為8位已經不能表示>255的值;過程中clz算法更多地使用16或32位整數,以充分利用芯片性能。
  3  適用范圍
  等待任務列表使用了與就緒表操作相似的過程,注意要同時更改其數據類型和算法。算法雖然是在Cortex—M3上執行的,但適用于ARM9及其以后芯片。支持ARM指令集的芯片,可以在C語言中使用內嵌匯編,不必再編寫匯編查找函數。
  本文所敘述的算法適用于下述兩種情況。
  ①使用μC/OS-Ⅱ系統:
  ◆要求更多的任務優先級;
  ◆要求產品性能優越或是時間關鍵的應用,想進一
  步提高效率;
  ◆學習、研究或希望優化μC/OS-Ⅱ以擴展其應用范圍。
  ②未使用μC/OS-Ⅱ系統:
  ◆移植改造其他操作系統的就緒表算法;
  ◆編寫新操作系統或執行調度程序;
  ◆編程愛好者借鑒、改進編程方法。
 
  結  語
  Cortex-M3推出時,筆者就認定它是單片機過渡到ARM的有力工具,其小存儲量使得它更適合用小型實時系統。在學習μC/OS-Ⅱ的過程中,發現其就緒表操作算法經過改動或許更好,于是就做了本文所述的試驗。
此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
一片黄亚洲嫩模| 看欧美日韩国产| 欧美在线观看视频在线| 亚洲午夜电影| 亚洲三级观看| 91久久精品一区二区三区| 国产一区二区三区在线观看网站| 国产精品麻豆va在线播放| 欧美视频在线播放| 欧美色图一区二区三区| 欧美日韩亚洲一区二区三区在线观看 | 欧美一区二区三区精品电影| 亚洲网站在线看| 亚洲网站啪啪| 亚洲在线成人精品| 午夜欧美精品| 欧美一区二区三区男人的天堂| 先锋影音一区二区三区| 性欧美大战久久久久久久久| 欧美一区午夜精品| 久久精品视频在线看| 亚洲高清在线| 亚洲日本视频| 一二三区精品福利视频| 亚洲一级黄色av| 亚洲欧美美女| 久久精品一区二区| 久久免费一区| 欧美jizz19hd性欧美| 欧美日韩免费高清一区色橹橹| 欧美日本国产精品| 国产精品极品美女粉嫩高清在线| 国产精品久久久久久久久免费桃花| 国产精品久久久久久久久久免费看 | 欧美国产另类| 欧美三日本三级少妇三2023 | 性欧美videos另类喷潮| 欧美专区在线| 久久婷婷蜜乳一本欲蜜臀| 老妇喷水一区二区三区| 欧美极品aⅴ影院| 国产精品成人观看视频免费| 国产欧美一区二区精品婷婷| 国内精品嫩模av私拍在线观看| 精品成人一区二区三区| 91久久黄色| 亚洲一区欧美| 亚洲第一福利社区| 正在播放欧美视频| 久久国产成人| 欧美精品日韩一本| 国产精品一区二区在线观看网站| 国模私拍一区二区三区| 亚洲国产日韩欧美在线图片| 中文在线资源观看网站视频免费不卡| 新狼窝色av性久久久久久| 亚洲国语精品自产拍在线观看| 一本色道综合亚洲| 久久aⅴ国产欧美74aaa| 欧美激情2020午夜免费观看| 国产精品一二| 亚洲黄色毛片| 午夜免费在线观看精品视频| 亚洲精品久久在线| 欧美一级网站| 欧美激情一区二区三级高清视频 | 亚洲高清免费| 亚洲一区二区视频在线| 亚洲韩日在线| 亚洲综合欧美日韩| 久久综合伊人77777蜜臀| 国产精品99一区| 亚洲成色999久久网站| 亚洲一区欧美| 一本色道久久综合亚洲精品不卡| 久久久久久国产精品mv| 欧美日韩在线不卡一区| 国内成+人亚洲| 亚洲一区二区伦理| aa成人免费视频| 另类av导航| 国产日韩欧美在线播放不卡| 亚洲毛片网站| 亚洲日本va午夜在线电影| 久久aⅴ乱码一区二区三区| 欧美精品一区二区三区久久久竹菊| 国产亚洲精品aa午夜观看| 一区二区三区四区五区精品| 亚洲精品久久久久久久久久久| 欧美一区日韩一区| 欧美体内谢she精2性欧美| 136国产福利精品导航网址| 性伦欧美刺激片在线观看| 亚洲一区欧美二区| 欧美另类亚洲| 在线观看91精品国产麻豆| 午夜一区二区三区不卡视频| 国产精品99久久久久久www| 欧美顶级大胆免费视频| 国内精品一区二区三区| 亚洲免费网址| 亚洲免费在线精品一区| 欧美乱人伦中文字幕在线| 在线精品视频免费观看| 欧美中文字幕| 香蕉乱码成人久久天堂爱免费| 欧美日韩一区二区欧美激情 | 欧美一级在线亚洲天堂| 新片速递亚洲合集欧美合集| 欧美午夜精品一区| 99精品国产在热久久下载| 99re6热在线精品视频播放速度| 美女成人午夜| 在线观看国产欧美| 欧美在线精品免播放器视频| 久久精品国产欧美亚洲人人爽 | 国内外成人免费激情在线视频 | 91久久久国产精品| 蜜桃av一区| 亚洲福利视频三区| 亚洲国产婷婷香蕉久久久久久99| 久久久无码精品亚洲日韩按摩| 国产色爱av资源综合区| 欧美亚洲日本一区| 久久精彩免费视频| 国产在线观看91精品一区| 久久国产主播精品| 久久资源av| 在线国产亚洲欧美| 亚洲激情不卡| 欧美高清成人| 亚洲精品无人区| 亚洲一区二区影院| 国产精品男女猛烈高潮激情| 亚洲影院色在线观看免费| 欧美亚洲一区三区| 国产午夜精品全部视频在线播放| 欧美在线黄色| 欧美成人综合在线| 日韩亚洲欧美一区| 午夜精品视频在线| 国产亚洲视频在线观看| 亚洲福利在线视频| 欧美极品一区| 亚洲先锋成人| 久久婷婷丁香| 亚洲精品一区在线观看香蕉| 亚洲一区二区精品在线| 国产欧美一区二区精品忘忧草 | 最新日韩在线视频| 欧美日本一道本在线视频| 一区二区三区四区国产精品| 欧美一区二区三区在线看| 国内久久精品| 日韩西西人体444www| 国产精品大片| 久久av二区| 欧美日本在线一区| 亚洲一区二区三区高清不卡| 久久久国产精品一区| 亚洲国产一区在线| 亚洲欧美日韩一区在线观看| 国产一区二区三区直播精品电影| 亚洲精品久久久久久久久久久| 欧美视频四区| 久久精品91久久香蕉加勒比| 欧美日本在线一区| 亚洲欧美国产毛片在线| 鲁大师成人一区二区三区| 99亚洲一区二区| 久久国产精品72免费观看| 亚洲黄色视屏| 欧美在线看片a免费观看| 亚洲电影第三页| 亚洲免费在线电影| 亚洲福利在线视频| 欧美一级久久久| 亚洲人成7777| 欧美中文字幕不卡| 亚洲精品影院| 久久久国产精品亚洲一区 | 影音国产精品| 亚洲免费中文字幕| 亚洲高清视频一区| 欧美亚洲一区二区在线| 91久久国产综合久久蜜月精品 | 欧美日韩亚洲一区在线观看| 久久国产毛片| 国产精品二区影院| 亚洲经典一区| 国产欧美日韩专区发布| 一本色道久久99精品综合| 国产亚洲va综合人人澡精品| 在线亚洲精品福利网址导航| 国产综合欧美在线看| 亚洲欧美精品在线观看| 亚洲精品免费在线| 老司机aⅴ在线精品导航| 亚洲欧美视频一区二区三区| 欧美日韩成人一区二区三区|