OpenEdv-开源电子网

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

刚看原子的战舰视频,看到第20讲,有个小疑问,哪位大手给小的解惑一下下。版主大大?

[复制链接]

1

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
58
金钱
58
注册时间
2016-10-16
在线时间
7 小时
发表于 2016-10-31 20:14:03 | 显示全部楼层 |阅读模式
1金钱
在原子官方库"system_stm32f10x.c"当中,第1021行代码开始连着的8行代码,
    /* HCLK = SYSCLK */
    RCC->CFGR |= (uint32_t)RCC_CFGR_HPRE_DIV1;
      
    /* PCLK2 = HCLK */
    RCC->CFGR |= (uint32_t)RCC_CFGR_PPRE2_DIV1;
   
    /* PCLK1 = HCLK */
    RCC->CFGR |= (uint32_t)RCC_CFGR_PPRE1_DIV2;
意思是让时钟 PCLK1=PCLK2= HCLK =SYSCLK,而它实现的条件是RCC_CFGR寄存器中的第7、10、13位的值为零。
但咱的代码 RCC->CFGR |= (uint32_t)RCC_CFGR_HPRE_DIV1;中用的是|0,而不是该位&0,怎样保证那个位是零呢?
还是那个位刚上电启动就是0不用操作?
或者(基本不可能)是库里这里的代码写错了?

QQ截图20161031200138.png
QQ截图20161031200238.png
QQ截图20161031200301.png
Xshot-0011.png

最佳答案

查看完整内容[请看2#楼]

这里说的不严谨,不是所有寄存器的复位值都是0x0000;
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

34

主题

283

帖子

0

精华

高级会员

Rank: 4

积分
739
金钱
739
注册时间
2015-11-15
在线时间
226 小时
发表于 2016-10-31 20:14:04 | 显示全部楼层
xueshawu 发表于 2016-10-31 20:28
例程里面,有好多写0的地方是采用的|0 的方式;之所以没出问题,因为i寄存器的复位值都是0X0000;

这里说的不严谨,不是所有寄存器的复位值都是0x0000;
与其感慨路难行,不如马上出发
回复

使用道具 举报

1

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
58
金钱
58
注册时间
2016-10-16
在线时间
7 小时
 楼主| 发表于 2016-10-31 20:17:00 | 显示全部楼层
参数
QQ截图20161031201525.png
QQ截图20161031201540.png
QQ截图20161031201553.png
回复

使用道具 举报

34

主题

283

帖子

0

精华

高级会员

Rank: 4

积分
739
金钱
739
注册时间
2015-11-15
在线时间
226 小时
发表于 2016-10-31 20:28:51 | 显示全部楼层
例程里面,有好多写0的地方是采用的|0 的方式;之所以没出问题,因为i寄存器的复位值都是0X0000;
与其感慨路难行,不如马上出发
回复

使用道具 举报

1

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
58
金钱
58
注册时间
2016-10-16
在线时间
7 小时
 楼主| 发表于 2016-10-31 20:33:21 | 显示全部楼层
xueshawu 发表于 2016-10-31 20:30
这里说的不严谨,不是所有寄存器的复位值都是0x0000;

好的,原来是不严谨啊,我说我怎么理解不透呢!多谢哈!
回复

使用道具 举报

北之海洋 该用户已被删除
发表于 2016-12-5 08:56:52 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-26 00:06

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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