怎么用Clion开发APM32

2024-12-17

# 01 前言

APM32 官方 SDK 中提供了三种开发环境:Keil、IAR 和 Eclipse。不否认这三种环境的强大,但是在 AI 时代做嵌入式开发,用这三种环境就显得有点不够优雅了。本篇文章主要介绍怎么用Clion 开发 APM32,涉及 CMake、Makefile、OpenOCD 和PyOCD 的知识,供大家参考。

# 02 环境搭建

## 软件环境

- Windows 10/11

- Clion 2023.2.2

- MinGW-w64 8.1.0

- OpenOCD 0.12.0-rc1

- gcc-arm-none-eabi 10.3.1

- APM32_DAL_SDK_V1.0

## 硬件环境

- APM32F407IG Tiny 开发板

## 搭建 MinGW-w64 环境

### 安装 MinGW-w64

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

MinGW-w64 支持在线安装和离线安装,这里建议大家使用离线安装方式,因为在线安装的速度太慢了。Windows 系统开发 Linux 应用选择 `x86_64-posix-seh`,Windows 系统开发 Windows 应用选择 `x86_64-win32-seh`。

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第1张

我是用 Windows 系统开发Windows 应用,所以选择 `x86_64-win32-seh` 进行下载。从上面链接下载完成后,解压压缩包中的 mingw64 文件夹到自己喜欢的位置,这里解压到 `E:ToolChain`。

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第2张

### 配置环境变量

将 `E:ToolChainmingw64in` 添加到环境变量 `Path` 中。

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第3张

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

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

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第4张

## 搭建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。

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第5张

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

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第6张

### 配置环境变量

将`E:ToolChaingcc-arm-none-eabi-10.3-2021.10in` 添加到环境变量 `Path` 中。

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第7张

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

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

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第8张

## 搭建 OpenOCD 环境

### 安装 OpenOCD

[OpenOCD](https://sourceforge.net/projects/openocd/files/openocd/0.12.0-rc1/)全称为 Open On-Chip Debugger,是一个开源的调试工具,支持多种调试器,包括 J-Link、ST-Link、CMSIS-DAP等。

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

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第9张

因为 OpenOCD 官方还未支持APM32,所以需要增加对 APM32 的支持。将附件提供的`apm32f4x.cfg` 文件拷贝到`E:ToolChainOpenOCDshareopenocdscripts arget` 目录下。

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第10张

### 配置环境变量

将 `E:ToolChainOpenOCDin` 添加到环境变量 `Path` 中。

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第11张

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

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

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第12张

# 03 配置 Clion

### 配置工具链

打开 Clion,点击 `File`-> `Settings` -> `Build, Execution, Deployment` -> `Toolchains`,点击 `+` 号,选择 `MinGW`,点击`OK`。将上述搭建的环境填入对应的位置,点击 `OK`。如下图所示:

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第13张

> 注意:CMake 选择 Bundled,Debuggers 选择 Bundled GDB。

到 `CMake` 选项卡中确认`Toolchain` 选择的是 `MinGW`,如下图所示:

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第14张

### 配置 OpenOCD

点击 `File` -> `Settings` -> `Build,Execution, Deployment` -> `Embedded Development` -> `OpenOCD Localtion` 设置为 `E:ToolChainOpenOCDinopenocd.exe`,如下图所示:

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第15张

# 04 Clion 开发 APM32

## 导入工程

Clion 使用 CMake 构建工程,所以在 APM32 官方 SDK 中的工程需要加入 CMakeLists.txt 文件。

这里用到我另一篇帖子 [使用CMake构建APM32工程](https://bbs.21ic.com/icview-3357660-1-1.html)里面的工程,大家可以去下载。下载完成后,将工程导入或直接拖拽工程目录入 Clion,如下图所示:

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第16张

工程导入后,Clion 会提示项目未配置。我们打开 `GPIO_Toggle` -> `Project` -> `CMake` 目录,然后在 `CMakeLists.txt` 文件右键选择 `Load CMakeProject`,如下图所示:

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第17张

等待配置完成即可,配置完成后,CMake 输出窗口会显示如下信息:

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第18张

并在 `GPIO_Toggle` -> `Project` ->`CMake` 目录下生成 `cmake-build-debug` 目录及 `Makefile` 文件,如下图所示:

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第19张

## 编译工程

点击 `Build` -> `Build Project` 进行工程的编译,编译完成后 Build 输出窗口会显示如下信息:

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第20张

## 下载和调试

点击 `Run` -> `Edit Configurations`,点击 `+` 号,选择 `OpenOCD Download & Run`,如下图所示:

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第21张

配置 `Target`、`Executablebinary` 和 `Board config file`,点击 `OK`,如下图所示:

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第22张

其中 `Board config file` 选择 `geehyLink.cfg`。文件内容如下:

adapterdriver cmsis-dap

transportselect swd

#0x100000 = 1M Flash Size

setFLASH_SIZE 0x100000

source[find target/apm32f4x.cfg]

#download speed = 10MHz

adapterspeed 10000

点击 `Run` -> `Debug`,开始下载和调试,如下图所示:

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第23张

## 查看外设寄存器

在 `Debug` 窗口中`Peripheral` 加载官方提供的 `svd` 文件,即可查看外设寄存器信息。

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第24张

## 查看 Memory 信息

在 `Debug` 窗口中`Memory View` 查看内存信息。

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第25张

## 观察变量

在 `Debug` 窗口中`Variables` 观察变量。

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第26张

## AI 代码提示

Clion 带有插件系统,可以安装插件,比如 Github Copilot,可以用 AI 技术帮助我们更快的编写代码。

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第27张

## 代码补全

Clion 还有着很强大的代码补全功能。

怎么用Clion开发APM32 (https://ic.work/) 技术资料 第28张

还有更多功能等待大家去发现,这里就不一一介绍了。

到此,Clion 开发 APM32 的环境搭建和工程配置就完成了,大家可以参考着优雅的开发 APM32 了。

文章推荐

相关推荐