首页 > 编程知识 正文

linux关中断的命令,linux配置时钟同步

时间:2023-05-04 02:41:16 阅读:63361 作者:3795

s3c2440实时时钟(RTC )定义了两个中断源:报警中断和心跳中断。 之前的网友问了这两个中断的使用方法,最近我抽出时间对这两个中断进行了研究,发现这两个中断都很实用。 在这里介绍它们的使用方法。

节奏中断,顾名思义,就像节拍器,可以等待时间来控制节奏。 因此,类似于计时器中断。 但是,时间差拍中断可以达到毫秒级别,计时器中断可以达到微秒或更低的级别。 节拍时间中断的周期公式为(n 1)128,单位为秒。 也就是说,每隔这点时间就会中断。 这里,n的值是1至127,存储在寄存器TICNT的较低6位中,当寄存器TICNT的第7位被设置为1时,接通的时间戳被中断,此时n递减,减小为0时

报警中断可在实时时间达到预设时间后触发报警。 预设时间存储在报警时间数据寄存器中,包括ALMYEAR (年)、ALMMON (月)、ALMDATE (日)、ALMHOUR (小时)、ALMMIN (分钟)、ALMSEC (秒) )。 如何报警由报警控制寄存器RTCALM控制。 第六个位置1表示全局警报,第五个到第零个位置1分别表示年、月、日、小时、分钟、秒警报。 例如,想要在2010年4月5日22时30分0秒发出警报时,为了在实时时钟到达该时刻时引起警报中断,将该时间分别存储在对应的警报时间数据寄存器中,并将RTCALM设定为0x7F。 例如,如果希望系统具有闹钟功能,以便每天早上6点起床,可以将ALMHOUR设置为6,RTCALM设置为0x44。 如果我们想让系统在4月提醒我们6点起床,该怎么办? 这个问题对s3c2440来说轻而易举。 只要在ALMMON中写4,把RTCALM改为0x54就可以了。 也就是说,系统基于设置在RTCALM中的第一相应比特,将相应的当前时间和报警时间数据寄存器的值进行比较,并且如果相等,则进入中断。

改写前面的程序,加入警报中断和心跳中断。 PC不仅可以通过UART修改s3c2440的实时时钟,还可以设置报警时间。 在此设定报警时间的通信协议与设定实时时钟类似。 也就是说,第一个字节以0xBB表示命令,第六个字节分别用于设置报警时间的年、月、日、小时、分钟和秒,最后一个字节用于设置RTCALM。 到了报警时间后,利用心跳中断控制LED的闪烁,闪烁15秒钟后自动停止。 另外,也可以用一个按钮停止LED的闪烁。 以下过程仅显示主要部分。。

unsigned char alarm_buffer[7]; //报警缓存数组。

//设定报警时间

voidset_alarm(void ) )

{

rALMYEAR=alarm_buffer[0]; //年

rALMMON=alarm_buffer[1]; //月

rALMDATE=alarm_buffer[2]; //日

rALMHOUR=alarm_buffer[3]; //小时

rALMMIN=alarm_buffer[4]; //分钟

rALMSEC=alarm_buffer[5]; 每秒

rRTCALM=alarm_buffer[6]; //警报控制

}

//按钮外部中断用于禁止心跳中断并停止LED的闪烁

void __irq Key1_ISR(void )

{

RSRCPND=RSRCPND|(0x11;

rintPND=rintPND|(0x11 );

rGPBDAT=0x1e0;//指示灯熄灭

rTICNT=0x0; //禁止中断时间节拍

}

//UART中断,与上一篇文章的相关内容进行了改写和完善

void__IRQuArtisr(void ) )。

{

char ch;

静态字符命令;

静态字符计数;

rSUBSRCPND |=0x3;

rSRCPND |=0x128;

rINTPND |=0x128;

if(rutrstat01 ) /接收数据处理部

{

ch=rURXH0; //接收字节数据

if (命令==0)//判断命令信息

{

开关(ch ) )。

{

设定case0xaa: //实时时钟时间

command=0xaa;

计数=0;

布雷克;

case0xbb:

          //设置报警时间

command = 0xbb;

count=0;

break;

default:          //其余命令

command = 0;

count =0;

rUTXH0=ch;

break;

}

}

else                //接收实时时钟时间或报警时间

{

if(command == 0xaa)           //实时时钟时间

{

date_buffer[count]=ch;

count++;

if(count==7)

{

set_date();

count=0;

command=0;

flag=1;

rUTXH0=0xaa;

}

}

else if(command ==0xbb)            //报警时间

{

alarm_buffer[count]=ch;

count++;

if(count==7)

{

set_alarm();

count=0;

command=0;

rUTXH0=0xbb;

}

}

}

}

}

//报警中断

void __irq Alarm_ISR(void)

{

rSRCPND |= 0x1<<30;

rINTPND |= 0x1<<30;

rTICNT = 0xbf;     //开启时间节拍中断,周期为500毫秒

}

//时间节拍中断,用于LED闪烁15秒

void __irq RTCTick_ISP(void)

{

static char count;

rSRCPND |= 0x1<<8;

rINTPND |= 0x1<<8;

if(count%2==0)            //LED亮0.5秒

rGPBDAT = ~0x1e0;

else                //LED灭0.5秒

rGPBDAT = 0x1e0;

count++;

if(count==30)

{

rTICNT = 0x0;              //禁止时间节拍中断

rGPBDAT = 0x1e0;              //LED灭

count=0;

}

}

void Main(void)

{

//初始化

……    ……

//中断源

pISR_UART0 = (U32)uartISR;

pISR_EINT0 = (U32)Key4_ISR;

pISR_EINT1 = (U32)Key1_ISR;

pISR_RTC = (U32)Alarm_ISR;

pISR_TICK = (U32)RTCTick_ISP;

……   ……

Brush_Background(0xffffff);

show_date();

flag=0;

while(1)

{

if(flag)           //显示实时时间

{

Brush_Background(0xffffff);

show_date();

flag=0;

}

}

}

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。