中级会员
 
- 积分
- 277
- 金钱
- 277
- 注册时间
- 2013-9-11
- 在线时间
- 40 小时
|
1金钱
做了一批设备,stm32f103rbt6,外部8M晶振,外部rtc时钟32.768,用了原子提供的RTC例程,开始做了一批样品没有发现问题,后来做了一个批量,调试的时候发现RTC总是启动不起来,追踪发现,卡在while (RCC_GetFlagStatus(RCC_FLAG_LSERDY) == RESET),过不去,不知道问什么,
后来在3.3V电源和RTC电源之间加了一个二极管,有一部分设备能工作,但仍有一些不能工作,不明白怎么回事,
大神给看看
uint8_t RTC_Init(void)
{
uint8_t temp=0;
RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR | RCC_APB1Periph_BKP, ENABLE); //使能PWR和BKP外设时钟
PWR_BackupAccessCmd(ENABLE); //使能后备寄存器访问
//
if(BKP_ReadBackupRegister(BKP_DR1) != 0x5050) //从指定的后备寄存器中读出数据:读出了与写入的指定数据不相乎
{
RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR | RCC_APB1Periph_BKP, ENABLE); //使能PWR和BKP外设时钟
PWR_BackupAccessCmd(ENABLE); //使能后备寄存器访问
BKP_DeInit(); //复位备份区域
RCC_LSEConfig(RCC_LSE_ON); //设置外部低速晶振(LSE),使用外设低速晶振
/* RTC时钟程序卡在这里过不去,不知道问什么*/
while (RCC_GetFlagStatus(RCC_FLAG_LSERDY) == RESET) //检查指定的RCC标志位设置与否,等待低速晶振就绪
{
temp++;
Delay_ms(10);
}
if(temp>=250)
{
#ifdef DEBUG_CM
printf("RTC_temp is %d\r\n",temp);
#endif
return 1;//初始化时钟失败,晶振有问题
}
RCC_RTCCLKConfig(RCC_RTCCLKSource_LSE); //设置RTC时钟(RTCCLK),选择LSE作为RTC时钟
RCC_RTCCLKCmd(ENABLE); //使能RTC时钟
RTC_WaitForLastTask(); //等待最近一次对RTC寄存器的写操作完成
RTC_WaitForSynchro(); //等待RTC寄存器同步
RTC_ITConfig(RTC_IT_SEC, ENABLE); //使能RTC秒中断
RTC_WaitForLastTask(); //等待最近一次对RTC寄存器的写操作完成
RTC_EnterConfigMode();/// 允许配置
RTC_SetPrescaler(32767); //设置RTC预分频的值
RTC_WaitForLastTask(); //等待最近一次对RTC寄存器的写操作完成
RTC_Set(2019,10,1,12,0,0); //设置时间
RTC_ExitConfigMode(); //退出配置模式
BKP_WriteBackupRegister(BKP_DR1, 0X5050); //向指定的后备寄存器中写入用户程序数据
}
else//系统继续计时
{
RTC_WaitForSynchro(); //等待最近一次对RTC寄存器的写操作完成
RTC_ITConfig(RTC_IT_SEC, ENABLE); //使能RTC秒中断
RTC_WaitForLastTask(); //等待最近一次对RTC寄存器的写操作完成
}
// RTC_NVIC_Config();//RCT中断分组设置
RTC_Get();//更新时间
#ifdef DEBUG_CM
printf("RTC_temp is %d\r\n",temp);
#endif
return 0; //ok
}
|
最佳答案
查看完整内容[请看2#楼]
已解决,启动的时候耗的时间太长了,触发了watchdog重启,初始化之后再开启watchdog就ok了
|