三分钟教你玩转cubeMX+USB+FATFS+FREERTOS

1、真的只要三分钟吗?

可能还不要,cubeMX的强大,你想都想不到,话不多说,直接开始。

2、配置过程

配置时钟源、配置USB、配置FATFS、配置FREERTOS,与其说是配置,其实就是勾选,除了特定选择的几个参数外,一切采用默认参数,完美通过。

2.1、配置时钟

选择外部时钟源,我的板子是12M晶振。
在这里插入图片描述
按照下面选择时钟
在这里插入图片描述

2.2、调试接口配置

SYS里面选择调试接口,这个地方不要忘记了,否则烧写不了程序。
在这里插入图片描述

2.3、USB配置

忽略我配置的其他东西,选择USB_OTG_FS后,选择Host_Only。
在这里插入图片描述
下面在USB_HOST里面选择MassStorageHostClass。
在这里插入图片描述

2.4、文件系统配置

直接勾选USB Disk。
在这里插入图片描述

2.5、操作系统配置

直接勾选打开就好了。
在这里插入图片描述
下面要注意一下,任务栈要设置的大一点,文件系统里面定义的一些结构体比较占空间,笔者开始没有注意这个地方,采用默认值,结果程序一直进hardfault,这里设置到512bytes
在这里插入图片描述

2.6、项目工程设置

最小堆和最小栈设置一下,其他的根据自己的工程来。
在这里插入图片描述

所有参数都默认就好了,不用折腾,下面直接生成代码,打开工程。

3、测试代码

打开工程后,直接在fatfs.c里面,编写一个测试代码,如下
在这里插入图片描述
在这里插入图片描述
然后在main.c里面的开始任务里面加入测试代码
在这里插入图片描述

4、结论

插一个U盘在你的板子上面,根据测试代码的编写逻辑,会在你的U盘里面简历一个STM32.TXT的文件,然后在文件里面写上一段话“The site is STM32cube.com working with FatFs”。看看你的成功了没有,就是这么简单。不要再去配置什么寄存器了。
USB的基本流程,先mount,再open,再write,最后close,然后unmount。在挂载前,注意检查USB的状态,要在READY状态下才可以,操作完了之后设置为DISCONNECT,然后卸载掉U盘。
笔者开始碰到一个问题,弄了半天,重建了几个工程,发现,重复这个过程,三分钟就搞定了。
有问题,可以给我留言。

### STM32CubeMXFATFS 文件系统和 FreeRTOS 的集成配置 #### 使用STM32CubeMX初始化项目 STM32CubeMX 是一款用于简化基于STM32微控制器项目的开发环境配置工具[^3]。当启动一个新的STM32工程时,可以通过该图形化界面轻松挑选目标MCU型号并完成初步设置。 对于具体的操作流程,在新项目创建界面上会展示众多可供选择的STM32设备选项;利用左边栏内的分类目录能够快速定位到所需的系列产品线,比如STM32F4家族下的成员——STM32F407VG,并继续推进至下一步骤以设定内部振荡器及时钟分配方案等重要参数[^4]。 ```c // 这里是通过STM32CubeMX生成的基础代码框架的一部分, // 它包含了必要的头文件引入以及全局变量声明。 #include "main.h" #include "stm32f4xx_hal.h" /* USER CODE BEGIN Includes */ extern uint8_t USB_to_SD(uint8_t *data, uint32_t length); /* USER CODE END Includes */ int main(void){ /* 初始化所有外设,Flash接口,GPIOs...*/ HAL_Init(); // 用户自定义部分开始... } ``` #### 添加FATFS支持 为了使应用程序具备读写SD卡的能力,需向STM32CubeMX中加入FatFs组件的支持。这一步通常是在中间件(Middlewares)标签页下找到FatFs库并勾选启用它。之后按照提示调整相应的挂载点路径和其他必要属性即可让系统识别外部存储介质上的数据结构。 一旦完成了上述操作,则可以在程序逻辑里面调用`f_mount()`函数关联卷标物理驱动器,进而执行诸如打开/关闭文件(`f_open()`, `f_close()`)、读取/写入数据(`f_read()`, `f_write()`)等一系列标准API命令来处理位于SD卡里的资料。 ```c // 下面展示了如何使用FatFs API进行简单的文件I/O操作的例子: FRESULT res; /* FatFs 函数返回的结果 */ FIL fileObject; /* 文件对象句柄 */ UINT bytesWritten; res = f_mount(&fatfs, "", 1); // 尝试安装默认分区 if (res != FR_OK){ // 如果失败则报告错误 Error_Handler(__FILE__, __LINE__); } res = f_open(&fileObject, "test.txt", FA_WRITE | FA_CREATE_ALWAYS); if(res == FR_OK){ const char* textToWrite = "Hello World!"; res = f_write(&fileObject, textToWrite, strlen(textToWrite), &bytesWritten); if(bytesWritten != strlen(textToWrite)){ Error_Handler(__FILE__, __LINE__); } f_close(&fileObject); } else { Error_Handler(__FILE__, __LINE__); } ``` #### 整合FreeRTOS多任务管理功能 为了让系统的各个模块能更高效有序地运行起来,建议采用实时操作系统(Real-Time Operating System),像广泛应用于嵌入式领域的FreeRTOS就是一个错的选择。借助于STM32CubeMX同样很容易就能把此内核纳入进来:只需前往“Middleware”菜单项处查找RTX或FreeRTOS条目并激活之便大功告成啦! 此时开发者就可以着手编写多个独立的任务单元了,每一个都对应着特定的工作职责。下面给出了一段示范性的源码片段,其中涉及到了两个并发执行的任务——一个是周期性打印消息给串口终端,另一个负责监听按键状态变化事件以便触发某些动作反应。 ```c void StartDefaultTask(void const * argument){ for(;;){ printf("This is the default task.\r\n"); osDelay(5000); // 延迟五秒再重复循环体内容 } } void StartButtonMonitorTask(void const * argument){ GPIO_PinState buttonState; while(1){ buttonState = HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_0); if(buttonState == GPIO_PIN_SET){ // 执行按下后的相应措施... }else{ // 处理释放情况... } osDelay(100); // 设置合理的轮询间隔时间 } } osThreadDef(default_task, StartDefaultTask, osPriorityNormal, 0, configMINIMAL_STACK_SIZE); osThreadDef(button_monitor_task, StartButtonMonitorTask, osPriorityAboveNormal, 0, configMINIMAL_STACK_SIZE); int main(void){ ... osKernelInitialize(); // 启动前准备工作 osThreadCreate(osThread(default_task), NULL); osThreadCreate(osThread(button_monitor_task), NULL); osKernelStart(); // 正式开启调度机制 ... } ```
评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值