UCOSIII的一些常用函数总结

2024-08-31 09:08
文章标签 函数 总结 常用 ucosiii

本文主要是介绍UCOSIII的一些常用函数总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

任务堆栈:存储任务中的调用的函数、局部变量、中断服务程序和CPU寄存器的值。

全局变量的保护:
1.如果只在一个任务中写(或只有一个数据),而在其他任务中只是读取,则可以不用互斥型信号量,最多会造成读取的数据未被完全写完。
2.如果全局变量在多个任务中写,则需要用互斥型信号量保护,这样当有任务申请到互斥型信号量(保护不可重入的程序段)写数据时,其他任务的同一个互斥型信号量必须等待上一个任务的释放才可进行写。
3.如果全局变量在中断中写,则在其他任务中的全局变量的写操作要用临界段(禁止中断和禁止调度:保护不可被分割的程序段)保护。(因为如果不关中断相当于中断的优先级最高,而且不能被像其他任务那样挂起。)

OS_CFG_ISR_POST_DEFERRED_EN1临界段使用锁调度器方式;
0临界段使用禁中断方式(CPU_SR_ALLOC();
OS_CRITICAL_ENTER();OS_CRITICAL_EXIT();
OS_CRITICAL_EXIT_NO_SCHED();
OSSchedLockNestingCtr记录调度器被锁的次数)。

检测任务堆栈的使用情况:
OS_CFG_STAT_TASK_STK_CHK_EN使能
OS_ERRerr;
CPU_STK_SIZE  stk_free;
CPU_STK_SIZE  stk_used;
OSTaskStkChk(&TaskBStkTCB,&stk_free,&stk_used,&err);
中断中使用OSIntEnter(); OSIntExit();是为了退出中断后执行中断调度操作,如果中断中并未用到OSSemPost();等系统函数,则退出中断服务程序后不需要进行任务调度,就可以不在中断服务程序中使用OSIntEnter(); OSIntExit();
(有时候用: CPU_CRITICAL_ENTER();OSIntNestingCtr++;
CPU_CRITICAL_EXIT(); 替代 OSIntEnter();

一、  变量类型

在cpu.h中是有关cpu变量的重新定义,还包括CPU_STK(CPU堆栈类型),
CPU_STK_SIZE CPU 堆栈类型的大小)的定义, CPU_SR CPU 状态寄存
器的定义)。
在os.h中是有关os类型的定义如OS_TCB(任务控制块)、OS_SEM(信号量)、OS_MUTEX(互斥型信号量)、OS_MSG(消息)、OS_Q(消息队列)、OS_ERR(系统错误)等。
在cpu_core.h中是有关cpu的定义,如CPU_ERR、CPU_TS、CPU_TS_TMR等。
CPU_STKtypedef unsigned int堆栈的类型定义
OS_TCBstruct os_tcb任务控制块的类型定义
OS_ERRenum os_err错误信息定义
CPU_TStypedef unsigned int时间戳变量
CPU_TS_TMRtypedef unsigned int定时器变量

二、  全局变量

(OS_CFG_STAT_TASK_EN使能且调用了OSStatTaskCPUUsageInit(&err);
则开启了统计任务的功能:可以统计CPU使用率等。)
OSStatTaskCPUUsageCPU的使用率(0—10000= 0.00-100.00%
OSStatTaskCPUUsageMaxCPU的使用率最大值(0—10000= 0.00-100.00%
OSTaskCtxSwCtr任务切换次数的记录变量
OSStatTaskCtr已经建立了的任务数

三、常用函数

一、OS_CORE.C

(1)void  OSInit()           //系统初始化
(2)void  OSIntEnter()       //发生了一次中断(中断嵌套的逐层进入)
(3)void  OSIntExit()        //退出了一次中断(中断嵌套的逐层退出)
(4)void  OSSched()         //系统进行调度
(5)void  OSSchedLock()     //给调度器上锁
(6)void  OSSchedUnlock()   //给调度器解锁,成对使用
(7)void  OSStart()         //启动多任务过程,在启动之前必须调用OSInit(),并已建立一个任务。其中OSStartHighRdy()必须调用OSTaskSwHook(),并令OSRunning = TRUE.
(8)void  OS_Pend()         //挂起任务
(9)void  OS_Post()         //解挂任务
(10)void  OS_PendAbort()   //取消挂起任务
(11)INT16UOSVersion ()   //返回uc/os的版本号*10000
(12)void  OS_IdleTaskInit()  //空闲任务初始化
(13)void  OS_IdleTask()     //空闲任务
二、 OS_TASK.C
(1)void OSTaskCreate(OS_TCB         *p_tcb,//任务控制块
CPU_CHAR      *p_name,//任务名
OS_TASK_PTR    p_task,//任务函数指针
void             *p_arg,//任务函数参数
OS_PRIO         prio,//任务优先级
CPU_STK        *p_stk_base,//堆栈指针
CPU_STK_SIZE   stk_limit,//任务的堆栈剩余警戒线
CPU_STK_SIZE   stk_size,//任务的空间大小
OS_MSG_QTY    q_size, //能接收的信息队列最大值
OS_TICK         time_quanta,//时间片轮转时间
void             *p_ext,// 任务控制块的扩展信息
OS_OPT          opt, //任务的选项
OS_ERR         *p_err) //任务的错误信息
(2)void OSTaskChangePrio()            //任务优先级别的改变
(3)void OSTaskDel()                   //任务的删除
(4)void OSTaskSuspend()              //任务的暂停
(5)void OSTaskResume()               //任务的恢复
(6)void OSTaskStkChk()               //校核空余内存的数量
(7)OS_MSG_QTY OSTaskQFlush()      //清空任务级消息队列中的消息
(8)void *OSTaskQPend()               //挂起任务级消息队列
(9)CPU_BOOLEAN OSTaskQPendAbort()//取消任务级消息队列的挂起状态
(10)void OSTaskQPost()               //向任务级消息队列中发送消息
(11)OS_REG OSTaskRegGet()          //获取任务寄存器的当前值
(12)void OSTaskRegSet()              //设置任务寄存器的当前值
(13)OS_SEM_CTR OSTaskSemPend()    //任务信号量等待信号
(14)CPU_BOOLEAN OSTaskSemPendAbort()//任务信号量取消挂起状态
(15)OS_SEM_CTR OSTaskSemPost()    //任务信号量发送消息
(16)OS_SEM_CTR OSTaskSemSet()     //设置任务信号量的计数值
(17)void OSTaskTimeQuantaSet()       //改变任务的时间片

voidTaskMain(void *pdata);              //任务声明
static   OS_TCB  TaskMainTCB;            //任务控制块
#define  TASK_MAIN_PRIO        3          //任务优先级
#define  TASK_MAIN_STK_SIZE   256   //任务堆栈大小256*4=1024B
static   CPU_STK TaskMainStk[TASK_MAIN_STK_SIZE];//任务堆栈定义
OSTaskCreate((OS_TCB    *)&TaskMainTCB,       //任务的控制块   
(CPU_CHAR  *)"Task Main Start",        //任务的名称
(OS_TASK_PTR )TaskMain,              //任务的函数指针
(void       *)0,                                    //任务的函数初值
(OS_PRIO     )TASK_MAIN_PRIO,    //任务的优先级
(CPU_STK   *)&TaskMainStk[0],      //任务的堆栈
(CPU_STK_SIZE)TASK_MAIN_STK_SIZE/10,//任务的堆栈剩余警戒线
(CPU_STK_SIZE)TASK_MAIN_STK_SIZE,//任务的空间大小
(OS_MSG_QTY  )0,         //所能接收的信息队列最大值
(OS_TICK     )0,            //任务的时间片轮转时间
(void       *)0,               //任务的任务控制块的扩展信息
(OS_OPT      )(OS_OPT_TASK_STK_CHK| OS_OPT_TASK_STK_CLR), //任务的选项
(OS_ERR    *)&err);        //任务的错误信息
三、 OS_TIME.C
(1)void OSTimeDly()                 //以时钟节拍数为单位延时
(2)void OSTimeDlyHMSM()            //用时、分、秒、毫秒为单位延时
(3)void OSTimeDlyResume()          //取消任务中的延时,引发一次调度
(4)OS_TICKOSTimeGet()            //获取OSTime 值
(5)void OSTimeSet()                 //设置 OSTime 值
四、 OS_SEM.C
(1)void OSSemCreate()              //创建信号量
(2)OS_OBJ_QTY OSSemDel()         //删除信号量
(3)OS_SEM_CTR OSSemPend()       //请求信号量
(4)OS_SEM_CTR OSSemPost()        //发送(释放)信号量
(5)void  OSSemSet()                  //设置信号量的计数值
(6)OS_OBJ_QTYOSSemPendAbort()    //取消信号量

static  OS_SEM  AppSem;          //定义一个信号量变量
CPU_TS  ts=0;//存放发送消息时的时间戳OS_TS_GET();(获取当前时间戳)
OS_ERR err;   //返回的错误信息
OSSemCreate(&AppSem,"Test Sem", 0, &err);//要在使用之前创建(如果在两个任务中都用到,则最好在两个任务创建前建立,也可在优先级高的任务中建立)
OSSemPend(&AppSem,0,OS_OPT_PEND_BLOCKING,&ts,&err);//等待信号量(ts为发送信号量的时间戳)
OSSemPost(&AppSem, OS_OPT_POST_1,&err);//发送信号量
五、 OS_FLAG.C
(1)void OSFlagCreate()                    //信号标志组的创建函数
(2)OS_OBJ_QTY OSFlagDel()                 //删除信号标志组
(3)OS_FLAGS OSFlagPend()                //挂起信号标志组
(4)OS_FLAGS OSFlagPost()                   //向信号标志组发送信号
(5)OS_OBJ_QTYOSFlagPendAbort()         //取消挂起信号标志组

staticOS_FLAG_GRP AppFlag;            //定义一个信号标志组变量
CPU_TSts=0;  //存放发送消息时的时间戳OS_TS_GET();(获取当前时间戳)
OS_ERRerr;   //返回的错误信息
OSFlagCreate(&AppFlag,"TestFlag",0x00,&err);//创建信号标志组且设置初值为0x00
OSFlagPend(&AppFlag,0x03,0,OS_OPT_PEND_FLAG_SET_ALL,&ts,&err);
//等待信号标志组的bit0和bit1都为1
OSFlagPost(&AppFlag,0x01,OS_OPT_POST_FLAG_SET,&err);
//把信号标志组的bit0设置为1
六、 OS_MUTEX.C
(1)void OSMutexCreate()                   //创建互斥型信号量
(2)OS_OBJ_QTY OSMutexDel()              //删除互斥型信号量
(3)void OSMutexPend()                       //请求互斥型信号量
(4)void OSMutexPost()                     //发送(释放)互斥型信号量
(5)OS_OBJ_QTYOSMutexPendAbort()       //取消互斥型信号量
static  OS_MUTEX AppMutex;             //定义一个互斥型信号量变量
CPU_TS  ts=0;//存放发送消息时的时间戳OS_TS_GET();(获取当前时间戳)
OS_ERR err;   //返回的错误信息
OSMutexCreate(&AppMutex,"Test Mutex", &err);//创建互斥型信号量
OSMutexPend(&AppMutex, 0, OS_OPT_PEND_BLOCKING,&ts,&err);
//互斥型信号量申请(阻塞方式)
OSMutexPost(&AppMutex, OS_OPT_POST_NONE,&err);
//互斥型信号量释放
七、 OS_Q.C
(1)void OSQCreate()                       //创建一个消息队列
(2)OS_OBJ_QTY OSQDel()                 //删除消息队列
(3)OS_MSG_QTY OSQFlush()               //清空消息队列
(4)void *OSQPend()                        //请求一个消息队列
(6)void OSQPost()                         //向消息队列发送消息
(6)OS_OBJ_QTYOSQPendAbort()           //取消消息队列的等待状态
以指针和长度的形式向其他任务发送消息,如果是阻塞方式则接收到的数据的次数等于发送的次数才会被阻塞。
static  OS_Q AppQ;                      //定义一个消息队列变量
u8sendq_a[2]={1,2};                     //要发送的数据
OSQCreate(&AppQ,"Test Q", 13, &err);//创建消息队列包含存放消息的条数
OSQPost(&AppQ,sendq_a,2, OS_OPT_POST_FIFO,&err);//发送数据
OS_MSG_SIZEmsg_size=0;               //接收到的数据的大小
CPU_TS  ts=0;                          //发送数据时的时间戳
OS_ERRerr;
u8 *req;                                //接收到的数据的地址
req=(u8*)OSQPend (&AppQ, 0, OS_OPT_PEND_BLOCKING,
&msg_size,&ts,&err);
//接收数据(阻塞方式,非阻塞方式是给中断用的)
八、 OS_MEM.C
(1) void OSMemCreate()                 //创建一个固定大小的内存分区 (2)void *OSMemGet()                    //从分区中获取一个内存块
(3)void OSMemPut()                     //返还一个内存块到分区
九、 OS_TMR.C
(1)void OSTmrCreate()                  //创建一个定时器,定时调用函数
(2)CPU_BOOLEAN OSTmrDel()           //删除定时器
(3)OS_TICK OSTmrRemainGet()           //定时器的剩余时间
(4)CPU_BOOLEAN OSTmrStart()          //定时器开始计时
(5)OS_STATE OSTmrStateGet()           //获取定时器的当前状态
(6)CPU_BOOLEAN OSTmrStop()          //定时器停止计时

版权声明:本文为博主原创文章,未经博主允许不得转载。

这篇关于UCOSIII的一些常用函数总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1123466

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

常用的jdk下载地址

jdk下载地址 安装方式可以看之前的博客: mac安装jdk oracle 版本:https://www.oracle.com/java/technologies/downloads/ Eclipse Temurin版本:https://adoptium.net/zh-CN/temurin/releases/ 阿里版本: github:https://github.com/

30常用 Maven 命令

Maven 是一个强大的项目管理和构建工具,它广泛用于 Java 项目的依赖管理、构建流程和插件集成。Maven 的命令行工具提供了大量的命令来帮助开发人员管理项目的生命周期、依赖和插件。以下是 常用 Maven 命令的使用场景及其详细解释。 1. mvn clean 使用场景:清理项目的生成目录,通常用于删除项目中自动生成的文件(如 target/ 目录)。共性规律:清理操作

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

二分最大匹配总结

HDU 2444  黑白染色 ,二分图判定 const int maxn = 208 ;vector<int> g[maxn] ;int n ;bool vis[maxn] ;int match[maxn] ;;int color[maxn] ;int setcolor(int u , int c){color[u] = c ;for(vector<int>::iter

整数Hash散列总结

方法:    step1  :线性探测  step2 散列   当 h(k)位置已经存储有元素的时候,依次探查(h(k)+i) mod S, i=1,2,3…,直到找到空的存储单元为止。其中,S为 数组长度。 HDU 1496   a*x1^2+b*x2^2+c*x3^2+d*x4^2=0 。 x在 [-100,100] 解的个数  const int MaxN = 3000