FreeRTOS系列推文很久之前就完结了, 最近在GD32进行相关移植, 发现还有更好的移植方案, 比起直接修改启动文件更加实用, 这里只简单做下介绍和总结;
第一步: 准备一个裸机工程文件, 最好配置了GPIO和串口, 因为这两个是最方便查看效果的;
第二步:把FreeRTOS的源码直接复制到工程目录下,这样就算没安装支持包都可以直接使用,也方便相关管理和维护:

第三步: 添加分组, 然后把相关源码添加进去:

注意: 配置文件可以在官方demo中找到:

第四步: 添加路径:

第五步: 在FreeRTOSConfig.h进行适当修改:

第六步: 屏蔽三个中断函数:

第七步: 编写任务函数:
#include "hal_led.h"
#include "hal_log.h"
#include "hal_usart.h"
#include "hal_printf.h"
#include "FreeRTOS.h"
#include "task.h"
#define START_TASK_PRIO 1 //任务优先级
#define START_STK_SIZE 128 //任务堆栈大小
TaskHandle_t StartTask_Handler; //任务句柄
void start_task(void *pvParameters);//任务函数
#define LED0_TASK_PRIO 2 //任务优先级
#define LED0_STK_SIZE 50 //任务堆栈大小
TaskHandle_t LED0Task_Handler; //任务句柄
void led0_task(void *p_arg); //任务函数
// 外设初始化
void hal_device_init(void)
{
hal_led_init();
hal_log_init();
hal_usart_init();
}
// 主循环
int main( void )
{
// 设置系统中断优先级分组 4
nvic_priority_group_set(NVIC_PRIGROUP_PRE0_SUB4);
// 外设初始化
hal_device_init();
//创建开始任务
xTaskCreate(
(TaskFunction_t )start_task, //任务函数
(const char* )"start_task", //任务名称
(uint16_t )START_STK_SIZE, //任务堆栈大小
(void* )NULL, //传递给任务函数的参数
(UBaseType_t )START_TASK_PRIO, //任务优先级
(TaskHandle_t* )&StartTask_Handler //任务句柄
);
vTaskStartScheduler(); //开启调度
while(1);
}
//开始任务函数
void start_task(void *pvParameters)
{
taskENTER_CRITICAL(); //进入临界区
//创建 LED0 任务
xTaskCreate(
(TaskFunction_t )led0_task,
(const char* )"led0_task",
(uint16_t )LED0_STK_SIZE,
(void* )NULL,
(UBaseType_t )LED0_TASK_PRIO,
(TaskHandle_t* )&LED0Task_Handler
);
vTaskDelete(StartTask_Handler); //删除开始任务
taskEXIT_CRITICAL(); //退出临界区
}
//LED0 任务函数
void led0_task(void *pvParameters)
{
while(1)
{
/* 测试精度*/
if(RESET == gpio_input_bit_get(GPIOC, GPIO_PIN_6)){
gpio_bit_write(GPIOC, GPIO_PIN_6, SET);
}else{
gpio_bit_write(GPIOC, GPIO_PIN_6, RESET);
}
usert_printf(USART0, "USART0
");
vTaskDelay(1000);
}
}
第八步: 看效果:

这种移植方案与以前的方案最大的不同就是不修改启动文件, 对于不懂汇编和启动文件的读者比较友好, 也比较推荐这种方案来使用FreeRTOS; 解决问题的方法千千万万, 选择自己喜欢的就好, 也没有什么不可。
审核编辑:汤梓红
全部0条评论
快来发表一下你的评论吧 !