【GD32F303红枫派使用手册】第一节 RCU-时钟配置及输出实验

本文主要是介绍【GD32F303红枫派使用手册】第一节 RCU-时钟配置及输出实验,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.1 实验内容

通过本实验主要学习以下内容:

  • RCU时钟原理及配置;
  • RCU时钟输出验证。

1.2 实验原理

1.2.1 RCU时钟树原理

GD32F303系列MCU的时钟树如下图所示,由该图可知,GD32F303系列MCU的时钟树可大致分为三个部分:1、主系统时钟以及外设时钟配置,如下图所示,GD32F303系列MCU最高主频为120MHz(CK_SYS),该系统时钟根据SCS[1:0]控制位进行选择,可选择来源于HSI8M、PLL或者HXTAL,PLL时钟源可根据PLLSEL控制位选择来自于HSI8M/2或者HXTAL以及HSI48M,之后经过2-63倍频(PLLMF)得到PLL时钟,PLL时钟可以通过USB分频输出给USB模块,系统时钟会直接输出给IIS外设使用,AHB时钟可由系统时钟分频而来,AHB时钟最高120M,AHB时钟会输出给内核以及外设使用;2、RTC以及独立看门狗时钟配置,如图中2所示,RTC时钟可选择HXTAL/128分频、LXTAL或者IRC40K,独立看门狗仅可选择IRC40K使用;3、时钟输出配置,如图中3所示,内部系统时钟、IRC8M、HXTAL以及PLL/2可通过CKOUT0SEL控制位控制输出到CKOUT引脚。

1.2.2 外部高速晶振原理

外部高速晶振可选择4-32M时钟,若系统应用中有异步通信以及高精度定时等应用建议选择使用外部高速晶振,外部高速晶振具有更高的精度,在GD32F303应用系统中建议选择8M/16M/24M晶振,因为外部晶振输入给PLL的时钟源仅可进行1分频或者2分频,选择其他频率的晶振难以配置到最高120M系统时钟。

HXTAL具有时钟监测的功能,置位CKMEN控制位将会使能该功能,使能后一旦监测到HXTAL失效,HXTAL将自动被禁止,中断寄存器RCU_INT中的HXTAL时钟阻塞中断标志位CKMIF将被置‘1’,并产生NMI不可屏蔽中断,使用者可在NMI中断中切换到内部时钟并重新进行时钟配置,可用于HXTAL失效情况下的异常处理。

1.2.3 内部高速时钟原理

GD32F303系列MCU的内部高速时钟有IRC8M和IRC48M,IRC8M较为常用,且具有更高的精度,另外需注意内部高速时钟并非晶振,电路上为RC振荡器,因而比较容易受外部环境的影响,如下图所示,常温下IRC8M的精度约为1%。

1.2.4 内部低速时钟原理

GD32F303系列MCU内部有IRC40K低速时钟,该低速时钟可以为RTC或FWDG使用,如下图所示,据测试IRC40K精度较差,如果作为RTC时钟源可能存在较大偏差的情况,如果使用者使用RTC建议可以选择LXTAL外部低频晶振,或者使用内部高速时钟对IRC40K进行校准(校准方法为使用内部高速时钟对IRC40K进行捕获,然后调整IRC40K的trim值)。

1.2.5 外部低速晶振原理

外部低速晶振一般选择32.768KHZ的晶振,外部低速晶振可以选择作为RTC时钟,在这种情况下,RTC可以在VDD掉电以及VBAT不掉电的情况下工作。

1.2.6 时钟输出功能

时钟输出功能可以输出4-120MHz的时钟,具体通过配置CKOUT0SEL控制位进行实现,另外需要将CKOUT引脚(一般为PA8引脚)配置为推挽输出的模式,有关时钟输出选择配置如下表所示。

1.3 硬件设计

本节主要介绍开发板外挂高速晶振以及低速晶振电路。

1.3.1 外部高速晶振电路设计

外部高速晶振电路如下图所示,其中外部高速晶振选择8MHZ,匹配电容选择20pf,该匹配电容可以参考以下公式:C1=C2=2*(Cload-CS),其中Cload为晶体负载电容,Cs为PCB以及MCU引脚的杂散电容,典型值为10pf,因而可以选择负载电容约为20pf的晶振,匹配电容即可选择20pf,需要注意晶振尽量靠近MCU引脚摆放,且晶振引脚走线尽量等长,PCB区域尽量禁空,走线可以包地,另外若走线不等长,匹配电容可以适当选择不同的匹配电容以适配不同的杂散电容。R28的1M欧姆为晶振引脚的反馈电阻,该反馈电阻的作用为减少晶振输出波形的谐波分量,提高晶振稳定性,该电阻并非必须,MCU内部也有400K的反馈电阻,从笔者使用来看,并不影响晶振起振及使用,但建议电路上可以选择保留。R29的100R电阻为晶振引脚串联电阻,用于限流以及引脚保护。另外测量晶振引脚波形时可能存在OSC_IN脚波形为较好的正弦波,OSC_OUT引脚波形可能存在畸变,该现象为正常现象,不影响使用,MCU内部使用的为OSC_IN引脚的波形,并通过内部整形方波供给MCU使用。

1.3.2 外部低速晶振电路设计

外部低速晶振电路如下图所示,外部低速晶振选择32.768KHz,匹配电容选择10pf,C1 = C2 = 2*(CLOAD - CS),其中CS为PCB和MCU引脚的杂散电容, 经验值在2pF-7pF之间,建议以5pF为参考值计算。推荐选用外部晶体时,尽量选择晶体负载电容在10pF左右的,这样外部所接匹配电容C1和C2电容值为10pF即可,且PCB Layout时尽可能近地靠近晶振引脚。

 1.4 代码解析

本节主要进行例程代码解析,主要分成两个部分:时钟配置以及CKOUT时钟输出验证。

1.4.1 时钟配置代码解析

时钟配置是一个MCU系统的基础,读者在开发MCU项目时需要首先明确当前系统所运行的主频具体是多少,这样才能够准确的进行外设时钟配置,定时器定时才会准确,ADC采样率才会准确,通信的速率才会准确等等,系统超频也会带来不可预料的风险,因而建议开发者在开发初期就需要明确系统主频配置,有条件的情况下可以通过定时或者时钟输出进行校验。

本例程中时钟配置函数代码如以下所示,该代码实现通过外部8M晶振进行PLL倍频,实现120MHz主系统时钟的功能。

C
void rcu_system_clk_config_120M(void)
{
  uint32_t timeout = 0U;
    uint32_t stab_flag = 0U;

    /* 使能外部8M晶振 */
    RCU_CTL |= RCU_CTL_HXTALEN;

    /* 等待外部晶振ready,或者外部晶振未ready情况下超时退出 */
    do{
        timeout++;
        stab_flag = (RCU_CTL & RCU_CTL_HXTALSTB);
    }while((0U == stab_flag) && (HXTAL_STARTUP_TIMEOUT != timeout));

    /* 如果外部晶振未ready,程序卡死进入while(1),读者若避免卡死可在此处切换到内部振荡器使用 */
    if(0U == (RCU_CTL & RCU_CTL_HXTALSTB)){
        while(1){
        }
    }

    RCU_APB1EN |= RCU_APB1EN_PMUEN;
    PMU_CTL |= PMU_CTL_LDOVS;

    /* AHB一分频,系统时钟等于AHB时钟 */
    RCU_CFG0 |= RCU_AHB_CKSYS_DIV1;
    /* APB2一分频,APB2高速外设时钟等于AHB时钟 */
    RCU_CFG0 |= RCU_APB2_CKAHB_DIV1;
    /* APB1 二分频,APB1低速外设时钟等于AHB时钟/2 */
    RCU_CFG0 |= RCU_APB1_CKAHB_DIV2;

    /* 选择HXTAL/2作为PLL时钟源,开发板外部晶振为8M,即8/2=4M作为PLL时钟源*/
    RCU_CFG0 &= ~(RCU_CFG0_PLLSEL | RCU_CFG0_PREDV0);
    RCU_CFG0 |= (RCU_PLLSRC_HXTAL_IRC48M | RCU_CFG0_PREDV0);

    /* CK_PLL = (CK_HXTAL/2) * 30 = 120 MHz */
/* 若希望调整系统时钟,可以调整RCU_PLL_MUL30倍频因子即可 */
    RCU_CFG0 &= ~(RCU_CFG0_PLLMF | RCU_CFG0_PLLMF_4 | RCU_CFG0_PLLMF_5);
    RCU_CFG0 |= RCU_PLL_MUL30;

    /* 使能 PLL */
    RCU_CTL |= RCU_CTL_PLLEN;

    /* 等待PLL Ready */
    while(0U == (RCU_CTL & RCU_CTL_PLLSTB)){
    }

    /* 使能PLL高驱模式 */
    PMU_CTL |= PMU_CTL_HDEN;
    while(0U == (PMU_CS & PMU_CS_HDRF)){
    }

    /* 选择PLL高驱模式 */
    PMU_CTL |= PMU_CTL_HDS;
    while(0U == (PMU_CS & PMU_CS_HDSRF)){
    }

    /* 选择PLL作为系统时钟 */
    RCU_CFG0 &= ~RCU_CFG0_SCS;
    RCU_CFG0 |= RCU_CKSYSSRC_PLL;

    /* 等待PLL被选择作为系统时钟 */
    while(0U == (RCU_CFG0 & RCU_SCSS_PLL)){
    }
}

如果读者使用的是其他频率的晶振,可以选择修改PLL倍频因子以及HXTAL的宏定义即可,比如若读者选择16MHz晶振,可以将历程中RCU_PLL_MUL30的倍频因子修改为RCU_PLL_MUL15,且将HXTAL_VALUE宏定义修改为16000000。

1.4.2 CKOUT时钟输出代码解析

CKOUT时钟输出配置代码如下所示,该函数无形参输入,首先将PA8配置为推挽输出,然后将系统时钟配置为CKOUT输出。

C
void ckout_config(void)
{
/* 以下两句配置PA8作为推挽输出,即作为CKOUT功能输出 */
rcu_periph_clock_enable(RCU_GPIOA);
gpio_init(GPIOA,GPIO_MODE_AF_PP,GPIO_OSPEED_MAX,GPIO_PIN_8);
/* 以下语句为配置系统时钟输出到CKOUT引脚,若希望输出其他时钟可以修改该函数形参,
在GD32F303上仅可以输出以下时钟:RCU_CKOUT0SRC_CKSYS,RCU_CKOUT0SRC_IRC8M,RCU_CKOUT0SRC_HXTAL,RCU_CKOUT0SRC_CKPLL_DIV2*/
rcu_ckout0_config(RCU_CKOUT0SRC_CKSYS);
}

1.4.3 主函数代码解析

本例程主函数如下所示,首先使用外部8M晶振倍频配置系统时钟为120MHZ,然后通过PA8将系统时钟输出。

C
int main(void)
{

  bsp_uart_init(&BOARD_UART);                                                                                                                                   /* 板载UART初始化 */
  printf("Example ofClock configuration and output.\r\n");
        rcu_system_clk_config_120M();                                                                                                                    /*使用外部8M晶振进行倍频,将系统时钟配置为120M*/
        
        ckout_config();                                                                                                                                                                            /*通过PA8(CKOUT)将系统时钟输出*/
        while (1)
        {}
}

1.5 实验结果

首先将PA8外接示波器,然后将本例程编译通过后,烧录到红枫派开发板中,通过示波器可以观察到系统时钟输出,如下图所示,本例程中系统时钟输出为120MHz。

由聚沃科技原创,来源于:【红枫派开发板】第一讲 RCU-时钟配置及输出实验 - 苏州聚沃电子科技有限公司 (gd32bbs.com)

GD32MCU技术交流群:859440462 

这篇关于【GD32F303红枫派使用手册】第一节 RCU-时钟配置及输出实验的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1011144

相关文章

关于Maven中pom.xml文件配置详解

《关于Maven中pom.xml文件配置详解》pom.xml是Maven项目的核心配置文件,它描述了项目的结构、依赖关系、构建配置等信息,通过合理配置pom.xml,可以提高项目的可维护性和构建效率... 目录1. POM文件的基本结构1.1 项目基本信息2. 项目属性2.1 引用属性3. 项目依赖4. 构

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

C++中实现调试日志输出

《C++中实现调试日志输出》在C++编程中,调试日志对于定位问题和优化代码至关重要,本文将介绍几种常用的调试日志输出方法,并教你如何在日志中添加时间戳,希望对大家有所帮助... 目录1. 使用 #ifdef _DEBUG 宏2. 加入时间戳:精确到毫秒3.Windows 和 MFC 中的调试日志方法MFC

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

Python使用Colorama库美化终端输出的操作示例

《Python使用Colorama库美化终端输出的操作示例》在开发命令行工具或调试程序时,我们可能会希望通过颜色来区分重要信息,比如警告、错误、提示等,而Colorama是一个简单易用的Python库... 目录python Colorama 库详解:终端输出美化的神器1. Colorama 是什么?2.

gradle安装和环境配置全过程

《gradle安装和环境配置全过程》本文介绍了如何安装和配置Gradle环境,包括下载Gradle、配置环境变量、测试Gradle以及在IntelliJIDEA中配置Gradle... 目录gradle安装和环境配置1 下载GRADLE2 环境变量配置3 测试gradle4 设置gradle初始化文件5 i

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件

C#读取本地网络配置信息全攻略分享

《C#读取本地网络配置信息全攻略分享》在当今数字化时代,网络已深度融入我们生活与工作的方方面面,对于软件开发而言,掌握本地计算机的网络配置信息显得尤为关键,而在C#编程的世界里,我们又该如何巧妙地读取... 目录一、引言二、C# 读取本地网络配置信息的基础准备2.1 引入关键命名空间2.2 理解核心类与方法

最新版IDEA配置 Tomcat的详细过程

《最新版IDEA配置Tomcat的详细过程》本文介绍如何在IDEA中配置Tomcat服务器,并创建Web项目,首先检查Tomcat是否安装完成,然后在IDEA中创建Web项目并添加Web结构,接着,... 目录配置tomcat第一步,先给项目添加Web结构查看端口号配置tomcat    先检查自己的to