stm32f4的程序移植到stm32f1_试管移植后hcg参考值

stm32f4的程序移植到stm32f1_试管移植后hcg参考值最近做了从STM32F103到STM32F407的程序移植工作。在做这项工作之前发现网上没有太全面的移植攻略,因而确实费了一番功夫和走了一些弯路。现在程序移植工作基本做完,趁着还能记起来遇到的问题,把程序移植需要注意的点整理在这里,希望对以后做这个工作的朋友能有些帮助。虽然我做的是F407的移植,但是大部分内容对于F40xx_41xx,乃至F4其他系列的芯片都适用。文章如要转载请私

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

最近做了从STM32F103到STM32F407的程序移植工作。在做这项工作之前发现网上没有太全面的移植攻略,因而确实费了一番功夫和走了一些弯路。现在程序移植工作基本做完,趁着还能记起来遇到的问题,把程序移植需要注意的点整理在这里,希望对以后做这个工作的朋友能有些帮助。

虽然我做的是F407的移植,但是大部分内容对于F40xx_41xx,乃至F4其他系列的芯片都适用。

文章如要转载请私信与我联系,并注明作者Mr.括号。

一、硬件兼容改造

先说一下硬件吧,两种芯片的大部分引脚是相同的,需要改动部分电源引脚。官方的芯片数据手册上给出了兼容版的设计图,以100引脚的为例:



stm32f4的程序移植到stm32f1_试管移植后hcg参考值

其中19引脚从VSS改成VDD,49和73引脚分别从接VSS改成接电容,电容值为2.2uF。

二、系统时钟设置

F407的外部高速时钟的宏定义在system_stm32f4xx.c中。

#define HSE_BYPASS_INPUT_FREQUENCY   8000000


其中8000000代表外部时钟选用8M晶振,此处需对应实际情况修改。

时钟设置在函数SetSysClock()中进行设置,关键语句为:

RCC->PLLCFGR = PLL_M | (PLL_N << 6) | (((PLL_P >> 1)-1) << 16) |(RCC_PLLCFGR_PLLSRC_HSE) | (PLL_Q << 24);


主时钟PLL的值等为:PLL=M*N/(M*P),对应需求进行修改。

三、外设时钟使能

F407的外设时钟使能的函数和F103的相同,但是外设对应的外设时钟的映射关系发生了改变。具体的映射关系在文件stm32f4xx.h中有宏定义。

例如:在F103中GPIOA的外设时钟使能语句为:

RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOA, ENABLE );


在F407中,在stm32f4xx.h查找GPIOA,可以查到宏定义:

#define RCC_AHB1Periph_GPIOA ((uint32_t)0x00000001)


因而该使能语句可以改为:

RCC_AHB1PeriphClockCmd ( RCC_AHB1Periph_GPIOA, ENABLE );

四、GPIO端口初始化

在F103中,GPIO_InitTypeDef结构体为:

typedef struct
{ 
     
  uint16_t GPIO_Pin;        
  GPIOSpeed_TypeDef  GPIO_Speed; 
  GPIOMode_TypeDef   GPIO_Mode;  
}GPIO_InitTypeDef;

在F407中,该结构体为:

typedef struct
{ 
    
  uint32_t GPIO_Pin;          
  GPIOMode_TypeDef  GPIO_Mode;    
  GPIOSpeed_TypeDef GPIO_Speed;   
  GPIOOType_TypeDef GPIO_OType;  
  GPIOPuPd_TypeDef  GPIO_PuPd;    
}GPIO_InitTypeDef;

F103中的GPIO_Mode在F407中被拆解成了三个参数:GPIO_Mode、GPIO_OType和GPIO_PuPd。其中GPIO_Mode有输入、输出、复用和模拟四种模式可选,GPIO_OType选择推挽和开漏,GPIO_PuPd选择上拉、下拉和浮空。

五、DMA设置

F407中DMA的Channel统一换成了Stream与Channel组合的形式。DMA的初始化结构体DMA_InitTypeDef中多出了参数DMA_InitStructure.DDMA_Channel。不同外设请求对应的数据流和通道在官方参考手册中有明确的示例。DMA1和DMA2的请求映射如下:

stm32f4的程序移植到stm32f1_试管移植后hcg参考值
stm32f4的程序移植到stm32f1_试管移植后hcg参考值



另外还有一个小改动,在F103中DMA_Channel_TypeDef结构体中的元素为:

typedef struct
{ 
    
__IO uint32_t CCR;
__IO uint32_t CNDTR;
__IO uint32_t CPAR;
__IO uint32_t CMAR;
} DMA_Channel_TypeDef;

对应在F407中的DMA_Stream_TypeDef为:

typedef struct
{ 
    
__IO uint32_t CR;    
__IO uint32_t NDTR;  
__IO uint32_t PAR;  
__IO uint32_t M0AR; 
__IO uint32_t M1AR;  
__IO uint32_t FCR;  
} DMA_Stream_TypeDef;

在调用到该结构体中参数时需要注意。

六、重映射

在F407中不存在重映射(REMAP)的概念了,取而代之的是引脚的复用映射(AF)。而相比于F103的重映射,引脚复用功能更加灵活和全面。引脚复用时是对单独引脚进行配置。例如对USART2的PA2和PA3的复用设置指令为:

       GPIO_PinAFConfig(GPIOA,GPIO_PinSource2,GPIO_AF_USART2);
       GPIO_PinAFConfig(GPIOA,GPIO_PinSource3,GPIO_AF_USART2);


Mr.括号我直接把复用映射表列出来,方便大家查询:

stm32f4的程序移植到stm32f1_试管移植后hcg参考值
stm32f4的程序移植到stm32f1_试管移植后hcg参考值
stm32f4的程序移植到stm32f1_试管移植后hcg参考值

七、其他

用BSRRH代替了BRR

用BSRRL代替了BSRR

目前想到的就是上述这些,如果还有其他没提及的欢迎补充,如有纰漏敬请指正!

转载:https://zhuanlan.zhihu.com/p/24981431

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/181729.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • Oracle初学者-常用工具介绍

    Oracle初学者-常用工具介绍

  • 【Mask RCNN】论文详解(真的很详细)

    【Mask RCNN】论文详解(真的很详细)论文:http://cn.arxiv.org/pdf/1703.06870v3本文主要是针对论文的详细解析,选出文章各部分的关键点,方便阅读立即。目录:摘要:1、Introduction2、RelatedWork3、MaskR-CNN3.1ImplementationDetails4、Experiments:InstanceSegmentation4…

  • quartz mysql 异常_SpringBoot+Quartz+MySql schedulerFactoryBean nested exception 错误[通俗易懂]

    quartz mysql 异常_SpringBoot+Quartz+MySql schedulerFactoryBean nested exception 错误[通俗易懂]ErrorstartingApplicationContext.Todisplaytheauto-configurationreportre-runyourapplicationwith’debug’enabled.[2020-03-1117:48:03.701]-[ERROR]-[org.springframework.boot.SpringApplication:7…

  • 数据预处理之Bartlett’s球状检验

    数据预处理之Bartlett’s球状检验用于检验相关阵是否为单位阵,即检验各个变量是否各自独立。在因子分析中,若拒绝原假设,则说明可以做因子分析,若不拒绝原假设,则说明这些变量可能独立提供一些信息,不适合做因子分析。因子分析前,首先进行KMO检验和巴特利球体检验,KMO检验系数&gt;0.5,(巴特利特球体检验的x2统计值的显著性概率)P值&lt;0.05时,问卷才有结构效度,才能进行因子分析,因子分析主要是你自己做了一份调查问…

  • 使用zabbix监控redis内存使用

    使用zabbix监控redis内存使用本篇提到的监控环境是有条件的,即默认单机只运行一个redis实例,且默认运行的端口是6379(也可以是其他端口,需要通过sed-i’s/6379/你修改的端口/g’xml模板文件修改模板文件里的端口号)。即然有这么多局限,岂不是适应用环境很差。确实,本篇算是一个基础部分,为后面提到的lld(lowleveldiscovery)自动发现做铺垫。由于前面几部分也对基础的东西做了很多总结…

  • 深入Springboot启动流程+自动配置原理

    深入Springboot启动流程+自动配置原理深入Springboot启动流程+自动配置原理?写在前面?相关常见面试题Springboot启动入口@SpringBootConfiguration解读@ComponentScan解读@EnableAutoConfiguration解读(重点)@AutoConfigurationPackage解读@Import({AutoConfigurationImportSelector.class})解读(重点)?写在前面?自从SpringBoot问世以来,开发界可以说是乱了套。我还记得我朋友几年前去参加

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号