vi button.c(实现input_dev)
#include <linux/module.h>
#include <linux/interrupt.h>
#include <linux/irq.h>
#include <mach/gpio-samsung.h>
#include <linux/gpio.h>
#include <linux/input.h>
struct pin_desc{
int irq;
char *name;
unsigned int pin;
unsigned int key_val;
};
struct pin_desc pin_desc[4]={
{IRQ_EINT0, "S2",S3C2410_GPF(0), KEY_L},
{IRQ_EINT2, "S3",S3C2410_GPF(2), KEY_S},
{IRQ_EINT11,"S4",S3C2410_GPG(3), KEY_ENTER},
{IRQ_EINT19,"S5",S3C2410_GPG(11),KEY_LEFTSHIFT},
};
static struct input_dev *buttons_dev;
static struct pin_desc *irq_pd;
static struct timer_list buttons_timer;
static irqreturn_t buttons_irq(int irq,void *dev_id)
{
irq_pd = (struct pin_desc *)dev_id;
mod_timer(&buttons_timer,jiffies+HZ/100);
return IRQ_HANDLED;
}
static void buttons_timer_function(struct timer_list *t)
{
unsigned int pinval;
struct pin_desc *pindesc = irq_pd;
if(!pindesc)
return;
pinval = gpio_get_value(pindesc->pin);
if(pinval)
{
input_event(buttons_dev,EV_KEY,pindesc->key_val,0);
input_sync(buttons_dev);
}
else
{
input_event(buttons_dev,EV_KEY,pindesc->key_val,1);
input_sync(buttons_dev);
}
}
static int buttons_init(void)
{
int i;
buttons_dev = input_allocate_device();
set_bit(EV_KEY,buttons_dev->evbit);
set_bit(KEY_L,buttons_dev->keybit);
set_bit(KEY_S,buttons_dev->keybit);
set_bit(KEY_ENTER,buttons_dev->keybit);
set_bit(KEY_LEFTSHIFT,buttons_dev->keybit);
input_register_device(buttons_dev);
timer_setup(&buttons_timer,buttons_timer_function,0);
for(i=0;i<4;i++)
request_irq(pin_desc[i].irq, buttons_irq,IRQ_TYPE_EDGE_BOTH,pin_desc[i].name,&pin_desc[i]);
return 0;
}
static void buttons_exit(void)
{
int i;
for(i=0;i<4;i++)
free_irq(pin_desc[i].irq,&pin_desc[i]);
del_timer(&buttons_timer);
input_unregister_device(buttons_dev);
input_free_device(buttons_dev);
}
module_init(buttons_init);
module_exit(buttons_exit);
MODULE_LICENSE("GPL");
# insmod button.ko
input: Unspecified device as /devices/virtual/input/input3
# ls /dev/input -l
total 0
crw-rw---- 1 0 0 13, 64 Jan 1 00:00 event0
crw-rw---- 1 0 0 13, 65 Jan 1 20:31 event1
# hexdump /dev/input/event1
0000000 21f2 0001 71e9 000b 0001 0026 0001 0000
0000010 21f2 0001 71e9 000b 0000 0000 0000 0000
0000020 21f2 0001 e2c1 000d 0001 0026 0000 0000
0000030 21f2 0001 e2c1 000d 0000 0000 0000 0000
# cat /dev/tty1
ls
# exec 0</dev/tty1
# ls
Makefile button.c button.mod.c button.o modules.order
Module.symvers button.ko button.mod.o forthdrvtest.c
驱动中增加set_bit(EV_REP,buttons_dev->evbit);
# cat /dev/tty1
lllllllllllllllllllssssssssssss