在大多OS里都存在Idle线程或任务,同样uCos也不例外,为什么估计很少有人细研究。为什么设立Idle? 能不能去了?

首先看看uCos中关于Idle的代码做个介绍:

config.h里对Idle的配置:

#define OS_LOWEST_PRIO              7     /* 最低优先级,OS_LOWEST_PRIO即空闲任务优先级(0 ~ 63)    */
     #define OS_TASK_IDLE_STK_SIZE    32    /* 空闲任务栈容量   单位类型:OS_STK *                            */

 

在Core.c文件里的OSInit()调用OS_InitTaskIdle();来创建OS_TaskIdle任务,OS_InitTaskIdle();封装了

CreateTask()的不同创建方法,有带ID名,有不带ID名的。

 

在Core.c文件里的OS_TaskIdle线程体

void  OS_TaskIdle (void *pdata)
    {
        #if OS_CRITICAL_METHOD == 3                    /* Allocate storage for CPU status register           */
        OS_CPU_SR  cpu_sr;
       #endif   
       pdata = pdata;                                           /* Prevent compiler warning for not using 'pdata'   */
       for (;;)

{
        OS_ENTER_CRITICAL();
        OSIdleCtr++;
        OS_EXIT_CRITICAL();
        #if OS_TASK_IDLE_HOOK_EN > 0                 /* Allocate storage for CPU status register           */       
        OSTaskIdleHook();                                    /* Call user definable HOOK                               */
      #endif   

  }
   }

  1. 空闲任务
  2. 描述:这个函数是uCOS-II内部函数,uCOS-II总要建立一个空闲任务,这个任务在没有其它任务进入
  3. 绪态时投入运行。这个空闲任务永远设为最低优先级,即OS_LOWEST_PRIO.空闲任务不可能 被应用软件删除。

之所以设立Idle是因为当用户任务都不行用cpu时有Idle回收,应为cpu总德有一个任务,或是有一个入口让cpu

停止工作。这种情况是在用户任务都处于挂起或是延时时,那么以uCos的调度器结构来说总有一个任务才能调度

这个任务就是Idle. 所以在Idle里不能将Idle自己挂起或是延时。否则系统将会崩溃。为了验证这个说法举例说明问题:

建立两个用户任务,统计任务不使用,加上Idle一共3个任务,3个任务同是用OSTimeDly();即所有任务都放弃CPU

连Idle也放弃。

/*   用户任务1 */
void  MainTask (void *pArg)
{
     OSSetupTask(Task0, 2);
    while(1)
    {
        pArg = pArg;
         OSTimeDly(50000);
    }
}

 

/*  用户任务 */
void Task0 (void *pArg)
{
    int cnt;
  cnt = 0;
    while(1)
    {
        pArg = pArg;
        OSTimeDly(50000);
        cnt++;
        if(cnt == 100)
            while(1);
    }
}

 

OSTaskIdleHook()

{

OSTimeDly(100);

OSTimeDly(50);

}

 

在stm32运行是直接是HardFault伺候。

 

所以在uCos里Idle永远是就绪态,不要在OSTaskIdleHook()中调用可以使任务挂起的PEND函数,

  •        OSTimeDly()函数和OSTaskSuspend()函数等延时挂起操作,否则系统将会崩溃。
  •  

    Idle能不能去了?答案是可以的,但是得修改调度器的写法,其实Idle也吃内存。至少20 个字。

    uCos 之 TaskIdle() 注意事项【worldsing笔记】的更多相关文章

    1. Keil uCos 2.52 stm32 【worldsing笔记】

      1.uCOSii V2.52    a.加了7个可以配置的钩子函数宏     #define OS_TASK_CREATE_HOOK_EN    0    /* 任务创建时调用钩子函数      使能 ...

    2. 简单OS(ucos超级精简版)——裸调度器【worldsing笔记】

      简单原则少ROM,少RAM,任务完成就让出CPU,调度器描述: 1.按最大任务数轮番调度: 2.任务调用延时接口将让出CPU使用权,进入下一个任务调度: 3.用户任务都处于延时或是不使用CPU运行Id ...

    3. emWin(ucGui)数值显示例程 -【worldsing笔记】

      本例程下载:2.emWin5.26(ucGui)VS2008数字显示.zip   在emWin显示文本字符还是容易,我们也可以使用字符串和标准 C 库的函数来显示数值.然而,有时候这会是件困难的事.通 ...

    4. WS103C8例程——串口2【worldsing笔记】

      在超MINI核心板 stm32F103C8最小系统板上调试Usart2功能:用Jlink 6Pin接口连接WStm32f103c8的Uart2,PC机向mcu发送数据,mcu收到数据后数据加1,回传给 ...

    5. OSStartHighRdy()一去不复返【worldsing笔记】

      有关于uCos的启动过程讲解有很多文章,这里主要记录已下OSStartHighRdy()在stm32下是怎么写和运行的:   stm32上电   运行SystemInit(): 配置时钟,这个不要也可 ...

    6. Keil Mdk5.0 破解包 和谐包【worldsing笔记】

      有关Keil MDK 5.0的介绍和下载 http://www.cnblogs.com/worldsing/p/3355911.html 下载地址 点击下载:http://pan.baidu.com/ ...

    7. FreeModbus Slave 改进的eMbPoll()【worldsing 笔记】

      eMbPoll()的作用是FreeMod协议通信过程中不断查询事件对列有无完速数据桢,并进行地址和CRD验证,最后运行和回复主机. 为了减小代码尺寸对eMbPoll进行改进: 原版: 1:  2: e ...

    8. oracle 事务处理 注意事项(笔记)

      事务:一个独立的逻辑工作单元.它有特定的一系列必须作为一个整体一起成功或者失败的SQL语句组成.是一个要么全有要么全无,很个性的一个东东. 事务的四大属性——ACID属性:原子性(atomicity) ...

    9. QTbaWidget控件几个例程 【worldsing笔记】

      Qt Creator自带的 QTabWidget控件几个例程 在Qt Windos版本安装后,在Example目录可以找到与QTabWidget相关的工程Demo,如果按默认安装的话他们分别是:   ...

    随机推荐

    1. [itint5]字符串匹配

      http://www.itint5.com/oj/#15 用hash来做,目前为止做到最好也是case16超时(20w的规模),即使分桶也超时.注意计算hashcode时,'a'要算成1,否则如果'a ...

    2. atoi函数的实现(考虑不同进制、溢出)

      2013-07-08 16:21:15 atio就是将ASCII码表示的字符为int型数据,看似简单的问题,实际上需要考虑的很多.对于简单的问题,考虑是否全面就显得特别重要. 小结: 对于该函数的实现 ...

    3. Function 1 - hello world

      Function 1 - hello world Make a simple function called greet that returns the most-famous "hell ...

    4. MSSQL复制功能实现与Oracle数据库同步

      1.分别建立链接对数据库进行操作,SQLServer可以用ADO.NET,操作Oracle可以用OLEDB或者用System.Data.OracleClient(需要添加引用才能用) 这种方案的优点就 ...

    5. C++中巧妙的位运算

      位运算要多想到与预算和异或运算,并常常将两个数对应位上相同和不同分开处理 一.x&(x-1)消除x二进制中最右边的一个1. 这个比较厉害,比如统计某个 二.与和异或的巧妙结合的思想 与运算可以 ...

    6. poj 2031 Building a Space Station(prime )

      这个题要交c++, 因为prime的返回值错了,改了一会 题目:http://poj.org/problem?id=2031 题意:就是给出三维坐标系上的一些球的球心坐标和其半径,搭建通路,使得他们能 ...

    7. 宏HASH_INSERT

      调用 方法 HASH_INSERT(lock_t, hash, lock_sys->rec_hash,lock_rec_fold(space, page_no), lock); /******* ...

    8. 函数hash_get_nth_cell

      /************************************************************//** Gets the nth cell in a hash table. ...

    9. BZOJ_1031_[JSOI2007]_字符串加密_(后缀数组)

      描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1031 长度为n的字符串形成环,枚举开头位置,得到n个长度为n的串,将这些串排序,然后按照顺序输 ...

    10. TreeList 实现多表头

      1. 先上图: 2. 再上代码: 原码