在实际项目中移植并配置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这套开发流程的(全链条开源、高效且高度可定制,可跨平台),可以留言,如果超过三个人,我就出一期教程。

相关推荐
大聪明-PLUS4 小时前
Linux 下的 C 语言编程:创建你自己的命令 shell
linux·嵌入式·arm·smarc
世转神风-1 天前
linux-嵌入式开发基础-网线直连-局域网传输文件-快速完成文件替换
linux·嵌入式
北京迅为2 天前
【北京迅为】iTOP-4412精英版使用手册-第七十八章 Qt界面切换
linux·人工智能·嵌入式·4412
大聪明-PLUS2 天前
关于 systemd 和桌面应用程序自动启动
linux·嵌入式·arm·smarc
Channon_2 天前
专题四:内存战场的无声战役——压缩、共享与空间复用
缓存·嵌入式·空间复用
大聪明-PLUS2 天前
了解 Linux 系统中用于流量管理的 libnl 库
linux·嵌入式·arm·smarc
大聪明-PLUS2 天前
使用 Shell 脚本生成配置文件的 6 种方法
linux·嵌入式·arm·smarc
大聪明-PLUS2 天前
Linux 下的 C 语言编程:创建命令行 shell:第二部分
linux·嵌入式·arm·smarc
大聪明-PLUS2 天前
在 Linux 6.8 中创建自定义系统调用
linux·嵌入式·arm·smarc