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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • shell 编译和执行java文件

    shell 编译和执行java文件

  • iOS 自我检測

    iOS 自我检測

  • 最小生成树的两种方法(Kruskal算法和Prim算法)[通俗易懂]

    关于图的几个概念定义:连通图:在无向图中,若任意两个顶点vivi与vjvj都有路径相通,则称该无向图为连通图。 强连通图:在有向图中,若任意两个顶点vivi与vjvj都有路径相通,则称该有向图为强连通图。 连通网:在连通图中,若图的边具有一定的意义,每一条边都对应着一个数,称为权;权代表着连接连个顶点的代价,称这种连通图叫做连通网。 生成树:一个连通图的生成树是指一个连通子图,它含有图中…

  • IDEA中使用SVN IDEA配置SVN步骤

    IDEA中使用SVN IDEA配置SVN步骤Idea集成使⽤SVN文章目录Idea集成使⽤SVN1.配置SVN环境2.检出Checkout项⽬3.提交Commit代码4.更新Update代码5.导出import项⽬至服务器6.版本冲突问题7.恢复历史版本1.配置SVN环境1.File—>OtherSettings(全局配置;Settings是局部配置)—>VersionControl—>Subversion2. 配置svn找不到svn.exe⽂件,TortoiseSVN的bin⽬录下⾯没有

  • jsp用户信息管理系统

    jsp用户信息管理系统实现功能1.用户信息注册2.用户信息新增3.用户信息列表4.用户信息删除5.用户信息修改6.用户登录项目包结构:sqlsever数据库结构USE[MyDB]GO/******Object:Table[dbo].[users]ScriptDate:2020/11/119:26:07******/SETANSI_NULLSONGOSETQUOTED_IDENTIFIERONGOSETANSI_PADDINGONGOCREATETABL

    2022年10月17日
  • IE中输入框绑定input事件触发解析(input事件初始化自动执行问题解决)

    IE中输入框绑定input事件触发解析(input事件初始化自动执行问题解决)在React项目中碰到了个问题,输入框绑定了input事件,在IE中初始化会自动执行,刚开始以为是只要有placeholder就会导致问题,后面网上搜了一轮,自己手撸了一下,总结了导致绑定的input事件自动执行的原因1.输入框的值为空,2.placeholder改变(注意这个改变的就算前后的placeholder值一样也算改变;还有就是input获得焦点时和失去焦点时,也会改变;但是改变前后…

发表回复

您的电子邮箱地址不会被公开。

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