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)
上一篇 2025年9月21日 下午3:22
下一篇 2025年9月21日 下午4:01


相关推荐

  • 绘图软件Origin新手使用教程「建议收藏」

    绘图软件Origin新手使用教程「建议收藏」*写在前面:本文为便于博主自己学习进行的摘录整理,由于经过实际软件操作验证,故投稿原创,主要来源为知乎*绘图软件Origin使用教程一、新手绘制新图(1)创建新图1.新建图2.文字输入3.绘制箭头4.新建图表选择(2)绘图实例讲解1.创建工程2.将数据导入book3.创建空的graph,设置画布尺寸4.添加坐标系,设置坐标系的位置与尺寸5.添加图线6.设置坐标轴格式7.设置图的标题8.设置图线的格式9.设置并添加图例10.导出图片二、导入数据(1)支持导入的数据格式1.主要介绍2.导入数据3.数据格式转

    2022年5月31日
    563
  • Ubuntu 20.04 CUDA&cuDNN安装方法[通俗易懂]

    Ubuntu 20.04 CUDA&cuDNN安装方法[通俗易懂]下载cuda输入nvidia-smi命令查看支持的cuda版本如果无法查看,则说明尚未安装nvidia驱动,点击附加驱动,选择对应版本的驱动即可自动下载。从https://developer.nvidia.com/cuda-toolkit-archive下载对应版本的cuda,选择18.04的版本即可。gcc降级Ubuntu20.04自带的gcc版本为9.7….

    2022年6月13日
    79
  • Mybase6激活成功教程方法

    Mybase6激活成功教程方法确保 Mybase 已关闭 打开 Mybase 安装目录 打开主目录下的 nyfedit ini 配置文件 删除 App UserLic FirstUseOn 属性 Ctrl F 快速查找

    2026年2月5日
    2
  • kafka-logs_logstash kafka

    kafka-logs_logstash kafkaKafka的Log存储解析标签(空格分隔):kafka引言Kafka中的Message是以topic为基本单位组织的,不同的topic之间是相互独立的。每个topic又可以分成几个不同的partition(每个topic有几个partition是在创建topic时指定的),每个partition存储一部分Message。借用官方的一张图,可以直观地看到topic和partit

    2022年10月14日
    3
  • Navicat连接mysql报错 1251错误

    Navicat连接mysql报错 1251错误错误提示出现这个原因是 mysql8 之前的版本中加密规则是 mysql native password 而在 mysql8 之后 加密规则是 caching sha2 password 解决办法 把 mysql 用户登录密码加密规则还原成 mysql native password 步骤 1 打开 cmd 命令窗口 输入命令 mysql uroot p 打开 MySQL 数据库 然后输入密码进行登录 2 修改加密规则将加密方式改为 mysql native passwordALTE root

    2026年3月17日
    2
  • Kimi浏览器助手

    Kimi浏览器助手

    2026年3月12日
    2

发表回复

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

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