内容如题,对于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这个条件。
这只是个人的看法,在此处指出了出来,鄙人的水平有限,理解之处还有些许的片面,不便之处还请谅解。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
一周热门 更多>