zoukankan      html  css  js  c++  java
  • STM32F4 RTC【使用库函数】

    F4的RTC与F1的RTC有很大的差别。F1系列的RTC就是一个简单的计数器,要想获得时间,得自己计算。F4的就不需要这么麻烦了,读出来的直接就是时间。

    【主要特点】

    STM32F4的RTC是一个独立的BCD/时钟计数器。RTC提供时间日历和两路闹钟中断,一个具有中断能力的周期可编程的环形标志。他哦南方是RTC还具有管理低功耗模式的唤醒单元。

    RTC的秒、分、小时、日期、月、年以BCD码的形式存储在一个32位寄存器中。

    每月的天数自动处理,同时还具有日间省电功能。可编程的闹钟信息存储在另一个寄存器中。

    数字标定(校准)功能,可用于处理晶振的偏差

    上电时,RTC寄存器被保护以防止误写入数据。

    不论MCU处于那种工作模式,只要供电电压在可操作范围,RTC就不会停止。

    【RTC时钟】

    RTC时钟可以使用LSE、LSI和不大于1M的HSE作为时钟,对时钟分频可得到1HZ的时钟供RTC使用。

    本实验DISCOVERY板子上没有LSE,外接晶振8M,也不能用。做RTC实验只能使用LSI时钟。

    这个实验首先应使能LSI时钟。并将LSI时钟设置成RTC时钟。被操作是通过RCC设置的,在RTC部分没有配置这个的寄存器:

    RCC_LSICmd(ENABLE);
    while(RCC_GetFlagStatus(RCC_FLAG_LSIRDY) == RESET);
    RCC_RTCCLKConfig(RCC_RTCCLKSource_LSI);

    RCC_RTCCLKCmd(ENABLE);
    RTC_WaitForSynchro();

    【RTC初始化】

    上电时,RTC寄存器写保护。要打开写操作,需要向RTC_WPR寄存器中写一个序列。先写入0xCA,再写入0x53即可关闭写保护。写别的数据将关闭写保护,比如写入0x00等。

    日历初始化和配置

    按照以下步骤设置RTC的时间日期以及对时钟输入的预分频:

    1、设置初始化和状态寄存器RTC_ISR中的INIT为为1进入初始化模式。在这个模式下,RTC时间寄存器计数停止,可被更新

    2、判断RTC_ISR中的INITF位,判断RTC是否已经被初始化过。当读出数据为1时,即可进入初始化模式。这个过程将持续大约两个RTC时钟周期

    3、为了得到1Hz的计数器时钟,先对RTC_PRER寄存器中的同步分频值PREDIV_S[14:0]进行设置再对该寄存器中的一部分频值PREDIV_A[6:0]进行设置。即使只有一个分频值需要写入,另一个分频值也需要再写入一遍。

    4、将要设置的时间和日期写入RTC_CR和RTC_DR的影子寄存器,在RTC_CR中设置时间格式。

    5、向INTI位写入0,退出初始化模式。这是,RTC_DR和RTC_CR就会将日期信息从影子寄存器中加载到寄存器中,并在4个RTC时钟周期后自动开始运行。

    实现代码如下:

    void RTC_Config(void)
    {
      RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR,ENABLE);
      PWR_BackupAccessCmd(ENABLE);//使能备份寄存器操作
     
      RCC_LSICmd(ENABLE);
        while(RCC_GetFlagStatus(RCC_FLAG_LSIRDY) == RESET);
        RCC_RTCCLKConfig(RCC_RTCCLKSource_LSI);
        RCC_RTCCLKCmd(ENABLE);
        RTC_WaitForSynchro();
     
      if(RTC_ReadBackupRegister(RTC_BKP_DR0) != 0x9527)   //一个变量,看看RTC初始化没
      {
       
        RTC_WriteProtectionCmd(DISABLE);
     
        RTC_EnterInitMode();
        RTC_InitStructure.RTC_HourFormat = RTC_HourFormat_24;
        RTC_InitStructure.RTC_AsynchPrediv = 0x7D-1;
        RTC_InitStructure.RTC_SynchPrediv = 0xFF-1;
        RTC_Init(&RTC_InitStructure);
     
        RTC_TimeStructure.RTC_Seconds = 0x00;
        RTC_TimeStructure.RTC_Minutes = 0x01;
        RTC_TimeStructure.RTC_Hours = 0x01;
        RTC_TimeStructure.RTC_H12 = RTC_H12_AM;
        RTC_SetTime(RTC_Format_BCD,&RTC_TimeStructure);
     
        RTC_DateStructure.RTC_Date = 30;
        RTC_DateStructure.RTC_Month = 5;
        RTC_DateStructure.RTC_WeekDay= RTC_Weekday_Thursday;
        RTC_DateStructure.RTC_Year = 12;
        RTC_SetDate(RTC_Format_BCD,&RTC_DateStructure);
     
        RTC_ExitInitMode();
        RTC_WriteBackupRegister(RTC_BKP_DR0,0X9527);
        RTC_WriteProtectionCmd(ENABLE);
        RTC_WriteBackupRegister(RTC_BKP_DR0,0x9527);  //初始化完成,设置标志
      }
      PWR_BackupAccessCmd(DISABLE);
    }

    编译运行,在主函数中使用RTC_GetTime读取时间。跟踪到这里可以看到时间在变化

    以后只要每次用RTC_GetTime就可以读取时间了。

    要设置时间,只需要用RTC_SetTime就行了,RTC_GetTime函数自己会打开写保护。

  • 相关阅读:
    A Bayesian Approach to Deep Neural Network Adaptation with Applications to Robust Automatic Speech Recognition
    nnet3的代码分析
    Kaldi中的L2正则化
    HMM拓扑与转移模型
    Kaldi阅读并更改代码
    nnet3中的数据类型
    nnet3配置中的“编译”
    Kaldi的delta特征
    Kaldi的交叉熵正则化
    【搜索】 Prime Path
  • 原文地址:https://www.cnblogs.com/zyqgold/p/RTC.html
Copyright © 2011-2022 走看看