如何申请中断
中断的产生原理
在加载函数中申请中断
irqno = IRQ_EINT(1);
//参数1--中断号码
//获取中断号码的方法: 1,外部中断IRQ_EINT(x)
// 2, 头文件 #include <mach/irqs.h> #include <plat/irqs.h>
//参数2--中断的处理方法
//参数3--中断触发方式: 高电平,低电平,上升沿,下降沿,双边沿
/*
#define IRQF_TRIGGER_NONE 0x00000000
#define IRQF_TRIGGER_RISING 0x00000001
#define IRQF_TRIGGER_FALLING 0x00000002
#define IRQF_TRIGGER_HIGH 0x00000004
#define IRQF_TRIGGER_LOW 0x00000008
*/
//参数4--中断的描述-自定义字符串
//参数5--传递个参数2的任意数据
//返回值0表示正确
ret = request_irq(irqno, key_irq_handler, IRQF_TRIGGER_FALLING|IRQF_TRIGGER_RISING, "eint1-downkey", &testdata);
if(ret != 0)
{
printk("request_irq error\n");
return ret;
}
在卸载函数中释放中断
// 释放中断
//参数1--中断号码
//参数5--和request_irq第5个参数保持一致
free_irq(irqno, &testdata);
实现中断处理函数
//中断处理方法
//参数1--当前产生的中断的号码
//参数2--request_irq传递过来的参数
irqreturn_t key_irq_handler(int irqno, void *dev_id)
{
int *p = (int *)dev_id;
//printk("-----------%s-------0x%x-----\n", __FUNCTION__, *p);
//区分按下还是抬起
int value = gpio_get_value(S5PV210_GPH0(1));
if(value)
{
//抬起
printk("<kernel>--down_key2 : release\n");
//填充值
event.code = KEY_DOWN;
event.value = 0;
}else
{
//按下
printk("<kernel>--down_key2 : pressed\n");
event.code = KEY_DOWN;
event.value = 1;
}
have_data = 1;//表示有数据了
wake_up_interruptible(&wq_head);
return IRQ_HANDLED;
}
实现应用读取到按键数据功能
设计一个对象--描述按键产生的数据包(这个数据包在应用层中也需要有一个相同的,相当于一个通信协议)
struct key_event{
int code; //什么按键: 左键, 回车键
int value; // 按键的状态: 按下/抬起 (1/0)
};
//相当于一个数据包--给用户的
static struct key_event event;
open函数中进行清零操作,确定打开设备节点时没有数据
int key_drv_open (struct inode *inode, struct file *filp)
{
printk("--------^_* %s-------\n", __FUNCTION__);
memset(&event, 0, sizeof(struct key_event));
have_data = 0; //为假--一开始都没有按键按下或者抬起
return 0;
}
一旦产生中断,就会给数据包赋值
//区分按下还是抬起,获取寄存器中的高低电位
int value = gpio_get_value(S5PV210_GPH0(1));
//中断处理方法
//参数1--当前产生的中断的号码
//参数2--request_irq传递过来的参数
irqre