RT-Thread&&STM32开发系列(2):FAT头文件包含报错与RTT和CubeMX文件兼容问题

2023-05-16

成就更好的自己

近期的项目需要在RTT下,使用SD卡运行FAT文件系统,而且还能通过USB将这个SD卡虚拟化成大容量可存储设备,在项目初期遇到了一些小问题,记录一下,防止别的朋友踩坑。

文章概览:

初始化后FAT头文件的包含问题;

RTT与CubeMX生成的其他模组文件的兼容;

测试平台:STM32F407VGT6

STM32CubeMX版本:6.1.2

HAL库版本:1.16.1

RTT组件包版本:3.1.3


目录

FAT头文件包含问题

RTT与CubeMX其他模组文件的兼容


FAT头文件包含问题

以往来说,笔者都是比较懒,都是像下面一样将各种外设的xx.h文件和自己写的一些xx.h文件都包含到main.h中,然后一些自定义的或者其他的.c文件直接包含main.h文件即可,这样的做法简单无脑。

但是在cubeMX生成的FAT工程里,将fatfs.h包含在main.h中就疯狂报错,具体如下:

 

我在网上查了半天,就看到了两个人跟我遇见的问题一样但是问而无果,所以这里把报错当做代码引用一下,增加编译报错关键字来让有同样问题的人搜到这篇博客。

error type>(36): error:  #20: identifier "Diskio_drvTypeDef" is undefined

  extern Diskio_drvTypeDef  USER_Driver;

../FATFS/App/fatfs.h(37): error:  #20: identifier "FATFS" is undefined

  extern FATFS SDFatFS; /* File system object for SD logical drive */

../FATFS/App/fatfs.h(38): error:  #20: identifier "FIL" is undefined

  extern FIL SDFile; /* File object for SD */

../FATFS/App/fatfs.h(41): error:  #20: identifier "FATFS" is undefined

  extern FATFS USERFatFS; /* File system object for USER logical drive */

../FATFS/App/fatfs.h(42): error:  #20: identifier "FIL" is undefined

  extern FIL USERFile; /* File object for USER */

../Middlewares/Third_Party/FatFs/src/ff_gen_drv.c: 0 warnings, 6 errors

compiling syscall.c...

../Middlewares/Third_Party/FatFs/src/ff_gen_drv.h(57): error:  #20: identifier "_VOLUMES" is undefined

    uint8_t                 is_initialized[_VOLUMES];

../FATFS/App/fatfs.h(37): error:  #20: identifier "FATFS" is undefined

  extern FATFS SDFatFS; /* File system object for SD logical drive */

../FATFS/App/fatfs.h(38): error:  #20: identifier "FIL" is undefined

  extern FIL SDFile; /* File object for SD */

../FATFS/App/fatfs.h(41): error:  #20: identifier "FATFS" is undefined

  extern FATFS USERFatFS; /* File system object for USER logical drive */

../FATFS/App/fatfs.h(42): error:  #20: identifier "FIL" is undefined

刚开始我以为这样做没有问题,但是解决报错将近两个小时后觉得根据语法和编译原理的知识仍然没有解决,所以就尝试恢复到代码初始生成的状态。当我把头文件恢复到main.c以后就不报错了。

到此为止,就是因为头文件的不当包含出现的问题,这样让我想出了几个利害关系:

  • 根据MDK的编译机制,如果写在一起,对其中任意一个头文件进行修改就会对所有包含这个头文件的.c文件进行重新编译,这样很费时间;
  • 会让整个工程杂乱无序,不符合高内聚低耦合的程序设计宗旨;
  • 对于程序的移植会出现各种各样想不通看不懂的问题;
  • 对于开源程序来说会让使用者不利于阅读与部分移植;

虽然并没有分析出包含在main.h中到底有什么错误,但是也确实该改掉这种方式了,这个问题就到此为止吧!

RTT与CubeMX其他模组文件的兼容

问题描述:

之前一直使用的RTT只是用到了UART,TIM,IIC等简单的外设,这次一下子开了很多复杂功能就出现了一些问题。按照之前的RTT移植过程的配置都没出现什么问题,这一次配置完成后编译0error0warning但是shell界面只出现了版本输出,不显示msh>的命令行提示。

 

很快就锁定了问题所在,但是在此之前需要先介绍一下几个知识点。

问题分析:

  • msh(或者说shell)实质上是一个进程,只要是进程就要参与时间片轮转调度才能运行,一个任务只要不让出cpu的使用权,其他任务就永远不会被轮到执行。

  • RTT的任务调度与轮转是依靠单个任务中使用rt_thread_mDelay()函数,是使自己暂时挂起来让出cpu的使用权。
  • Main函数实质上是一个进程,如果main不结束且者main函数中没有rt_thread_mDelay()让出资源或者在某一个进程中卡死,都会使程序卡死,导致其他进程无法使用cpu。

回到正题,msh配置没问题但是不显示说明目前的进程并没有让出cpu的使用权,进而说明程序在某个地方陷入循环或者卡死。进过Debug后发现程序卡死在初始化的MX_USB_DEVICE_Init(),这是USB的初始化,进而深入查找在其调用的USB底层文件看到了一个裸机开发熟悉的函数HAL_Delay(),就是他让程序卡死的。为什么呢?再来几个知识点。

  • HAL库的HAL_Delay函数的原理是使用systick内核滴答定时器进行精准定时从而延时的,在裸机开发中经常使用到。
  • RTT的时基定时器默认也是systick内核滴答定时器,通过这个定时器控制进程调度和时间片轮转,从而控制进程调度。由rt_thread_mDelay()函数进行调用控制。

所以在RTT系统中不能出现HAL_Delay函数,否则会使程序卡死。在MX_USB_DEVICE_Init()中的底层配置中调用了这个函数,因此程序卡死在这里。然后我又查了一下,我滴乖乖,SDIO和USB的操作中都不同程度的存在HAL_Delay函数,原因在于RTT与FAT一样属于第三方的软件包,不是ST官方的东西,所以在兼容性上与CubeMX生成的其他文件会有差异与兼容问题,不过由于HAL库的全面与强大,通常这种兼容问题都只需要进行小部分修改即可解决。

解决办法:

因为HAL_Delay()函数存在的地方不少,所以直接替换这个函数不太合适。所以我们直接修改HAL_Delay()的定义。在stm32f4xx_hal.c文件中,包含rtthread.h文件,然后找到HAL_Delay()函数,将函数体全部注释,因为rt_thread_mdelay()函数的传入参数与HAL_Delay()传入参数类型一致,直接加一句rt_thread_mdelay(Delay)即可;

或者由于HAL_Delay()是_week弱定义,我们可以直接在main.c中用户代码区重新定义一个void HAL_Delay(uint32_t Delay),内容就一句话rt_thread_mdelay(Delay);这样重新生成代码时就不会担心被删掉。

问题解决!!!

写在最后,未来几期博客就以目前的项目为Handle来写,涉及STM32外设开发,模块开发,RTT开发,项目完成的时候打算开源到gitee上,敬请期待。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

RT-Thread&&STM32开发系列(2):FAT头文件包含报错与RTT和CubeMX文件兼容问题 的相关文章

  • 室内外融合北斗+uwb终端数据监听和发送控制方法

    UDP接收GNGGA报文同时转发UDP报文的方法 span class token keyword package span span class token class name Frame span span class token p
  • Ubuntu使用终端命令安装谷歌Chrome浏览器

    使用命令行安装谷歌浏览器稳定版 span class token function sudo span span class token function wget span http www linuxidc com files repo
  • 无人机PX4使用动捕系统mocap的位置实现控制+MAVROS

    动捕系统Optitrack xff0c 有很高的定位精度 xff0c 能够给无人机提供比较精确的位置信息 xff0c 因此如果实验室有条件 xff0c 都可以买一套动捕系统 动捕系统的原理 xff1a 光学式动作捕捉依靠一整套精密而复杂的光
  • Optitrack使用ros完成实时接收刚体的位置与四元数信息

    1 Opitrack系统标定 工作环境 xff1a 运行Motive的Windows主机 和一台安装有ROS的ubuntu电脑 标定步骤 1 准备 优化捕获设置 xff1b 2 在相机预览窗口 xff08 Camera Preview xf
  • RoboMaster机甲大师比赛入门?我们从STM32开始!

    同步博客地址 xff1a 从STM32开始的RoboMaster生活 xff1a 入门篇 项目 amp 教程仓库 xff1a STM32 RoboMaster 1 0 STM32是什么 1 1 定义 ST 43 M 43 32 61 STM
  • C++头文件定义类的方法

    新手在写C 43 43 程序定义类的时候 xff0c 可能会犯一个错误 xff0c 就是在main函数文件里定义很多类 xff0c 一个文件中包含很多函数 xff0c 这样程序看起来很冗杂 今天总结一下如何在C 43 43 中使用头文件来定
  • 相机光学(十五)——如何提高相机标定的精度

    为了提高单目相机标定的精度 xff0c 认真看了张正友标定法的原文 xff0c 并且学习过网上一些牛人的方法 xff0c 但是大部分时候说的很笼统 xff0c 自己把这些经验总结起来并都测试了一下 xff0c 感觉靠谱的结论列出如下 xff
  • TCP/UDP、封装与解封装

    目录 传输类型 网络里面三层架构 TCP IP模型 OSI模型 TCP IP模型 掌握 TCP IP模型当中重点 数据传递过程中的封装和解封装 封装 解封装 TCP UDP ICMP ICMP错误报告 ICMP重定向 典型应用 PING应用
  • 解决 ERROR: cannot launch node of type [xxx]: can‘t locate node [xxx] in package [xxx]

    背景 xff1a 从github下载的ros代码 xff0c 修改添加节点后 xff0c catkin make 编译通过 xff0c 但在运行launch文件时候报错 原因 xff1a 1 从github上下载的很多文件 xff0c 下载
  • stm32控制步进电机

    本文使用DM542c驱动器驱动 使用前注意根据实际情况调节拨码开关 本文不会提到GPIO使能 xff0c 请自行使能 一 PWM操作驱动器使步进电机一直转 使能定时器时钟 xff0c 并配置基本参数 下图以TIM3为例 配置输出比较PWM1
  • 树莓派GPIO

    命令行执行下行 xff0c 即可得树莓派管脚编码表 gpio readall 也可看下图 xff1a BOARD 编号参考 Raspberry Pi 主板上 P1 接线柱的针脚编号 使用该方式的优点是无需考虑主板的修订版本 xff0c 无需
  • python opencv滤波

    1 均值滤波 算法简单 xff0c 计算速度快 xff0c 在去噪的同时去除了很多细节部分 xff0c 将图像变得模糊 cv2 blur 2 高斯滤波 去除高斯噪声 cv2 GaussianBlur 3 中值滤波 去除椒盐噪声 cv2 me
  • opencv imwrite()保存指定路径

    cpp为例 include lt opencv2 opencv hpp gt include lt string gt include lt iostream gt using namespace cv using namespace st
  • python pip安装的包的路径

    以ubuntu为例 从一个店家那里拿到的一个ubuntu环境中 xff0c 同时安装了python3 6和python2 7 xff0c 又安装了ros xff0c 最后pip安装包的位置很混乱 xff0c 安装的包不知道安装在了哪里 使用
  • solidworks实体显示线框

    sw有段时间没使用 xff0c 今天打开突然发现打开的sw窗口数超过1 xff0c 那么从第二个窗口以后的模型都显示成以下样子 xff08 无论是之前的文件还是新建的都不行 xff09 如上是一个圆盘 xff0c 明明是实体 xff0c 却
  • vscode使用虚拟环境

    我的conda没有添加入path xff0c 每次打开总是报错 一 选择对应虚拟环境的解释器 1 点击vscode的右下角这里 2 点击后可能会在vscode上方出现下图样子 xff0c 如果出现下图 xff0c 则点击第二项Select
  • TabError: inconsistent use of tabs and spaces in indentation

    错误原因是tab制表符和空格混用了 从其他地方复制源码容易出现此错误 解决办法 xff1a 把处于同级缩进的所有缩进修改统一 比较流行的几个编辑器都能标识tab和空格 xff0c 比如我用的vscode 用鼠标框选 不知道是tab还是空格的
  • 关于深度学习的问题笔记

    感谢沐神教我深度学习 x1f64f 损失为什么要平均 xff1f 平均即除以batch size xff0c 若不除 xff0c 则批越大梯度越大 xff0c 梯度下降的步长就越大 除以batch size可使梯度与批大小无关 也可以不在损
  • 简单(炫酷)的单链表快速排序写法

    昨天在复习快排的时候 在B站看到一个小哥哥说某大厂的面试让写一个单链表的快速排序 我们见的最多的快排写法都是从两端向中间扫描 这种写法在单链表上不能实现 哥们分析道 快排的核心思想是每次扫描后 所有pivot左侧的元素都比pivot小 右侧
  • char* char[]

    C 43 43 判断char 的指向 char a 61 34 Peter 34 char b 61 34 Peter 34 char c 61 new char 6 strcpy s c 6 34 Peter 34 这里a指向常量区 b指

随机推荐

  • HTTP 基本认证 HttpBasic

    HTTP 的认证机制 基本认证 摘要认证 一 基本认证 用BASE64 算法加密后的字符串放在HTTP Request中的Header Authorization中发送给服务端 xff0c 这种方式叫HTTP基本认证 Basic Authe
  • libcurl异步调用

    span class token keyword int span span class token function main span span class token punctuation span span class token
  • 标准c++库、stl库,boost库,qt库

    C 43 43 标准库 C C xff0b xff0b 标准库主要包含3部分 xff1a STL IO流及本地化 C的函数库 标准库不是STL STL是标准模板库 是标准库的一个子集 它是一个可复用的组件库 xff0c 其中包含了很多实用的
  • 生成2023年节假日/工作日维表

    项目中有一张维表 xff0c 维护的是历史节假日工作日的信息 xff0c 估计在很多场合都有类似的需求 到了新年 xff0c 需要生成新一年的数据 xff0c 下面看看如何在维表中插入新一年的数据 1 查询节假日 根据国务院发布的休假信息
  • C++智能指针

    参考 xff1a 头文件auto ptr使用示例 unique ptr类模板声明示例 shared ptr模板声明通过辅助类模拟实现 shared ptrshared ptr使用示例 weaked ptrweak ptr 用法weak pt
  • 使用SiftGPU对两幅图像进行特征点匹配

    前言 继上一篇博客中谈到使用Changchang Wu的SiftGPU xff0c 使用GLSL语言在Windows系统下的编译方法http blog csdn net qq 36007951 article details 7847234
  • CAN通信学习笔记(一)

    1 CAN通信的基本原理 1 1 基本概念 CAN 是 Controller Area Network 的缩写 xff08 以下称为 CAN xff09 xff0c 是 ISO 国际标准化的串行通信协议 在北美和西欧 xff0c CAN 总
  • DSP28335 SCI FIFO深度设置

    SCI工作在FIFO模式下一般是因为所传输的信息并不是以一个字节为单位 xff0c 而是以多个字节组成的一个包为单位的 如果一包数据包括10个字节 xff0c 可以设置FIFO接收中断为10个字节时产生中断 设置以后 xff0c 每接收到1
  • Serial Studio简单使用说明

    Serial Studio简介 Serial Studio是一个跨平台的软件 xff0c 支持将串口 xff0c TCP UDP xff0c MQTT等协议传输数据 xff0c 并将数据可视化显示 xff0c 方便嵌入式开发人员实现数据的可
  • YOLOV1个人理解总结

    YOLO是著名的端到端目标检测框架 xff0c 最大的特点是检测快 xff0c 亲自试验YOLOv3 v5 v5在jeston Xavier NX上可以达到15FPS左右 xff0c 检测精度也相当可观 xff0c 可以达到实时检测 xff
  • STM32HAL库-USART-调试串口(大小端测试)

    概述 本篇文章介绍如何使用STM32HAL库 xff0c USART 调试串口 xff08 大小端测试 xff09 示例 硬件 xff1a STM32F103CBT6最小系统板 软件 xff1a Keil 5 29 43 STM32Cube
  • Windows下实现C语言Socket通讯TCP传送结构体信息

    版权声明 xff1a 本文为博主原创文章 xff0c 未经博主允许不得转载 Windows下实现C语言Socket通讯 lt TCP传送结构体信息 gt 首先socket通信的步骤 xff1a 三次握手协议 三次握手协议 代码 服务器端 i
  • #STC8A8K# #STC8F1K# #STC8G1K# #STC8H1K# ——STC8系列单片机整体评价

    成就更好的自己 声明 xff1a 这不是广告 xff0c 只是发表看法和吐槽 xff0c 不吹不擂 xff1b 本文以STC8A8K64S4A12 为例 xff0c 简要分析一下STC8系列 xff1b STC 宏晶科技 公司作为国内的一家
  • 拓展模块使用教程和心得(三):ULN2003模块与28BYJ48步进电机(测试平台:STC8A8K,STM32F103)

    成就更好的自己 关于ULN2003模块和对应的28BYJ48步进电机 xff0c 网上现有的资料与教程对于初学者有点不太友好 xff0c 造成的现象是仅仅只能让步进电机转起来 xff0c 但是没有对于控制转速和转角的实践分析 xff0c 本
  • intellij 从2020升级到2023 踩坑实录

    1 下载新版本intellij 工作机器上的intellij版本为2020社区版 xff0c 版本比较老旧 xff0c 需要进行升级 IDE这种提高生产力的工具 xff0c 还是蛮重要的 xff0c 也是值得稍微多花点时间研究一下的 升级之
  • 拓展模块使用教程和心得(五):HC08及HC系列蓝牙模块

    成就更好的自己 今天在做单片机的数据采集并给PC处理 xff0c 根据前期的想法本来是要使用nRF24L01进行的 xff0c 奈何nRF无线模块转USB接口太不给力 xff0c 因此使用到了HC08作为发送和接收数据的模块 目录 简介 内
  • ROS四旋翼无人机快速上手指南(3):工作环境文件框架与各功能包整体讲解

    成就更好的自己 这一章节主要讲解无人机平台的控制文件架构和各个功能包组成和用法 uav ws与shell源码链接 xff1a https gitee com theroadofengineers ros uav 目录 主要项目文件架构概述
  • STM32程序不运行与MicroLIB讲解

    成就更好的自己 目录 引言 什么是MicroLIB 不使用Microlib导致卡死的原理 卡死解决办法 xff1a 优化空间测评 引言 先说问题 xff0c 这几天在使用STM32H750调试程序的过程中出现了一些问题 xff0c 博主使用
  • 拓展模块使用教程和心得(7):3irobotix杉川Delta-1A激光雷达的STM32F407HAL驱动

    成就更好的自己 随着现代智能化设备程度的提高 xff0c 激光雷达已经是在智能控制与检测领域的极其常用的智能化传感器 xff0c 今天就来介绍一下3irobotix公司的Delta 1A激光雷达 Delta 1A激光雷达是一款低成本中等性能
  • RT-Thread&&STM32开发系列(2):FAT头文件包含报错与RTT和CubeMX文件兼容问题

    成就更好的自己 近期的项目需要在RTT下 xff0c 使用SD卡运行FAT文件系统 xff0c 而且还能通过USB将这个SD卡虚拟化成大容量可存储设备 xff0c 在项目初期遇到了一些小问题 xff0c 记录一下 xff0c 防止别的朋友踩