【UCOS-III】自我学习笔记→第31讲→任务内嵌消息队列

该文记录了在STM32F411RET6开发板上使用uC/OS-III实时操作系统进行任务消息队列的实验。首先复制消息队列工程,修改为任务消息队列,然后观察串口现象。文中提供了相关的任务配置和代码示例,包括任务创建、消息发送和接收。
摘要由CSDN通过智能技术生成

前言

无,仅作记录,不具有参考价值,所用开发板为STM32F411RET6nucleo开发板。

实验步骤

1.复制消息队列工程,将创建,发送,获取消息队列的内容改为任务消息队列

在这里插入图片描述
在这里插入图片描述

2.查看串口现象

在这里插入图片描述

测试代码

us-os3_demo.c:

/**
 ****************************************************************************************************
 * @file        uc-os3_demo.c
 * @author      ÕýµãÔ­×ÓÍŶÓ(ALIENTEK)
 * @version     V1.0
 * @date        2022-04-13
 * @brief       uC/OS-III ÒÆֲʵÑé
 * @license     Copyright (c) 2020-2032, ¹ãÖÝÊÐÐÇÒíµç×ӿƼ¼ÓÐÏÞ¹«Ë¾
 ****************************************************************************************************
 * @attention
 *
 * ʵÑéƽ̨:ÕýµãÔ­×Ó Ì½Ë÷Õß F407¿ª·¢°å
 * ÔÚÏßÊÓƵ:www.yuanzige.com
 * ¼¼ÊõÂÛ̳:www.openedv.com
 * ¹«Ë¾ÍøÖ·:www.alientek.com
 * ¹ºÂòµØÖ·:openedv.taobao.com
 *
 ****************************************************************************************************
 */

#include "uc-os3_demo.h"
#include "./MALLOC/malloc.h"
/*uC/OS-III*********************************************************************************************/
#include "os.h"
#include "cpu.h"
#include "main.h"
#include "key.h"
#include "stdio.h"
#include "interrupt.h"

extern struct keys key[4];
/******************************************************************************************************/
/*uC/OS-IIIÅäÖÃ*/

/* START_TASK ÈÎÎñ ÅäÖÃ
 * °üÀ¨: ÈÎÎñÓÅÏȼ¶ ÈÎÎñÕ»´óС ÈÎÎñ¿ØÖÆ¿é ÈÎÎñÕ» ÈÎÎñº¯Êý
 */
#define START_TASK_PRIO				5
#define START_TASK_STACK_SIZE 256
CPU_STK start_task_stack[START_TASK_STACK_SIZE];
OS_TCB start_task_tcb;

void start_task(void * p_arg);

/* TASK1 ÈÎÎñ ÅäÖÃ
 * °üÀ¨: ÈÎÎñÓÅÏȼ¶ ÈÎÎñÕ»´óС ÈÎÎñ¿ØÖÆ¿é ÈÎÎñÕ» ÈÎÎñº¯Êý
 */
#define TASK1_PRIO				4
#define TASK1_STACK_SIZE 256
CPU_STK * task1_stack;
OS_TCB task1_tcb;

void task1(void * p_arg);

/* TASK2 ÈÎÎñ ÅäÖÃ
 * °üÀ¨: ÈÎÎñÓÅÏȼ¶ ÈÎÎñÕ»´óС ÈÎÎñ¿ØÖÆ¿é ÈÎÎñÕ» ÈÎÎñº¯Êý
 */
#define TASK2_PRIO 3 //1.¶¨ÒåÓÅÏȼ¶ºê¶¨Òå
#define TASK2_STACK_SIZE 256 //2.¶¨Òå¶ÑÕ»´óС
CPU_STK task2_stack[TASK2_STACK_SIZE]; //3.¿ª±Ù¶ÑÕ»¿Õ¼ä
OS_TCB task2_tcb; //4.´´½¨ÈÎÎñÖ¸Õë

void task2(void * p_arg);

/**
 * @brief       uC/OS-IIIÀý³ÌÈë¿Úº¯Êý
 * @param       ÎÞ
 * @retval      ÎÞ
 */
void uc_os3_demo(void)
{
    OS_ERR err;
    
    /* ³õʼ»¯uC/OS-III */
    OSInit(&err);
    OSTaskCreate (  (OS_TCB        *) &start_task_tcb,
                    (CPU_CHAR      *) "start_task",
                    (OS_TASK_PTR    ) start_task,
                    (void          *) 0,
                    (OS_PRIO        ) START_TASK_PRIO,
                    (CPU_STK       *) start_task_stack,
                    (CPU_STK_SIZE   ) START_TASK_STACK_SIZE / 10,
                    (CPU_STK_SIZE   ) START_TASK_STACK_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);
    /* ¿ªÊ¼ÈÎÎñµ÷¶È */
    OSStart(&err);
}

void start_task(void * p_arg)
{
	OS_ERR err;
	CPU_INT32U cnts = 0;
	CPU_Init();
	CPU_SR_ALLOC();
	

	cnts = HAL_RCC_GetSysClockFreq() / OS_CFG_TICK_RATE_HZ;
	OS_CPU_SysTickInit(cnts);
	
	CPU_CRITICAL_ENTER(); /* ½øÈëÁÙ½çÇø */
	task1_stack = mymalloc(SRAMIN, TASK1_STACK_SIZE * sizeof(CPU_STK));
	/* ´´½¨task1 */
	OSTaskCreate ((OS_TCB        *) &task1_tcb,
								(CPU_CHAR      *) "task1",
								(OS_TASK_PTR    ) task1,
								(void          *) 0,
								(OS_PRIO        ) TASK1_PRIO,
								(CPU_STK       *) task1_stack,
								(CPU_STK_SIZE   ) TASK1_STACK_SIZE / 10,
								(CPU_STK_SIZE   ) TASK1_STACK_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);
		
		OSTaskCreate ((OS_TCB        *)&task2_tcb,
									(CPU_CHAR      *)"task2",
									(OS_TASK_PTR    )task2,
									(void          *)0,
									(OS_PRIO        )TASK2_PRIO,
									(CPU_STK       *)task2_stack,
									(CPU_STK_SIZE   )TASK2_STACK_SIZE / 10,
									(CPU_STK_SIZE   )TASK2_STACK_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);
									

		CPU_CRITICAL_EXIT(); /* Í˳öÁÙ½çÇø */
		printf("ÕýÔÚ´´½¨ÖÐ\r\n");
		OSTaskDel((OS_TCB*)0, &err); //±ðÍüÁËɾ³ýÈÎÎñStart
}

/* дÈÎÎñÄÚǶ¶ÓÁÐ */
void task1(void * p_arg)
{
	OS_ERR err;
	uint8_t keyValue = 0;
	while(1)
	{
		if(key[0].single_flag)
		{
			keyValue = 1; 
			printf("·¢ËͼüÖµ!\r\n");
			OSTaskQPost (&task2_tcb, &keyValue, sizeof(keyValue), OS_OPT_POST_FIFO, &err);
			key[0].single_flag = 0;
		}
		if(key[0].long_flag)
		{
			keyValue = 2; 
			printf("·¢ËͼüÖµ!\r\n");
			OSTaskQPost (&task2_tcb, &keyValue, sizeof(keyValue), OS_OPT_POST_FIFO, &err);
			key[0].long_flag = 0;
		}
		OSTimeDly(10, OS_OPT_TIME_DLY, &err);
	}
}

/* ¶ÁÈÎÎñÄÚǶ¶ÓÁÐ */
void task2(void * p_arg)
{
	OS_ERR err;
	uint8_t *keyValueReceive;
	OS_MSG_SIZE MsgSize = 0;
	while(1)
	{
		keyValueReceive =  OSTaskQPend (0, OS_OPT_PEND_BLOCKING, &MsgSize, 0, &err);
		printf("½ÓÊÕµ½µÄ¼üֵΪ:%d\r\n", *keyValueReceive);
		printf("½ÓÊÕµ½µÄÊý¾Ý³¤¶ÈΪ:%d×Ö½Ú\r\n", MsgSize);
	}
}




工程文件

任务内嵌消息队列实验

总结

【正点原子】手把手教你学UCOS-III实时操作系统第31讲任务内嵌消息队列

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值