OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 1949|回复: 0

固件时钟函数"SetSysClockTo72"有一句代码不明白

[复制链接]

1

主题

3

帖子

0

精华

初级会员

Rank: 2

积分
50
金钱
50
注册时间
2019-9-5
在线时间
16 小时
发表于 2019-10-22 05:50:22 | 显示全部楼层 |阅读模式
本帖最后由 sanbikappa 于 2019-10-22 05:58 编辑

函数 SetSysClockTo72 的定义在文件"stm32f10x.c"中:

  1. /* Enable PLL */
  2.     RCC->CR |= RCC_CR_PLLON;

  3.     /* Wait till PLL is ready */
  4.     while((RCC->CR & RCC_CR_PLLRDY) == 0)
  5.     {
  6.     }
  7.    
  8.     /* Select PLL as system clock source */
  9.     RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_SW));
  10.     RCC->CFGR |= (uint32_t)RCC_CFGR_SW_PLL;  
复制代码


其中设置PLL作为系统时钟源的两句代码(也就是上面的最后两句)有点不明白。
倒数第二句的作用是将CFGR的位0和位1设为00,最后一句将CFGR的位1设为1,合起来就是将最低两位设为10(PLL输出作为系统时钟)。

问题出在倒数第二句的位操作。

RCC_CFGR_SW 本身就是一个uint32_t类型的常量(宏定义里将RCC_CFGR_SW定义为((uint32_t)0x00000003)的常量),为什么每做完一次位操作(取反、与操作)之后都要重复一次强制转换,可是上面那句 RCC->CR |= RCC_CR_PLLON; 却不需要对结果做强制转换?
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-2 20:27

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表