μC/OS之OSTaskCreate()[通俗易懂]

μC/OS之OSTaskCreate()[通俗易懂]转自 http://blog.csdn.net/xiaocaichonga/article/details/7449409建立任务OSTaskCreate()1.OSTaskCreate()函数的声明  INT8UOSTaskCreate(void(*task)(void*pd),void*pdata,OS_STK*ptos,INT8Uprio)   1.1返

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

转自 http://blog.csdn.net/xiaocaichonga/article/details/7449409

建立任务OSTaskCreate()
1.OSTaskCreate()函数的声明
    INT8U OSTaskCreate(void(*task)(void*pd),void*pdata,OS_STK *ptos,INT8U prio)
     1.1返回类型 INT8U
     1.2参数:4个参数,分别是指向任务代码段的函数指针task,指向任务数据的指针pdata,指向任务所分配的堆栈的栈顶指针ptos,以及任务的优先级prio
2.OSTaskCreate()函数的定义
     INT8U OSTaskCreate(void(*task)(void*pd),void*pdata,OS_STK *ptos,INT8U prio)
     {

         void *psp;                             /*用于指向任务堆栈初始化后栈顶的指针*/
         INT8U err;                             /*用于存放任务TCB初始化后返回的值*/
 
         if(prio>OS_LOWEST_PRIO)                /*判断任务的优先级是否在允许的范围内,即如果该任务的优先级比系统的空闲优先级*/
         {                                       /*都低的话,那么就出错了*/
             return (OS_PRIO_INVALID)            /*返回优先级不可得*/
         }
         OS_ENTER_CRITICAL();
         if (OSTCBPrioTbl[prio]==(OS_TCB *)0)   /*判断所分配的优先级是否已经被其他任务占用,(OS_TCB)*0 表示没有占用*/
         {

             OSTCBPrioTbl[prio]=(OS_TCB *)1;    /*将新分配的优先级在OSTCBPrioTbl[]中更改为已占用状态即(OS_TCB)*1,注意:
             OS_EXIT_CRITICAL();                /*在(OS_TCB)*1状态下表示仅仅被占用,但是并没有为任务分配资源等操作*/
             psp=(void *)OSTaskStkInit(task,pdata,ptos,0);/*将任务堆栈进行初始化,并返回初始化后的栈顶指针给psp*/  
                                                          /*注意任务堆栈的初始化函数的参数:①代码段指针②数据段指针③堆栈的栈顶*/
             err=OSTCBInit(prio,psp,(void *)0,0,0,(void*0),0);/*TCB的初始化,注意传入的参数:①任务的优先级即任务的标识符②堆栈初始化后的栈顶指针*/
             if(err==OS_NO_ERR)                              /*如果TCB初始化成功*/
             {

                OS_ENTER_CRITICAL();
                OSTaskCtr++;                                 /*则将系统中的进程数加1*/
                OSTaskCreateHook(OSTCBPrioTbl[prio]);        /*新建任务的扩展功能,可以由用户自行定义,但是代码不能太长,因为此时中断关闭*/
                OS_EXIT_CRITICAL();
                if(OSRunning)                               /*判断任务建立时,系统中是否有其他任务在运行,即系统是否已经OSStart()了*/
                   {

                      OSSched();                           /*如果系统中已经有其他任务运行,则用任务调度函数OSSched()进行任务调度*/
                   }
              }
              else
              {

                 OS_ENTER_CRITICAL();
                 OSTCBPrioTble[prio]=(OS_TCB *)0;          /*如果TCB初始化失败,则将本来占用的OSTCBPrioTble[]中对应的位标识为此优先级未被使用*/
                 OS_EXIT_CRITICAL();
              }
              return (err);                                /*在判断优先级在于规定范围内的情况下,无论TCB初始化是成功还是失败,都将返回TCB初始化的值*/
           }
           else
           {

               OS_EXIT_CRITICAL();
               return (OS_PRIO_EXIST);                    /*如果此优先级已经被占用,则返回OS_PRIO_EXIST,以告诉系统和用户优先级已被占用*/
            }
      }
    
    
3.小结
任务的建立函数OSTaskCreate()到底做了哪些事情呢?    
①判断任务的优先级;
②系统的OSTCBPrioTbl[];
③任务堆栈的初始化;
④任务TCB的初始化。    

执行过程:第一步,判断任务的优先级是否越界,如果越界则返回失败,如果没越界进行下一步;
          第二步,判断任务的优先级是否已经被占用,如果被占用则返回失败,如果没有被占用进行下一步;
          第三步,对OSTCBPrioTbl[]相应位置1,表明此优先级被使用了;
          第四步,任务堆栈的初始化;
          第五步,任务TCB的初始化,无论初始化失败还是成功,都将TCB初始化的返回值返回给OSTaskCreate();
          第六步,如果TCB初始化失败了,则将OSTCBPrioTbl[]中的相应位再清0,以表明此优先级没被使用;如果TCB初始化成功了
                  则将系统中的任务数加1,并进行下一步;
          第七步,盘对系统是否已经处于运行状态,如果处于运行状态则进行任务调度。

注意:1.OSTaskCreate()的四个参数分别做了什么:
      ①task,pdata和ptos用于了任务堆栈的初始化,即要对任务的代码指针,数据指针,根据当前分配的栈顶继续压栈
      ②prio用于了PCB的初始化。
      2.对于OSTCBPrioTbl[]的理解,该表中的元素是指向TCB的指针,当该指针为(OS_TCB *)0时标明该位对应的优先级并未被使用,
      该为不为(OS_TCB *)0时,标明该位对应的优先级被使用,至于使用的情况还要分为两种:
      ①(OS_TCB *)1时,标明该优先级被占用但是并没说明该优先级对应哪个TCB;
      ②指名该优先级被占用并且指向对应的TCB,这部分在TCB的初始化中完成了。
            

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/196678.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • RPC协议及常用框架

    RPC协议及常用框架https://www.jianshu.com/p/8ba4b7b834aaRPC协议RPC:远程过程调用,原则上来说系统间跨进程的调用都属于RPC范畴RMI/HTTP/dubbo/SpringCloud/thriftRPC框架如何实现分布式环境下的远程调用在一个典型的RPC的使用场景中,包含了服务发现,负载,容错,网络传输,序列化等组件,其中RPC协议指明了程序如何进行网络传输和序列化。RPC协议的组成RPC协议的组成1.地址:服务提供者地址2.端口:.

    2022年5月12日
    46
  • javascript字典中添加数组_JS数组添加字典的方法

    javascript字典中添加数组_JS数组添加字典的方法varary_RoleType=[];//申明数组变量for(varj=0;jif($.inArray(treeData[j].value,ary_RoleType)<0){//使用jquery进行判断该数组是否包含该值ary_RoleType.push({//类似于JS添加JSON的字典方法,Key对应键值,value对应值‘key‘:treeData[j]….

    2022年5月3日
    313
  • 不用go-(xxoo)agent的也有可能是程序员

    不用go-(xxoo)agent的也有可能是程序员记得是去年某个时候,在一个群里问大家是怎么翻(什么)墙的,发现很多人是用go-(xxoo)agent的,而我当时完全没听说过go-agent,因为我已经N多年不翻(什么)墙了,于是,有人就说:“连go-(xxoo)agent都没用过你还是程序员吗?”说实话,我也不希望我是程序员啊!可我真的没用过go-(xxoo)agent啊!想起我一位前同事,工作很多年了,却从来没用过linux!(也不知道他

    2022年7月17日
    21
  • 图像分割必备知识点 | Unet详解 理论+ 代码

    图像分割必备知识点 | Unet详解 理论+ 代码文章转自:微信公众号【机器学习炼丹术】。文章转载或者交流联系作者微信:cyx645016617Unet其实挺简单的,所以今天的文章并不会很长。喜欢的话可以参与文中的讨论、在文章末尾点赞、在看点一下呗。0概述语义分割(SemanticSegmentation)是图像处理和机器视觉一个重要分支。与分类任务不同,语义分割需要判断图像每个像素点的类别,进行精确分割。语义分割目前在自动驾驶、自动抠图、医疗影像等领域有着比较广泛的应用。上图为自动驾驶中的移动分割任务的分割结果,可以从一张图片中有效的识别

    2022年6月16日
    56
  • 开发网络游戏的成本(经营成本与总成本区别)

    开发一个网络游戏以开发团队30人,开发周期18个月,人均月成本1万元计算.(这个是概数),约为540万.计算技术购买,测试服务器费用等等等等其他一切费用,普通国产网络游戏开发成本应该在600-1000万之间.运营成本.假设准备做到在线5万人,以平均10台服务器/组,5000人/组承载计算,约需10组,100台服务器.算上网站服务器,备用服务器等等,120台服务器投入是比较保守的估计.以单台平…

    2022年4月15日
    295
  • 眼下最好的JSP分页技术

    眼下最好的JSP分页技术

    2021年11月23日
    42

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号