微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > Cortex-M3 (NXP LPC1788)之RTC

Cortex-M3 (NXP LPC1788)之RTC

时间:11-19 来源:互联网 点击:
实时时钟是一组用于测量时间的计数器,如果使用电池供电,在系统掉电以后它也可以正常运行以记录系统的时间。LPC1788时钟采用内部的32K振荡器输出1HZ的时钟信号做为RTC的时钟源。

RTC的寄存器比较简单,主要有时钟计数器寄存器包括秒SEC 分MIN 小时HOUR 日期(月)DOM 星期DOW 日期(年)DOY 月MONTH 年YEAR, 这些寄存器为R/W 可以从中读出具体的时间信息。其中的秒计数由1HZ时钟驱动。报警寄存器组中的值将和时间计数器寄存器中的值比较,如果所有为屏蔽的报警寄存器都与他们对应的时间计数器相匹配,那么将产生一次中断。报警屏蔽在报警屏蔽寄存器AMR中设置。中断设置在中断位置寄存器ILR中设置。RTC中断不仅可以在报警寄存器和时间计数器匹配时产生,我们也可以配置计数器增量中断寄存器CIIR,使计数器每增加1就产生一次中断。RTC的控制在时钟控制寄存器CCR中,我们可以使能或禁止时钟,以及复位等。

在下面的程序中,首先PC端使用串口软件发送一串固定格式的时间信息给开发板,开发板收到字符‘a’表示后面跟着的是时间信息,设置了初始时间后,我们配置CCIR使1秒产生一次中断,配置报警寄存器组合报价屏蔽寄存器,使秒计数为30的时候产生中断。在RTC的中断函数中,如果是计数中断,就让接LED的GPIO输出反向电平,根据设置LED灯将1S闪烁。 如果是报警中断,就通过串口在PC打印时间信息。

注意:为了程序的简洁,省去了之前介绍了的系统时钟配置和串口的配置。具体的信息可查询之前的文章。

  1. #include"LPC1788_REG.h"
  2. #include"uart.h"
  3. #definerILR(*(volatileunsigned*)0x40024000)
  4. #definerCCR(*(volatileunsigned*)0x40024008)
  5. #definerCIIR(*(volatileunsigned*)0x4002400C)
  6. #definerAMR(*(volatileunsigned*)0x40024010)
  7. #definerCALIBRATION(*(volatileunsigned*)0x40024040)
  8. #definerYEAR(*(volatileunsigned*)0x4002403C)
  9. #definerMONTH(*(volatileunsigned*)0x40024038)
  10. #definerDOM(*(volatileunsigned*)0x4002402C)
  11. #definerHOUR(*(volatileunsigned*)0x40024028)
  12. #definerMIN(*(volatileunsigned*)0x40024024)
  13. #definerSEC(*(volatileunsigned*)0x40024020)
  14. #definerALSEC(*(volatileunsigned*)0x40024060)
  15. #definerCTIME0(*(volatileunsigned*)0x40024014)
  16. #definerCTIME1(*(volatileunsigned*)0x40024018)
  17. #definerCTIME2(*(volatileunsigned*)0x4002401C)
  18. unsignedcharflag_setTime=1;
  19. unsignedcharflag_receiveStatus=0;
  20. unsignedchartimeData[14],cnt;
  21. voidSet_Data()
  22. {
  23. rCCR&=~(0x1<0);
  24. rYEAR=(timeData[0]-0)*1000+(timeData[1]-0)*100+(timeData[2]-0)*10+(timeData[3]-0);
  25. rMONTH=(timeData[4]-0)*10+(timeData[5]-0);
  26. rDOM=(timeData[6]-0)*10+(timeData[7]-0);
  27. rHOUR=(timeData[8]-0)*10+(timeData[9]-0);
  28. rMIN=(timeData[10]-0)*10+(timeData[11]-0);
  29. rSEC=(timeData[12]-0)*10+(timeData[13]-0);
  30. }
  31. voidDisplay_Data()
  32. {
  33. Uart2SendC(\n);
  34. Uart2SendC(rYEAR/1000+0);
  35. Uart2SendC(rYEAR%1000/100+0);
  36. Uart2SendC(rYEAR%100/10+0);
  37. Uart2SendC(rYEAR%10+0);
  38. Uart2SendC(-);
  39. Uart2SendC(rMONTH/10+0);
  40. Uart2SendC(rMONTH%10+0);
  41. Uart2SendC(-);
  42. Uart2SendC(rDOM/10+0);
  43. Uart2SendC(rDOM%10+0);
  44. Uart2SendC(\n);
  45. Uart2SendC(rHOUR/10+0);
  46. Uart2SendC(rHOUR%10+0);
  47. Uart2SendC(:);
  48. Uart2SendC(rMIN/10+0);
  49. Uart2SendC(rMIN%10+0);
  50. Uart2SendC(:);
  51. Uart2SendC(rSEC/10+0);
  52. Uart2SendC(rSEC%10+0);
  53. }
  54. voidUART2_IRQHandler()
  55. {
  56. unsignedintintId;
  57. chartmp_char;
  58. intId=rU2IIR&0xf;
  59. if(intId==0xc||intId==0x4)//RDA或者CTI中断
  60. {
  61. rU2LCR&=~(0x1<7);//DLAB=0
  62. tmp_char=rU2RBR&0xff;
  63. rU2THR=tmp_char;
  64. }
  65. if(tmp_char==a&&flag_receiveStatus==0)
  66. {
  67. flag_receiveStatus=1;
  68. cnt=0;
  69. }
  70. elseif(flag_receiveStatus==1)
  71. {
  72. timeData[cnt]=tmp_char;
  73. cnt++;
  74. if(cnt==14)
  75. {
  76. Set_Data();
  77. cnt=0;
  78. flag_receiveStatus=0;
  79. flag_setTime=0;
  80. }
  81. }
  82. }
  83. voidRTC_IRQHandler()
  84. {
  85. unsignedcharIntStatus;
  86. IntStatus=rILR;
  87. if(IntStatus&0x1)//计数中断
  88. {
  89. rFIO1PIN=~rFIO1PIN;
  90. rILR=IntStatus;
  91. }
  92. elseif(IntStatus&(0x1<1))//报警中断
  93. {
  94. Display_Data();
  95. rILR=IntStatus;
  96. }
  97. }
  98. voidInit_RTC()
  99. {
  100. rILR=0;
  101. rCCR=0;
  102. rCIIR=0;
  103. rAMR=0xff;
  104. rCALIBRATION=0;
  105. rCCR|=0x1<1;//CTCReset
  106. rCCR&=~(0x1<1);
  107. }
  108. intmain(void)
  109. {
  110. charmenu[]={"\n\r===>Sendaframewith6BytedatatosetRTC\n[a]+[year]+[month]+[day]+[hour]+[minute]+[second]\n"};
  111. charstr[]={"\r\nTimesetok!\r\nCurrenttimesetto:\r\n"};
  112. rFIO1DIR|=(1<18);//GPIO1.18->OUTPUT
  113. Init_Uart2();
  114. Uart2Se

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top