时钟图
APB1的最高频率是36MHz
APB2的最高频率是72MHz
经过总线桥AHB–APB,通过设置分频,可由HCLK得到 PCLK1与PCLK2时钟,而PCLK1和PCLK2一般也默认配置为其最高工作频率36M和72M,PCLK2对应APB2外设,PCLK1对应APB1外设。
HCLK :AHB总线时钟,由系统时钟SYSCLK 分频得到,一般不分频,等于系统时钟
SYSCLK 系统时钟,最大72MHz。
SPI时钟最快18MHZ,可超频。
SPI1时钟由APB2时钟分频而来,可以选择2、4、8、16、32、64、128、256这几个分频系数。而手册规定STM32的SPI时钟最快是18MHz。对于STM32F103的SPI1接口时钟,由72M的PCLK2分频得到,所以分配系数大于等于4(72M/4 = 18M)。
STM32F103的SPI2/3接口时钟,在APB1下面,由36M的PCLK1分频得到,所以分配系数大于等于2(36M/2 = 18M)。
总线接口:
APB1(最大36MHZ)下连:DA、USB、SPI、I2C、串口2345、普通TIM
APB2(最大72MHZ)下连:串口1、AD、I/0、高级TIM
APB1下的外设
APB2下的外设
AHB下的外设
之前好奇的DMA就在AHB下面。
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
所以使能DMA时钟因为在AHB下所以这样写
因为AHB用于高性能的CPU DMA DSP等之间的连接,即数据吞吐量大,APB用于低宽带的周围外设。
STM32SPI、APB等总线关系总结
最新推荐文章于 2025-03-02 22:25:21 发布