您的位置 首页 模拟

Cortex-M3 (NXP LPC1788)之RTC

实时时钟是一组用于测量时间的计数器,如果使用电池供电,在系统掉电以后它也可以正常运行以记录系统的时间。LPC1788时钟采用内部的32K…

实时时钟是一组用于丈量时刻的计数器,假如运用电池供电,在体系掉电今后它也能够正常运转以记载体系的时刻。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. Uart2SendS(menu);
  115. while(flag_setTime);
  116. Uart2SendS(str);
  117. Display_Data();
  118. rCCR|=0x1;
  119. rCCR|=0x1<<4;
  120. rCIIR|=0x1;//秒值添加发生一次中止
  121. rAMR&=~(0x1<<0);//秒值与报警寄存器比较
  122. rALSEC=30;//秒值为30的时分发生一个报警
  123. rISER0|=0x1<<17;//使能RTC中止
  124. while(1);
  125. }

程序运转串口打印信息如下图:

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/zhishi/moni/265722.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部