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

2019-10-16 05:14发布

在原子官方库"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不用操作?
或者(基本不可能)是库里这里的代码写错了?

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。