STM32单片机:外设时钟(STM32L4xx)

通过前面的文章我们知道:HSE,HSI16,MSI,PLLCLK这几个时钟源可以作为系统主时钟,如下图:

STM32L4xx系列单片机有3个外设时钟:**AHB-HCLK,APB1-PCLK1,APB2-PCLK2,**这些时钟为绝大多数的片上外设提供时钟源。

这几个时钟的层级结构如下:


SYSCLK ===> / RCC_CFGR.HPRE[3:0] ===>【AHB-HCLK】

系统时钟SYSCLK 通过寄存器RCC_CFGRHPRE[3:0] 定义分频系数分频生成外设时钟**AHB-HCLK,**其分频系数为:1, 2, 4, 8, 16, 64, 128, 256, 512


AHB-HCLK ===> / RCC_CFGR.PPRE2[2:0] ===> APB2-PCLK2

时钟AHB-HCLK 通过寄存器RCC_CFGRPPRE2[2:0] 定义分频系数分频生成外设时钟**APB2-PCLK2,**其分频系数为:1, 2, 4, 8, 16


AHB-HCLK ===> / RCC_CFGR.PPRE1[2:0] ===> APB1-PCLK1

时钟AHB-HCLK 通过寄存器RCC_CFGRPPRE1[2:0] 定义分频系数分频生成外设时钟**APB1-PCLK1,**其分频系数为:1, 2, 4, 8, 16


芯片内的大部分外设的时钟均由以上3个时钟来提供,具体哪个外设对应哪个时钟,可以查阅芯片手册,比如:

在这个表格里可以找到某外设的时钟来自哪个时钟源,然后在以下几个寄存器中找到对应的外设时钟使能位,将其置位后,对应的外设时钟信号被使能。

AHB-HCLK作为时钟源的外设时钟使能控制:

**RCC_AHB1ENR:**AHB1 外设时钟使能寄存器

**RCC_AHB2ENR:**AHB2 外设时钟使能寄存器

**RCC_AHB3ENR:**AHB3 外设时钟使能寄存器

APB1-PCLK1作为时钟源的外设时钟使能控制:

RCC_APB1ENR1:APB1 外设时钟使能寄存器 1

RCC_APB1ENR2:APB1 外设时钟使能寄存器 2

APB2-PCLK2作为时钟源的外设时钟使能控制:

RCC_APB2ENR: APB2 外设时钟使能寄存器


比如上图中红框部分的定时器TIM2,如果要使能TIM2的时钟,由图中信息可知TIM2由APB1-PCLK1来提供时钟,所以找到寄存器RCC_APB1ENR1的说明:

RCC_APB1ENR1.TIM2EN 置位即可使能TIM2的时钟:

RCC_APB1ENR1 |= RCC_APB1ENR1_TIM2EN;

相关推荐
学工科的皮皮志^_^1 小时前
网口学习理解
经验分享·笔记·嵌入式硬件·学习·fpga开发·以太网
沐欣工作室_lvyiyi2 小时前
基于物联网的家畜管理的监测与控制系统(论文+源码)
单片机·物联网·毕业设计·家畜管理
大牛攻城狮2 小时前
使用stm32cubeide stm32f103 freeRTOS 实现Modbus RTU协议寄存器读写过程详解
stm32·freertos·modbus·stm32cubeide·modbus rtu·stm32从机·工程代码
蓑衣客VS索尼克3 小时前
第二篇:按键交互入门:STM32 GPIO输入与消抖处理
stm32·单片机·嵌入式硬件
蓬荜生灰3 小时前
第5章—STM32工程创建
stm32·单片机·嵌入式硬件
hazy1k3 小时前
51单片机基础-定时器中断
stm32·单片机·嵌入式硬件·51单片机
恒锐丰小吕3 小时前
矽塔 SA8204 输入耐压36V 2.5A可调过流保护 集成故障报告的智能过压/过流保护芯片
嵌入式硬件·硬件工程
太空1号4 小时前
VxWorks入门小白菜鸟教程3 —— 编译运行VxWorksSDK示例hello_cmake_rtp(Windows篇)
windows·嵌入式硬件
小莞尔5 小时前
【51单片机】【protues仿真】基于51单片机火灾报警控制系统
c语言·单片机·嵌入式硬件·物联网·51单片机
可爱的鸡仔6 小时前
STM32--------DMA
stm32·单片机·嵌入式硬件