文章目录
- 前言
- 实验步骤
- 1.复制消息队列工程,并创建OS内存区句柄和内存地址,并删除task2\task3及其相关内容
- 2.修改task1任务函数
- 3.查看串口现象
- 测试代码
- 工程文件
- 总结
前言
无,仅作记录,不具有参考价值,所用开发板为STM32F411RET6nucleo开发板。
实验步骤
1.复制消息队列工程,并创建OS内存区句柄和内存地址,并删除task2\task3及其相关内容
2.修改task1任务函数
3.查看串口现象
测试代码
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);
OS_MEM OSmem;
static unsigned char OSmemBuffer[10][100];
/**
* @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);
/* ´´½¨Ò»¸öÄÚ´æÇø */
OSMemCreate (&OSmem, "OSmem", OSmemBuffer, 10, 100, &err);
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);
CPU_CRITICAL_EXIT(); /* Í˳öÁÙ½çÇø */
printf("ÕýÔÚ´´½¨ÖÐ\r\n");
OSTaskDel((OS_TCB*)0, &err); //±ðÍüÁËɾ³ýÈÎÎñStart
}
/* °´¼üÅжϣ¬KEY0¶Ì°´ÉêÇëÄÚ´æ¿é£¬³¤°´ÊÍ·ÅÄÚ´æ¿é£¬²¢´òÓ¡ÌáʾÐÅÏ¢ */
void task1(void * p_arg)
{
OS_ERR err;
unsigned int task1_num = 0;
unsigned char *memBlocksGet;
while(1)
{
if(key[0].single_flag)
{
memBlocksGet = OSMemGet(&OSmem, &err); /* ÉêÇëÄÚ´æ¿é */
if(memBlocksGet != NULL)
{
printf("ÄÚ´æ¿éÉêÇë³É¹¦!!²¢ÇÒÄÚ´æ¿ìµÄÆäʵµØÖ·:0x%p\r\n", memBlocksGet);
}
else
{
printf("ÄÚ´æ¿éÉêÇëʧ°Ü!!\r\n");
}
key[0].single_flag = 0;
}
if(key[0].long_flag)
{
if(memBlocksGet != NULL)
{
OSMemPut(&OSmem, memBlocksGet, &err); /* ÊÍ·ÅÄÚ´æ¿é */
printf("ÊÍ·ÅÄÚ´æ¿é!!\r\n");
memBlocksGet = NULL;
}
key[0].long_flag = 0;
}
if(++task1_num % 100 == 0)
{
task1_num = 0;
printf("¿ÕÏÐÄÚ´æ¿éµÄÊýÁ¿Îª:%d\r\n", OSmem.NbrFree);
}
OSTimeDly(10, OS_OPT_TIME_DLY, &err);
}
}
工程文件
内存管理实验
总结
要么每申请一次就要释放一次,要么每释放一次就用一个指针存放,否则会导致内存泄漏现象产生
【正点原子】手把手教你学UCOS-III实时操作系统第37讲内存管理实验