0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

AT32讲堂033 | AT32F403A/407时钟配置指南

雅特力 AT32 MCU 2022-11-01 10:01 次阅读

简介

时钟芯片正确高效运行的基础,正确的时钟配置是芯片能正确运行的必要条件,其重要性不言而喻。AT32各系列产品的时钟配置部分可能存在细微的差异和需要注意的事项,本文档就着重针对各系列的情况来详细介绍如何结合雅特力提供的V2.x.x的板级支持包(BSP)来配置时钟。

以下介绍时钟配置的方法主要分两种:

1、以手动编写代码调用BSP中提供的驱动函数接口来进行时钟配置。2、采用时钟工具来配置并生成相应的源码文件。

时钟树

在进行时钟配置之前,应充分了解对应芯片的时钟树结构,这样在进行时钟配置时才会游刃有余。对于系统时钟频率及路径的配置我们需要关注时钟源、倍频及系统时钟部分。类似如下图:图1. 时钟框图78dbca1a-5753-11ed-b116-dac502259ad0.png

可由图中得到以下几个关键信息

1) SCLKSEL:系统时钟可以由HEXT、PLLCLK、HICK三大时钟源提供。2) HEXT:HEXT是外部高速时钟,其可以外接范围是4~25 MHz的晶振或时钟源。3) HICK:HICK RC是内部高速振荡器,频率为48MHz。HICK时钟由内部振荡器给出,但在初始情况下由HICKDIV控制并默认6分频后为8MHz,亦可配置为不分频,保持48MHz的频率。4) PLLCLK:PLL时钟=PLL输入时钟*PLL倍频系数。5) PLL输入时钟:PLL的输入时钟由PLLRCS及PLLHEXTDIV共同决定,其细分可分为三个来源:HICK 4MHz、HEXT和HEXTDIV,HEXTDIV由HEXT分频系数决定,默认为2分频。

代码配置解析

以下将以库函数接口为核心来对时钟配置流程和方法进行说明。

函数接口

各系列产品对应提供的BSP中对硬件的时钟设置部分已封装好接口函数以供调用,以下罗列出时钟配置常用的函数接口,各函数的具体参数及返回值类型等请参考at32f403a_407_crm.c/.h文件。790441fc-5753-11ed-b116-dac502259ad0.png

时钟配置流程

按常规应用来讲解时钟配置流程,其内容可大致分为如下步骤:图2. 时钟配置流程图791ba09a-5753-11ed-b116-dac502259ad0.png复位(CRM Reset)首先按规范流程应复位CRM配置参数,其主要是将系统时钟切换到HICK,其余的系统时钟配置寄存器写入默认值,待后续进行新配置参数的写入。函数调用的代码实现如下:79456100-5753-11ed-b116-dac502259ad0.png时钟源配置(Clock Source Configuration)与系统时钟相关的高速时钟源主要包括HEXT和HICK,PLL也是使用以上时钟源来进行倍频。需要在配置使能PLL前将所使用的PLL参考时钟源开启并等待其稳定。

HEXT

外部高速时钟如采用外接有源时钟的方式时,可开启旁路模式来进行使用,采用晶振时,不能开启旁路模式,旁路模式应在外部高速时钟源使能前进行设定,其默认情况为关闭。旁路模式使能代码实现如下:79587754-5753-11ed-b116-dac502259ad0.png使能HEXT时钟源并等待HEXT时钟稳定,代码实现如下:7969d42c-5753-11ed-b116-dac502259ad0.png

HEXT

内部高速时钟是由芯片内部振荡器提供,使能HICK时钟源并等待HICK时钟稳定,代码实现如下:7983c8d2-5753-11ed-b116-dac502259ad0.png
PLL配置(PLL Configuration)PLL配置主要包括:PLL时钟源、PLL倍频系数、PLL倍频频率范围等的设置。倍频时钟公式为:PLLCLK=PLL输入时钟*PLL倍频系数。

PLL时钟源

PLL时钟源细分有三个来源:1、HICK(4 MHz),2、HEXT,3、HEXT分频时钟,PLL时钟源应在PLL配置使能前开启并等待稳定。以上PLL时钟源在crm_pll_config函数中对应的参数定义如下:79989c30-5753-11ed-b116-dac502259ad0.png当选择PLL时钟源为CRM_PLL_SOURCE_HEXT_DIV时,HEXT的分频系数可以通过函数crm_hext_clock_div_set进行设置,其默认分频系数为2分频。

PLL倍频系数

倍频系数为2~64倍可选,但应该注意最高主频限制,以此按实际情况来合适选择倍频系数,如8倍频使用参数CRM_PLL_MULT_8。

PLL频率范围

频率范围主要以倍频后的PLLCLK频率来做设定,其范围参数以72MHz为界限设定,如下:79aaaf24-5753-11ed-b116-dac502259ad0.png当PLL参数设置完成后,即可开启PLL并等待PLL稳定。示例:外部时钟晶振8MHz,采用HEXT 2分频时钟作为PLL时钟源,PLLCLK倍频到240MHz的代码实现如下:79bdb808-5753-11ed-b116-dac502259ad0.png总线分频(Set Bus Frequency Division)总线分频包含SCLK到AHBCLK分频、AHBCLK到APB1CLK分频、AHBCLK到APB2CLK分频。AHB总线1分频、APB1/APB2总线2分频的代码实现如下:79d77d10-5753-11ed-b116-dac502259ad0.png切换系统时钟(Switch System Clock)系统时钟来源主要有三个:HICK、HEXT、PLLCLK。在切换系统时钟到如上时钟源时应提前确保对 应时钟源已稳定。

  • 顺滑模式

时钟顺滑模式是为了确保整个系统时钟切换过程的稳定而设计,当即将切换为系统时钟的目标时钟频率大于108MHz时应开启时钟顺滑模式,所以其主要应用对象为PLLCLK用作系统时钟时的场景。通常使用方法是在系统时钟切换前开始,切换成功后关闭。代码实现如下:7a00899e-5753-11ed-b116-dac502259ad0.png

HICK系统时钟

内部高速时钟在系统复位重新运行时默认作为系统时钟,后期代码进行设定时,可有两种频率值来进行设定(8MHz和48MHz)。如图1所述HICK默认情况下用的是8MHz,可配置为48 MHz。HICK 8MHz用作系统时钟的代码实现如下:7a1d20f4-5753-11ed-b116-dac502259ad0.pngHICK 48 MHz用作系统时钟的代码实现如下:7a4abe10-5753-11ed-b116-dac502259ad0.png

HEXT系统时钟

外部高速时钟用作系统时钟时,其系统时钟频率以实际使用的外部时钟频率为准,范围为4~25MHz。HEXT用作系统时钟的代码实现如下:7a7be92c-5753-11ed-b116-dac502259ad0.png

PLLCLK系统时钟

PLLCLK用作系统时钟时,其系统时钟频率以实际的PLL倍频结果为准。其最高频率应满足芯片规格为基础。PLLCLK用作系统时钟的代码实现如下:7a8ec682-5753-11ed-b116-dac502259ad0.png

更新核心频率(Update Core Frequency)提供的BSP中,其代码框架内保留了一个表示系统核心频率的参数值system_core_clock,其保存的是CPU核心的运行频率值,应该在每次系统时钟配置完成后来进行更新。为的是在整个代码框架下,各外设驱动的频率配置能很快获取到当前核心运行频率值并使用。代码实现如下:7aa54236-5753-11ed-b116-dac502259ad0.png

时钟配置示例

以下将以完整的时钟配置流程来进行说明,示例:由8MHz外部时钟晶振作为时钟源,其2分频路径经PLL倍频到240MHz并用做系统时钟,AHB不分频,APB1/APB2采用2分频。函数system_clock_config代码实现如下:7ab19e50-5753-11ed-b116-dac502259ad0.png

时钟工具

时钟配置工具是雅特力科技为方便对AT32系列MCU进行时钟配置而开发的一个图形化配置工具,其主旨是使用户清晰了解时钟路径和配置出期望的时钟频率并生成源码文件。

环境要求

  • 软件要求

需要Windows7及以上操作系统支持。

安装

  • 软件安装

本软件不需要安装,只需直接运行可执行程序AT32_New_Clock_Configuration.exe。

功能介绍

本章节将介绍此工具的基本操作,其主要的启动界面和配置界面如下所示图3. 启动界面7aec9618-5753-11ed-b116-dac502259ad0.png图4. 配置界面7b0820f4-5753-11ed-b116-dac502259ad0.png

菜单栏

菜单栏内容如图所示:图5. 菜单栏7b3556dc-5753-11ed-b116-dac502259ad0.png

“项目”(Project)菜单:

新建:新建时钟配置项目打开:打开已存在的配置项目保存:保存已打开的配置项目

“语言”(Language)菜单:

English:选择English作为显示语言简体中文:选择简体中文作为显示语言

“生成代码”(General code)菜单:

当在对应型号的操作配置界面将所期望的时钟路径和时钟频率配置完成之后,可点击“生成代码”菜单来选择源码文件的存储路径并生成相应的源码文件。

“帮助”(Help)菜单:

新版本下载:联网进行新版本下载版本:查看当前版本

新建配置项目

双击打开时钟配置工具,可看到图示的启动界面,可点击“项目”菜单-->“新建”,进行配置项目的新建,在新建配置项目的过程中需要对芯片的系列所属进行选择,操作方法如下图所示图6. MCU选择界面7b48205a-5753-11ed-b116-dac502259ad0.png

MCU系列的选择,可点击下拉框来进行选择,当选择好MCU后点击“确定”可进入到时钟配置界面。

配置界面的使用

配置界面主要用来进行时钟路径及参数的配置,以下的介绍将以 AT32F403A 系列作为示例来展开进行,其余系列的配置方法与此类似。

整个配置界面主要可以分为四个大块,如下图所示

图7. 配置界面框架7b5e88d6-5753-11ed-b116-dac502259ad0.png1. 标题部分:用于展示当前配置项目所选择的MCU系列。2. 配置部分:用于对时钟路径和时钟参数进行选择和配置,以达到期望的应用需求。3. 输出部分:用于时钟输出(CLKOUT)的配置。4. 在SCLK栏也可在选中PLL为系统时钟时作为输入框,可输入期望的系统时钟频率来反向自动配置出倍频参数。5. 结果部分:用于显示当前外设所使用的时钟频率及总线上的外设。接下来就着重介绍一下配置部分的使用。配置部分的流程界面是对应着MCU时钟树来进行的,各系列MCU的此部分可能存在着差异,但使用方式大同小异。时钟路径的配置可按流程对各开关进行点选来进行选择,配置部分如下图所示,将逐个流程点的功能及其注意事项进行介绍。

图8. 时钟配置框

7b9ed184-5753-11ed-b116-dac502259ad0.png1. rtc使能:rtc时钟代码配置的使能下拉框。2. rtcsel:点选框,rtc时钟源选择。当rtc使能开启后,此点选框可配置。3. lext bypass:外部低速时钟的旁路使能。4. hext:此为输入框,8MHz为所采用外部时钟源的默认频率,用户可根据实际使用的外部时钟源频率进行修改。(注:此8MHz被修改为其他频率值时,对应的BSP中demo目录下的inc/at32f403a_407_conf.h文件内的HEXT_VALUE宏定义也应该一致修改,也可以采用工具生成的at32f403a_407_conf.h文件来进行使用)。5. hext bypass:高速外部时钟的旁路使能。6. hextdiv:下拉框,当HEXT的分频路径作为PLL时钟源时,可配置输入源HEXT的分频系数。7. pllhextdiv:点选框,当HEXT作为PLL时钟源时,可配置输入频率为HEXT分频或HEXT不分频。8. pllrcs:点选框,可配置PLL时钟源为HEXT或HICK。9. 倍频系数:使用PLL_MULT参数进行倍频,计算公式为:PLLCLK=PLL输入时钟*PLL_MULT。为了用户的使用方便,在选定PLL输入时钟源后,结果部分的sclk框中输入目标时钟并按下键盘“Enter”键,会自动计算一组倍频参数以满足用户期望或相近的时钟频率。10. sclk select:点选框,可配置HEXT、PLL或HICK作为系统时钟。11. sclk频率:当采用正向配置时,此作为系统时钟频率的配置结果显示,当将其用作输入框时,输入期望的频率后点击回车键,会根据此输入值反向计算一组合适的或最接近期望值的PLL配置参数。12. hick to sclk:点选框,当sclk select选择HICK作为系统时钟时,可配置HICK的8MHz或48MHz到系统时钟(注:当选择48 MHz HICK到系统时钟后,CLKOUT输出HICK时的频率也为48MHz)。13. usbdiv:下拉框。当PLL时钟被选作为USB的时钟来源时,此处配置PLL时钟到USB时钟的分频系数。14. hick to usb:点选框,可配置USB时钟由PLL时钟或HICK 48 MHz提供,USB时钟配置代码由下拉框to usb来进行选择控制。因USB时钟需要的是固定48MHz,所以在usbdiv可分频参数为前提下,PLL倍频出来的频率可能不满足USB 48 MHz的时钟需求。15. USB使能:USB时钟代码配置的使能下拉框。16. USB时钟频率的显示。此显示栏会实时计算USB时钟的频率并显示,如果配置出来的USB时钟不等于48MHz时,显示出来的USB时钟频率会标注为红色,而实际应用中没有用到USB时选择disable则不会显示。(注:此部分只针对USB时钟频率的配置,USB外设时钟使能需自行额外打开)

生成代码

当时钟配置完成后,可点击生成代码,然后选择代码生成的路径并确认,最后会在所选目录下生成两个文件夹inc和src,源文件存放在src文件夹下,头文件存放在inc文件夹下。这些文件可结合到BSP_V2.x.x内的工程来进行使用。可以采用新生成的时钟代码文件(at32f4xx_clock.c/at32f4xx_clock.h/ at32f4xx_conf.h)将原BSP demo中的对应文件替换,在main函数中进行system_clock_config函数调用即可。

注意事项

外部时钟源(HEXT)修改

因本文档所示例的demo和配置工具都默认采用的8MHz外部时钟频率,当实际硬件使用的外部时钟源是非8MHz频率时需注意以下几点。

代码修改

1、以实际的外部时钟频率按文中时钟配置流程章节所描述的时钟配置流程及方法来编写相应的代码,配置出期望的时钟配置及时钟路径。2、修改对应demo工程中at32f4xx_conf.h文件的HEXT_VALUE值,以实际使用的外部时钟源频率值来进行修改。如实际外部高速时钟使用12.288MHz的晶振或时钟源时,at32f4xx_conf.h文件应修改如下:7bb384d0-5753-11ed-b116-dac502259ad0.png

工具修改

1、在时钟配置工具中的HEXT输入框内填入外部时钟源实际频率值并按“Enter”键确认。2、配置好所需的时钟路径及时钟频率,生成代码。采用新生成的时钟代码文件(at32f4xx_clock.c/at32f4xx_clock.h/at32f4xx_conf.h)将原BSP demo中的对应文件替换或取其中函数内容进行替换,在main函数中进行system_clock_config函数调用即可。

工具使用

在使用本时钟配置工具时需注意:1. 此工具生成的时钟配置源码文件需结合雅特力科技提供的BSP_V2.x.x进行使用。2. 不同系列所生成的时钟配置源码文件不能型号混用,只能在相对应的工程项目中进行调用。3. 配置工具中各输入框参数修改后,请以“Enter”键结束。

案例 系统时钟

功能简介

在系统运行过程中来进行系统时钟切换。

资源准备

1) 硬件环境对应产品型号的AT-START BOARD2) 软件环境project\at_start_f403a\examples\crm\sysclk_switch

软件设计

1) 配置流程

  • 初始化按键。
  • 配置clkout时钟输出pll 4分频。
  • 编写从hick经pll倍频64MHz到系统时钟的配置代码。
  • 编写从hext 2分频经pll倍频96MHz到系统时钟的配置代码。

2) 代码介绍

main函数代码描述7bcef940-5753-11ed-b116-dac502259ad0.pnghick经pll倍频64MHz到系统时钟的代码描述7beda066-5753-11ed-b116-dac502259ad0.pnghext 2分频经pll倍频96MHz到系统时钟的代码描述7cb03afe-5753-11ed-b116-dac502259ad0.png

实验效果

  • 上电运行led2以间隔100ms时间进行闪烁,clkout(PA8)输出60MHz。
  • 每次USER按键按下,系统时钟在64MHz与96MHz之间进行交替切换,clkout输出对应的4分频频率,led4 toggle一次。

案例 时钟失效检测

功能简介

在当HEXT时钟直接或间接作为系统时钟时,当HEXT时钟出现故障,且时钟失效模块侦测到失效后,时钟失效事件将产生NMI中断,在此中断中可完成系统的营救操作。

资源准备

1) 硬件环境对应产品型号的AT-START BOARD2) 软件环境project\at_start_f403a\examples\crm\clock_failure_detection

软件设计

1) 配置流程

  • 配置clkout时钟输出pll 4分频。
  • 开启时钟失效检测,并完善void NMI_Handler(void)函数。
  • 编写从hick经pll倍频240MHz到系统时钟的配置代码。

2) 代码介绍

main函数代码描述7d0a921a-5753-11ed-b116-dac502259ad0.pnghick经pll倍频240MHz到系统时钟的代码描述7d1642cc-5753-11ed-b116-dac502259ad0.pngNMI中断实现7dd43caa-5753-11ed-b116-dac502259ad0.png

实验效果

在运行过程中将晶振拔掉或晶振脚接地,产生时钟失效。通常来说hext比hick更稳定,可观测clkout(PA8)的输出,可发现时钟拯救回来后hick作为源时的频率上存在细微波动。关于雅特力雅特力科技于2016年成立,是一家致力于推动全球市场32位微控制器(MCU)创新趋势的芯片设计公司,专注于ARM Cortex-M4/M0+的32位微控制器研发与创新,全系列采用55nm先进工艺及ARM Cortex-M4高效能或M0+低功耗内核,缔造M4业界最高主频288MHz运算效能,并支持工业级别芯片工作温度范围(-40°~105°)。雅特力目前已累积相当多元的终端产品成功案例:如微型打印机、扫地机、光流无人机、热成像仪、激光雷达、工业缝纫机、伺服驱控、电竞周边市场、断路器、ADAS、T-BOX、数字电源、电动工具等终端设备应用,广泛地覆盖5G物联网、消费、商务及工控等领域。

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

    关注

    11

    文章

    1736

    浏览量

    131596
  • AT32
    +关注

    关注

    1

    文章

    115

    浏览量

    2112
收藏 人收藏

    评论

    相关推荐

    AT32F403A_407固件库驱动程序发行说明

    电子发烧友网站提供《AT32F403A_407固件库驱动程序发行说明.zip》资料免费下载
    发表于 12-10 15:57 0次下载

    TPS785EVM-033评估模块用户指南

    电子发烧友网站提供《TPS785EVM-033评估模块用户指南.pdf》资料免费下载
    发表于 11-24 14:20 0次下载
    TPS785EVM-<b class='flag-5'>033</b>评估模块用户<b class='flag-5'>指南</b>

    AT32讲堂088 | 雅特力AT32F402/F405时钟配置

    简介时钟是芯片正确高效运行的基础,正确的时钟配置是芯片能正确运行的必要条件,其重要性不言而喻。AT32各系列产品的时钟
    的头像 发表于 09-15 08:08 540次阅读
    <b class='flag-5'>AT32</b><b class='flag-5'>讲堂</b>088 | 雅特力AT32<b class='flag-5'>F</b>402/<b class='flag-5'>F</b>405<b class='flag-5'>时钟</b><b class='flag-5'>配置</b>

    AT32讲堂087 | 雅特力AT32 IDE快速入门指南

    话框内,输入项目名称,这里以AT32F403AVGT7为例,项目名称输入AT32F403AVGT7;项目类型选择AT32F403A_407Project;工具链默认选择ArmCross
    的头像 发表于 09-15 08:08 488次阅读
    <b class='flag-5'>AT32</b><b class='flag-5'>讲堂</b>087 | 雅特力<b class='flag-5'>AT32</b> IDE快速入门<b class='flag-5'>指南</b>

    STM32CUBEMX(7)--移植雅特力AT32F403AVGT(兼容STM32F103VGT6),DAC输出电压

    STM32F103系列,故选取STM32f103VG进行开发。 配置时钟源 HSE与LSE分别为外部高速时钟和低速
    发表于 09-06 16:40

    AT32讲堂085 | 雅特力AT32 MCU HICK时钟校准

    简介AT32系列MCU内部都有提供适合运行的内部高速时钟(HICK),其本质就是内置于芯片的RC振荡器。在25℃下,其典型值频率8MHz的精度由工厂校准到±1%,在-40到105℃,该内部高速时钟
    的头像 发表于 08-30 12:26 676次阅读
    <b class='flag-5'>AT32</b><b class='flag-5'>讲堂</b>085 | 雅特力<b class='flag-5'>AT32</b> MCU HICK<b class='flag-5'>时钟</b>校准

    stm32f401与stm32f407在工程配置与代码上有什么区别?

    如题。之前调试好的一个项目,用的stm32f407IGT6, 后来同事重新画板,改用的stm32f401cdu6, 我们本来觉得都是F4系列,也只是flash sram 引脚 时钟不同
    发表于 05-09 06:01

    STM32F407系列使用HSI时钟后,PLL最高能配置到多少?

    最近在使用STM32F407系列,当使用HSI时钟后,PLL最高只能配置到42MHz,找了很多文档也没有介绍这方面的资料。如果超过42Mhz,就会发生跑飞的情况。我也试过配置到48MH
    发表于 04-26 07:49

    使用CubeMX配置STM32F407VGT6的SPI DMA发送16位数据,时钟有波形的原因?

    使用CubeMX配置STM32F407VGT6的SPI DMA发送16位数据,时钟有波形,MOSI无数据,上电就是高电平,其他CLK有波形的时候也还是高电平,发送的数据是0x0001和0x0000
    发表于 03-28 07:40

    使用stm32F407外接LAN8720A时,CubeIDE进行Ethernet和LWIP进行配置,为什么不能设置PHY Address?

    在使用stm32F407外接LAN8720A时,使用CubeIDE进行Ethernet和LWIP进行配置配置时发现不能设置PHY Address,但是网上很多的教程都是有这一项设置的
    发表于 03-22 06:15

    stm32cubemx无法配置32.768外部时钟是为什么?

    我的cube6.9.1时钟树无法配置32.768外部时钟是灰色的以前版本可以配置RTC现在只有默认lsiRC 接通无法选择32.768.RCC 的High /low都已经
    发表于 03-14 07:09

    雅特力AT32F423时钟配置

    简介时钟是芯片正确高效运行的基础,正确的时钟配置是芯片能正确运行的必要条件,其重要性不言而喻。AT32各系列产品的时钟
    的头像 发表于 02-19 13:26 623次阅读
    雅特力AT32<b class='flag-5'>F</b>423<b class='flag-5'>时钟</b><b class='flag-5'>配置</b>

    雅特力AT32F423时钟配置入门指南

    电子发烧友网站提供《雅特力AT32F423时钟配置入门指南.pdf》资料免费下载
    发表于 01-31 09:37 1次下载
    雅特力AT32<b class='flag-5'>F</b>423<b class='flag-5'>时钟</b><b class='flag-5'>配置</b>入门<b class='flag-5'>指南</b>

    AT32F403A系列 数据手册

    电子发烧友网站提供《AT32F403A系列 数据手册.pdf》资料免费下载
    发表于 01-22 10:06 7次下载

    STM32F407+PCM5102APWR+SD卡内播放wav或mp3音乐如何实现?

    ,我们需要连接硬件组件。将STM32F407开发板的引脚连接到PCM5102APWR的相应引脚上。这些引脚包括I2S时钟、I2S数据、I2S位时钟、I2S帧同步、音频时钟和地线。使用适
    的头像 发表于 01-16 17:11 2851次阅读