S3C2440拥有一个实时时钟模块, 可以在当系统电源关闭后通过备用电池工作。RTC可以通过使用STRB/LDRB ARM操作发送8位二-十进制交换码(BCD)值数据给CPU。这些数据包括年、月、日、星期、时、分和秒的时间信息。RTC单元工作在外部32.768kHz晶振并且可以执行闹钟功能

实时时钟模块保存的数据是DCD码形式.

框图如下

可以看到,要使用实时时钟依靠以下几个寄存器

包含时钟使能和时钟复位(还有两个寄存器是测试模式,我们用不到)

关联着时钟节拍中断,也就是每增加1S发生一次中断

时钟中断,时钟的时分秒年月日都是可以进行使能的

接下来是时分秒年月日闹钟点设置

有六个就不一一列举了,意思是当到达这个时间点时发生中断,比如我设置23秒发生中断,那么每一分钟的23秒都会中断一次

还要注意,因为使用的是BCD计数,所以对时钟的读取,写入都要进行BCD码的转换,否则数据不对哦

详细查看代码

#include "rtc.h"

char *week_num[7]={ "SUN","MON", "TUES", "WED", "THURS","FRI", "SAT" };

RTC_TIMER rtcTimer ;

ALARM_TIMER alarmTimer ;

/********************************
*
* TICK中断
*
*********************************/
void __irq RTC_tickHandler(void)
{
rSRCPND |= BIT_TICK;//清除源挂起
rINTPND |= BIT_TICK;//清除中断挂起
RTCGetValue();
printf("current year %d mouth %d day %d hour %d minute %d sec %d\r\n",rtcTimer.year,\
rtcTimer.month,rtcTimer.day,rtcTimer.hour,rtcTimer.minute,rtcTimer.second);
} /********************************
*
* alarm闹钟中断
*
*********************************/
void __irq RTC_alarmHandler(void)
{
rSRCPND |= BIT_RTC;//清除源挂起
rINTPND |= BIT_RTC;//清除中断挂起 printf("alarm int happend\r\n");
} //rtc获取时间
void RTCGetValue(void)
{
u8 temp = 0,cover = 0;
rRTCCON |= 0x01; //RTC读写使能,BCD时钟、计数器、无复位
temp = rBCDYEAR;
temp = ((temp/16)*10)+(temp%16);
rtcTimer.year = temp+YEAR_BASE; temp = rBCDMON;
temp = ((temp/16)*10)+(temp%16);
rtcTimer.month = temp; temp = rBCDDATE;
temp = ((temp/16)*10)+(temp%16);
rtcTimer.day = temp; temp = rBCDDAY;
temp = ((temp/16)*10)+(temp%16);
rtcTimer.weekDay = temp; temp = rBCDHOUR;
temp = ((temp/16)*10)+(temp%16);
rtcTimer.hour = temp; temp = rBCDMIN;
temp = ((temp/16)*10)+(temp%16);
rtcTimer.minute = temp; temp = rBCDSEC;
temp = ((temp/16)*10)+(temp%16);
rtcTimer.second = temp; rRTCCON &= ~(1<<0); //RTC读写禁止,BCD时钟、计数器、无复位
} void RTCSetValue(void)
{
u8 temp;
rRTCCON |= 0x01; //RTC读写使能,BCD时钟、计数器、无复位 temp = rtcTimer.year - YEAR_BASE;
temp = ((temp/10)*16)+(temp%10);
rBCDYEAR = temp; temp = rtcTimer.month;
temp = ((temp/10)*16)+(temp%10);
rBCDMON = temp; temp = rtcTimer.day;
temp = ((temp/10)*16)+(temp%10);
rBCDDATE = temp; temp = rtcTimer.weekDay;
temp = ((temp/10)*16)+(temp%10);
rBCDDAY = temp; temp = rtcTimer.hour;
temp = ((temp/10)*16)+(temp%10);
rBCDHOUR = temp; temp = rtcTimer.minute;
temp = ((temp/10)*16)+(temp%10);
rBCDMIN = temp; temp = rtcTimer.second;
temp = ((temp/10)*16)+(temp%10);
rBCDSEC = temp; rRTCCON &= ~(1<<0); //RTC读写禁止,BCD时钟、计数器、无复位
} void RtcSetAlarm(void)
{
u8 temp;
rRTCCON |= 0x01; //RTC读写使能,BCD时钟、计数器、无复位 temp = alarmTimer.year - YEAR_BASE;
temp = ((temp/10)*16)+(temp%10);
rALMYEAR = temp; temp = alarmTimer.month;
temp = ((temp/10)*16)+(temp%10);
rALMMON = temp; temp = alarmTimer.day;
temp = ((temp/10)*16)+(temp%10);
rALMDATE = temp; temp = alarmTimer.hour;
temp = ((temp/10)*16)+(temp%10);
rALMHOUR = temp; temp = alarmTimer.minute;
temp = ((temp/10)*16)+(temp%10);
rALMMIN = temp; temp = alarmTimer.second;
temp = ((temp/10)*16)+(temp%10);
rALMSEC = temp; rRTCALM = 0x41; //RTC闹钟控制寄存器,启动秒中断和总中断 rRTCCON &= ~(1<<0); //RTC读写禁止,BCD时钟、计数器、无复位
} void RtcInit(u8 tick)
{
rtcTimer.year = 2014;
rtcTimer.month = 10;
rtcTimer.day = 10;
rtcTimer.weekDay = 5;
rtcTimer.hour = 16;
rtcTimer.minute = 34;
rtcTimer.second = 52;
alarmTimer.year = 2014;
alarmTimer.month = 10;
alarmTimer.day = 10;
alarmTimer.weekDay = 5;
alarmTimer.hour = 16;
alarmTimer.minute = 34;
alarmTimer.second = 52;
rRTCCON = 0x01;
rTICNT=(tick&0x7f)|0x80; //使能中断 RTCSetValue();//设置时间
RtcSetAlarm();//设置闹钟
//开启中断
pISR_RTC = (unsigned)RTC_alarmHandler;
pISR_TICK=(unsigned)RTC_tickHandler; //中断函数入口地址 rSRCPND |= BIT_RTC;//清除源挂起
rINTPND |= BIT_RTC;//清除中断挂起
rINTMOD &= ~BIT_RTC;//设置中断模式为IRQ模式 rSRCPND |= BIT_TICK;//清除源挂起
rINTPND |= BIT_TICK;//清除中断挂起
rINTMOD &= ~BIT_TICK;//设置中断模式为IRQ模式 rINTMSK &= ~BIT_RTC; //开中断
rINTMSK &= ~BIT_TICK; //开中断 }
#ifndef __RTC_H
#define __RTC_H
#include "2440addr.h"
#include "def.h"
#include "uart0.h" #define YEAR_BASE 2000 typedef struct RTC_TIMER
{
u16 year;
u8 month;
u8 day;
u8 weekDay;
u8 hour;
u8 minute;
u8 second;
}RTC_TIMER; typedef struct ALARM_TIMER
{
u16 year;
u8 month;
u8 day;
u8 weekDay;
u8 hour;
u8 minute;
u8 second;
}ALARM_TIMER; extern struct RTC_TIMER rtcTimer; void RTCGetValue(void); void RTCSetValue(void); void RtcSetAlarm(void); void RtcInit(u8 tick); #endif

S3C2440的RTC解析的更多相关文章

  1. S3C2440上RTC时钟驱动开发实例讲解(转载)

    嵌入式Linux之我行,主要讲述和总结了本人在学习嵌入式linux中的每个步骤.一为总结经验,二希望能给想入门嵌入式Linux的朋友提供方便.如有错误之处,谢请指正. 共享资源,欢迎转载:http:/ ...

  2. s3c2440 的 rtc 操作

    实时时钟(RTC)其主要功能是电源故障的制度下,使用后备电源,时钟继续.为了不浪费时间信息. s3c2440内部集成了RTC模块,并且用起来也十分简单. 其内部的寄存器BCDSEC,BCDMIN,BC ...

  3. S3C2440硬件连接解析

    S3c2440是三星公司推出的一款基于ARM920T的处理器,采用ARM内核,不同于单片机,无片上rom与ram,必须搭配相应的外围电路进行使用,现在,让我们从零开始进行这一块MCU的学习,为了入门简 ...

  4. S3C2440的SPI解析

    位串行数据的频率.如果只希望发送,则接收数据可以保持伪位(dummy).此外如果只希望接收,则需要发送伪位'1'数据 使用SPI主要需要以下寄存器 选择SPI模式,中断模式,查询模式等SCK选择,主从 ...

  5. S3C2440看门狗解析

    个PCLK周期的复位信号 也就是说,在某些环境下,看门狗可以当做定时器使用,当他中断的时候并不发生复位,只发生中断,我看看图 看门狗的中断和复位信号是可以依靠wtcon来切断的(看门狗的时钟是无法切断 ...

  6. 应用程序 /dev/rtc 编程 获取时间 2011-12-13 01:01:06【转】

    本文转载自:http://blog.chinaunix.net/uid-16785183-id-3040310.html 分类: 原文地址:应用程序 /dev/rtc 编程 获取时间 作者:yuwei ...

  7. [nRF51822] 10、基础实验代码解析大全 · 实验15 - RTC

    一.实验内容: 配置NRF51822 的RTC0 的TICK 频率为8Hz,COMPARE0 匹配事件触发周期为3 秒,并使能了TICK 和COMPARE0 中断. TICK 中断中驱动指示灯D1 翻 ...

  8. 关于在Arduino下STM32编程——RTC函数解析

    注意:相关RTC基础知识这里不提! 该库头文件引用: #include <RTClock.h>   该库所在Arduino位置: 初始化RTC相关时钟 Arduino版的库里初始化配置PW ...

  9. S3C2440启动代码2440init.s彻底解析

    可以选择nand启动和nor启动,这两者之间的关系通过一个按键来选择 这个OM0有何玄机,在数据手册中有这么一段 位宽RAM启动了(当然,还得设置一些东西,下面就说), Nanaflash启动经历的过 ...

随机推荐

  1. 内联函数 inline 漫谈

    内联函数存在的结论是: 引入内联函数是为了解决函数调用效率的问题 由于函数之间的调用,会从一个内存地址调到另外一个内存地址,当函数调用完毕之后还会返回原来函数执行的地址.函数调用会有一定的时间开销,引 ...

  2. %3f URL --> '?'拼接引发的问题

    转载自:https://www.reddit.com/r/swift/comments/2w19kp/how_do_you_send_a_through_nsmutableurlrequest/ ho ...

  3. JSON文件存入MySQL数据库

    目标:将不同格式的JSON文件存入MySQL数据库 涉及的点有: 1. java处理JSON对象,直接见源码. 2. java.sql.SQLException: Incorrect string v ...

  4. Python基础学习3---数据结构

    数据结构 数据结构基本上就是---他们是可以处理数据的结构或者说他们是用来存储一组相关数据的. 在python中有三种内建的数据结构-----列表.元组和字典 列表(list) 列表就像是我们要去超市 ...

  5. unit正交相机Size的计算公式

    如:相机的大小为800*480,要使相机适应800*480像素的图,则 Size = 相机高/2/像素单位 = 480/2/100 = 2.4

  6. HDU 3966 Aragorn's Story 动态树 树链剖分

    Aragorn's Story Time Limit: 10000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  7. Android Studio的使用(五)--导入第三方Jar包

    本篇博文将介绍一下如何导入第三方Jar包. 1.首先将下载的Jar包直接Copy到libs目录下面,然后右击Jar文件,点击Add As Library后,在出现的弹出框点击确定即可. 2.打开bui ...

  8. 【栈】 poj 1363

    poj1363,这道题是数据结构与算法中的经典问题,给定一组进栈顺序,问栈有多少种出去的顺序. #include<stdio.h> #include <stack> #incl ...

  9. android脚步---将layout和其输出一起保存成图片

    public void convertViewToBitmap(View view) { //View view = getLayoutInflater().inflate(R.layout.test ...

  10. CodeForces 139C Literature Lesson(模拟)

    这个题,读懂了就是水,读不懂就没办法下手,论英语阅读的重要性...只有五种形式,第一种万能型aaaa,是另外3种的特殊情况,第二种克莱里林四行打油诗aabb形式,第三种是交替的abab形式,第四种是封 ...