APM32芯得EP.43|使用CMake构建APM32工程

极海Geehy 2024-10-28 20:37


《APM32芯得》系列内容为用户使用APM32系列产品的经验总结,均转载自21ic论坛极海半导体专区,全文未作任何修改,未经原文作者授权禁止转载。




# 01 前言


一般嵌入式开发都是用集成 IDE 工具,IDE 的好处是集成了编辑器、编译器、调试器等工具,可以一站式开发。但是 IDE 也有很多缺点,比如不跨平台、不开源等。如果想要摆脱 IDE 的束缚,就需要手动编写编译规则,比如 Makefile 构建工程,但是 Makefile 语法比较复杂,很多时候手动编写 Makefile 比较繁琐,工作量也比较大。


CMake 是一个比较流行的跨平台构建工具,它可以自动生成 Makefile,本篇文章主要介绍怎么用 CMake 和 MinGW-w64 构建 APM32 工程,编译器使用 gcc-arm-none-eabi,调试器使用 DAPLink。


# 02 环境搭建


## 软件环境准备

- Windows 10/11

- CMake 3.28.0-rc5

- MinGW-w64 8.1.0

- gcc-arm-none-eabi 10.3.1

## 搭建 MinGW-w64 环境

### 安装 CMake

[CMake](https://cmake.org/download/) 是一个开源的跨平台构建工具,可以用简单的语句来描述所有平台的安装(编译过程)。它能够输出各种各样的makefile 或者 project 文件。到官网找到二进制版本的 CMake,本篇文章使用的是`cmake-3.28.0-rc5-windows-x86_64.zip`。

下载压缩包并解压到自己喜欢的位置,这里解压到 `E:\ToolChain\`。

### 配置环境变量

将`E:\ToolChain\cmake-3.28.0-rc5-windows-x86_64\bin` 添加到环境变量 `Path` 中。

### 验证 CMake 是否安装成功

打开 CMD,输入 `cmake -version`,如果出现如下信息,则说明 CMake 安装成功。

### 安装 MinGW-w64

[MinGW-W64](https://sourceforge.net/projects/mingw-w64/files/mingw-w64/)全称为 Minimalist GNU for Windows,是一个在 Windows 平台上编译 32 位和64 位应用程序的工具集。

下载 `x86_64-win32-seh` 并 解压压缩包中的 mingw64 文件夹到自己喜欢的位置,这里解压到 `E:\ToolChain\`。

### 配置环境变量

将 `E:\ToolChain\mingw64\bin` 添加到环境变量 `Path` 中。

### 验证 MinGW-w64 是否安装成功

打开 CMD,输入 `gcc -v`,如果出现如下信息,则说明 MinGW-w64 安装成功

## 搭建gcc-arm-none-eabi 环境

### 安装gcc-arm-none-eabi

[gcc-arm-none-eabi](https://developer.arm.com/tools-and-software/open-source-software/developer-tools/gnu-toolchain/gnu-rm/downloads)是 ARM 官方提供的一款免费的编译器,支持多种操作系统,包括Windows、Linux 和 macOS。

从上面的链接下载压缩包后,同样解压到 `E:\ToolChain\`。

### 配置环境变量

将 `E:\ToolChain\gcc-arm-none-eabi-10.3-2021.10\bin`添加到环境变量 `Path` 中。

### 验证gcc-arm-none-eabi 是否安装成功

打开 CMD,输入`arm-none-eabi-gcc -v`,如果出现如下信息,则说明 gcc-arm-none-eabi 安装成功。

# 03 构建工程

## 准备 APM32 工程

从 [APM32 DAL SDK](https://www.geehy.com/support/apm32?id=311) 下载APM32_DAL_SDK_V1.0,这里使用 GPIO_Toggle 工程进行构建。

## 编写CMakeLists.txt

在 `GPIO_Toggle` -> `Project` 目录下新建 `CMake` 目录并新增 `CMakeLists.txt` 文件,如下图所示。

CMake 的语法可以参考[CMake Documentation and Community](https://cmake.org/documentation/),这里只介绍一些常用和关键的语法。

### 指定 CMake 最低版本和项目名称

`cmake_minimum_required` 用于指定构建此项目所需的 CMake 的最低版本,`project` 用于指定项目名称。


```cmake

cmake_minimum_required(VERSION 3.21) # 指定构建此项目所需的 CMake 的最低版本

project(GPIO_Toggle C CXX ASM) # 指定项目名称和编程语言

```


### 指定编译器

`set` 用于设置变量,`CMAKE_C_COMPILER`用于指定 C 语言编译器,`CMAKE_CXX_COMPILER`用于指定 C++ 语言编译器,`CMAKE_ASM_COMPILER`用于指定汇编语言编译器。

`CMAKE_OBJCOPY` 用于指定生成二进制文件的工具,`CMAKE_OBJDUMP` 用于指定生成汇编文件的工具,`CMAKE_SIZE` 用于指定生成大小报告的工具。


```cmake

set(CMAKE_C_COMPILER "arm-none-eabi-gcc") # 指定 C 语言编译器

set(CMAKE_ASM_COMPILER "arm-none-eabi-gcc") # 指定汇编语言编译器

set(CMAKE_OBJCOPY arm-none-eabi-objcopy) # 指定生成二进制文件的工具

set(SIZE arm-none-eabi-size) # 指定生成大小报告的工具

```


### 配置设备 ID

`set` 用于设置变量,`DEVICE_ID`用于指定设备 ID,`BSP_DEFINE` 用于指定 BSP 宏定义,`BSP_DIR_NAME` 用于指定 BSP 目录名称。


```cmake

# device settings

set(DEVICE_ID "APM32F407xx")

set(BSP_DEFINE BOARD_APM32F407_MINI)

set(BSP_DIR_NAME Board_APM32F407_Mini)

# select startup file

if ("${DEVICE_ID}" STREQUAL "APM32F405xx")

set(STARTUP_FILE startup_apm32f405xx.S)

set(LINKER_FILE apm32f405xg_flash.ld)

set(DEVICE_DEFINE APM32F405xx)

elseif ("${DEVICE_ID}" STREQUAL "APM32F407xx")

set(STARTUP_FILE startup_apm32f407xx.S)

set(LINKER_FILE apm32f407xg_flash.ld)

set(DEVICE_DEFINE APM32F407xx)

elseif ("${DEVICE_ID}" STREQUAL "APM32F417xx")

set(STARTUP_FILE startup_apm32f417xx.S)

set(LINKER_FILE apm32f417xg_flash.ld)

set(DEVICE_DEFINE APM32F417xx)

else()

message(FATAL_ERROR "Please select first the target APM32F4xx device")

endif ()

```


### 添加编译选项

`add_compile_options` 用于添加编译选项,`-mcpu=cortex-m4` 用于指定 CPU 架构,`-mthumb` 用于指定 Thumb 指令集,

`-mthumb-interwork` 用于指定 Thumb 指令集兼容 ARM 指令集。


```cmake

add_compile_options(-mcpu=cortex-m4 -mthumb -mthumb-interwork)

add_compile_options(-ffunction-sections -fdata-sections -fno-common -fmessage-length=0)

```


### 配置宏定义

`add_definitions` 用于添加宏定义,`-D${DEVICE_DEFINE}` 用于指定设备宏定义,`-D${BSP_DEFINE}`用于指定 BSP 宏定义,`-DUSE_DAL_DRIVER`用于指定使用 DAL 库。


```cmake

add_definitions(

-DUSE_DAL_DRIVER

-D${DEVICE_DEFINE}

-D${BSP_DEFINE}

)

```


### 添加头文件和源文件路径

`include_directories` 用于添加头文件路径,`file(GLOB_RECURSE SOURCES)` 用于添加源文件路径。


```cmake

# add include file

include_directories(

../../Include

../../Config/Include

../../../../../../Libraries/CMSIS/Include

../../../../../../Libraries/Device/Geehy/APM32F4xx/Include

../../../../../../Libraries/APM32F4xx_DAL_Driver/Include

../../../../../../Boards/${BSP_DIR_NAME}/Include

)

# add source file

file(GLOB_RECURSE SOURCES

"${STARTUP_FILE}"

"../../Source/*.c"

"../../Config/Source/*.c"

"../../../../../../Libraries/APM32F4xx_DAL_Driver/Source/*.c"

"../../../../../../Boards/${BSP_DIR_NAME}/Source/*.c"

)

```


PS: GCC编译器可以输出静态库、动态库和可执行文件,理论上来说可以将所有的源文件都放在一起编译,但是这样做的话,每次编译都会编译所有的源文件,这样会导致编译时间过长,所以一般情况下,我们会将源文件分成多个库,然后再将这些库链接到一起,这样可以减少编译时间。这样就会用到 `add_library`。比如将LwIP库编译成静态库,然后将静态库链接到主程序中。比如将 LwIP 编译成静态库:


```cmake

add_library(lwip

../../../../../../Middlewares/lwip-2.1.2/src/api/api_lib.c

...

)

```


### 添加链接脚本

`add_link_options` 用于添加链接脚本。


```cmake

set(LINKER_SCRIPT ${CMAKE_SOURCE_DIR}/${LINKER_FILE})

add_link_options(-T ${LINKER_SCRIPT})

```


### 添加链接选项

`-gc-sections`:这是一个链接器选项,用于在链接过程中删除未使用的代码和数据,有助于减小最终生成的二进制文件的大小。

`--print-memory-usage`:这是一个链接器选项,用于在链接过程结束后打印内存使用情况。

`-Map=${PROJECT_BINARY_DIR}/firmware.map`:这是一个链接器选项,用于生成一个map文件,该文件包含了链接过程的详细信息,如各个函数和变量在内存中的位置等。


```cmake

add_link_options(-Wl,-gc-sections,--print-memory-usage,-Map=${PROJECT_BINARY_DIR}/firmware.map)

add_link_options(-mcpu=cortex-m4 -mthumb -mthumb-interwork)

```


### 添加可执行文件

`add_executable` 用于添加可执行文件,`${SOURCES}` 用于指定源文件,`${LINKER_SCRIPT}` 用于指定链接脚本。


```cmake

add_executable(firmware.elf ${SOURCES} ${LINKER_SCRIPT})

```


### 添加生成二进制文件和汇编文件的命令

`add_custom_command` 用于添加自定义命令,`TARGET firmware.elf POST_BUILD` 用于指定在生成可执行文件后执行命令,`COMMAND ${CMAKE_OBJCOPY} -Oihex $ ${HEX_FILE}` 用于生成 HEX 文件,`COMMAND ${CMAKE_OBJCOPY} -Obinary $ ${BIN_FILE}` 用于生成 BIN 文件。


```cmake

set(HEX_FILE ${PROJECT_BINARY_DIR}/firmware.hex)

set(BIN_FILE ${PROJECT_BINARY_DIR}/firmware.bin)

add_custom_command(TARGET firmware.elf POST_BUILD

COMMAND ${CMAKE_OBJCOPY} -Oihex [        DISCUZ_CODE_420        ]lt;TARGET_FILE:firmware.elf> ${HEX_FILE}

COMMAND ${CMAKE_OBJCOPY} -Obinary [        DISCUZ_CODE_420        ]lt;TARGET_FILE:firmware.elf> ${BIN_FILE}

COMMENT "Building ${HEX_FILE}

Building ${BIN_FILE}")

```


## 编译工程

### 生成 Makefile

用下面的命令生成 Makefile。


```bash

$ cd .\Project\CMake

$ mkdir cmake-build

$ cmake -G "MinGW Makefiles" -B cmake-build

```


创建 `cmake-build` 目录用于存放生成的 Makefile。

生成 Makefile。

PS: `cmake -DCMAKE_BUILD_TYPE=Debug -B cmake-build` 可用于指定编译类型为 Debug。


### 生成可执行文件

用下面的命令编译工程。


```bash

$ cd .\Project\CMake\cmake-build

$ make (or mingw32-make)

```


编译完成后,会在 `cmake-build` 目录下生成 `firmware.elf`、`firmware.hex` 和 `firmware.bin` 文件。

PS:`make clean` 用于清除编译生成的文件。

PS:`make -j` 用于指定使用多线程编译。`-j`后面还可以跟一个数字来指定线程数。例如,`make -j4`会使用4个线程进行编译。

到此就完成了用 CMake 构建APM32 工程并输出可执行文件, 接着就可以用 OpenOCD 或 PyOCD 配合 DAPLink 进行下载、调试了。


# 参考资料

[CMake Documentation and Community](https://cmake.org/documentation/)

APM32F4xx_DAL_SDK_V1.0(CMake).zip



注:文章作者在原帖中提供了工程文件,有需要请至原文21ic论坛下载


原文地址:https://bbs.21ic.com/icview-3357660-1-1.html

或点击下方 阅读原文 跳转


↑↑↑ 点击上方卡片关注极海 ↑↑↑

极海Geehy 极海半导体是一家致力于开发工业级/车规级MCU、模拟与混合信号IC及系统级芯片的集成电路设计型企业
评论 (0)
  •   电磁干扰测试系统:电子设备电磁兼容性保障利器   北京华盛恒辉电磁干扰测试系统作为评估电子设备在电磁环境中电磁兼容性(EMC)的关键工具,主要用于检测与分析设备在电磁干扰环境下的性能表现,确保其符合相关标准,能够在实际应用中稳定运行。   应用案例   目前,已有多个电磁干扰测试系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润电磁干扰测试系统。这些成功案例为电磁干扰测试系统的推广和应用提供了有力支持。   系统组成   电磁干扰测试系统一般由以下核心部分构成:  
    华盛恒辉l58ll334744 2025-04-14 10:40 39浏览
  •  亥姆霍兹线圈的制造材料选择需兼顾导电性、绝缘性、机械强度及磁场性能,具体分类如下:一、‌导线材料1、‌高纯度铜线:‌作为线圈绕制的核心材料,铜因其you异的导电性(电阻率低)和热稳定性成为shou选。漆包铜线通过表面绝缘漆层实现匝间绝缘,避免短路‌。2、‌其他导电材料‌ 铝线等材料可用于特定场景(如轻量化需求),但导电性和抗氧化性较铜略逊二、‌磁源材料‌1、‌永磁体‌如钕铁硼(NdFeB)或铁氧体,适用于无需外部电源的静态磁场生成,但磁场强度有限。2、‌电磁铁‌通过电流控制磁场强度,
    锦正茂科技 2025-04-14 10:22 32浏览
  • 在当今汽车电子化和智能化快速发展的时代,车规级电子元器件的质量直接关系到汽车安全性能。三星作为全球领先的电子元器件制造商,其车规电容备受青睐。然而,选择一个靠谱的三星车规电容代理商至关重要。本文以行业领军企业北京贞光科技有限公司为例,深入剖析如何选择优质代理商。选择靠谱代理商的关键标准1. 授权资质与行业地位选择三星车规电容代理商首先要验证其授权资质及行业地位。北京贞光科技作为中国电子元器件行业的领军者,长期走在行业前沿,拥有完备的授权资质。公司专注于市场分销和整体布局,在电子元器件领域建立了卓
    贞光科技 2025-04-14 16:18 94浏览
  • 你知道精益管理中的“看板”真正的意思吗?在很多人眼中,它不过是车间墙上的一块卡片、一张单子,甚至只是个用来控制物料的工具。但如果你读过大野耐一的《丰田生产方式》,你就会发现,看板的意义远不止于此。它其实是丰田精益思想的核心之一,是让工厂动起来的“神经系统”。这篇文章,我们就带你一起从这本书出发,重新认识“看板”的深层含义。一、使“看板”和台车结合使用  所谓“看板”就是指纸卡片。“看板”的重要作用之一,就是连接生产现场上道工序和下道工序的信息工具。  “看板”是“准时化”生产的重要手段,它总是要
    优思学院 2025-04-14 15:02 81浏览
  • 亥姆霍兹线圈的应用领域‌物理学研究‌:在原子物理中,用于研究塞曼效应;在磁学研究中,用于测试磁性材料的磁滞回线等特性;还可用于研究电子荷质比等实验‌。‌工程与技术领域‌:用于电子设备校准和测试,提供标准磁场环境;在大型加速器中用于磁场校准;用于电磁干扰模拟实验,测试电子设备在不同磁场干扰下的性能‌。‌生物医学领域‌:研究生物磁场效应,如探索磁场对生物细胞的影响;在生物医学工程基础研究中,提供可控磁场环境‌。‌其他应用‌:作为磁场发生装置产生标准磁场;用于地球磁场的抵消与补偿、地磁环境模拟;还可用
    锦正茂科技 2025-04-14 10:41 51浏览
  • 时源芯微 专业EMC解决方案提供商  为EMC创造可能(适用于高频时钟电路,提升EMC性能与信号稳定性)一、设计目标抑制电源噪声:阻断高频干扰(如DC-DC开关噪声)传入晶振电源。降低时钟抖动:确保晶振输出信号纯净,减少相位噪声。通过EMC测试:减少晶振谐波辐射(如30MHz~1GHz频段)。二、滤波电路架构典型拓扑:电源输入 → 磁珠(FB) → 大电容(C1) + 高频电容(C2) → 晶振VDD1. 磁珠(Ferrite Bead)选型阻抗特性:在目标频段(如100MHz~1GH
    时源芯微 2025-04-14 14:53 58浏览
  •   高空 SAR 目标智能成像系统软件:多领域应用的前沿利器   高空 SAR(合成孔径雷达)目标智能成像系统软件,专门针对卫星、无人机等高空平台搭载的 SAR传感器数据,融合人工智能与图像处理技术,打造出的高效目标检测、识别及成像系统。此软件借助智能算法,显著提升 SAR图像分辨率、目标特征提取能力以及实时处理效率,为军事侦察、灾害监测、资源勘探等领域,提供关键技术支撑。   应用案例系统软件供应可以来这里,这个首肌开始是幺伍扒,中间是幺幺叁叁,最后一个是泗柒泗泗,按照数字顺序组合
    华盛恒辉l58ll334744 2025-04-14 16:09 96浏览
  • 软瓦格化 RISC-V 处理器集群可加速设计并降低风险作者:John Min John Min是Arteris的客户成功副总裁。他拥有丰富的架构专业知识,能够成功管理可定制和标准处理器在功耗、尺寸和性能方面的设计权衡。他的背景包括利用 ARC、MIPS、x86 和定制媒体处理器来设计 CPU SoC,尤其擅长基于微处理器的 SoC。RISC-V 指令集架构 (ISA) 以其强大的功能、灵活性、低采用成本和开源基础而闻名,正在经历各个细分市场的快速增长。这种多功能 ISA 支持汽车、航空航天、国防
    ArterisIP 2025-04-14 10:52 68浏览
  • 一、磁场发生设备‌电磁铁‌:由铁芯和线圈组成,通过调节电流大小可产生3T以下的磁场,广泛应用于工业及实验室场景(如电磁起重机)。‌亥姆霍兹线圈‌:由一对平行共轴线圈组成,可在线圈间产生均匀磁场(几高斯至几百高斯),适用于物理实验中的磁场效应研究。‌螺线管‌:通过螺旋线圈产生长圆柱形均匀磁场,电流与磁场呈线性关系,常用于磁性材料研究及电子束聚焦。‌超导磁体‌:采用超导材料线圈,在低温下可产生3-20T的强磁场,用于核磁共振研究等高精度科研领域。‌多极电磁铁‌:支持四极、六极、八极等多极磁场,适用于
    锦正茂科技 2025-04-14 13:29 53浏览
  • 在制造业或任何高度依赖产品质量的行业里,QA(质量保证)经理和QC(质量控制)经理,几乎是最容易被外界混淆的一对角色。两者的分工虽清晰,但职责和目标往往高度交叉。因此,当我们谈到“谁更有可能升任质量总监”时,这并不是一个简单的职位比较问题,而更像是对两种思维方式、职业路径和管理视角的深度考察。QC经理,问题终结者QC经理的世界,是充满数据、样本和判定标准的世界。他们是产品出厂前的最后一道防线,手里握着的是批次报告、不合格品记录、纠正措施流程……QC经理更像是一位“问题终结者”,目标是把不合格扼杀
    优思学院 2025-04-14 12:09 56浏览
  •   电磁干扰测试系统软件:深度剖析   电磁干扰(EMI)测试系统软件,是电子设备电磁兼容性(EMC)测试的核心工具,在通信、汽车、航空航天、医疗设备等众多领域广泛应用。它的核心功能涵盖信号采集、频谱分析、干扰定位、合规性评估以及报告生成,旨在保障设备在复杂电磁环境中稳定运行。下面从功能、技术原理、应用场景、主流软件及发展趋势这五个方面展开详细解析。   应用案例  软件开发可以来这里,这个首肌开始是幺乌扒,中间是幺幺叁叁,最后一个是泗柒泗泗,按照你的顺序组合可以找到。   目前
    华盛恒辉l58ll334744 2025-04-14 10:02 27浏览
  • 在公共安全、工业调度、户外作业等场景中,对讲机作为关键通信工具,正面临从“功能单一化”向“智能融合化”的转型需求。WT2605C蓝牙语音芯片凭借双模蓝牙架构、高扩展存储方案与全场景音频处理能力,推动传统对讲机实现无屏化操控、专业级音频解码与蓝牙音箱功能融合,为行业用户打造更高效、更灵活、更低成本的通信解决方案。一、无屏化交互革命:BLE指令重构操作逻辑针对工业环境中对讲机操作复杂、屏幕易损的痛点,WT2605C通过双模蓝牙(BR/EDR+BLE)与AT指令集,实现全链路无屏控制:手机APP远程控
    广州唯创电子 2025-04-14 09:08 33浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦