博客
关于我
在MDK5中新建STM32F4XX工程模板(基于固件库)
阅读量:774 次
发布时间:2019-03-24

本文共 1535 字,大约阅读时间需要 5 分钟。

库函数和寄存器的区别

本质上,库函数和寄存器都是用于控制芯片外设的工具。库函数通过函数调用提供接口,方便开发者操作特定的外设,而寄存器则是底层硬件直接控制的分担存储器单元。两者在操作外设时都能达到类似的效果,但性能特性存在差异。需要注意的是:寄存器操作通常只能通过ASM代码实现,而库函数则需要通过C语言API调用

寄存器的理解至关重要。深入理解寄存器的工作原理,能帮助开发者快速定位和解决硬件配置问题,因为寄存器是调试过程中最直接的操作对象。


所用到的工具

开发环境:MDK5

固件库版本:V1.4(F4专用)
固件库下载地址:[官方下载链接](https://www.st.comtools stm32工具包)


新建工程模板

新建工程模板的具体步骤如下:

  • 创建文件夹结构:建立根目录Template,再创建子文件夹CORE、FWLIB、OBJ、SYSTEM、USER。这些文件夹名可任意命名,方便识别。

  • 选择芯片型号:在MDK中完成项目设置,选择芯片型号STM32F407ZG

  • 复制固件库文件:将固件库中的srcinc文件复制到FWLIB文件夹,启动文件startup_stm32f40_41xxx.s复制至CORE

  • 配置头文件路径:在MDK中手动添加头文件目录,确保头文件路径正确。添加路径如下:

    • COREUSERFWLIB\inc
  • 添加特定头文件:在USER中添加必要的头文件,包括stm32f4xx.hsystem_stm32f4xx.h

  • Springconfiguration:打开system_stm32f4xx.c,修改PLL_M8以达到系统时钟频率168MHz,并配置外部时钟HSE8MHz

  • payload<


    编码与调试

    在编码阶段,建议将main.c文件中的Delay函数实现如下:

    #include "stm32f4xx.h"void Delay(__IO uint32_t nCount){    while(nCount--)    {        /* delay单个周期 */    }}int main(void){    GPIO_InitTypeDef  GPIO_InitStructure;    // 配置GPIOF引脚为输出    RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOF, ENABLE);    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9 | GPIO_Pin_10;    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUTPP;    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;    GPIO_Init(GPIOF, &GPIO_InitStructure);    while(1)    {        GPIO_SetBits(GPIOF, GPIO_Pin_9 | GPIO_Pin_10);        Delay(0x7FFFFF); // 偽Wait 0.5秒        GPIO_ResetBits(GPIOF, GPIO_Pin_9 | GPIO_Pin_10);        Delay(0x7FFFFF);    }}

    注意事项

  • 移除无用文件:删除stm32f4xx_it.c中的函数调用和主函数内容。
  • 处理编译问题:如果发现stm32f4xx_it.c文件左边缺少加号,切断并重新启动工程即可。

  • 该工程模板基于官方固件库V1.4配置完成,适合STM32F40xx系列芯片使用。

    转载地址:http://sbdkk.baihongyu.com/

    你可能感兴趣的文章
    mysql面试题学校三表查询_mysql三表查询分组后取每组最大值,mysql面试题。
    查看>>
    Mysql面试题精选
    查看>>
    MySQL面试题集锦
    查看>>
    mysql面试题,存储引擎InnoDB和MyISAM
    查看>>
    mysql面试题:为什么MySQL单表不能超过2000W条数据?
    查看>>
    mysql面试题:创建索引时会不会锁表?
    查看>>
    mysql面试题:高度为3的B+树可以存放多少数据?
    查看>>
    mysql颠覆实战笔记(八)--mysql的自定义异常处理怎么破
    查看>>
    mysql驱动、durid、mybatis之间的关系
    查看>>
    mysql驱动支持中文_mysql 驱动包-Go语言中文社区
    查看>>
    MySQL高可用切换_(5.9)mysql高可用系列——正常主从切换测试
    查看>>
    MySQL高可用解决方案详解
    查看>>
    MYSQL高可用集群MHA架构
    查看>>
    MySQL高级-MySQL并发参数调整
    查看>>
    MySQL高级-MySQL应用优化
    查看>>
    MySQL高级-MySQL查询缓存优化
    查看>>
    MySQL高级-MySQL锁
    查看>>
    MySQL高级-SQL优化
    查看>>
    MySQL高级-SQL优化步骤
    查看>>
    MySQL高级-内存管理及优化
    查看>>