• <li id="00i08"><input id="00i08"></input></li>
  • <sup id="00i08"><tbody id="00i08"></tbody></sup>
    <abbr id="00i08"></abbr>
  • 新聞中心

    EEPW首頁 > 嵌入式系統 > 設計應用 > Cortex-M3的μC/OS-II任務調度硬件指令實現

    Cortex-M3的μC/OS-II任務調度硬件指令實現

    作者: 時間:2011-03-24 來源:網絡 收藏

    1.2 高優先級的查找
    就緒表中查找最高優先級,即從OSRdyTb1[]變量中找到最低為1的位是第幾位(對應的就是最高優先級任務)。μC/采用查表的方式來找出處于就緒態的最高優先級任務,μC/中有一張256個單元的數據表OSUnMapTb1[],表中按一定規律有128個O,64個1,32個2,16個3,8個4,4個5,2個6,1個7,還有1個0,共256字節。OSUnMapTb1[]的定義如下所示:
    d.jpg
    找出進入就緒態的最高優先級任務的代碼如下:
    e.jpg
    f.jpg
    初看這張表感覺雜亂無章,實際是很有規律的。以“OSUnMapTb1[0]~OSUnMapTb1[15]:0,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,/*0x00~0x0F*/”為例說明:
    g.jpg
    其他依次類推。
    下面再以一個實例進行說明:假設變量OSRdyGrp=01011000B,表示變量OSRdyTb1[3]、OSRdyTb1[4]、OSRdyTb1[6]有任務處于就緒狀態,任務是去查找最高優先級任務(y=OSUnMapTb1[0x58])。由于OSRdyTb1[3]>OSRdyTb1[4]>OSRdyTb1[6],結果y=3。如果OSRdyTb1[3]=1000 0001B,則通過查表x=OS-UnMapTb1[OSRdyTb1[3]],即可得到x=O,表明這組數中第0位為1處于最優狀態。這樣,prio=(y3)+x=(33)+0=24。再利用這個優先級的值,查找任務控制塊優先級表OSTCBPrioTb1[],得到指向任務的任務控制塊OS_TCB。

    2 中μC/任務
    采用精簡集,采用Thumb-2,其中包括基于RTOS的算法(CLZ),可以通過這種指令查找處于就緒態的最高優先級任務。μC/OS-II中任務的就緒態是反映在OSRdyTb1[]變量中,共計8字節(64位),對應64個任務。可以將其折分成兩個32位的數據,然后分別查找這兩個32位的數據中優先級最高的任務。先查找低32位,如果低32位中不為零,則找出其中最高優先級任務;否則查找高32位,找出其中最高優先級任務,高32位的的查找結果應加上數值32。
    Cotrex-M3中通過以下兩條指令就可完成最高優先級任務的定位:RBIT和CLZ。RBIT的含義是把一個32位數據水平旋轉180°;CLZ的含義是計算前導零的個數。


    評論


    相關推薦

    技術專區

    關閉
    主站蜘蛛池模板: 永修县| 太仆寺旗| 探索| 杭州市| 揭东县| 修武县| 隆子县| 海盐县| 弥勒县| 新和县| 米易县| 黎平县| 电白县| 婺源县| 疏勒县| 常宁市| 长宁区| 海伦市| 新巴尔虎左旗| 乐陵市| 迁西县| 莆田市| 西安市| 安庆市| 石柱| 和龙市| 洛隆县| 保定市| 金寨县| 塔河县| 多伦县| 巨野县| 梅河口市| 图片| 宁南县| 祥云县| 哈尔滨市| 青铜峡市| 盐亭县| 天镇县| 汾西县|