如何理解STM32系统时钟和分频

发布时间:2023-08-21  

  首先来手册里的一段话。

  三种不同的时钟源可被用来驱动系统时钟 (SYSCLK)

  · HSI振荡器时钟

  · HSE振荡器时钟

  · PLL时钟

  一般用的是PLL时钟,后面有证据。

  我们可以通过库函数获取各时钟值

  void RCC_GetClocksFreq(RCC_ClocksTypeDef* RCC_Clocks)

  在我的系统里,把时钟值打印信息如下:

  SYSCLK:0x44aa200 //72000000, 72MHz

  HCLK:0x44aa200 //72000000, 72MHz

  PCLK1:0x2255100 //36000000, 36MHz

  PCLK2:0x44aa200 //72000000, 72MHz

  ADCCLK:0x2255100 //36000000,36MHz

  RCC-》CFGR:0x001D040A //PLL输出作为系统时钟

  可推测几个预分频值为

  AHB prescaler = 1

  APB1 prescaler = 2

  APB2 prescaler = 1

  ADC prescaler = 2

  根据读取RCC-》CFGR寄存器值为:0x001D040A,上面推测完全正确。

  CFGR寄存器的SWS段也说明:PLL输出作为系统时钟。

  TIM2使用PCLK1,但注意时钟树里有这一段

  见附图

  如何理解STM32系统时钟和分频

  已知APB1 prescaler=2,故TIM2CLK = PCLK1*2 = 72MHz.

  所以被TIM2分频的时钟大小是72MHz。

  我的程序也证明了这点

  TIM_TimeBaseInitTypeDef tim2_InitStruct;

  TIM_DeInit(TIM2);

  RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);//Enable Timer2 clock.

  NVIC_ConfigurationForTimer2();

  // PCLK1=36MHz, PSC=36000-1, CK_CNT=36MHz/(PSC+1)=1000

  // ARR=2000, 1s/1000 * 2000 = 2s.

  tim2_InitStruct.TIM_Prescaler = 36000-1;

  tim2_InitStruct.TIM_Period = 2000-1;

  tim2_InitStruct.TIM_CounterMode = TIM_CounterMode_Up;

  tim2_InitStruct.TIM_ClockDivision = TIM_CKD_DIV1;

  tim2_InitStruct.TIM_RepetitionCounter = 0;

  TIM_TimeBaseInit(TIM2, &tim2_InitStruct);

  TIM_ClearFlag(TIM2, TIM_FLAG_Update);

  TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE);//Enables the specified TIM interrupts.

  这段配置原本以为定时时间是2s,实际只有1s。看了手册才理解原因。


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

相关文章

    部低速晶体振荡器。 LPC1754内部PLL0原理简介 PLL0包含多个寄存器,其中PLL0时钟源的选择可在CLKSRCSEL寄存器中设置,PLL0将输入时钟进行倍频,然后再分频为CPU及芯片外设提供实时时钟......
    CK_INT=2*36M=72M 2.计数器模式 向下计数模式:(时钟分频因子=1) 向下计数模式:(时钟分频因子=1) 中央对齐计数模式:(时钟分频因子=1 ARR=6) ** 3.定时......
    ]:Clock generator、Serial interface、Wishbone interface如图3所示。 3.2.1 时钟产生模块SPI-clgen设计 SPI时钟分频模块中的时钟信号的来源是外部系统提供的时钟......
    源可以为: 由RCC的内部时钟分频得到 由定时器的TIMx_ETR引脚得到 由其他定时器通过TRGO输出得到 一般使用RCC的内部时钟CK_INT,也即定时器时钟TIMxCLK,经APB1或......
    GPIO 配置时钟, 使能中断(计数阈值,预分频时钟分频,计数模式) void tim3() //配置TIM3为基本定时器模式 ,约10us触发一次,触发频率约100kHz......
    提供 4 个高性能电流模式逻辑 (CML) 输出,每个输出都配备了一个独立的低噪声时钟分频器和数字延迟构件,以涵盖从 1.95MHz 到 2700MHz 的宽频率范围。当以高输入频率和快速输出数据传送速率为数据转换器提供时钟......
    要使用定时器接收某种波形时(如电机编码器信号) 先来看一下定时器的原理框图,对定时器的内部原理有一个整体直观的感受: 1.3.1 时钟源 从上图可以看出,计数器的时钟源可以为: 由RCC的内部时钟分频得到 由定......
    到代码实际执行处start_code 3,关闭看门狗WATCHDOG 3,关闭所有中断INTERRUPT 4,设置时钟分频,主要设置寄存器CLKDVN,MPLLCON,UPLLCON 5,关闭MMU和......
    时钟信号的处理是的特色之一,因此也是设计中使用频率非常高的基本设计之一。一般在FPGA中都有集成的锁相环可以实现各种时钟的分频和倍频设计,但是通过语言设计进行时钟分频是最基本的训练,在对时钟......
    定时中断 ARR设置中断周期,例如设置为1000,则每1000计数周期会触发一次更新中断。 PSC设置时钟分频系数,例如分频比为7200,时钟频率72MHz。则中断周期为1000 * 7200......

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

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

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

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

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

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

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