uCOS-II整理之任务的同步与通信

1、任务间的同步
任务间的制约关系:直接制约关系和间接制约关系
任务之间具有互斥的关系(例如多个任务不能同时访问同一资源),相关任务爱执行上要有先后次序,任务之间的这种制约性运行机制叫做任务间的同步
2、事件(信号量、消息邮箱、消息队列的统称)
信号量:相当于一个标志,各任务通过判断信号量的值来决定接下来该怎么运行。例如交通灯,绿灯时通过,红灯时等待。信号量是为了保证多个任务不同时访问同一个资源的,当一个任务访问一个共享资源是,信号量由1变为0,此时其他任务也想访问该资源,但是读取到信号量为0,表示该资源正在被访问,于是该任务等待资源被释放再去访问。
相关函数:
OS_EVENT *OSSemCreate(INT16U cnt):创建信号量,其中cnt可以理解为信号的容量,可允许多少任务“同时”访问一个共享资源(但不仅仅只是指资源),且一般不为1。
Void OSSemPend(OSEVENT * pevent,INT16U timeout,INT8U *err):请求信号量,第一个参数为被请求信号量的指针。
INT8U OSSemPost(OS_EVENT *pevent):发送信号量,发送成功,返回OS_NO_ERR,失败返回相应错误。
OS_EVENT *OSSemDel(OS_EVENT *pevent,INT8U opt,INT8U *err):删除信号量,pevent为信号量指针,opt为删除选项,errweiOS_DEL_NO_PPEND,则没有等待任务后才删除信号量,err为OS_DEL_ALLWAYS,则马上删除。
INT8U OSSemQuery(OS_EVENT *pevent,OS_SEM_DATA *pdata):查询信号量的状态,结果存储在pdata中,所以在调用此函数前需要先定义OS_SEM_DATA指针类型的变量pdata。
当信号的容量为1时,叫做互斥型信号量,即一个共享资源(但不仅仅只是指资源)在一段时间内只能被一个任务访问,其他任务只能等待。为了防止出现优先级反转的出现,互斥型信号量有专门的函数。
OS_EVENT *OSMutexCreate(INT8U prio,INT8U *err):创建互斥型信号量,prio为需要反转的优先级任务。
Void OSMutexPend(OS_EVENT *pevent,INT16U timeout,INT8U *err):请求互斥型信号量
INT8U OSMutexPost(OS_EVENT *pevent):发送互斥型信号量。
消息邮箱:再任务与任务之间常常需要通过传递一个数据来进行通信,为此,在内存中创建一个存储空间作为该数据的缓冲区。最简单的方法就是通过传递该缓冲区的指针(地址)来进行数据传输。用来传递消息缓冲区指针的数据架构叫做消息邮箱
这里写图片描述
相关函数:
OS_EVENT *OSMboxCreate(void *msg):创建消息邮箱,msg为消息的指针,即消息内容的地址,函数返回值为消息邮箱的指针。
INT8U OSMboxPost(OS_EVENT *pevent,void *msg):向消息邮箱发送消息,msg为消息邮箱的内容
Void *OSMboxPend(OS_EVENT *pevent,INT16U timeout,INT8U *err):请求消息邮箱。
INT8U OSMboxQuery(OS_EVENT *pevent,OS_MBOX_DATA *pdata):查询邮箱的状态
OS_EVENT *OSMboxDel(OS_EVENT *pevent,INT8U opt,INT8U *err):删除消息邮箱。

消息队列:消息邮箱存放一个数组的指针,而数组的每个成员又存放一个消息缓冲区,从而传递多个消息,就构成了消息队列。
这里写图片描述
相关函数:
创建消息队列:
这里写图片描述
请求消息队列
这里写图片描述
向消息队列发送消息(先进先出的方式)
这里写图片描述
和(先进后出的方式)
这里写图片描述
3、事件控制块的结构
当一个事件被占用时(即信号量、邮箱等被占用时)会导致其他请求该事件的任务处于等待状态,因此需要对这些任务进行管理,一是对等待任务进行登记并排序,二是允许等待任务有一个等待时限。
uCOS-II定义了INT8U 类型的OSEventTbl[]:等待任务表,为了加快对该表的访问速度,也定义了一个INT8U 类型的变量OSEventGrp来表示等待任务表中的任务组
至于等待的时限,记录在TCB的OSTCBDly成员中
4、事件控制块结构
这里写图片描述
这里写图片描述
这里写图片描述
在uCOS-II初始化时会创建空事件控制块链表,以后每创建一个事件,系统从链表中取出一个控制块进行初始化,而删除一个事件,就会将该控制块归还给空事件控制块链表

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
抱歉,作为AI语言模型,我没有权限写代码,只能回答一些问题并提供一些相关的资料,以供参考。 UCOS-II是一款小型的可裁剪的实时操作系统,它提供了一种方式来组织和管理复杂的嵌入式系统。UCOS-II支持任务管理、信号量、消息队列、邮箱等通信机制,可以实现多任务并发执行,并提供了优先级调度和时间片轮转两种任务调度方式。 UCOS-II任务通信管理是通过信号量、消息队列、邮箱等来实现的。在任务中需要使用相应的通信机制进行同步或异步的数据交换。具体的实现方法可以参考UCOS-II的官方文档或者相关的书籍。 以下是参考代码: ``` /* 任务1 */ static void task1(void *p_arg) { OS_ERR err; CPU_INT08U buffer[10]; while (1) { /* 从消息队列中获取数据 */ OSQPend(&queue, 0, OS_OPT_PEND_BLOCKING, NULL, &err); /* 处理数据 */ handle_data(buffer); } } /* 任务2 */ static void task2(void *p_arg) { OS_ERR err; CPU_INT08U buffer[10]; while (1) { /* 等待信号量 */ OSSemPend(&semaphore, 0, OS_OPT_PEND_BLOCKING, NULL, &err); /* 发送数据到消息队列 */ OSQPost(&queue, buffer, sizeof(buffer), OS_OPT_POST_FIFO, &err); } } int main(void) { /* 初始化UCOS-II内核 */ OSInit(&err); /* 创建任务 */ OSTaskCreate(&task1_tcb, "Task 1", task1, NULL, TASK1_PRIORITY, task1_stack, TASK_STACK_SIZE, 0, 0, 0, 0, &err); OSTaskCreate(&task2_tcb, "Task 2", task2, NULL, TASK2_PRIORITY, task2_stack, TASK_STACK_SIZE, 0, 0, 0, 0, &err); /* 创建信号量和消息队列 */ OSSemCreate(&semaphore, "Sem", 0, &err); OSQCreate(&queue, "Queue", QUEUE_SIZE, &err); /* 启动UCOS-II */ OSStart(&err); return 0; } ``` 此外,UCOS-II还提供了一些与应用相关的服务,如时钟管理、内存管理、文件系统等。如果需要更加详细的资料,可以参考UCOS-II的官方文档或者相关的书籍。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值