
7.1 Keil创建工程模板 在前面“C语言使用HAL库开发”章节里,体验了如何使用HAL快速开发。不同于使用汇编和寄存器开发,使用HAL库需要为工程准备许多相关文件,也就是创建HAL库的工程模板。工程模块没有统一的格式,通常是根据多年的开发经验和使用习惯总结出来的,以“5_程序源码\1_创建工程模板”为例,介绍如何一个工程模板是如何创建的。 如图 7.1.1 所示,一个工程包含五个文件夹,一个清理脚本,一个说明文本文件。 - q' m$ ^5 c: A. m! F ![]() 图 7.1.1 工程模板文件夹/ E9 F/ X B" R* d; z - e8 s: i+ x- N- ? I5 d8 H " R7 D9 l& J/ e 各文件夹、文件说明如下: Core:存放从SDK文件夹抽取的部分可能会修改的核心文件;4 \7 [6 M0 \7 z4 b Driver: 存放用户编写的外设驱动文件;3 A, c! r4 ]3 ~$ x, Q9 | O' H Main: 存放主函数文件; Project: 存放Keil工程文件,包含目标二进制文件;$ N' _& }% K# F% T( g6 T% N SDK:存放CMSIS和HAL库; Clean.bat:Windows脚本,用于清理Project里Keil生成的工程文件; Readme.txt:该工程的说明信息; “SDK”目录的内容来自配套资料“2_原厂资料\7.0_en.stm32cubef1(原厂固件包示例源码).zip”,即里面“Drivers”目录下的“CMSIS”和“STM32F1xx_HAL_Driver”。 8 A" {/ N7 r3 L# T, M “Core”目录的内容来自“CMSIS\Device\ST\STM32F1xx\Source\Templates\arm\startup_stm32f103xb.s”; “STM32Cube_FW_F1_V1.8.0\Projects\STM3210E_EVAL\Templates\”下的“Src\system_stm32f1xx.c”、“Src\stm32f1xx_it.c”、“Inc\stm32f1xx_it.h”、“Inc\stm32f1xx_hal_conf.h”;还需要手动创建“stm32f1xx_clk.c”和“stm32f1xx_clk.h”,这两个文件内容是一些时钟初始化,参考“1_工程模板”的工程代码。( X* n+ B- s8 @ " d1 g9 M& }* d; C( j “Driver”目录存放用户编写的外设驱动代码,比如LED灯驱动,这里示例不涉及外设,暂为空。 “Main”为存放主函数文件目录,创建“main.c”和“main.h” ,参考“1_工程模板”的工程代码。8 r2 o+ h/ |; U& d- W “Project”用于存放工程文件,工程文件由创建Keil工程自动生成,这里打开Keil。0 X- c5 @# S$ o+ p/ M( i# } 打开Keil后,点击“Project”下的“New μVision Project”,如图 7.1.2 所示。 # p' w# ?. U( ^& f# J ![]() $ m2 x+ `3 ^7 b! r* Q# e 图 7.1.2 创建Keil工程 随后在弹出的路径选择界面,选择“Project”目录,工程名字任意,假设这里为“Template”,如图 7.1.3所示。- q3 e" I/ Z% e ![]() 8 J5 ]0 s0 j0 K) m g o# @ |+ ~ 图 7.1.3 选择工程路径和设置工程名称 接着在设备选择界面的搜索框输入“STM32F103C8”,然后选择“STM32F103C8”,点击“OK”,如图 7.1.14 所示。' H- K- N- m) u( ]4 i9 j7 B4 h7 a9 U ![]() 图 7.1.4 选择设备型号 随后弹出运行时环境(Run-Time Environment,RTE),目前用不到,直接选择“Cancel”,如图 7.1.5所示。- q. w* z* Y2 K7 q 7 u4 W( j6 w' T' \5 n ![]() 图 7.1.5 管理RTE 接着进入主界面,点击“工程项目管理”按钮 ,为工程添加文件,如图 7.1.6 所示。 ![]() " T3 P! s% z3 F# x/ T1 L% f 图 7.1.6 工程项目管理按钮* @; t/ k! q+ M1 u0 g( ` 在工程项目管理界面,有三个窗口,分别是目标工程(Project Targets)、分组(Groups)、文件(Core)。双击“Project Targets”下的“Target 1”,可修改名字,这里改为“Template”,双击“Groups”下的“Source Groups 1”,改为“Core”,如图 7.1.7 所示。 ![]() 4 l+ c$ \6 Q9 g3 F8 U 图 7.1.7 工程项目管理界面. B r2 K$ \3 T. {( H' _9 L 接着选中“Core”,点击“Add Files…”,接着在弹出的文件选择界面,进入“Core”目录,然后需要修改“文件类型”下拉选择框为“All files(*.*)”,才能看到所有文件,如图 7.1.8 所示。 8 u2 j8 A1 R* I8 V1 g ![]() 图 7.1.8 选择所有文件类型 然后选中“startup_stm32f103xb.s”,点击“Add”,如此循环直至如图 7.1.9所示的五个文件全部加入“Core”。$ j4 T! l+ k" v. |- P* |1 y$ d. C3 x ; L9 J+ i3 Q1 N' d. p8 L F, n ![]() - V" Q7 F6 |9 g! C 图 7.1.9 选择加入Core的文件 再点击“Groups”的 新建图标,创建一个新的组,名为“Main”,如图 7.1.10 所示。 ![]() 图 7.1.10 创建新组Main: l" Y' ^3 G6 ^* { 接着选中“Main”组后,点击“Add Files…”,选中“main.c”,再点击“Add”,如图 7.1.11 所示。 8 S0 W# m. y6 k ![]() / W0 Z3 d8 G/ J 图 7.1.11 选择加入Main的文件) [6 D% w4 x* m8 m 再点击“Groups”的 新建图标,创建一个新的组,名为“Driver”,该组没有文件,无需添加。再新建“SDK”,加入“SDK\STM32F1xx_HAL_Driver\Src”下的几个必须文件,如图 7.1.12 所示。$ _% q5 P, D* K- [* X ![]() - c/ Y: G) K8 ~$ M3 ^; N: T+ t 图 7.1.12 选择加入Src的文件3 _: v/ ?0 r' r+ V' V2 }4 R 所有文件添加完成后,效果如图 7.1.13 所示。 ![]() , O$ L2 ?" b' }, @7 S" p9 G1 p 图 7.1.13 工程添加后各目录效果8 n# j ~* ?1 w: E3 `* @5 i 3 }, B7 i+ E# `4 p/ H 按上图添加完后,点击“OK”保存,如图 7.1.14 所示。 ! K( s: J) {$ S6 l ![]() 图 7.1.14 添加完成 接着进入主界面,点击“工程项目选项”按钮。 + I+ o* \; k. V7 ? ![]() 图 7.1.15 工程项目选项按钮 - K3 D3 u4 S" f9 U1 r( M 在弹出的窗口,选择“Target”标签,如图 7.1.16 所示。追求稳定,这里设置ARM交叉编译工具链为“Use default compiler version 5”。“Use MicroLIB”也可以勾选上,编译出来的文件占用资源会更小,也为后面调试串口实验提供printf。再下面是Flash和RAM的起始地址和大小,与前面图 6.1.4 所示的Flash和RAM是吻合的,这里无需修改。 % t k, P# p6 `. _( _3 T ![]() - _ h1 P; @2 _; O; ?; k 图 7.1.16 Keil设置Target+ n: E3 ?6 }; p0 a. M5 k; z; O m - V1 W- n. I8 q$ u& n! x8 L, E 切换到“Output”,勾选上“Create HEX File”,生成hex文件供其它烧写工具使用,如图 7.1.17 所示。 5 ]4 P# e+ B' @9 K3 L ![]() * C5 g l3 n) m- Q1 y 图 7.1.17 Keil设置Output, {7 f; \% q. p4 i7 y- s 再切换到“C/C++”标签,在“Define”栏填入“USE_HAL_DRIVER,STM32F103xB”,分别表示使用HAL库,使用的芯片型号系列。HAL库很多C语言语法采用C99标准,这里需要勾选上“C99 Mode”,不然会编译报错。最后点击“Include Paths”最右边的按钮 添加头文件,如图 7.1.18 所示。! s9 h$ K; C% O1 @/ h 在弹出的文件夹设置窗口,点击 按钮,依次添加如图 7.1.19 所示路径,最后点击“OK”。- q) u/ {9 O5 O# c " h, B/ ~- G7 { ![]() 图 7.1.18 Keil设置C/C++! z1 A1 R0 m; O# p / X5 Z! ~$ k5 n% ]% E" | ![]() ! W- k' V. B% D3 Q 图 7.1.19 添加头文件路径 切换到“Debug”标签,我们使用的ST-Link,因此需要选择“ST-Link Debugger”,最后点击“OK”,如图 7.1.20 所示。 6 e* R1 G- N9 o9 Z2 N, U ![]() 图 7.1.20 Keil设置Debug $ h3 g$ n% T' J5 |" \3 q/ J1 w 以上全部设置完后,点击编译,编译完后,点击下载(这里需连接ST-Link才能点击下载,否则使用100ASK_STM32F103_Tools的自动下载),出现如图 7.1.21 所示的红色下划线提示,即表示编译、烧写都正常(当前工程主函数没有任何内容,开发板无任何现象)。之后便可以,以此工程为模板,编辑main.c,向“Driver”添加外设驱动程序,进行开发。) t; e0 j6 d$ @% p) a& {6 f ![]() 图 7.1.21 编译、下载测试 【总结】, z% T. p) g# g% a5 F: \1 o; u, t , N, a5 L, X- } 工程模块的创建步骤如下:' I$ ^* Z9 y, Y" k, F2 p& E / n! N' |: R, E: V2 b 1. 创建相关文件夹; 2. 复制CMSIS和HAL库; 3. 创建“main.c/h”和“stm32f1xx_clk.c/h”; ) C8 L* z4 A# u- n$ [: D" e 4. 创建新Keil工程; 5. 添加组文件夹和工程文件;+ A2 ]6 x* V) A3 r3 Y4 G5 Z; N% | 6. 配置Keil设置0 W4 O) _$ l" n2 S% i$ [" b 1 P" q: g8 e( R2 ]! c 7.2 Keil常用设置 除了上述基本设置外,还有一些设置可以方便日常使用。 q$ ]2 f I* C, L4 ^* V; c . r. d. f {3 v) X4 }. `# A2 S 1.2.1 下载后自动运行程序 Keil默认在下载程序后,需要手动按下开发板复位才能启动程序。通过修改修改配置,可以下载后自动复位重启运行程序,方便调试。# y& I% v' S1 E4 K. g( h% v1 v y+ L7 S7 k2 b5 U& D! h S0 N 点击“Optinos for Target…”按钮,切换到“Utilities”标签,点击“Settings”,如图 7.2.1 所示。& z& e$ [3 g$ ^3 |" z+ m' u ![]() 图 7.2.1 Keil设置Utilities2 o2 F- O' @/ O, h7 c ' M& e2 L! x3 g8 c3 r, w 随后弹出设置界面,切换到“Flash Download”标签,勾选上“Reset and Run”,如图 7.2.2 所示。接着再切换到“Pack”标签,去掉勾选“Enable”,如图 7.2.3 所示。 ![]() " Y3 i2 C' i' i; V 图 7.2.2 设置自动运行1 ![]() 图 7.2.3设置自动运行2 6 F y4 t) Y& J! n* F7 [ 1.2.2 生成Bin文件 实际开发中,可能需要Bin格式的下载文件,而Keil默认不会生成Bin格式文件,需要进行相关配置。点击 按钮,切换到“User”标签,在“After Build/Rebuild”添加“fromelf --bin -o "$[url=mailto ![]() ![]() 1 K& W3 h: f- m$ G 图 7.2.4 设置生成bin文件 设置完成后,点击“OK”保存。重新编译整个工程,将在工程的“Project\Objects”目录下生成xx.bin文件(xx为工程名)。 ! N6 d+ }, U4 u) B# n6 q" q7 s 1.2.3 字体编码等设置* U$ X% b8 z" q3 c 点击下图按钮,进入Keil设置界面,如图 7.2.5 所示。 ![]() 图 7.2.5 Keil设置界面 在“Editor”标签,字符编码选择“Chinese GB2312(Simplified)”,可以解决代码中中文注释乱码问题。在下方的“C/C++ Files:”的“Tab size:”设置为4,可以解决代码中缩进对齐问题,如图 7.2.6 所示。0 @, j; Q) ^1 r* k + c, N$ Y% r4 l* m ![]() 图 7.2.6 Keil设置Editor 然后切换到“Colors & Fonts”界面,选择“C/C++ Editor files”,可修改字体、数字、关键词等的字体样式、大小、颜色,如果没特殊需求,默认即可,如图 7.2.7 所示。 ![]() ( ]8 J4 C2 f3 P( }# n& v+ v 图 7.2.7 Keil设置Colors&Fonts( U" Q# S+ L* a6 D 7.3 STM32CubeMX创建工程模板5 G' C5 x9 J0 a, S. F- N" g5 \. U STM32CubeMX是ST意法半导体推出的STM32系列芯片图形可视化配置工具,用户可以通过图形化向导为Cortex-M系列MCU生成初始化代码工程模板。7 N* n9 [) Y% ] 相较于Keil创建工程模板,STM32CubeMX步骤少、上手快,但生成的工程模板比较臃肿,因此本小结只简单介绍下相关创建操作,后面的实验仍使用前面自定义创建工程模板。读者也无需纠结使用哪一种方法,以后熟悉后,自然知道修改哪些内容,在两种方式之间任意转换。 从ST官网下载STM32CubeMX,解压、安装、打开。首次运行会自动下载更新文件,待更新完成,点击“ACCESS TO MCU SELECTOR”通过选择芯片创建工程,如图 7.3.1 所示。 + }, O* Q% F1 r. N1 T ![]() 图 7.3.1 通过选择芯片创建工程/ f" l6 \. R: _# m" {5 i0 Z 随后在搜索框输入“STM32F103C8”,右边选择“LQFP48”封装,最后点击“Start Project”,开始创建工程,如图 7.3.2 所示。: Y: H, ]5 e5 I' d8 s5 J ![]() $ E! P' x* N! k" n% J 图 7.3.2 选择芯片型号 2 V( j8 s( F4 E8 o, A" X" Z 随后进入引脚配置界面,该界面可以图形化选择芯片引脚并配置,如图 7.3.3 所示,这里就不展开叙述,感兴趣的读者可以网上搜索下资料,比较简单。 ' h7 Z. ~1 K! g) o: W ![]() I8 ?* { L+ r2 I: {5 Z4 y& ] 图 7.3.3 引脚配置 / a/ S+ O/ y( M, i 点击“Clock Configuration”进入时钟配置界面,如图 7.3.4 所示,在该界面可以图形化的配置时钟来源、倍频、分频等,这里也不展开介绍。 ![]() 图 7.3.4 时钟配置 点击“Project Manager”进入工程管理界面,如图 7.3.5 所示,在该界面先设置工程名字,再设置导出目标IDE为“MDK-ARM”,版本默认V5.27。 ![]() 图 7.3.5 工程管理界面 再点击“Code Generator”,勾选如图 7.3.6 所示,最后点击“GENERATE CODE”。 ![]() 图 7.3.6 设置生成代码样式/ X5 @( l% U+ r" U4 F # G' _; N }: i, ] 待代码生成完后,出现如图 7.3.7 所示提示,点击“Open Project”打开工程。 ![]() % B3 e* J$ x! H6 R9 \7 h7 S2 Y% L 图 7.3.7 打开工程 ' U( }: n4 R$ P6 M/ x" T/ T* @0 i1 y; Z 随后,将使用Keil自动打开工程,点击编译测试,编译成功,没有错误,如图 7.3.8 所示。以后用户只需要在“main()”里添加代码内容即可。 & Z- R9 ]5 W; r7 |8 h Y: k ![]() 4 c5 Q% S% [1 l# J$ Z5 O 图 7.3.8 编译测试) b5 L. A+ e# }0 G , J3 e/ i* F5 v( f# F# ` 【总结】 使用STM32CubeMX创建工程,非常的便利。但同时也限制了用户对工程的调整,代码内容、注释也臃肿。如果用户需要快速搭建工程环境,STM32CubeMX是一个非常不错的选择;如果想深入学习,根据自己的习惯优化,可先熟悉如何自定义创建工程模板,以后根据自己习惯调整。 . v& |8 R$ c2 j! [3 A2 h , M* u3 Y; y' ~ , j" Q* N6 F( \6 I5 { 9 @3 j; ^9 N9 a 3 D! t7 u* l5 e0 W* |* Z: d . \- S. s+ |7 v: k8 b; w7 z |
【2025·STM32峰会】GUI解决方案实训分享2-编译运行TouchGFX咖啡机例程(含桌面仿真)
实战经验 | Keil工程使用NEAI库的异常问题
STM32 ISP IQTune:真正零门槛的免费ISP调整软件
【经验分享】STM32 新建基于STM32F40x 固件库的MDK5 工程
意法半导体MCU双供应链策略,打消中国客户后顾之忧
【经验分享】基于STM32使用HAL库实现USB组合设备CDC+MSC
2024意法半导体工业峰会:赋能智能电源和智能工业,构筑可持续未来
ST推出灵活、面向未来的智能电表通信解决方案,助力能源转型
意法半导体 x Qu-Bit Electronix:推动新一轮的数字声音合成革命
从STM32 MPU产品看嵌入式系统中微处理器的新变化