今天看F4探索者板子的RTC实验中的初始化,发现有个地方有问题,特指出

2019-07-20 03:39发布

内容如题,对于RTC的初始化,有这样一段代码: [mw_shl_code=c,true]//RTC初始化 //返回值:0,初始化成功; // 1,LSE开启失败; // 2,进入初始化模式失败; u8 My_RTC_Init(void) { RTC_InitTypeDef RTC_InitStructure; u16 retry=0X1FFF; RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);//使能PWR时钟 PWR_BackupAccessCmd(ENABLE); //使能后备寄存器访问 if(RTC_ReadBackupRegister(RTC_BKP_DR0)!=0x5050) //是否第一次配置? { RCC_LSEConfig(RCC_LSE_ON);//LSE 开启 while (RCC_GetFlagStatus(RCC_FLAG_LSERDY) == RESET) //检查指定的RCC标志位设置与否,等待低速晶振就绪 { retry++; delay_ms(10); } if(retry==0)return 1; //LSE 开启失败. RCC_RTCCLKConfig(RCC_RTCCLKSource_LSE); //设置RTC时钟(RTCCLK),选择LSE作为RTC时钟 RCC_RTCCLKCmd(ENABLE); //使能RTC时钟 RTC_InitStructure.RTC_AsynchPrediv = 0x7F;//RTC异步分频系数(1~0X7F) RTC_InitStructure.RTC_SynchPrediv = 0xFF;//RTC同步分频系数(0~7FFF) RTC_InitStructure.RTC_HourFormat = RTC_HourFormat_24;//RTC设置为,24小时格式 RTC_Init(&RTC_InitStructure); RTC_Set_Time(23,59,56,RTC_H12_AM); //设置时间 RTC_Set_Date(14,5,5,6); //设置日期 RTC_WriteBackupRegister(RTC_BKP_DR0,0x5050); //标记已经初始化过了 } return 0; }[/mw_shl_code] 我觉得问题出在这个地方,是一个逻辑上的判断,可能是当初写程序的人的疏忽,但我还是理解了他的意思: 在等待低速晶振的过程中 [mw_shl_code=c,true]while (RCC_GetFlagStatus(RCC_FLAG_LSERDY) == RESET) //检查指定的RCC标志位设置与否,等待低速晶振就绪 { retry++; delay_ms(10); } if(retry==0)return 1; //LSE 开启失败. [/mw_shl_code]
其中里面包含了retry++这样的程序,对于retry在程序开头已经定义了 [mw_shl_code=c,true]u16 retry=0X1FFF; [/mw_shl_code]
很显然,结合下面的判断 [mw_shl_code=c,true]if(retry==0)return 1; //LSE 开启失败. [/mw_shl_code] 可以轻易的得出 retry表示了等待的次数,当retry从0x1fff开始尝试,每次加一,当溢出到0的时候说明尝试结束 故鄙人认为在等待的过程中还应该加上另外一个条件——判断retry时候为零这个条件,这样程序应更改如下: [mw_shl_code=c,true]RCC_LSEConfig(RCC_LSE_ON);//LSE 开启 while (RCC_GetFlagStatus(RCC_FLAG_LSERDY) == RESET && retry) //检查指定的RCC标志位设置与否,等待低速晶振就绪 { retry++; delay_ms(10); } if(retry==0)return 1; //LSE 开启失败. [/mw_shl_code] 也就是加上了retry这个条件。

这只是个人的看法,在此处指出了出来,鄙人的水平有限,理解之处还有些许的片面,不便之处还请谅解。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。