求助:STM32F407的RTC没有秒钟中断的问题

2019-07-21 03:54发布

之前的STM32F1系列都有秒钟中断,我现在这STM32F407发现没有秒中断,在参考手册里面有看到配置异步分频设置为:0x7F 同步分频:0xFF,就是产生1HZ。可是配置完后,发现,秒跳的非常快,不是一秒跳一次。而且设置了24小时格式的,根本上不了13之后的,如果是设置13之后的小时格式,就会超出24,移植到四十几小时,再跳回1小时。以下下是我RTC的配置 和读取:
void RTCTime_Test(void)
{
                RTC_InitTypeDef RTC_InitStructure;
    /* Output a message on Hyperterminal using printf function */
    printf("   *********************** RTC Time Stamp Example *********************** ");   
    if (RTC_ReadBackupRegister(RTC_BKP_DR0) != 0x5566)
    {
        /* RTC configuration  */
        RTC_Config();
        /* Check on RTC init */
        if (RTC_Init(&RTC_InitStructure) == ERROR)
        {
            printf("         /!\***** RTC Prescaler Config failed ********/!\ ");
        }       
        /* Configure the time register */
        RTC_TimeRegulate(); 
//                                RTC_WriteProtectionCmd(DISABLE);
//                                RCC_RTCCLKCmd(ENABLE); 
    }
    else
    {
        /* Check if the Power On Reset flag is set */
        if (RCC_GetFlagStatus(RCC_FLAG_PORRST) != RESET)
        {
          printf(" Power On Reset occurred.... ");
        }
        /* Check if the Pin Reset flag is set */
        else if (RCC_GetFlagStatus(RCC_FLAG_PINRST) != RESET)
        {
          printf(" External Reset occurred.... ");
        }       
        printf(" No need to configure RTC.... ");        
        /* Enable the PWR clock */
        RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);       
        /* Allow access to RTC */
        WR_BackupAccessCmd(ENABLE);      
        /* Wait for RTC APB registers synchronisation */
        RTC_WaitForSynchro();        
        /* Clear the RTC Alarm Flag */
//        RTC_ClearFlag(RTC_FLAG_ALRAF);        
        /* Clear the EXTI Line 17 Pending bit (Connected internally to RTC Alarm) */
//        EXTI_ClearITPendingBit(EXTI_Line17);       
        /* Display the RTC Time/Date and TimeStamp Time/Date */
        RTC_TimeShow();
        RTC_DateShow();
        RTC_TimeStampShow();
    }
}


void RTC_Config(void)
{
        RTC_InitTypeDef RTC_InitStructure;
  //使能电源时钟//
  RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);
        //使能后备区域时钟//
  RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_BKPSRAM, ENABLE);
        RTC_DeInit();
  //允许RTC后备后备寄存器读写权限//
  WR_BackupAccessCmd(ENABLE);
  //复位后备域//
//  RCC_BackupResetCmd(ENABLE);
//  RCC_BackupResetCmd(DISABLE);
  // 使能外部低速时钟/
  RCC_LSEConfig(RCC_LSE_ON);
  //等待低速时钟准备就绪/  
  while(RCC_GetFlagStatus(RCC_FLAG_LSERDY) == RESET)
  {
  }
  //选择外部低速时钟(LSE)作为RTC时钟源//
  RCC_RTCCLKConfig(RCC_RTCCLKSource_LSE); 
        //使能RTC//
        RCC_RTCCLKCmd(ENABLE); 
        //等待RTC APB 寄存器同步//
  RTC_WaitForSynchro();
        //Enable The TimeStamp
        RTC_TimeStampCmd(RTC_TimeStampEdge_Falling, ENABLE);
        RTC_WriteProtectionCmd(ENABLE);
        //配置RTC分频值        设置1Hz//
//        RTC->CR |= 0x0010;                                                                                                                                                                                                //基准时钟
  RTC_InitStructure.RTC_AsynchPrediv = 0x7F;                          //设置异步分频值
  RTC_InitStructure.RTC_SynchPrediv  = 0xFF;                         //设置同步分频值
  RTC_InitStructure.RTC_HourFormat   = RTC_HourFormat_24;             //设置时间格式为24小时制
  RTC_Init(&RTC_InitStructure);                                        //初始化RTC
        // 使能低电压时使用后备电池//
  WR_BackupRegulatorCmd(ENABLE);
//        RCC_BackupResetCmd(ENABLE);
        RCC_RTCCLKCmd(ENABLE);
  // 等待后备域低电压稳定器就绪 //
  while(PWR_GetFlagStatus(PWR_FLAG_BRR) == RESET)
  {
  }
   //向后备寄存器0写入0x5566用于标记已经配置过RTC//
//   RTC_WriteBackupRegister(RTC_BKP_DR0, 0X5566);                
}


void RTC_TimeStampRead(void)
{
//                RTC_Time RTC_Read;
        
                RTC_TimeTypeDef RTC_TimeStructure;
                RTC_DateTypeDef RTC_DateStructure;
        
                RTC_GetTime(RTC_Format_BIN,&RTC_TimeStructure);                                                //获取时间BCD码
                RTC_GetDate(RTC_Format_BIN,&RTC_DateStructure);                                                //获取日期BCD码
                BACK_COLOR = WHITE;
                POINT_COLOR = RED;

                LCD_ShowNum(56,100,RTC_DateStructure.RTC_Year,2,RED);
                LCD_ShowNum(104,100,RTC_DateStructure.RTC_Month,2,RED);
                LCD_ShowNum(160,100,RTC_DateStructure.RTC_Date,2,RED);
                LCD_ShowNum(72,120,RTC_DateStructure.RTC_WeekDay,2,RED);
                LCD_ShowNum(40,140,RTC_TimeStructure.RTC_Hours,2,RED);
                LCD_ShowNum(96,140,RTC_TimeStructure.RTC_Minutes,2,RED);
                LCD_ShowNum(136,140,RTC_TimeStructure.RTC_Seconds,2,RED);
}
int main(void)
{                 
        Clock_Config();                        //系统时钟设置 168M 此后可以设置超频输出到432MHz
        Delay_Init();
        LCD_Init();
        LED_Init();                                  //初始化与LED连接的硬件接口
        COM1Init(115200);
        DMA_Conf(USART_REC_LEN);
        DMA_NVIC_Init();
        USART_NVIC_Init();
        
//        RTC_AlarmConfig();
        Address_set(0,0,800,480);
        LCD_Clear(WHITE);
        LCD_ShowString(40,100,"20  year  month  data",1,BLUE);
        LCD_ShowString(40,120,"week  ",1,BLUE);
        LCD_ShowString(40,140,"  hours  min  sec",1,BLUE);
        if (SysTick_Config(SystemCoreClock / 1000))  //延时1毫秒
        { 
         /* Capture error */ 
                while (1);
        }
        while(1)
        {
                RTCTime_Test();
                RTC_TimeStampRead();
                Delay_ms(500);
//                LCD_Clear(WHITE);
        }
}
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
14条回答
CHENGJUN
1楼-- · 2019-07-21 18:54
哥们,给我发一份407的全部的资料好吗?我只有板子没有资料啊,谢谢
Lin_811
2楼-- · 2019-07-21 22:52
回复【7楼】林子:
---------------------------------
RTC_InitStructure.RTC_SynchPrediv  = 0xFF;                                
RTC_InitStructure.RTC_AsynchPrediv = 0x7F;                         
RTC_InitStructure.RTC_HourFormat   = RTC_HourFormat_24;     
我用这样直接赋值竟然不行,非得这样设置赋值如下:
__IO uint32_t AsynchPrediv = 0, SynchPrediv = 0;
RTC_InitStructure.RTC_AsynchPrediv = AsynchPrediv;
        RTC_InitStructure.RTC_SynchPrediv = SynchPrediv;
        RTC_InitStructure.RTC_HourFormat = RTC_HourFormat_24;
总在怀远
3楼-- · 2019-07-22 03:56
回复【4楼】正点原子:
---------------------------------
原子哥,有没有库函数版的RTC唤醒中断程序???拜谢
总在怀远
4楼-- · 2019-07-22 06:50
 精彩回答 2  元偷偷看……
注册个号来学习
5楼-- · 2019-07-22 07:18
回复【4楼】正点原子:
---------------------------------
原子哥,我在学RTC时发现一个问题:
用RTC_WAKE_UP中断控制LED1,用定时器中断控制LED1,都设置的是1秒钟发生一次中断,为什么板子测试时两个灯亮的有先后顺序,并且中间有事还不准。
为什么呢?原子哥,我哪个地方弄错了。
还有一个问题:
RTC_Set_WakeUp(RTC_WakeUpClock_CK_SPRE_16bits,0); //配置WAKE UP中断,1秒钟中断一次
这个函数后面那个设置装载值0,那么它的频率也是1HZ吗?
谢谢了,原子哥
正点原子
6楼-- · 2019-07-22 12:21
回复【12楼】注册个号来学习:
---------------------------------
定时器和RTC都控制LED1???
那不乱套了么?

RTC_Set_WakeUp,这个我们F4的教程都出来了,请下载<STM32F4开发指南>学习RTC实验,这个章节内容.

一周热门 更多>