今天看了下时钟中断,在此记下一笔。
如果同时能对哪位朋友有帮助实在是再好不过。
开始正题。
每种中断都有一个中断号,时钟中断号如下
时钟中断的频率为18.2HZ,每一次中断,系统都会对其做出处理。
所谓处理就是进行一次相应的中断服务程序调用。
而中断服务程序的地址可以通过中断向量计算出来。
中断向量其实就是中断服务程序的段基值和偏移量。
这些中断向量按照中断号被保存在一张查询表里,这就是我们经常提到的中断向量表。
因此我们可以通过中断号,得到相应的中断向量,即中断服务程序地址。
如果我们某些时候需要实现自己的中断服务程序,该怎么办呢?
1.定义一个指向中断函数的指针变量,用来保存系统的中断服务程序地址
2.定义一个新的中断处理函数
3.设置新的中断处理
4.别忘了最后重置回以前的中断处理
大概就是这样了。
附件里是一个小的demo程序,每18次时钟中断,即1秒,打印一次。
如果同时能对哪位朋友有帮助实在是再好不过。
开始正题。
每种中断都有一个中断号,时钟中断号如下
#define CLOCK_INT 0x1c /*时钟中断号*/
时钟中断的频率为18.2HZ,每一次中断,系统都会对其做出处理。
所谓处理就是进行一次相应的中断服务程序调用。
而中断服务程序的地址可以通过中断向量计算出来。
中断向量其实就是中断服务程序的段基值和偏移量。
这些中断向量按照中断号被保存在一张查询表里,这就是我们经常提到的中断向量表。
因此我们可以通过中断号,得到相应的中断向量,即中断服务程序地址。
void interrupt(*getvect(int intr_num));
如果我们某些时候需要实现自己的中断服务程序,该怎么办呢?
1.定义一个指向中断函数的指针变量,用来保存系统的中断服务程序地址
void interrupt (*old_handler)(void);
2.定义一个新的中断处理函数
void interrupt new_handler(void)
{
/*新的中断处理函数实现*/
}
3.设置新的中断处理
void set_handler(void interrupt(*IntProc)(void))
{
old_handler=getvect(CLOCK_INT); /*获取并保存中断号为CLOCK的中断处理函数的入口地址*/
disable();/*设置新的时钟中断处理过程时,屏蔽所有中断*/
setvect(CLOCK_INT,IntProc);/*将中断号为CLOCK的中断处理函数的入口地址改为IntProc()函数的入口地址即中断发生时,将调用IntProc()函数--我们新的handler*/
enable();/*开启中断*/
}
4.别忘了最后重置回以前的中断处理
void reset_handler()
{
disable();
setvect(CLOCK_INT,old_handler);
enable();
}
大概就是这样了。
附件里是一个小的demo程序,每18次时钟中断,即1秒,打印一次。