在原子官方库"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不用操作?
或者(基本不可能)是库里这里的代码写错了?
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
这里说的不严谨,不是所有寄存器的复位值都是0x0000;
一周热门 更多>