新聞中心

        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的含義是計算前導零的個數。


        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 清水县| 蚌埠市| 黎平县| 许昌市| 莫力| 嘉祥县| 叙永县| 桃江县| 海阳市| 大埔县| 江西省| 乌拉特前旗| 合江县| 磐石市| 元阳县| 五莲县| 金川县| 卓资县| 万年县| 名山县| 禄丰县| 赞皇县| 德惠市| 莲花县| 塔河县| 怀集县| 德保县| 新野县| 金溪县| 花垣县| 宿州市| 许昌县| 金湖县| 绥芬河市| 墨江| 丰都县| 祁阳县| 突泉县| 稻城县| 洪泽县| 柳州市|