(一)分配一个输入子系统结构体

static struct input_dev *buttons_dev;        /*分配一个input_dev结构体*/

(二)设置这个输入子系统需要的动作

    /* 1. 分配一个input_dev结构体 */
buttons_dev = input_allocate_device();; /*使用这个函数分配一个input_dev结构体*/
/*
unsigned long evbit [NBITS(EV_MAX)]; // 表示能产生哪类事件
unsigned long keybit[NBITS(KEY_MAX)]; // 表示能产生哪些按键
unsigned long relbit[NBITS(REL_MAX)]; // 表示能产生哪些相对位移事件, x,y,滚轮
unsigned long absbit[NBITS(ABS_MAX)]; // 表示能产生哪些绝对位移事件, x,y
*/
/* 2. 设置 */
/* 2.1 能产生哪类事件 */
/*按键类事件 buttons_dev里面的哪一类事件*/
set_bit(EV_KEY, buttons_dev->evbit);
/*能够产生重复类事件,就是按键按下可以重复输出*/
set_bit(EV_REP, buttons_dev->evbit); /* 2.2 能产生这类操作里的哪些事件: L,S,ENTER,LEFTSHIT */
set_bit(KEY_L, buttons_dev->keybit); /*L*/
set_bit(KEY_S, buttons_dev->keybit); /*S*/
set_bit(KEY_ENTER, buttons_dev->keybit); /*回车*/
set_bit(KEY_LEFTSHIFT, buttons_dev->keybit); /*shift*/ /* 3. 注册 */
input_register_device(buttons_dev); /*初始化完成上面的参数之后进行初始化*/

(三)当有动作产生时候,上报事件

        /*上报事件*/
/*上报给哪个结构体 上报什么事件 上报值 值*/
input_event(buttons_dev, EV_KEY, pindesc->key_val, );
input_sync(buttons_dev);/*上报同步事件,表示上面的事件已经上报完成*/

(四)删除这个字输入系统结构体

    input_unregister_device(buttons_dev);
input_free_device(buttons_dev);

(五)示例,按键输入子系统全部代码(详解)

/* 参考drivers\input\keyboard\gpio_keys.c */

#include <linux/module.h>
#include <linux/version.h> #include <linux/init.h>
#include <linux/fs.h>
#include <linux/interrupt.h>
#include <linux/irq.h>
#include <linux/sched.h>
#include <linux/pm.h>
#include <linux/sysctl.h>
#include <linux/proc_fs.h>
#include <linux/delay.h>
#include <linux/platform_device.h>
#include <linux/input.h>
#include <linux/irq.h> #include <asm/gpio.h>
#include <asm/io.h>
#include <asm/arch/regs-gpio.h> struct pin_desc{
int irq; /*中断号*/
char *name; /*按键名字*/
unsigned int pin; /*按键引脚*/
unsigned int key_val; /*键值*/
}; struct pin_desc pins_desc[] = {
{IRQ_EINT0, "S2", S3C2410_GPF0, KEY_L},
{IRQ_EINT2, "S3", S3C2410_GPF2, KEY_S},
{IRQ_EINT11, "S4", S3C2410_GPG3, KEY_ENTER},
{IRQ_EINT19, "S5", S3C2410_GPG11, KEY_LEFTSHIFT},
}; static struct input_dev *buttons_dev; /*分配一个input_dev结构体*/
static struct pin_desc *irq_pd;
static struct timer_list buttons_timer; /*定时器结构体*/ static irqreturn_t buttons_irq(int irq, void *dev_id) /*按键中断处理函数*/
{
/* 10ms后启动定时器 */
irq_pd = (struct pin_desc *)dev_id; /*按键中断触发之后,获取按键相关参数*/
/*修改超时时间 超时结构体 超时时间 在jiffies上加一,也就是10ms,因为10ms加一次*/
mod_timer(&buttons_timer, jiffies+HZ/);
return IRQ_RETVAL(IRQ_HANDLED);
} static void buttons_timer_function(unsigned long data) /*定时器超时处理函数*/
{
struct pin_desc * pindesc = irq_pd; /*获取按键中断中保留下来的数据*/
unsigned int pinval; if (!pindesc) /*假如没有按下就返回,因为初始化时候会自动调用一次,因为我们初始化时候没有设置超时时间*/
return; pinval = s3c2410_gpio_getpin(pindesc->pin);/*获取按键值*/ if (pinval)
{
/* 松开 : 最后一个参数: 0-松开, 1-按下 */
/*上报事件*/
/*上报给哪个结构体 上报什么事件 上报值 值*/
input_event(buttons_dev, EV_KEY, pindesc->key_val, );
input_sync(buttons_dev);/*上报同步事件,表示上面的事件已经上报完成*/
}
else
{
/* 按下 */
input_event(buttons_dev, EV_KEY, pindesc->key_val, );
input_sync(buttons_dev);
}
} static int buttons_init(void)
{
int i; /* 1. 分配一个input_dev结构体 */
buttons_dev = input_allocate_device();; /*使用这个函数分配一个input_dev结构体*/ /*
unsigned long evbit [NBITS(EV_MAX)]; // 表示能产生哪类事件
unsigned long keybit[NBITS(KEY_MAX)]; // 表示能产生哪些按键
unsigned long relbit[NBITS(REL_MAX)]; // 表示能产生哪些相对位移事件, x,y,滚轮
unsigned long absbit[NBITS(ABS_MAX)]; // 表示能产生哪些绝对位移事件, x,y
*/
/* 2. 设置 */
/* 2.1 能产生哪类事件 */
/*按键类事件 buttons_dev里面的哪一类事件*/
set_bit(EV_KEY, buttons_dev->evbit);
/*能够产生重复类事件,就是按键按下可以重复输出*/
set_bit(EV_REP, buttons_dev->evbit); /* 2.2 能产生这类操作里的哪些事件: L,S,ENTER,LEFTSHIT */
set_bit(KEY_L, buttons_dev->keybit); /*L*/
set_bit(KEY_S, buttons_dev->keybit); /*S*/
set_bit(KEY_ENTER, buttons_dev->keybit); /*回车*/
set_bit(KEY_LEFTSHIFT, buttons_dev->keybit); /*shift*/ /* 3. 注册 */
input_register_device(buttons_dev); /*初始化完成上面的参数之后进行初始化*/ /* 4. 硬件相关的操作 */
init_timer(&buttons_timer); /*初始化time*/
buttons_timer.function = buttons_timer_function; /*但超时时间到了之后调用这个函数*/
add_timer(&buttons_timer); /*将这个定时器告诉给内核,相当于初始化*/ for (i = ; i < ; i++) /*注册四个中断号*/
{
request_irq(pins_desc[i].irq, buttons_irq, IRQT_BOTHEDGE, pins_desc[i].name, &pins_desc[i]);
} return ;
} static void buttons_exit(void)
{
int i;
for (i = ; i < ; i++)
{
free_irq(pins_desc[i].irq, &pins_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");

buttons.c

020_linux驱动之_输入子系统按键应用的更多相关文章

  1. Linux 驱动——Button8(输入子系统)

    输入子系统由驱动层.输入子系统核心.事件处理层三部分组成.一个输入事件,如鼠标移动.键盘按下等通过Driver->Inputcore->Event handler->userspac ...

  2. Linux输入子系统 : 按键驱动

    一.Linux input system框架: 1.由输入子系统核心层(input.c),驱动层(gpio_keys.c)和事件处理层(Event Handler)三部份组: 2.主要的三个结构体:i ...

  3. INPUT输入子系统——按键

    一.什么是input输入子系统? 1.1. Linux系统支持的输入设备繁多,例如键盘.鼠标.触摸屏.手柄或者是一些输入设备像体感输入等等,Linux系统是如何管理如此之多的不同类型.不同原理.不同的 ...

  4. Linux驱动之输入子系统简析

    输入子系统由驱动层.输入子系统核心.事件处理层三部分组成.一个输入事件,如鼠标移动.键盘按下等通过Driver->Inputcore->Event handler->userspac ...

  5. linux 输入子系统之电阻式触摸屏驱动

    一.输入子系统情景回忆ING...... 在Linux中,输入子系统是由输入子系统设备驱动层.输入子系统核心层(Input Core)和输入子系统事件处理层(Event Handler)组成.其中设备 ...

  6. Linux输入子系统(转)

    Linux输入子系统(Input Subsystem) 1.1.input子系统概述 输入设备(如按键,键盘,触摸屏,鼠标等)是典型的字符设备,其一般的工作机制是低层在按键,触摸等动作发生时产生一个中 ...

  7. 10. linux输入子系统/input 设备【转】

    转自:https://www.cnblogs.com/crmn/articles/6696819.html 按键事件信息之上报绝对事件信息之上报相对事件信息之上报功能键驱动编写多点触控事件的上报 只产 ...

  8. Linux输入子系统详解

    input输入子系统框架  linux输入子系统(linux input subsystem)从上到下由三层实现,分别为:输入子系统事件处理层(EventHandler).输入子系统核心层(Input ...

  9. linux输入子系统简述【转】

    本文转载自:http://blog.csdn.net/xubin341719/article/details/7678035 1,linux输入子系统简述 其实驱动这部分大多还是转载别人的,linux ...

随机推荐

  1. Linux驱动函数解读

    一.kmalloc().kzalloc()和vmalloc() 这三个函数都可以分配连续的虚拟内存 除此之外,这三个函数的区别有: 1. kmalloc()和kzalloc()函数分配的物理内存也是连 ...

  2. Django入门(下)

    一.创建APP 在每一个django项目中可以包含多个APP,相当于一个大型项目中的分系统.子模块.功能部件等.互相之间比较独立,但也有联系. 在pycharm下方的Terminal终端中输入命令: ...

  3. 判断pdf文件是否正常可用

    之前在下载港交所的文件的时候会碰到有些文件异常的情况,文件下载下来,但是不能打开.查到其他的方法不是判断错误就是很麻烦.   整理出一个非常简单的方法,将文件以二进制方式打开,然后判断文件的开头是否符 ...

  4. Unity性能优化-对象池

    1.对象池Object Pool的原理: 有些GameObject是在游戏中需要频繁生成并销毁的(比如射击游戏中的子弹),以前的常规做法是:Instantiate不断生成预设件Prefab,然后采用碰 ...

  5. (十五)Hibernate中的多表操作(5):双向多对多

    Hibernate的双向关联. 对象之间可以相互读取.        双向只针对读取的操作.对于增.删除.改的操作没有任何影响. 案例 : 实现双向多对多 MenuBean.java package ...

  6. IDEA如何本机调试springboot应用打的jar包

    背景: 我用命名行 执行 java -jar  ***.jar发现 springboot启动时抛出错误,因此想debug进去看看究竟为什么出错. 1  在命令行执行 java -jar -Xdebug ...

  7. Joy OI【走廊泼水节】题解--最小生成树推论变式

    题目链接: http://joyoi.org/problem/tyvj-1391 思路: 首先这需要一个推论: "给定一张无向图,若用\(k(k<n-1)\)条边构成一个生成森林(可以 ...

  8. Mysql 中删除重复数据(保留一条)

    sql去重 先根据需要去重的字段进行分组,取到主键值最小的记录(id 是主键,删除重复的 record_id 的记录) select min(id) from tb_traffic_wf_record ...

  9. 货币转换B

    描述 人民币和美元是世界上通用的两种货币之一,写一个程序进行货币间币值转换,其中:‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮ ...

  10. Ubuntu输入密码后重新返回登陆界面

    Xserver启动时,需要读取文件~/.Xauthority.由于权限不够,导致登录失败 解决办法 ctrl+alt+F1组合键进入终端,修改文件权限 # ls -l .Xauthority -rw- ...