[STM32L1] 时钟怎么还是32M?

[复制链接]
1948|21
 楼主| zyf部长 发表于 2020-9-29 21:52 | 显示全部楼层 |阅读模式
STM32L151外接3.6864MHz晶振,时钟怎么还是32M?
zhanghqi 发表于 2020-9-29 21:53 | 显示全部楼层

楼主详细说说怎么回事啊,这么说太笼统了
 楼主| zyf部长 发表于 2020-9-29 21:54 | 显示全部楼层
公司有个以前做的项目,拿到前人留下的程序,想学习学习。刚上来就被时钟搞混了。

这块板子用的是STM32L151,外接3.6864MHz晶振,OSC32IN和OSC32out没接晶振。这块板子需要精确延时的。
按我理解,时钟应该是3.6864*8/2=14.7456M,但是我看代码里还是基于8M来设置的。

RCC_GetClocksFreq(&RCC_Clocks);      //获取系统时钟频率,外部晶振8.00M,倍频后系统时钟8.000*8/2=32.00M

注释是说外部晶振8M,可实际上没有接,只接的是3.6864MHz晶振。
 楼主| zyf部长 发表于 2020-9-29 21:55 | 显示全部楼层

对应的RCC_GetClocksFreq如下:
void RCC_GetClocksFreq(RCC_ClocksTypeDef* RCC_Clocks)
{
  uint32_t tmp = 0, pllmul = 0, plldiv = 0, pllsource = 0, presc = 0, msirange = 0;
  /* Get SYSCLK source -------------------------------------------------------*/
  tmp = RCC->CFGR & RCC_CFGR_SWS;
  
  switch (tmp)
  {
    case 0x00:  /* MSI used as system clock */
      msirange = (RCC->ICSCR & RCC_ICSCR_MSIRANGE ) >> 13;
      RCC_Clocks->SYSCLK_Frequency = (((1 << msirange) * 64000) - (MSITable[msirange] * 24000));
      break;
    case 0x04:  /* HSI used as system clock */
      RCC_Clocks->SYSCLK_Frequency = HSI_VALUE;
      break;
    case 0x08:  /* HSE used as system clock */
      RCC_Clocks->SYSCLK_Frequency = HSE_VALUE;
      break;
    case 0x0C:  /* PLL used as system clock */
      /* Get PLL clock source and multiplication factor ----------------------*/
      pllmul = RCC->CFGR & RCC_CFGR_PLLMUL;
      plldiv = RCC->CFGR & RCC_CFGR_PLLDIV;
      pllmul = PLLMulTable[(pllmul >> 18)];
      plldiv = (plldiv >> 22) + 1;
      
      pllsource = RCC->CFGR & RCC_CFGR_PLLSRC;
      if (pllsource == 0x00)
      {
        /* HSI oscillator clock selected as PLL clock entry */
        RCC_Clocks->SYSCLK_Frequency = (((HSI_VALUE) * pllmul) / plldiv);
      }
      else
      {
        /* HSE selected as PLL clock entry */
        RCC_Clocks->SYSCLK_Frequency = (((HSE_VALUE) * pllmul) / plldiv);
      }
      break;
    default:
      RCC_Clocks->SYSCLK_Frequency = HSI_VALUE;
      break;
  }


在system_stm32lxx.c里,看到倍频分频设置值跟外接8M一样,几乎没改动。
    /*  PLL configuration: PLLCLK = (HSE * 8) / 2 = 32MHz */
    RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_PLLSRC | RCC_CFGR_PLLMUL |
                                        RCC_CFGR_PLLDIV));
    RCC->CFGR |= (uint32_t)(RCC_CFGR_PLLSRC_HSE | RCC_CFGR_PLLMUL8 | RCC_CFGR_PLLDIV2);
wenfen 发表于 2020-9-29 21:56 | 显示全部楼层
利用的内部的HSI 8M来计算的
 楼主| zyf部长 发表于 2020-9-29 21:57 | 显示全部楼层
我在相关代码里没找到使用HSI的语句
 楼主| zyf部长 发表于 2020-9-29 21:58 | 显示全部楼层
也没有发现用此晶振3.6864MHz晶振代替系统默认的8M。
songqian17 发表于 2020-9-29 21:59 | 显示全部楼层
对RCC有点糊涂
wangzsa 发表于 2020-9-29 22:01 | 显示全部楼层
这也太邪乎了,没有8M,怎么结果会是个8M的
zwll 发表于 2020-9-29 22:02 | 显示全部楼层
这是cubeMX生成的代码?
chuxh 发表于 2020-9-29 22:03 | 显示全部楼层
怀疑是HSI内部8M的
llljh 发表于 2020-9-29 22:04 | 显示全部楼层
但这产品需要精确延时
 楼主| zyf部长 发表于 2020-9-29 22:05 | 显示全部楼层
而且我在程序里也没找到内部HSI之类的代码
renyaq 发表于 2020-9-29 22:08 | 显示全部楼层
怀疑注释有问题
 楼主| zyf部长 发表于 2020-9-29 22:08 | 显示全部楼层
前面讲了,没用CUBX,是人家用IAR写的,
renyaq 发表于 2020-9-29 22:09 | 显示全部楼层
还有这种时钟?
xxrs 发表于 2020-9-29 22:11 | 显示全部楼层
你这个真的好奇怪啊
yinxiangh 发表于 2020-9-29 22:12 | 显示全部楼层
所以最好用官方的例子配置啊。都是使用的库函数,不容易错。
 楼主| zyf部长 发表于 2020-9-29 22:13 | 显示全部楼层

嗯,预料中的结果,多谢大家啦
keaibukelian 发表于 2020-10-12 08:38 | 显示全部楼层
能接这样的晶振?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

694

主题

7102

帖子

8

粉丝
快速回复 在线客服 返回列表 返回顶部