在实际项目中移植并配置hal库

下图是我项目的目录结构,关于目录设计思想,这里不展开描述,只讲解如何将hal库移植到该项目中并配置:

首先先明确 HAL 移植的"最小闭环"需要哪些文件(以STM32F407为例):

  1. CMSIS + STM32F4xx_HAL_Driver

    CMSISARM Cortex‑M 内核 + STM32 设备提供"最底层统一接口/头文件/启动模板" STM32F4xx_HAL_DriverSTHAL 驱动库

  2. 三件套:startup / system / linker

    • startup_stm32f407xx.s

    MCU 上电复位后执行的第一段代码

    • system_stm32f4xx.c

    芯片级系统初始化与全局时钟变量维护

    • app.ld

    告诉链接器 Flash/RAM/CCMRAM 的地址与大小和各内存段(.isr_vector/.text/.rodata/.data/.bss)的位 置,并导出启动文件需要的符号(_estack/_sidata/_sdata/_edata/_sbss/_ebss)

  3. stm32f4xx_hal_conf.h

    HAL 的"编译期配置开关",决定:

    • 开启哪些 HAL 模块(GPIO/UART/RCC/SDIO/FSMC...)
    • 时钟参数(例如 HSE_VALUE
    • 断言/回调等选项
  4. stm32f4xx_it.c/.h

    实现"中断入口函数"

  5. stm32f4xx_hal_msp.c

    实现 HAL 提供的"硬件相关回调(钩子)"

关于本项目hal移植,我将其分为三部分:

  • external/st(原始代码):包括CMSISSTM32F4xx_HAL_Driver
  • platform(芯片级):包括startup_stm32f407xx.ssystem_stm32f4xx.c
  • applications(产物级): 包括app.ldstm32f4xx_hal_conf.hstm32f4xx_it.c/.hstm32f4xx_hal_msp.c

在完成文件移植后还需要进行一些配置:

  • HAL 配置文件stm32f4xx_hal_conf.h,必须正确配置:
    • HSE_VALUE(板子外部晶振频率,错了 PLL 会失败)
    • 启用用到的 HAL 模块宏(例如 GPIO/RCC/PWR...)
  • 配置stm32f4xx_it.c/.h,至少实现:
    • SysTick_Handler():调用 HAL_IncTick()(建议再调用 HAL_SYSTICK_IRQHandler())

至此hal库的移植和配置都已完成,但要想使项目运行起来,在Keil或其他IDE软件中再配置一下编译器、编译路径等,基本就可以用了,如果只想用vscode进行开发,可以配置外部编译器arm-none-eabi-gcc,并用cmakeninja组织和构建编译,再用openocd+任意仿真器下载程序即可,如果有想了解vscode+arm-gcc+cmake+ninja+openocd这套开发流程的(全链条开源、高效且高度可定制,可跨平台),可以留言,如果超过三个人,我就出一期教程。

相关推荐
421!14 分钟前
ESP32学习笔记之UART
笔记·学习·嵌入式·esp32·通信
隔壁大炮1 小时前
PID控制结构&角度环实现直立
stm32·嵌入式·硬件·pid·平衡车·江协科技
FreakStudio13 小时前
不用费劲编译ulab了!纯Mpy矩阵micronumpy库,单片机直接跑
python·嵌入式·边缘计算·电子diy
Zevalin爱灰灰1 天前
零基础入门学用物联网(ESP8266) 第一部分 基础知识篇(三)
单片机·物联网·嵌入式·esp8266
优信电子2 天前
ESP32开发板单向点对点ESP-NOW无线通信
单片机·嵌入式·arduino
FreakStudio2 天前
保姆级 uPyPi 教程|从 0 到 1:MicroPython 驱动包一键安装 + 分享全攻略
python·嵌入式·电子diy
GetcharZp3 天前
只有代码是不够的:手搓手机第一课,看懂那条“看不见的河流”
嵌入式
busideyang3 天前
数据手册和参考手册区别
stm32·单片机·嵌入式硬件·嵌入式
vockydesign3 天前
SUBDEV驱动的set_fmt和get_fmt实现
嵌入式
网易独家音乐人Mike Zhou3 天前
【嵌入式基础】Keil自动编译脚本及环境变量配置
c语言·stm32·单片机·51单片机·嵌入式·keil