STM32的FreeRtos的学习

首先就是去官网下载一个源文件:FreeRtos官网

下载下来的是一个zip文件,解压缩了。

然后再工程文件夹中创建个文件夹:

在这个文件夹中创建3个文件夹:

然后开始把下载下来的文件夹中的文件挑选出来放到我们的工程文件夹中:

至此所需要的文件就全部拷贝齐全了,接下来就是在工程中添加各个文件了。

最后三个文件夹的文件在工程中的分布如图:

接下来就是主程序了,其实过程就是:

1:声明一个任务句柄。

2:创建一个任务函数。

3:创建一个任务。

4:开启调度器。

cs 复制代码
#include "stm32f10x.h"                  // Device header
#include "freertos.h"      //包含freeRtos头文件
#include "task.h"           //包含task头文件

TaskHandle_t myTaskHandler;   //声明一个任务句柄

void myTask( void * arg)     //创建一个任务函数
{
	while(1)             //任务函数就是一个死循环
	{
		GPIO_ResetBits(GPIOC, GPIO_Pin_13);   //GPIO13口置0
		vTaskDelay(500);                      //延时500
		GPIO_SetBits(GPIOC, GPIO_Pin_13);     //GPIO13口置1
		vTaskDelay(500);                      //延时500
	}
}


int main(void)
{
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
	GPIO_InitTypeDef GPIO_InitStruct;
	GPIO_InitStruct.GPIO_Mode = GPIO_Mode_Out_PP;
	GPIO_InitStruct.GPIO_Pin = GPIO_Pin_13;
	GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_Init(GPIOC, &GPIO_InitStruct);
	
	GPIO_ResetBits(GPIOC, GPIO_Pin_13);
	
	/*创建一个任务(第一个参数是任务函数名称,
				   第二个参数是一个字符串,随便写
				   第三个参数是任务堆栈大小,我定的是512
	               第四个参数是任务传递参数,这里暂时不用写NULL
				   第五个参数是任务优先级,可以随意设置,我设置的是2
				   第六个参数是任务句柄)*/
	xTaskCreate(myTask, "myTask", 512, NULL, 2, &myTaskHandler); 
	
	vTaskStartScheduler();   //开启调度器
	while(1)
	{
		
	}
}

还需要在FreeRTOSConfig.h中添加几行宏定义:

#define xPortPendSVHandler PendSV_Handler

#define vPortSVCHandler SVC_Handler

#define xPortSysTickHandler SysTick_Handler

还要在stm32f10x_it.c文件中把刚刚宏定义的三个函数注释掉:107行 126行 135行

至此编译主函数下载到单片机中就能看到PC13的小灯在闪烁了。其他的地方我也不懂呢?今天第一天开始学习。

相关推荐
就叫飞六吧1 天前
普中stm32大Dap烧录流程
stm32
递归不收敛1 天前
吴恩达机器学习课程(PyTorch适配)学习笔记:1.5 决策树与集成学习
pytorch·学习·机器学习
菜鸟‍1 天前
【论文学习】2025年图像处理顶会论文
图像处理·人工智能·学习
Logintern091 天前
【学习篇】Redis 分布式锁
redis·分布式·学习
A9better1 天前
嵌入式开发学习日志38——stm32之看门狗
stm32·嵌入式硬件·学习
小莞尔1 天前
【51单片机】【protues仿真】基于51单片机智能路灯控制系统
c语言·stm32·单片机·嵌入式硬件·51单片机
Vizio<1 天前
《基于 ERT 的稀疏电极机器人皮肤技术》ICRA2020论文解析
论文阅读·人工智能·学习·机器人·触觉传感器
weixin_514221851 天前
FDTD与matlab、python耦合
python·学习·matlab·fdtd
递归不收敛1 天前
吴恩达机器学习课程(PyTorch 适配)学习笔记大纲
pytorch·学习·机器学习
不太可爱的叶某人1 天前
【学习笔记】kafka权威指南——第10章 监控kafka (7-10章只做了解)
笔记·学习·kafka