μ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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • linux ettercap,linux下面ettercap的安装(双向arp欺骗)

    linux ettercap,linux下面ettercap的安装(双向arp欺骗)arpspoof真是老掉牙了,有以下三个缺点:1。不支持双向欺骗,要实现,只能启动两个进程。2。不支持多个ip,要不就是整个网段(除非也启动多个进程)3。不支持mac地址伪造。还是用ettercap吧,这个东西,介绍的资料都是windows下面的多。我的被控端是linux下呀,而目标是windows。没有办法,硬着头皮装吧:1..libnet-1.1.2.1.tar.gz2.libpcap-1.0…

    2022年6月28日
    27
  • 计算机网络期末考试题库(超级多的那种)「建议收藏」

    计算机网络期末考试题库(超级多的那种)「建议收藏」废话不多说,不管是应对期末考试还是考研基础复习,刷题是必不可少的!!!大家冲就完了!!!!记得给罡罡同学点关注哦!后期还会更新其他题库的呢!!!点关注!!!点关注!!!点关注!!!谢谢另外还有4套模拟题哦!!!计算机网络试题库——选择题及答案(共500题)1、Internet中发送邮件协议是(B)。A、FTPB、SMTP C、HTTP D、POP2、在OSI模型中,第N层和其上的N+l层的关系是(A

    2022年6月28日
    31
  • Java集合篇:fail-fast机制 与 fail-safe

    Java集合篇:fail-fast机制 与 fail-safe

    2021年10月4日
    43
  • Python正则表达式语法_re正则表达式语法

    Python正则表达式语法_re正则表达式语法python正则表达式的语法及使用概念:按照程序员的指示,字符串里提取你要的数据。应用:爬虫清洗数据,匹配电话,匹配邮箱,匹配账号……最重要的就是(.*?)正则语法(元字符)1、?:前面的内容出现0-1次2、+:前面的内容出现1-多次3、*:前面的内容出现0-多次‘’’正则(Regular):记住的点:1、(.?)2、re.findall()结果是一个列表3、用(.?)的是后,一定要复制,而不是手敲!‘’’importre‘’’正则语法(普通字符):

    2022年10月3日
    1
  • goland激活码【2021免费激活】

    (goland激活码)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月28日
    983
  • 面试:精通Java;面试官:来讲一下JVM虚拟机内存模型的最底层原理,必须说详细说清楚,知其所以然。看完后,你还敢在简历上写精通Java吗?

    面试:精通Java;面试官:来讲一下JVM虚拟机内存模型的最底层原理,必须说详细说清楚,知其所以然。看完后,你还敢在简历上写精通Java吗?面试简历:精通Java和JVM面试官:来说说JVM虚拟机内存模型的最底层原理,必须说详细说清楚,达到知其所以然的目的。看完后你还敢在简历上写精通Java吗?

    2022年5月12日
    33

发表回复

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

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