2. GD32F103单片机学习笔记之固件库移植
ztj100 2024-10-27 18:32 53 浏览 0 评论
上一节进行了一个开发板的小小入门仪式,这节就要开始来点“猛料”了。首先,我确定好了要像STM32那样的开发模式,使用官方提供的固件库。既然确定了“路数”,那就要去实施了。GD32单片机的固件库移植过程跟STM32基本一样,所以我就参考之前STM32固件库移植的过程来对GD32F103的固件库进行移植。移植虽然听着“高大上”,其实说白了在这里就是把官方提供给我们的固件库代码文件添加到我们自己创建的工程中,然后进行相应的配置。
进入正题,首先打开Keil:
依次点击左上角菜单栏Project→New uVision Project...开始创建新的GD32F103工程:
在弹出的对话框中选择相应的目录,设置好工程名称,点击保存即可:
随后在选择芯片型号的对话框中依次点开GigaDevice中的分组(需要确认上一节中的GD32F103的芯片支持包安装成功,否则这里没有GigaDevice分组),找到我们需要的GD32F103ZE单片机型号后,点击OK:
在后面出现的软件依赖元件窗口中选择CMSIS分钟中CORE(由于我在测试官方例程时发现使用固件库中的CMSIS时编译出错,所以这里决定使用Keil提供的CMSIS):
点击OK后,左边显示框中出现了我新创建的工程:
工程创建完成了,我们就要“粉饰”一下了,现在还是个“毛坯房”,下面就要就行“装修”了。首先,我们先确定固件库有哪些东西,按照我之前给STM32做的划分,我把移植固件库后的工程目录分成了“startup”、“cmsis”、“fwlib”和“source”四部分,下面是对这四个目录功能的简介:
目录 | 功能 |
startup | 存放单片机启动代码,也就是对应的汇编文件 |
cmsis | 存放CMSIS相关的文件 |
fwlib | 存放固件库中各个外设的源文件和头文件 |
source | 存放main函数代码文件、系统中断代码文件等等 |
由于我们在前面已经决定使用Keil提供的CMSIS,所以后面也可以不创建cmsis目录。
下一步就是在工程中创建添加上这些目录了,点击“品”字形状的图标:
在弹出的对话框中双击红框中的内容即可修改。此对话框中有三部分,左边部分为工程一级目录,中间为二级目录,右边为二级目录中加入的源文件:
了解了工程的目录结构,那就要开始修改了,像上面说的双击对应的位置即可,一级目录和二级目录均可采用这种方式进行修改。点击下一行后再点击上面的新建即可创建新的目录:
采用这种方式创建好“startup”、“fwlib”和“source”三个二级目录后点击OK:
这时左边的工程显示框中已经有了我们刚才创建的目录:
接下来我们就要进行移植中的“移”了,将固件库中需要的代码文件复制到工程目录中,在此之前呢,也要在工程所在的目录下创建相同的“startup”、“fwlib”和“source”三个目录:
依次进行以下复制操作:
GD32F10x_Demo_Suites_V2.1.0\GD32F10x_Firmware_Library\CMSIS\GD\GD32F10x\Source\ARM
中的startup_gd32f10x_hd.s复制到工程所在目录下的“startup”中;
STM32芯片Flash在256K-512K之间属于大容量芯片,启动文件要选择hd的,GD32单片机也是一样的,这里开发板上的芯片是GD32F103ZET6,Flash为512K,所以启动文件也要选择hd的。
GD32F10x_Demo_Suites_V2.1.0\GD32F10x_Firmware_Library\GD32F10x_standard_peripheral
中的“Include”和“Source”两个目录及里面的所有文件复制到工程目录下的“fwlib”中;
GD32F10x_Demo_Suites_V2.1.0\GD32F10x_Firmware_Library\CMSIS\GD\GD32F10x\Include
中的gd32f10x.h和system_gd32f10x.h复制到工程所在目录下的“source”中;
GD32F10x_Demo_Suites_V2.1.0\GD32F10x_Firmware_Library\CMSIS\GD\GD32F10x\Source
中的system_gd32f10x.c复制到工程所在目录下的“source”中;
GD32F10x_Demo_Suites_V2.1.0\GD32F10x_Firmware_Library\CMSIS\GD\GD32F10x\Source
中的system_gd32f10x.c复制到工程所在目录下的“source”中;
GD32F10x_Demo_Suites_V2.1.0\GD32103E_EVAL_Demo_Suites\Projects\01_GPIO_Runing_Led
中的gd32f10x_it.c、gd32f10x_it.h、gd32f10x_libopt.h、main.c、systick.c和systick.h复制到工程所在目录下的“source”中;
这里使用开发板小灯闪烁例程中的gd32f10x_it.c、gd32f10x_it.h、gd32f10x_libopt.h、main.c、systick.c和systick.h这些文件来使用,就不用再单独创建了,后续我们只需要修改里面的相关代码即可。
复制完成后需要将复制过来的源文件添加到工程中,此前我们已经在工程中也创建了相应的目录,因此我们在对应的目录中添加相关源文件即可,再次打开“品”字图标,依次点击相应按钮添加源文件:
注意:在选择文件的对话框中需将文件类型改成All Files,否则看不到.s的启动文件。
使用相同的方法,依次将工程所在目录下的“fwlib”下的“Source”里面的所有.c文件都添加到二级目录“fwlib”下,以及将工程所在目录下的“source”中的所有.c的文件都添加到二级目录“source”中:
以上操作完成后,点击OK后,会发现左侧工程显示框中二级目录下出现了我们刚刚添加的文件:
该“移”的东西移完了,还需对工程进行配置,包括声明宏定义、声明头文件目录等等。
点击“魔法棒”按钮,在点击“C/C++”,在Define选项中添加“USE_STDPERIPH_DRIVER”和“GD32F10X_HD”两个宏定义。我们使用固件库就需要声明“USE_STDPERIPH_DRIVER”,而且我们使用的启动文件是hd的,所以要声明“GD32F10X_HD”。注意,两个宏定义之间要用半角的逗号隔开,否则编译时会报错:
然后在点击窗口中Include Paths后面的...按钮,进行头文件的目录的声明,在打开的窗口中先选择空白行,再点击新建:
此时所选行后面出现...按钮,点击此按钮,在弹出的对话框中找到头文件包含在的目录,比如gd32f103_test\fwlib\Include,然后点击选择即可:
使用相同的方法将头文件所在的其他两个目录gd32f103_test\source和gd32f103_test\startup也添加上,添加完后是这么个样子:
然后依次点击两个OK即可。
此时对工程进行编译会发现有错误提示:
这是因为我们的main.c是直接复制的小灯闪烁例程中的main.c,里面有部分内容不适合我们现在的工程,我们可以把他们删掉,双击打开左侧工程显示框中的main.c,将下面红框中的内容删掉:
再次编译,将不再出现错误提示:
此时完成了一个带有延时函数的空白工程的创建,并移植好了固件库。那么怎么来验证我们移植了固件库的工程有没有问题呢,那我们就得写个小小的测试程序了,同样,我们还是使用小灯闪烁的程序来验证。
在main.c中的main函数的while之前添加如下代码:
rcu_periph_clock_enable(RCU_GPIOF);
gpio_init(GPIOF, GPIO_MODE_OUT_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_0);
gpio_bit_reset(GPIOF, GPIO_PIN_0);
在while循环中添加如下代码:
gpio_bit_set(GPIOF, GPIO_PIN_0);
delay_1ms(500);
gpio_bit_reset(GPIOF, GPIO_PIN_0);
delay_1ms(500);
最终添加代码后的main.c文件是这么个样子:
添加的这两段代码是实现了开发板上的LED2半秒闪烁一次的功能,代码具体的工作原理我们会在后续的章节中学习到相应内容的时候进行讲解。
编译后没有错误,按照上一节中对烧录器进行配置的方法设置完后即可烧录到开发板中进行验证,烧录后开发板上的LED2将进行亮灭交替闪烁:
如果开开发板上的小灯开始闪烁了,那就说明我们的工程创建完成了,固件库移植成功了,此处散花。
OK,今天就到这里吧。
相关推荐
- 如何将数据仓库迁移到阿里云 AnalyticDB for PostgreSQL
-
阿里云AnalyticDBforPostgreSQL(以下简称ADBPG,即原HybridDBforPostgreSQL)为基于PostgreSQL内核的MPP架构的实时数据仓库服务,可以...
- Python数据分析:探索性分析
-
写在前面如果你忘记了前面的文章,可以看看加深印象:Python数据处理...
- C++基础语法梳理:算法丨十大排序算法(二)
-
本期是C++基础语法分享的第十六节,今天给大家来梳理一下十大排序算法后五个!归并排序...
- C 语言的标准库有哪些
-
C语言的标准库并不是一个单一的实体,而是由一系列头文件(headerfiles)组成的集合。每个头文件声明了一组相关的函数、宏、类型和常量。程序员通过在代码中使用#include<...
- [深度学习] ncnn安装和调用基础教程
-
1介绍ncnn是腾讯开发的一个为手机端极致优化的高性能神经网络前向计算框架,无第三方依赖,跨平台,但是通常都需要protobuf和opencv。ncnn目前已在腾讯多款应用中使用,如QQ,Qzon...
- 用rust实现经典的冒泡排序和快速排序
-
1.假设待排序数组如下letmutarr=[5,3,8,4,2,7,1];...
- ncnn+PPYOLOv2首次结合!全网最详细代码解读来了
-
编辑:好困LRS【新智元导读】今天给大家安利一个宝藏仓库miemiedetection,该仓库集合了PPYOLO、PPYOLOv2、PPYOLOE三个算法pytorch实现三合一,其中的PPYOL...
- C++特性使用建议
-
1.引用参数使用引用替代指针且所有不变的引用参数必须加上const。在C语言中,如果函数需要修改变量的值,参数必须为指针,如...
- Qt4/5升级到Qt6吐血经验总结V202308
-
00:直观总结增加了很多轮子,同时原有模块拆分的也更细致,估计为了方便拓展个管理。把一些过度封装的东西移除了(比如同样的功能有多个函数),保证了只有一个函数执行该功能。把一些Qt5中兼容Qt4的方法废...
- 到底什么是C++11新特性,请看下文
-
C++11是一个比较大的更新,引入了很多新特性,以下是对这些特性的详细解释,帮助您快速理解C++11的内容1.自动类型推导(auto和decltype)...
- 掌握C++11这些特性,代码简洁性、安全性和性能轻松跃升!
-
C++11(又称C++0x)是C++编程语言的一次重大更新,引入了许多新特性,显著提升了代码简洁性、安全性和性能。以下是主要特性的分类介绍及示例:一、核心语言特性1.自动类型推导(auto)编译器自...
- 经典算法——凸包算法
-
凸包算法(ConvexHull)一、概念与问题描述凸包是指在平面上给定一组点,找到包含这些点的最小面积或最小周长的凸多边形。这个多边形没有任何内凹部分,即从一个多边形内的任意一点画一条线到多边形边界...
- 一起学习c++11——c++11中的新增的容器
-
c++11新增的容器1:array当时的初衷是希望提供一个在栈上分配的,定长数组,而且可以使用stl中的模板算法。array的用法如下:#include<string>#includ...
- C++ 编程中的一些最佳实践
-
1.遵循代码简洁原则尽量避免冗余代码,通过模块化设计、清晰的命名和良好的结构,让代码更易于阅读和维护...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- node卸载 (33)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- exceptionininitializererror (33)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)