OSTaskCreateExt_getlocaltime函数

OSTaskCreateExt_getlocaltime函数uC/OS创建任务有几个硬性要求1.任务必须被创建在多任务开始之前或者是运行的任务中。2.任务不能由ISR创建。3.任务必须在死循环中,并且不能有返回。//建立一个新任务  #if OS_TASK_CREATE_EN > 0                //允许生成OSTaskCreate()函数  INT8U  OSTaskCreate

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

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

uC/OS创建任务有几个硬性要求

1. 任务必须被创建在多任务开始之前或者是运行的任务中。

2. 任务不能由ISR创建。

3. 任务必须在死循环中,并且不能有返回。



  1. //建立一个新任务  
  2. #if OS_TASK_CREATE_EN > 0                //允许生成OSTaskCreate()函数  
  3. INT8U  OSTaskCreate (void (*task)(void *pd), void *pdata, OS_STK *ptos, INT8U prio)  
  4. {  
  5. #if OS_CRITICAL_METHOD == 3                  //中断函数被设定为模式3  
  6.     OS_CPU_SR  cpu_sr;  
  7. #endif  
  8.     OS_STK    *psp;                         //初始化任务堆栈指针变量,返回新的栈顶指针  
  9.     INT8U      err;                         //定义(获得并定义初始化任务控制块)是否成功  
  10.   
  11.   
  12. #if OS_ARG_CHK_EN > 0                        //所有参数必须在指定的参数内  
  13.     if (prio > OS_LOWEST_PRIO) {            //检查任务优先级是否合法  
  14.         return (OS_PRIO_INVALID);           //参数指定的优先级大于OS_LOWEST_PRIO  
  15.     }  
  16. #endif  
  17.     OS_ENTER_CRITICAL();            //关闭中断  
  18.     if (OSTCBPrioTbl[prio] == (OS_TCB *)0) { //确认优先级未被使用,即就绪态为0  
  19.         OSTCBPrioTbl[prio] = (OS_TCB *)1;    //保留这个优先级,将就绪态设为1  
  20.                                               
  21.         OS_EXIT_CRITICAL();             //打开中断  
  22.         psp = (OS_STK *)OSTaskStkInit(task, pdata, ptos, 0);    //初始化任务堆栈  
  23.         err = OS_TCBInit(prio, psp, (OS_STK *)0, 0, 0, (void *)0, 0);       //获得并初始化任务控制块  
  24.         if (err == OS_NO_ERR) {     //任务控制初始化成功  
  25.             OS_ENTER_CRITICAL();    //关闭中断  
  26.             OSTaskCtr++;            //任务计数器加1  
  27.             OS_EXIT_CRITICAL();     //打开中断  
  28.             if (OSRunning == TRUE) {         //检查是否有(某个)任务在运行  
  29.                 OS_Sched();                  //任务调度,最高任务优先级运行  
  30.             }  
  31.         } else {        //否则,任务初始化失败  
  32.             OS_ENTER_CRITICAL();        //关闭中断  
  33.             OSTCBPrioTbl[prio] = (OS_TCB *)0;       //放弃任务,设此任务就绪态为0  
  34.             OS_EXIT_CRITICAL();                     //打开中断  
  35.         }  
  36.         return (err);           //返回(获得并定义初始化任务控制块是否成功)  
  37.     }  
  38.     OS_EXIT_CRITICAL();         //打开中断  
  39.     return (OS_PRIO_EXIST);     //返回(具有该优先级的任务已经存在)  
  40. }  
  41. #endif  
  42.   
  43.   
  44.   
  45. //建立一个新任务。与OSTaskCreate()不同的是,OSTaskCreateExt()允许用户设置更多的细节  
  46. //内容。任务的建立可以在多任务环境启动之前,也可以在正在运行的任务中建立,但中断处理  
  47. //程序中不能建立新任务。一个任务必须为无限循环结构,且不能有返回点。  
  48. #if OS_TASK_CREATE_EXT_EN > 0                //允许生成OSTaskCreateExt()函数  
  49. INT8U  OSTaskCreateExt (void   (*task)(void *pd),   //建立扩展任务(任务代码指针)  
  50.                         void    *pdata,             //传递参数指针  
  51.                         OS_STK  *ptos,              //分配任务堆栈栈顶指针  
  52.                         INT8U    prio,              //分配任务优先级  
  53.                         INT16U   id,                //(未来的)优先级标识(与优先级相同)  
  54.                         OS_STK  *pbos,              //分配任务堆栈栈底指针  
  55.                         INT32U   stk_size,          //指定堆栈的容量(检验用)  
  56.                         void    *pext,              //指向用户附加的数据域的指针  
  57.                         INT16U   opt)               //建立任务设定选项  
  58. {  
  59. #if OS_CRITICAL_METHOD == 3                  //中断函数被设定为模式3  
  60.     OS_CPU_SR  cpu_sr;  
  61. #endif  
  62.     OS_STK    *psp;                         //初始化任务堆栈指针变量,返回新的栈顶指针  
  63.     INT8U      err;                         //定义(获得定义初始化任务控制块)是否成功  
  64.   
  65.   
  66. #if OS_ARG_CHK_EN > 0        //所有参数必须在指定的参数内  
  67.     if (prio > OS_LOWEST_PRIO) {             //检查任务优先级是否合法  
  68.         return (OS_PRIO_INVALID);            //参数指定的优先级大于OS_LOWEST_PRIO  
  69.     }  
  70. #endif  
  71.     OS_ENTER_CRITICAL();        //关闭中断  
  72.     if (OSTCBPrioTbl[prio] == (OS_TCB *)0) { //确认优先级未被使用,即就绪态为0  
  73.         OSTCBPrioTbl[prio] = (OS_TCB *)1;    //保留这个优先级,将就绪态设为0  
  74.                                                
  75.         OS_EXIT_CRITICAL();     //打开中断  
  76.   
  77.         //以下两为1堆栈才能清0  
  78.         if (((opt & OS_TASK_OPT_STK_CHK) != 0x0000) ||   //检验任务堆栈,CHK=1  
  79.             ((opt & OS_TASK_OPT_STK_CLR) != 0x0000)) {   //任务建立时是否清0,CLR=1  
  80.             #if OS_STK_GROWTH == 1          //堆栈生长方向  
  81.             (void)memset(pbos, 0, stk_size * sizeof(OS_STK));       //从下向上递增  
  82.             #else  
  83.             (void)memset(ptos, 0, stk_size * sizeof(OS_STK));       //从下向下递减  
  84.             #endif  
  85.         }  
  86.   
  87.         psp = (OS_STK *)OSTaskStkInit(task, pdata, ptos, opt);      //初始化任务堆栈  
  88.         err = OS_TCBInit(prio, psp, pbos, id, stk_size, pext, opt);     //获得并初始化任务控制块  
  89.         if (err == OS_NO_ERR) { //任务控制初始化成功  
  90.             OS_ENTER_CRITICAL();        //关闭中断  
  91.             OSTaskCtr++;                //任务计数器加1  
  92.             OS_EXIT_CRITICAL();         //打开中断  
  93.             if (OSRunning == TRUE) {              //检查是否有(某个)任务在运行  
  94.                 OS_Sched();                       //任务调度,最高任务优先级运行  
  95.             }  
  96.         } else {        //否则,任务初始化失败  
  97.             OS_ENTER_CRITICAL();        //关闭中断  
  98.             OSTCBPrioTbl[prio] = (OS_TCB *)0;                 //放弃任务,设此任务就绪态为0  
  99.             OS_EXIT_CRITICAL();         //打开中断  
  100.         }  
  101.         return (err);       //返回(获得并定义初始化任务控制块是否成功)  
  102.     }  
  103.     OS_EXIT_CRITICAL();     //打开中断  
  104.     return (OS_PRIO_EXIST);     //具有该优先级的任务已经存在  
  105. }  
  106. #endif  

具体函数的介绍好需要看官方的文档:http://sigpromu.org/brett/elec3730/quickref.html

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

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

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


相关推荐

  • Adobe Dreamweaver的使用教程

    Adobe Dreamweaver的使用教程1.打开AdobeDreamweaver软件2.打开后的界面3.新建一个站点,保存网页文件,图片,视频等4.输入站点的名字和保存的路径5.新建html文件6.选择设计模式7.制作你所需要的结果8.保存网页,才能在浏览器中预览

    2022年6月12日
    44
  • kong组件_Kong

    kong组件_Kong1、简介Kong是一个企业级服务网关,底层是使用lua语言,整合Nginx实现了强大的服务转发,路由,验证功能,1.2官方描述KongwasoriginallybuiltatMashapetosecure,manageandextendover15,000APIs&MicroservicesforitsAPIMarketplace,which…

    2022年6月26日
    31
  • 激光测距原理与方法

    激光测距原理与方法激光测距粗划分为两种第一种原理大致是光速和往返时间的乘积的一半,就是测距仪和被测量物体之间的距离,以激光测距仪为例;第二种是以激光位移传感器原理为原理的方法的。激光的测量方法激光的测量方法大致有三种,脉冲法(激光回波法),相位法,三角反射法。脉冲法测量距离的精度一般是在+/-1米左右。另外,此类测距仪的测量盲区一般是15米左右。(激光回波分析法则用于远距离测量。…

    2022年5月5日
    56
  • phpstorm—下载安装配置教程

    phpstorm—下载安装配置教程本文仅供学习交流使用,如侵立删!联系方式及demo下载见文末PhpStorm是JetBrains公司开发的一款商业的PHP集成开发工具,主要为程序开发者提高开发效率,可深刻理解用户的编码,提供强大的智能代码补全,快速导航以及即时错误检查,大大提高了开发效率,但也为很多开发者带来了不便,phpstorm已经不提供注册码了,需要购买商业的版权才能使用。1、下载phpstrom软件官网:https://www.jetbrains.com/phpstorm/嗯!!!好像打不开了,没有关系,站长已为你准

    2025年7月4日
    3
  • IntelliJ IDEA 2022.01 x64 激活码【中文破解版】

    (IntelliJ IDEA 2022.01 x64 激活码)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html1M2OME2TZY-eyJsa…

    2022年4月2日
    514
  • 阿里云服务器如何配置开放端口

    阿里云服务器如何配置开放端口 1.进入ECS服务实例2.点击“资源管理”3.来到“实例”界面,点击“配置安全组规则”4.加入相应的端口号即可。5.这里说一句,避免入坑。你们别进到这个实例为0的安全组里面,这样你再

    2022年7月3日
    27

发表回复

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

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