什么是时钟树架构

发布时间:2024-01-10  

2.1 时钟树结构图

STM32属于Cortex-M3内核的单片机,时钟结构比之前的51单片机较复杂的多,根据数据手册,STM32F103的时钟结构如下图所示。

图片

根据上图可以看到,STM32F103系列单片机具有4个时钟源,内部的8MHz时钟发生器,外部的晶体振荡器接口,最高支持16MHz,外部的32.768kHz晶体振荡器接口和内部的40kHz时钟发生器,其中32.768kHz和40kHz主要用于内部RTC时钟脉冲,8MHz的晶振通过PLL时钟倍乘器,将系统总线时钟提高为72MHz。


STM32F103系列内部具有2条外设时钟总线,APB1和APB2,其中APB2的时钟最高可达72MHz,APB1的时钟最高可达36MHz,通过配置对应的寄存器,就可以将CPU内核时钟提高到最大速度。


通过最小系统可以看到,我们使用外部高速晶体振荡器接口,外接8MHz晶振,RTC则是使用32.768kHz晶振,现在我们来通过数据手册来配置对应的寄存器位来配置APB2时钟达到72MHz,APB1时钟达到36MHz。


2.2 时钟配置

图片

上图是ST公司推出的一款软件,这款软件可以自动生成寄存器代码,但是我们在这里只用到其中提供的时钟配置功能,通过上面的时钟结构,我们可以得到配置时钟的大概流程。


2.2.1 时钟配置流程

(1)开启HSE时钟接口,这个接口用于使能晶体振荡器输入端;


(2)设置PLL倍频系数为9,因为外接8MHz时钟,所以设置系数为9就可以轻松达到8×9=72MHz的时钟频率;


(3)设置时钟源为PLLCLK,因为HSE使用的时候可以发现最终的输出就是PLL时钟脉冲;


(4)设置APB1时钟总线的分频系数为2,因为APB1时钟总线最高频率只有36MHz;


(5)设置APB2时钟总线的分频系数为1。


2.2.2 相关寄存器

(1) 时钟控制寄存器 :RCC_CR

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16
- PLLRDY PLLON - CSSON HSEBYP HSERDY HSEON







15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
HSICAL[7:0] HSITRIM[4:0] - HISRDY HISON










Bit 25:PLL准备状态


0:PLL解锁


1:PLL锁定

Bit 24:PLL使能


0:PLL关闭


1:PLL打开

Bit 19:时钟安全系统开关


0:时钟保护关闭


1:时钟保护打开

Bit 18:HSE旁路(禁用HSE振荡器时才能写入)


0:HSE禁止旁路


1:HSE打开旁路

Bit 17:HSE准备状态


0:HSE未准备好


1:HSE准备完毕

Bit 16:HSE时钟使能


0:HSE时钟关闭


1:HSE时钟打开

Bit 15~ Bit 8:HSI校准值(这个值在启动的时候自动初始化)


Bit 7~ Bit 3:HSI微调(对其进行编程以适应电压和温度的变化影响内部HSI的频率。初始值16,步长约为40kHz)


Bit 1:HSI准备状态


0:HIS未准备好


1:HSI准备完毕

Bit 0:HSI时钟使能


0:HIS时钟关闭


1:HSI时钟开启

(2) 时钟配置寄存器 :RCC_CFGR

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16
- MCO[2:0] - USBPRE PLLMUL[3:0] PLLXTPRE PLLSRC








15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
ADCPRE[1:0] PPRE2[2:0] PPRE1[2:0] HPRE[3:0] SWS[1:0] SW[1:0]









Bit 26~Bit 24:芯片时钟输出


0xx:禁止输出


          100:选择系统时钟SYSCLK


          101:选择HSI时钟


          110:选择HSE时钟


          111:选择PLL分频输出(2分频)

Bit 22:USB时钟分频系数


0:PLL时钟1.5分频作为USB时钟


          1:PLL时钟不分频作为USB时钟

Bit 21~Bit 18:PLL倍频系数


0000:2倍频


          0001:3倍频


          0010:4倍频


          0011:5倍频


          0100:6倍频


          0101:7倍频


          0110:8倍频


          0111:9倍频


          1000:10倍频


          1001:11倍频


          1010:12倍频


          1011:13倍频


          1100:14倍频


          1101:15倍频


          1110:16倍频


          1111:16倍频

Bit 17:HSE输入分频器


0:HSE输入不分频


          1:HSE输入2分频

Bit 16:PLL时钟选择(PLL处于禁止模式才能写入)


0:HSI时钟2分频作为PLL时钟输入


          1:HSE作为PLL时钟输入

Bit 15~Bit 14:ADC分频系数


00:PCLK2分频系数为2


          01:PCLK2分频系数为4


          10:PCLK2分频系数为6


          11:PCLK2分频系数为8

Bit 13~Bit 11:APB2分频系数(最高可达72MHz)


0xx:HCLK不分频


          100:HCLK分频系数为2


          101:HCLK分频系数为4


          110:HCLK分频系数为8


          111:HCLK分频系数为16

Bit 10~Bit 8:APB1分频系数(最高只能达到36MHz)


0xx:HCLK不分频


          100:HCLK分频系数为2


          101:HCLK分频系数为4


          110:HCLK分频系数为8


          111:HCLK分频系数为16

Bit 7~Bit 4:AHB总线预分频系数


0xxx:SYSCLK不分频


          1000:SYSCLK分频系数为2


          1001:SYSCLK分频系数为4


          1010:SYSCLK分频系数为8


          1011:SYSCLK分频系数为16


          1100:SYSCLK分频系数为64


          1101:SYSCLK分频系数为128


          1110:SYSCLK分频系数为256


          1111:SYSCLK分频系数为512

Bit 3~Bit 2:系统时钟选择状态


00:HSI作为系统时钟


          01:HSE作为系统时钟


          10:PLL作为系统时钟


          11:保留

Bit 1~Bit 0:系统时钟选择


00:选择HSI作为系统时钟


          01:选择HSE作为系统时钟


          10:选择PLL作为系统时钟


          11:保留

2.3 设置例程

配置STM32的时钟需要创建几个文件,这几个文件如下表所示。

文件目录 文件名 文件功能
./SYSTEM/sys sys.c 时钟设置函数外部中断设置函数中断优先级设置函数
sys.h 数据类型定义
stm32f103x.h 定义寄存器结构定义寄存器地址定义中断编号

(1)创建上述三个文件,其中c文件添加进工程中,h文件包含进程序中,如下图所示。

图片

图片

图片

(2)stm32f103x.h文件输入以下内容:

图片

这个文件用于定义程序用到的所有寄存器的地址和结构体,是整个STM32程序的最基础的文件。


(3)sys.h输入以下内容

图片

sys.h文件用于定义STM32的时钟配置和中断配置,以及后面的端口位操作模式。

(3)sys.c文件输入以下内容


void STM32_Clock_Init( u8 PLL )

{

   RCC->CR |= 0x00010000 ;              //外部高速时钟使能HSEON

  while( !( RCC->CR>>17 ) ) ;              //等待外部时钟就绪

  RCC->CFGR = 0x00000400 ;            //APB1=DIV2;APB2=DIV1;AHB=DIV1;

  PLL -= 2 ;                    //抵消2个单位(因为是从2开始的,设置0就是2)

  RCC->CFGR |= ( u32 )PLL<<18 ;            //设置PLL值 2~16

  RCC->CFGR |= 1<<16 ;              //PLLSRC ON

  FLASH->ACR |= 0x32 ;                //FLASH 2个延时周期

  RCC->CR |= 1<<24 ;                //PLLON

  while( ( RCC->CR&0x02000000 )!=0x02000000 ) ;    //等待PLL锁定

  RCC->CFGR |= 0x00000002 ;            //PLL作为系统时钟

  while( ( RCC->CFGR&0x0000000C )!=0x00000008 ) ;  //等待PLL作为系统时钟设置成功

}


这个文件的函数就是真正配置时钟的过程,可以对照之前描述的配置时钟的过程来看这段代码。


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    的各卦位置看成一个个结点时,伏羲八卦就是一个二叉树。 在数据结构研究中,人们为了快速检索数据,设定了二叉树、B+树、基数树等许多种二叉或多叉树,统称为检索树。检索树的生长过程是:在根结点下有1个以......
    时间轮为数组,新增和删除一个任务,时间复杂度都是O(1)。 PerTickBookkeeping每次转动一格,时间复杂度也是O(1)。 2.4 最小堆实现 最小堆是堆的一种, (堆是一种二叉树......
    号的识别。这里采用了“完全二叉树”的排序思想(图6)。具体思路:设在K位首次发生数据位冲突,这时所有的传感器分成两类,即该位为1的传感器和为0的传感器。“需要的位值”给1,K位为1的传......
    费程序空间。 作为一个天天看《编程之美》的码农,决定改变现状。 酷狗百度一番,找到了两个参考: 《基于二叉树的多层的液晶菜单界面设计》 《基于......
    速度和实现复杂度之间提供一个很好的平衡。 红黑树是具有以下特征的二叉树: 每个节点或红或黑。 每个......
    架构的网络空间上的位置定位系统的主维是三种类型的携带遗传代码的可生长的结构树:IP地址结构树、地理空间位置结构树、北斗时空码。其中: 1、IP地址结构树是64叉整数树,包含目前的IPV4和IPV6的IP地址,且根据需要IP地址可无限增长产生。IP地址结构树的......
    优先搜索在PCI驱动结构中大量被用到.它类似于二叉树的先根遍历.深 度优先搜索类似于二叉树的层遍历.具体到UHCI的QH遍历方式上:深度优先:UHCI先处理完QH下面的所有TD,然后再处理下一个QH......
    易用的图形用户界面, 可配置3. 具有自动解决冲突的引脚排列4. 外设和中间层功能模式与参数约束的动态验证 Arm®Cortex®-M 核心5. 具有动态验证配置的时钟树6. 带有估计功耗结果的电源序列7. 初始......
    红外反射率的高分辨率概率图(3)另一类是基于八叉树的地图。该地图用于存储具有不同3D分辨率的信息(如图12所示)。与具有不同3D分辨率的OGM相比,OctoMaps(基于八叉树的地图)仅存......
    tiny4412的中断资源连接关系示意图;在tiny4412的设备树中可以发现,中断资源是以树的形式呈现的,下面是我画的一张图,大致描述了tiny4412上中断资源的连接关系。 可以到http......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>