STM32F4 RTC的使用

发布者:cw57324588最新更新时间:2017-09-11 来源: eefocus关键字:STM32F4  RTC 手机看文章 扫描二维码
随时随地手机看文章

比较F1的片子对于F4的RTC来说有很大提升,F4的RTC提供了日历时钟和两个可编程闹钟中断,一个周期性可编程唤醒标志。这样很方便设置系统时间,并不会像F1的RTC那样要自己计算年月日时分秒。F4的RTC是一个独立的BCD定时计数器,系统可以自动将月份天数补偿为28、29(闰年)、30、31天。并且还可以进行夏令时补偿。

由此可见RTC,下面贴出代码方便以后查看(这里特别提一下RTC_AlarmMask=RTC_AlarmMask_DateWeekDay;//屏蔽日期和星期后设置的日期和星期是无效的,RTC闹钟只会比较设置的时分秒,当时分秒匹配后触发闹钟中断。同样如果设置RTC_AlarmMask=RTC_AlarmMask_None;则为精确匹配,即闹钟不仅要求时分秒匹配还要匹配日期和星期,都匹配后触发闹钟中断)


  1. //代码来自正点原子  


  1. NVIC_InitTypeDef   NVIC_InitStructure;  

  2.   

  3. //RTC时间设置  

  4. //hour,min,sec:小时,分钟,秒钟  

  5. //ampm:@RTC_AM_PM_Definitions  :RTC_H12_AM/RTC_H12_PM  

  6. //返回值:SUCEE(1),成功  

  7. //       ERROR(0),进入初始化模式失败   

  8. ErrorStatus RTC_Set_Time(u8 hour,u8 min,u8 sec,u8 ampm)  

  9. {  

  10.     RTC_TimeTypeDef RTC_TimeTypeInitStructure;  

  11.       

  12.     RTC_TimeTypeInitStructure.RTC_Hours=hour;  

  13.     RTC_TimeTypeInitStructure.RTC_Minutes=min;  

  14.     RTC_TimeTypeInitStructure.RTC_Seconds=sec;  

  15.     RTC_TimeTypeInitStructure.RTC_H12=ampm;  

  16.       

  17.     return RTC_SetTime(RTC_Format_BIN,&RTC_TimeTypeInitStructure);  

  18.       

  19. }  

  20. //RTC日期设置  

  21. //year,month,date:年(0~99),月(1~12),日(0~31)  

  22. //week:星期(1~7,0,非法!)  

  23. //返回值:SUCEE(1),成功  

  24. //       ERROR(0),进入初始化模式失败   

  25. ErrorStatus RTC_Set_Date(u8 year,u8 month,u8 date,u8 week)  

  26. {  

  27.       

  28.     RTC_DateTypeDef RTC_DateTypeInitStructure;  

  29.     RTC_DateTypeInitStructure.RTC_Date=date;  

  30.     RTC_DateTypeInitStructure.RTC_Month=month;  

  31.     RTC_DateTypeInitStructure.RTC_WeekDay=week;  

  32.     RTC_DateTypeInitStructure.RTC_Year=year;  

  33.     return RTC_SetDate(RTC_Format_BIN,&RTC_DateTypeInitStructure);  

  34. }  

  35.   

  36. //RTC初始化  

  37. //返回值:0,初始化成功;  

  38. //       1,LSE开启失败;  

  39. //       2,进入初始化模式失败;  

  40. u8 RTC_Init(void)  

  41. {  

  42.     RTC_InitTypeDef RTC_InitStructure;  

  43.     u16 retry=0X1FFF;   

  44.     RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);//使能PWR时钟  

  45.     PWR_BackupAccessCmd(ENABLE);    //使能后备寄存器访问   

  46.       

  47.     if(RTC_ReadBackupRegister(RTC_BKP_DR0)!=0x5050)     //是否第一次配置?  

  48.     {  

  49.         RCC_LSEConfig(RCC_LSE_ON);//LSE 开启      

  50.         while (RCC_GetFlagStatus(RCC_FLAG_LSERDY) == RESET) //检查指定的RCC标志位设置与否,等待低速晶振就绪  

  51.             {  

  52.             retry++;  

  53.             delay_ms(10);  

  54.             }  

  55.         if(retry==0)return 1;       //LSE 开启失败.   

  56.               

  57.         RCC_RTCCLKConfig(RCC_RTCCLKSource_LSE);     //设置RTC时钟(RTCCLK),选择LSE作为RTC时钟      

  58.         RCC_RTCCLKCmd(ENABLE);  //使能RTC时钟   

  59.   

  60.             RTC_InitStructure.RTC_AsynchPrediv = 0x7F;//RTC异步分频系数(1~0X7F)  

  61.         RTC_InitStructure.RTC_SynchPrediv  = 0xFF;//RTC同步分频系数(0~7FFF)  

  62.             RTC_InitStructure.RTC_HourFormat   = RTC_HourFormat_24;//RTC设置为,24小时格式  

  63.             RTC_Init(&RTC_InitStructure);  

  64.    

  65.         RTC_Set_Time(23,59,56,RTC_H12_AM);  //设置时间  

  66.         RTC_Set_Date(14,5,5,1);     //设置日期  

  67.        

  68.         RTC_WriteBackupRegister(RTC_BKP_DR0,0x5050);    //标记已经初始化过了  

  69.     }   

  70.    

  71.     return 0;  

  72. }  

  73.   

  74. //设置闹钟时间(按星期闹铃,24小时制)  

  75. //week:星期几(1~7) @ref  RTC_Alarm_Definitions  

  76. //hour,min,sec:小时,分钟,秒钟  

  77. void RTC_Set_AlarmA(u8 hour,u8 min,u8 sec)  

  78. {   

  79.     EXTI_InitTypeDef   EXTI_InitStructure;  

  80.     RTC_AlarmTypeDef RTC_AlarmTypeInitStructure;  

  81.     RTC_TimeTypeDef RTC_TimeTypeInitStructure;  

  82.       

  83.     RTC_AlarmCmd(RTC_Alarm_A,DISABLE);//关闭闹钟A   

  84.       

  85.     RTC_TimeTypeInitStructure.RTC_Hours=hour;//小时  

  86.     RTC_TimeTypeInitStructure.RTC_Minutes=min;//分钟  

  87.     RTC_TimeTypeInitStructure.RTC_Seconds=sec;//秒  

  88.     RTC_TimeTypeInitStructure.RTC_H12=RTC_H12_AM;  

  89.     

  90.     RTC_AlarmTypeInitStructure.RTC_AlarmDateWeekDay=1;//星期  

  91.     RTC_AlarmTypeInitStructure.RTC_AlarmDateWeekDaySel=RTC_AlarmDateWeekDaySel_WeekDay;//按星期闹  

  92.     RTC_AlarmTypeInitStructure.RTC_AlarmMask=RTC_AlarmMask_DateWeekDay;//屏蔽日期和星期  

  93.     RTC_AlarmTypeInitStructure.RTC_AlarmTime=RTC_TimeTypeInitStructure;  

  94.     RTC_SetAlarm(RTC_Format_BIN,RTC_Alarm_A,&RTC_AlarmTypeInitStructure);  

  95.    

  96.       

  97.     RTC_ClearITPendingBit(RTC_IT_ALRA);//清除RTC闹钟A的标志  

  98.     EXTI_ClearITPendingBit(EXTI_Line17);//清除LINE17上的中断标志位   

  99.       

  100.     RTC_ITConfig(RTC_IT_ALRA,ENABLE);//开启闹钟A中断  

  101.     RTC_AlarmCmd(RTC_Alarm_A,ENABLE);//开启闹钟A   

  102.       

  103.     EXTI_InitStructure.EXTI_Line = EXTI_Line17;//LINE17  

  104.     EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;//中断事件  

  105.     EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising; //上升沿触发   

  106.     EXTI_InitStructure.EXTI_LineCmd = ENABLE;//使能LINE17  

  107.     EXTI_Init(&EXTI_InitStructure);//配置  

  108.   

  109.     NVIC_InitStructure.NVIC_IRQChannel = RTC_Alarm_IRQn;   

  110.     NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x02;//抢占优先级1  

  111.     NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x02;//子优先级2  

  112.     NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;//使能外部中断通道  

  113.     NVIC_Init(&NVIC_InitStructure);//配置  

  114. }  

  115.   

  116. //周期性唤醒定时器设置    

  117. /*wksel:  @ref RTC_Wakeup_Timer_Definitions 

  118. #define RTC_WakeUpClock_RTCCLK_Div16        ((uint32_t)0x00000000) 

  119. #define RTC_WakeUpClock_RTCCLK_Div8         ((uint32_t)0x00000001) 

  120. #define RTC_WakeUpClock_RTCCLK_Div4         ((uint32_t)0x00000002) 

  121. #define RTC_WakeUpClock_RTCCLK_Div2         ((uint32_t)0x00000003) 

  122. #define RTC_WakeUpClock_CK_SPRE_16bits      ((uint32_t)0x00000004) 

  123. #define RTC_WakeUpClock_CK_SPRE_17bits      ((uint32_t)0x00000006) 

  124. */  

  125. //cnt:自动重装载值.减到0,产生中断.  

  126. void RTC_Set_WakeUp(u32 wksel,u16 cnt)  

  127. {   

  128.     EXTI_InitTypeDef   EXTI_InitStructure;  

  129.       

  130.     RTC_WakeUpCmd(DISABLE);//关闭WAKE UP  

  131.       

  132.     RTC_WakeUpClockConfig(wksel);//唤醒时钟选择  

  133.       

  134.     RTC_SetWakeUpCounter(cnt);//设置WAKE UP自动重装载寄存器  

  135.       

  136.       

  137.     RTC_ClearITPendingBit(RTC_IT_WUT); //清除RTC WAKE UP的标志  

  138.     EXTI_ClearITPendingBit(EXTI_Line22);//清除LINE22上的中断标志位   

  139.        

  140.     RTC_ITConfig(RTC_IT_WUT,ENABLE);//开启WAKE UP 定时器中断  

  141.     RTC_WakeUpCmd( ENABLE);//开启WAKE UP 定时器   

  142.       

  143.     EXTI_InitStructure.EXTI_Line = EXTI_Line22;//LINE22  

  144.     EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;//中断事件  

  145.     EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising; //上升沿触发   

  146.     EXTI_InitStructure.EXTI_LineCmd = ENABLE;//使能LINE22  

  147.     EXTI_Init(&EXTI_InitStructure);//配置  

  148.    

  149.    

  150.     NVIC_InitStructure.NVIC_IRQChannel = RTC_WKUP_IRQn;   

  151.     NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x02;//抢占优先级1  

  152.     NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x02;//子优先级2  

  153.     NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;//使能外部中断通道  

  154.     NVIC_Init(&NVIC_InitStructure);//配置  

  155. }  

  156.   

  157. //RTC闹钟中断服务函数  

  158. void RTC_Alarm_IRQHandler(void)  

  159. {      

  160.     if(RTC_GetFlagStatus(RTC_FLAG_ALRAF)==SET)//ALARM A中断?  

  161.     {  

  162.         RTC_ClearFlag(RTC_FLAG_ALRAF);//清除中断标志  

  163.         printf("ALARM A!\r\n");  

  164.     }     

  165.     EXTI_ClearITPendingBit(EXTI_Line17);    //清除中断线17的中断标志                                             

  166. }  


关键字:STM32F4  RTC 引用地址:STM32F4 RTC的使用

上一篇:STM32 USB的DFU功能
下一篇:STM32F407的RTC时间

推荐阅读最新更新时间:2024-03-16 15:36

STM32F4_RCC系统时钟配置及描述
Ⅰ、概述 对于系统时钟应该都知道它的作用,就是驱动整个芯片工作的心脏,如果没有了它,就等于人没有了心跳。 对于使用开发板学习的朋友来说,RCC系统时钟这一块知识估计没怎么去配置过,原因在于开发板提供的晶振基本上都是官方标准的时钟频率,使用官方的标准库,这样系统时钟就是默认的配置,也就是默认的频率。但对于自己设计开发板,或者想要改变系统时钟频率(如:降低功耗就需要降频)的朋友来说,配置系统时钟就有必要了。 关于时钟这一块对定时器(TIM、RTC、WDG等)相关的外设也比较重要,因为要求精准,就需要时钟频率精准。 该文将描述关于系统时钟配置及注意的相关事项,更多详情内容,请往下看。 本着免费分享的原则,方便大家手机学习知识,定期在
[单片机]
<font color='red'>STM32F4</font>_RCC系统时钟配置及描述
stm32F4编码器测速并通过串口打印--- 程序源码
一、使用cubeMX软件对程序需要使用的端口和资源进行初始化。 为了保持程序的简洁性,这里仅使用一个串口和一路通用定时器。 (1)引脚的初始化 注:在引脚配置这里,是没有编码器模式的,不知道为什么。高级寄存器是由combined channels选项的。 这里先暂时选择为Input Capture direct mode,后面在针对具体的代码进行修改即可。 (2)时钟的配置 (3)串口资源的配置 (4)定时器的配置 (5)中断的配置 这里不适用串口来接收数据,所以串口的中断也不用打开。这里需要打开定时器的中断,在定时器发生上下计数溢出时,需要对进行记录,保证记录的准确性。 (6)最后生成的定时器初始化代码如下:
[单片机]
HAL库-STM32F4 HAL_GPIO_Init()
以下使用ST的HAL_GPIO_Init()函数举例。 在ST官方库中,我们可以找到对于某个GPIO初始化的函数 HAL_GPIO_Init() void HAL_GPIO_Init(GPIO_TypeDef *GPIOx, GPIO_InitTypeDef *GPIO_Init) { uint32_t position; uint32_t ioposition = 0x00; uint32_t iocurrent = 0x00; uint32_t temp = 0x00; /* Check the parameters */ assert_param(IS_GPIO_ALL_INSTANCE(GPIOx)
[单片机]
STM32F411 Discovery学习笔记(二)点亮你的第一个LED
对于开发板来说,点亮第一个LED可能就像程序里的HELLO WORLD!一样重要吧。 由于缺少资源,点亮这个LED浪费了我两天的宝贵时光,也没能成功,后来想到了老师一直强调的要看芯片手册和原理图,想想LED应该也不难,那么从零应该也是可以的。 对于STM32来说最难的是配置底层文件了,然而STM32CUBEMX可以帮助我们完成这一项操作,关于STM32CUBEMX的使用方法网上有好多,然而我竟然在B站搜索到了视频教程!而且讲的也很好! 接下来要说的内容是对B站UP主的现学现卖和自己的一些补充。 首先你需要找到原理图和芯片手册 不说废话直接放连接 https://www.st.com/content/st_com/en/prod
[单片机]
<font color='red'>STM32F4</font>11 Discovery学习笔记(二)点亮你的第一个LED
STM32F429 >> 16. WWDG_窗口看门狗
窗口看门狗和独立看门狗最大的不同就是,独立看门狗的喂狗限制是在计数器递减为零前,而窗口看门狗的喂狗限制则是在一个窗口期内,即喂狗时间必须在一个时间段内,在狗饱腹时和饥饿时喂狗都会触发复位 这个窗口期的下限为0x40,上限小于或等于0x7F RLR 是重装载寄存器,用来设置独立看门狗的计数器的值。TR 是窗口看门狗的计数器的值,由用户独立设置,WR 是窗口看门狗的上窗口值,由用户独立设置。 WWDG 功能框图 ①. 窗口看门狗时钟 窗口看门狗时钟来自 PCLK1,PCLK1 最大是 45M,由 RCC 时钟控制器开启。 ②. 计数器时钟 计数器时钟由 CK 计时器时钟经过预分频器分频得到,分频系数由配置寄存器
[单片机]
<font color='red'>STM32F4</font>29 >> 16. WWDG_窗口看门狗
stm32f4的IWDG和WWDG(HAL库版本)
看门狗原理: 单片机系统在外界的干扰下会出现程序跑飞的现象导致出现死循环,看门狗电路就是为了避免这种情况的发生。 看门狗的作用:就是在一定时间内(通过定时计数器实现)没有接收喂狗信号(表示 MCU 已经挂了),便实现处理器的自动复位重启(发送复位信号) 。 独立看门狗和窗口看门狗的区别(F4版本): 1、相同点 都是为了防止CPU跑飞 2、独立看门狗 根据内部看门狗时钟频率,装载寄存器定一个时间值,比如是1000,那么独立看门狗就会按照时钟频率,从1000开始向下每隔一个时钟周期减1,如果在减到0之前,你用程序代码重新向向下计数器里面写1000(喂狗),那么定时器会重新从1000开始向下递减。如果在减到
[单片机]
<font color='red'>stm32f4</font>的IWDG和WWDG(HAL库版本)
STM32 RTC设置日期失败(重启后生效)的解决方法
调试STM32F429的RTC时钟时遇到了如下问题: RTC设置日期时会延迟一段时间(几秒)或重启后才生效。 分析过程: 1、分析发现原程序在RTC的WAKEUP中断里读取时间和日期,后关闭此中断,在while循环中轮询读取,再设置日期,发现可以立即生效。所以猜测在WAKEUP中断里读取日期会对日期设置产生影响。 2、重新打开WAKEUP中断,并删除其中的日期读取函数,发现可以正常设置日期。 解决方法: 1、使用WAKEUP中断读取时间,轮询读取日期。 2、不使用WAKEUP中断,轮询读取时间和日期。
[单片机]
测试STM32F4中断向量表移到内部RAM对中断响应速度的影响
测试环境:STM32F407 168MHz,IAR 7.4,优化级别low 测试方法:第一个信号是TIM比较器的输出,同时产生比较器中断。中断服务程序里第一句就立即拉高一个GPIO,示波器查两个信号的延迟大致了解中断响应速度。 中断向量表在Flash,中断服务程序在Flash,延迟约155ns: 中断向量表在内部RAM,中断服务程序在Flash,少了约20ns 中断向量表在内部RAM,中断服务程序在内部RAM,看起来没多大区别: 说明:这个测试方法中断响应延时并不准确,因为GPIO拉高至少要两条指令,还加上总线访问延迟和GPIO输出延时。不过也还是能得到自己想要的结果:中断发生到执行结果要多长时间。
[单片机]
测试<font color='red'>STM32F4</font>中断向量表移到内部RAM对中断响应速度的影响
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved