STM32F103移植到AT32F403A之MDK(三)

描述

STM32F103移植到AT32F403A详细教程

 在篇2当中,我们已经实现了使用内部晶振使主频达到72M,使各总线时钟也达到了和使用外部晶振一样的频率。

但部分模块在使用STM32标准库时还是会有些问题,本篇就针对常用的外设遇到的问题予以说明并解决。

首先,串口是我们最常用的外设,在使用内部晶振使各总线与使用外部晶振达到一样的频率时,使用串口时会存在数据收发乱码的问题。

我们来分析一下问题点,因为串口在使用外部晶振时,都是正常的,说明串口配置是没错的。再改为使用内部时钟后就出现串口异常问题,那问题一定来自时钟这块的问题,我们通过代码仿真看一下。在串口初始化过程中有和时钟相关的操作,在void USART_Init(USART_TypeDef* USARTx, USART_InitTypeDef* USART_InitStruct)函数中。

USARTUSARTUSART

通过仿真看一下RCC_ClocksStatus中各总线的时钟值,发现总线时钟都不对

USART

经过对RCC_GetClocksFreq(&RCC_ClocksStatus)函数的分析发现,获取的倍频系数竟然是3,这是怎么回事?

USART

通过看AT32F403A的用户手册发现,PLL倍频系数是两部分组成的,我们在总线时钟初始化时使用的是倍频18倍,正好两部分都用到的,而ST的库在取值时只取了其中的一部分,导致倍频系数在计算时出现了错误。

USARTUSART

好了,现在问题的原因找到了,我们该怎么解决呢?

有两种方式解决,第一种是改宏定义,使CFGR_PLLMull_Mask能够完整的取到正确的倍频系数(本人没有采用这种方式,因为倍频系数不连续,处理起来比较麻烦,而且容易出现其他调用问题)。

USARTUSART

第二种是,不改宏,而是改串口初始化函数,因为获取各总线频率后用来计算波特率,我们人为将用到的总线频率改成正确的值就行了,我是这么改的。

USART

通过修改此处,串口通信恢复正常。串口问题就此解决。

注意:其他外设如果也有通过获取总线时钟用于计算的,都要注意这个问题!!!

接着我们要处理个很容易忽略的问题,那就是FLASH问题,这里要说的不是厂家手册里说过的零等待啊,FLASH延时等问题。而是页大小问题,这个问题不是在所以的AT32F403A替换STM32F103系列都会遇到的问题。

我们先来看看STM32F103系列FLASH页大小的定义。

  USART    

我们再来看看AT32F403A系列FLASH页大小的定义。

USART

在使用AT32F403A替换STM32F103系列小容量和中容量时,由于页大小定义不同,在进行FLASH操作时要注意页大小问题,此问题多会出现在IAP,或将FLASH用于存储数据时会出现问题,而STM32F103大容量和互联型者不会有问题。

至此,我在使用AT32F403A替换STM32F103过程中遇到的问题就都介绍完了,如果在后续使用过程中再发现其他问题,请点击下方图片打开问个芯小程序进行咨询哦

本文来自创易栈平台用户 @峰@ 投稿

  审核编辑:汤梓红

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分