s3c2440的rtc操作

发布者:快乐舞动最新更新时间:2024-08-30 来源: cnblogs关键字:s3c2440  rtc操作  寄存器 手机看文章 扫描二维码
随时随地手机看文章

实时时钟(RTC)其主要功能是电源故障的制度下,使用后备电源,时钟继续。为了不浪费时间信息。


s3c2440内部集成了RTC模块,并且用起来也十分简单。


其内部的寄存器BCDSEC,BCDMIN,BCDHOUR,BCDDAY。BCDDATE,BCDMON和BCDYEAR分别存储了当前的秒,分,小时。星期,日,月和年,表示时间的数值都是BCD码。


这些寄存器的内容可读可写。而且仅仅有在寄存器RTCCON的第0位为1时才干进行读写操作。为了防止误操作。当不进行读写时。要把该位清零。当读取这些寄存器时。可以获知当前的时间;当写入这些寄存器时,可以改变当前的时间。


另外须要注意的是。由于有所谓的“一秒


误差”,因此当读取到的秒为0时,,才干保证时间的正确(关于这点能够看s3c2440文档)。


以下给出一个简单的程序。当刚上电的时候读取当前时间值,通过串口显示出来。并设置当前的时间为 2014年8月25日,21点40分 33秒:


write_date(0x14,0x8,0x25,0x1,0x21,0x40,0x33);

read_date();

printf('year:%4d,month:%2d,day:%2d,week:%2d,hour:%2d,minute:%2d,second:%2drn',

rYear, rMonth,rDay,rDayOfWeek,rHour,rMinute,rSecond);

//參数须要是BCD形式的

void write_date(UINT8 year,UINT8 month,UINT8 day,UINT8 dayofweek,UINT8 hour,UINT8 minute,UINT8 second)

{

rRTCCON = 1;

rBCDYEAR = year;            //年

rBCDMON  = month ;           //月

rBCDDAY  = dayofweek;            //日

rBCDDATE = day; //星期

rBCDHOUR = hour;            //小时

rBCDMIN  = minute;                   //分

rBCDSEC  = second;            //秒

rRTCCON = 0;

}


void read_date(void)

{

rRTCCON = 1 ;

if(rBCDYEAR==0x99)

rYear = 1999;

else

rYear    = (2000 + FROM_BCD(rBCDYEAR));

rMonth  = FROM_BCD(rBCDMON & 0x1f);

rDayOfWeek = FROM_BCD(rBCDDAY & 0x0f);

rDay = FROM_BCD(rBCDDATE&0x3f);

rHour   = FROM_BCD(rBCDHOUR & 0x3f);

rMinute     = FROM_BCD(rBCDMIN & 0x7f);

rSecond     = FROM_BCD(rBCDSEC & 0x7f);

rRTCCON = 0 ;

}


发懒了,竟然没有考虑到一秒误差。这算是个简单的 小功能。能够在我github上clone。


除了简单的计时之外RTC还提供了2种时钟中断功能:报警中断和时间节拍中断,时间节拍中断。顾名思义。就像一个节拍器。能够等时性的控制节拍。


因此它类似于定时器中断


但时间节拍中断是毫秒级的,而定时器中断能够达到微秒,甚至更小级别。时间节拍中断的周期公式为:(n+1)÷128。单位是秒,即每隔这么长时间,会中断一次。


当中n的值为1~127,它存储在寄存器TICNT的低6位中,当寄存器TICNT的第7位被置1时,表示开启时间节拍中断。这时n递减,当减为0时,进入时间节拍中断。一般在ucos里面的节拍就是ms级别,作为ucos的节拍比較合适。


报警中断能够实现当实时时间达到预置的时间后。引起报警。预置的时间是存储在报警时间数据寄存器中的(rtc有2套时间有关的寄存器,都是BCD形式存储。当前时间用一套,),包含ALMYEAR(年)、ALMMON(月)、ALMDATE(日)、ALMHOUR(小时)、ALMMIN(分)和ALMSEC(秒)。而怎样报警。是由报警控制寄存器RTCALM控制的。


它的   第6位置1表示全局报警,而第5位到第0位置1分别表示年、月、日、小时、分和秒报警。

7a232f64e28cd7186adb029c2db99833_SouthEast.png?imageView2/2/w/1000

比方,我们想要在2010年4月5日22时30分0秒报警。那么把这个时间分别存储到对应的报警时间数据寄存器中,然后设置RTCALM为0x7F,这样当实时时钟到达这个时刻时,会引起报警中断;


又比方我们想要系统具有闹钟的功能,让它每天早上6点提醒我们起床。那么我们能够设置ALMHOUR为6,RTCALM为0x44。


假设我们仅仅想让系统在4月份的时候提醒我们6点起床,那该怎么办呢?这个问题对于s3c2440来说就是小菜一碟,仅仅要我们再在ALMMON里写入4,然后把RTCALM改为0x54就可以。


总之,就是系统依据RTCALM所置1的相应位来比較相相应的当前时间与报警时间数据寄存器中的值。假设相等就进入中断,不论设置什么形式的闹钟中断全局使能须要置位。


能够依据这个实现一些功能:时间节拍中断设置为1s一次,每次节拍中断向串口写一串字符'beat int'。而   刚上电之后设置闹钟中断   则是在上电之后1分钟之后向串口写字符


串'alarm int'。



void Task2(void *pdata)

{

int i=0;

write_date(0x14,0x8,0x25,0x1,0x21,0x40,0x33);

set_alarm(0x14,0x8,0x25,0x21,0x41,0x33);


while(1)

{

i++;

if(i>99)i=0;

read_date();

printf('year:%4d,month:%2d,day:%2d,week:%2d,hour:%2d,minute:%2d,second:%2drn',

rYear, rMonth,rDay,rDayOfWeek,rHour,rMinute,rSecond);


OSTimeDly( 5 );

OSTimeDly(OS_TICKS_PER_SEC);

}

}



void init_rtc(void)

{

rINTMSK &= ~( (1<<8) | (1<<30) );

pIRQ_RTC = (UINT32)alarm_rtc;

pIRQ_TICK=(UINT32)tick_rtc;


rTICNT=(0x7f)|0x80;    //使能中断   tick=127

rRTCALM = 0x41;     //RTC闹钟控制寄存器   //0x41表示使能RTC闹钟,以及使能秒时钟闹钟   

}


void tick_rtc(void)

{

printf('beat intrn');

}


void alarm_rtc(void)

{

printf('alarm intrn');

}


关键字:s3c2440  rtc操作  寄存器 引用地址:s3c2440的rtc操作

上一篇:uboot在s3c2440上的移植(6)
下一篇:s3c2440 地址分配讲解

推荐阅读最新更新时间:2026-03-22 22:35

s3c2440rtc操作
实时时钟(RTC)其主要功能是电源故障的制度下,使用后备电源,时钟继续。为了不浪费时间信息。 s3c2440内部集成了RTC模块,并且用起来也十分简单。 其内部的寄存器BCDSEC,BCDMIN,BCDHOUR,BCDDAY。BCDDATE,BCDMON和BCDYEAR分别存储了当前的秒,分,小时。星期,日,月和年,表示时间的数值都是BCD码。 这些寄存器的内容可读可写。而且仅仅有在寄存器RTCCON的第0位为1时才干进行读写操作。为了防止误操作。当不进行读写时。要把该位清零。当读取这些寄存器时。可以获知当前的时间;当写入这些寄存器时,可以改变当前的时间。 另外须要注意的是。由于有所谓的“一秒 误差”,因此当读
[单片机]
<font color='red'>s3c2440</font>的<font color='red'>rtc</font><font color='red'>操作</font>
s3c2440裸机-时钟编程-2-配置时钟寄存器
1.2440时钟时序 下图是2440时钟配置时序: 1.上电后,nRESET复位信号拉低,此时cpu还无法取指令工作。 2.nRESET复位信号结束后变为高电平,此时cpu开始工作。此时cpu主频FCLK=osc。 3.此时可以配置PLL,经过lock time后,FCLK倍频成新的时钟。 2.如何配置时钟 在参考手册的特性里介绍了S3C2440的工作频率,Fclk最高400MHz,Hclk最高136MHz,Pclk最高68MHz。那么 我们干脆配置FCLK:HCLK:PCLK= 400:100:50 (MHz). 1,先配置lock time 我们取芯片手册上的推荐值。
[单片机]
uboot-2011.12移植到S3C2440(序五)——ARM寄存器说明
参考《ARM应用系统开发详解》 ARM体系结构的寄存器R0~R15主要有三类: @未分组寄存器R0~R7 @分组寄存器R8~R14 @PC寄存器R15 未分组寄存器 同一个寄存器名在ARM微处理器内部只有一个独立的物理寄存器与之对应。 分组寄存器 每一个物理寄存器分别与不同的处理器模式相对应。对于R8~R12来说,每个寄存器对应两个不同的物理寄存器,当使用fiq模式时,访问寄存器R8_fiq~R12_fiq;当使用除fiq模式以外的其他模式时,访问寄存器R8_usr~R12_usr。对于于R13、R14来说,每个寄存器对应6个不同的物理寄存器,其中的一个是用户模式与系统模式共用,另外5个物理寄存器对应于其他5种不同的运行
[单片机]
S3C2440中断寄存器
S3C2440的中断寄存器: 1.中断分两大类:内部中断和外部中断。 2.外部中断。24个外部中断占用GPF0-GPF7(EINT0-EINT7),GPG0-GPG15(EINT8-EINT23)。用这些脚做中断输入,则必须配置引脚为中断,并且不要上拉。具体参考datesheet数据手册。 寄存器:EXTINT0-EXTINT2:三个寄存器设定EINT0-EINT23的触发方式。 EINTFLT0-EINTFLT3:控制滤波时钟和滤波宽度。 EINTPEND:这个是中断挂起寄存器,清除时要写1,后面还有几个是写1清除。当一个外部中断(EINT4-EINT23)发生后,那么相应的位会被置1。为什么没有EINT0-EINT3,呵呵,看
[单片机]
s3c2440(ARM9)通用寄存器地址
89c51的通用寄存器组是对应内存的,即在内存中分配地址,那么ARM9的呢? 来源: http://zhidao.baidu.com/link?url=Nf9NDaITEiA4Gc9q6Y4dP3yt xLJPwBjvRhizxtP0hUu6sQaN qUFqPnS7KEfvfjpIJBlzFKFz q-rBNYXSGx1-va s3c2440a 通用寄存器地址:例如R0,R1,R2之类的通用寄存器对应内存的地址??? 这么说,在C编程中,就不存在所谓的R1、R2之类的通用寄存器了?? R0,R1,R2是 寄存器 ,在cpu内部,用于计算和存储访问、存放临时数据、以及一些cpu或程序运行的状态,是不直接对应内存的,所以也就没有
[单片机]
MSP430单片机RTC操作-TimeA实现的实时时钟
//******************************************************************************* // D13x Demo - 利用Timer_A及中断实现RTC,观察LED灯的闪烁频率 // // 描述:利用Timer_A及中断实现RTC;通过 P1 异或 来取反 P1.5; // 系统处于休眠状态LPM3,中断时唤醒执行P1.5切换 // ACLK= n/a, MCLK= SMCLK= default DCO ~ 800k // // MSP430F13x // ------------------- // /|| XIN|- // | | | 32kHz //
[单片机]
s3c2440 地址分配讲解
(一)s3c2440 地址分配讲解 (很难很纠结) mini2440的地址怎么分配。mini2440处理器的地址怎么分配。 S3C2440处理器可以使用的物理地址空间可以达到4GB,其中前1GB的地址(也就是0x0000 0000--0x4000 0000)为外设地址空间,外设地址究竟怎么确定的呢??好烦?? 还有一部分为CPU内部使用的特殊功能寄存器地址空间(地址范围为0x4800 0000--0x5FFF FFFF),其余的地址空间没有使用。 下面用两个表格说明外设地址空间好特殊功能寄存器地址空间 3FF FFFF 共 26根地址线,也就是 2^6=64 2^20=1M 那么就是 64M 内存概念: 内存是代码的
[单片机]
<font color='red'>s3c2440</font> 地址分配讲解
uboot在s3c2440上的移植(3)
一、移植环境 主 机:VMWare--Fedora 9 开发板:Mini2440--64MB Nand,Kernel:2.6.30.4 编译器:arm-linux-gcc-4.3.2.tgz u-boot:u-boot-2009.08.tar.bz2 二、移植步骤 5)准备进入u-boot的第二阶段(在u-boot中添加对我们开发板上Nand Flash的支持)。 目前u-boot中还没有对2440上Nand Flash的支持,也就是说要想u-boot从Nand Flash上启动得自己去实现了。 首先,在include/configs/my2440.h头文件中定义Nand要用到的宏和寄存器,如下: #gedit in
[单片机]
uboot在<font color='red'>s3c2440</font>上的移植(3)
小广播
最新单片机文章
何立民专栏 单片机及嵌入式宝典

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

厂商技术中心

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

 
机器人开发圈

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2026 EEWORLD.com.cn, Inc. All rights reserved