新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > μC/OS2Ⅱ中优先级调度算法的改进及实现

μC/OS2Ⅱ中优先级调度算法的改进及实现

作者:时间:2012-04-06来源:网络收藏


该算法在扩展了系统可管理任务数目的同时,考虑了如何在任务数目增大时,还能够快速进行最高就绪任务判定的问题,并给出了一种快速的判定方法。在介绍判定最高就绪任务的方法之前,先描述μC/OS2Ⅱ中原有的判定表格OSUnMapTbl ( [256]),该表格为16×16的数组,每个数组元素的值是固定的。当使用该表格时,数组下标转换为相应的八位二进制,其中高四位对应数组的行,低四位对应数组的列(假设最右边的一位是第0位bit0) ,由此就可查表判断一组任务就绪态任务中优先级最高的那个任务所在的位置(查表后返回的值在0到7之间) ,再经过计算,就可得到最高优先级就绪任务的优先级。

为了减少不必要的工作,在判定最高优先级就绪任务的方法中,利用了上面介绍的优先级判定表格OSUnMapTbl ( [256]) ,把改进后的优先级看作一个类似二维坐标的平面(如图3所示) ,使256个



任务优先级平均分布在4个象限中(图中的数字0~255表示256个任务优先级,每个位置实际存放的是任务优先级的状态信息) ,同时使用了两个变量ox和oy来共同确定任务的优先级所在象限,并由此进一步查找最高优先级的就绪任务。

变量ox和oy的取值情况如图3所示,下面的查找最高优先级算法首先从判断优先级所在的象限开始进行查找。具体代码如下:
oy=OSRdyGrp 0X00FF ;
if ( oy==0)
 y=OSUnMapTbl[OSRdyGrp> > 8]+ 8;
else
 y=OSUnMapTbl[oy];
ox=OSRdyTbl[y] 0X00FF ;
if ( ox==0)
 x=OSUnMapTbl[OSRdyTbl[y]> > 8]+ 8;
else
 x=OSUnMapTbl[ox];
prio=( y 4) + x;

例如,如果OSRdyGrp的值为0X0068,则利用上面的代码,首先可以判断oy! =0,则查优先级判定表格得到OSUnMapTbl[oy]的值为3,假设OSRdyTbl[3]的值为0X00E4,则可判断ox! =0,再查优先级判定表格得到OSUnMapTbl[ox]的值为2,最后计算得到任务的优先级prio为50。

μC/OS2Ⅱ中优先级调度算法的第二种改进方法

在μC/OS2Ⅱ中,原来的优先级调度算法只使用了一个字节中的6位,剩余两位空闲。在第一种改进方法中,我们是直接扩展了定位就绪任务优先级在中位置的行和列信息的比特位。现在介绍的第二种方法是利用原来存放优先级的字节中剩余的两位作为索引,重建,使任务优先级扩展到256个。这里需要增加一个变量OSRdyXY,用于存放索引信息,另外还要使用变量OSRdyGrp[]存放任务优先级的行信息,OSRdyTbl0[ ],OSRdyTbl1[ ],OSRdyTbl2[ ]和OSRdyTbl3[ ]4个8位数组用于存放每个优先级的任务是否就绪的信息。这种方法的任务优先级字节的定义如图4所示。


评论


相关推荐

技术专区

关闭