内核驱动之内核定时器示例

#include<linux/module.h>
#include<linux/timer.h>
#include<linux/jiffies.h>
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/ioport.h>
#include <linux/err.h> 
#include <asm/io.h> 
#define	IBX_GPIO12_OUT   ( 1 << 12 )
#define	IBX_GPIO44_OUT   ( 1 << 12)
#define	IBEX_GPIOBASE  (0x500)
#define GP_LVL   (IBEX_GPIOBASE + 0x0c)
#define GP_LVL2   (IBEX_GPIOBASE+0x38)
#define GPIO_USE_SEL   (IBEX_GPIOBASE + 0x00)
#define GP_IO_SEL   (IBEX_GPIOBASE+0x04)
#define GPIO_USE_SEL2   (IBEX_GPIOBASE + 0x30)
#define GP_IO_SEL2   (IBEX_GPIOBASE+0x34)
#define TRUE 1
#define FALSE 0
typedef unsigned int        uint32;
typedef unsigned char       BOOL;
struct timer_list watchdogtimer;
BOOL Enablewatchdog( BOOL b)
{    
    uint32 value;
    if(b){
        value=inl(GP_LVL2)&(~IBX_GPIO44_OUT);
        outl(value,GP_LVL2);
        if(inl(GP_LVL2)&(IBX_GPIO44_OUT))
           return FALSE;
        else 
            return TRUE;
    }else{
       value=inl(GP_LVL2)|(IBX_GPIO44_OUT);
       outl(value,GP_LVL2);
       if(inl(GP_LVL2)&(IBX_GPIO44_OUT))
          return TRUE;
       else 
          return FALSE;
    }
}
static void feed_dog(unsigned long data)
{
	uint32 forword;
    forword=inl(GP_LVL)|IBX_GPIO12_OUT;
    outl(forword,GP_LVL);
    if((forword=inl(GP_LVL))&(IBX_GPIO12_OUT)){
        msleep(8000);
        forword&=(~IBX_GPIO12_OUT);
        outl(forword,GP_LVL);
    }else{
        printk(KERN_ALERT"feed dog fault !\n");
        mod_timer(&watchdogtimer,jiffies+1*HZ);
        return;
    }
    mod_timer(&watchdogtimer,jiffies+10*HZ);
}
static int __init watchdogtimer_init(void)
{
	uint32 value;
    value=inl(GPIO_USE_SEL2)|IBX_GPIO44_OUT;
        outl(value,GPIO_USE_SEL2);
    value=inl(GP_IO_SEL2)&(~IBX_GPIO44_OUT);
        outl(value,GP_IO_SEL2);
    value=inl(GPIO_USE_SEL)|IBX_GPIO12_OUT;
        outl(value,GPIO_USE_SEL);
    value=inl(GP_IO_SEL)&(~IBX_GPIO12_OUT);
        outl(value,GP_IO_SEL);
   setup_timer(&watchdogtimer,feed_dog,0);
   watchdogtimer.expires=jiffies+2*HZ;
   if(Enablewatchdog(TRUE))
   {
		printk(KERN_ALERT"Watchdog is start succeed !\n");
		add_timer(&watchdogtimer);
   }else{
     printk(KERN_ALERT"Watchdog is start fail !\n");
   }
	return 0;
}
static void __exit watchdogtimer_exit(void)
{
   if(Enablewatchdog(FALSE))
   {
		printk(KERN_ALERT"Watchdog is stop succeed !\n");
		del_timer(&watchdogtimer);
   }else{
		printk(KERN_ALERT"Watchdog is stop fault !\n");
   }   
}
module_init(watchdogtimer_init);
module_exit(watchdogtimer_exit);
MODULE_LICENSE("GPL");


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux内核驱动中的定时器是一种常见的机制,可以在指定的时间间隔内触发中断。它的主要作用是进行定时操作,如周期性地刷新屏幕、进行数据采集等。下面是一个简单的Linux内核驱动定时器中断的代码示例: ``` #include <linux/timer.h> #include <linux/init.h> #include <linux/module.h> struct timer_list my_timer; void my_timer_callback(unsigned long data) { printk(KERN_INFO "my_timer_callback called (%ld).\n", jiffies); } static int __init timer_init(void) { int ret; printk(KERN_INFO "timer_init() called\n"); // 设置定时器 setup_timer(&my_timer, my_timer_callback, 0); ret = mod_timer(&my_timer, jiffies + msecs_to_jiffies(1000)); // 定时1秒 if (ret) printk(KERN_ERR "Error in mod_timer\n"); return 0; } static void __exit timer_exit(void) { int ret; ret = del_timer(&my_timer); if (ret) printk(KERN_ERR "The timer is still in use...\n"); printk(KERN_INFO "timer_exit() called\n"); } module_init(timer_init); module_exit(timer_exit); MODULE_LICENSE("GPL"); MODULE_DESCRIPTION("Linux Timer Driver"); ``` 在上面的示例中,我们定义了一个名为`my_timer`的定时器,并将其设置为1秒钟后触发中断。当定时器到期时,它会调用`my_timer_callback()`函数来处理中断。这个函数会输出一条信息,表明它已被调用。 上述示例只是一个简单的示例,实际上在Linux内核驱动中使用定时器有许多不同的方法和实现方式。如果你需要更深入地了解Linux内核驱动定时器中断代码,你可以查阅相关的文档或书籍,例如《Linux设备驱动开发详解》等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值