Linux输入子系统input_dev概述

Linux 系统提供了input子系统,按键、触摸屏、键盘、鼠标等输入都可以利用input接口函数来实现设备驱动,因此,12.1~12.2节的按键和触摸屏设备驱动都可以作为input设备驱动而实现。

在Linux 内核中,input设备用input_dev 结构 体描述,使用input子系统实现输入设备驱动的时候,驱动的核心工作是向系统报告按键、触摸屏、键盘、鼠标等输入事件(event,通过input_event结构 体描述),不再需要关心文件操作接口,因为input子系统已经完成了文件操作接口。驱动报告的事件经过InputCore和 Eventhandler最终到达用户空间。

通过input子系统,具体的输入设备驱动只需要完成如下工作。

l 在模块加载函数中告知input子系统它可以报告的事件。

设备驱动通过set_bit()告诉input子系统它支持哪些事件,如下所示:

set_bit(EV_KEY, button_dev.evbit);
 l 在模块加载函数中注册输入设备。

注册输入设备的函数为:

int input_register_device(struct input_dev
 *dev);
 l 在键被按下/抬起、触摸屏被触摸/抬起/移动、鼠标被移动/单击/抬起时通过input_ report_xxx()报告发生的事件及对应的键值/坐标等状态。

主要的事件类型包括EV_KEY(按键事件)、EV_REL(相对值,如光标移动,报告的是相对最后一次位置的偏移)和EV_ABS(绝对值,如触摸屏和操纵杆,它们工作在绝对坐标系统)。

用于报告EV_KEY、EV_REL和EV_ABS事件的函数分别为:

void input_report_key(struct input_dev
 *dev, unsigned int code, int value);
void input_report_rel(struct input_dev
 *dev, unsigned int code, int value);
void input_report_abs(struct input_dev
 *dev, unsigned int code, int value);
 input_sync()用于事件同步,它告知事件的接收者驱动已经发出了一个完整的报告。

例如,在触摸屏设备驱动中,一次坐标及按下状态的整个报告过程如下:

input_report_abs(input_dev
, ABS_X, x);  //X坐标
input_report_abs(input_dev
, ABS_Y, y);   //Y坐标
input_report_abs(input_dev
, ABS_PRESSURE, pres); //压力
input_sync(input_dev
);  //同步
 在模块卸载函数中注销输入设备。注销输入设备的函数为:

void input_unregister_device(struct input_dev
 *dev);
 代码清单12.28给出了一个最简单的使用input接口实现按键设备驱动的范例,它在中断服务程序中向系统报告按键及同步事件。

代码清单12.28 最简单的input设备驱动

1  /*在按键中断中报告事件*/
2  static void button_interrupt(int irq, void *dummy, struct pt_regs *fp)
3  {
4    input_report_key(&button_dev, BTN_1, inb(BUTTON_PORT) &1);
5    input_sync(&button_dev);
6  }

8  static int _ _init button_init(void)
9  {
10   /*申请中断*/
11   if (request_irq(BUTTON_IRQ, button_interrupt, 0, "button", NULL))
12   {
13     printk(KERN_ERR "button.c: Can't allocate irq %d ", button_irq);
14     return  - EBUSY;
15   }
16
17   button_dev.evbit[0] = BIT(EV_KEY);    //支持EV_KEY事件
18   button_dev.keybit[LONG(BTN_0)] = BIT(BTN_0);
19
20   input_register_device(&button_dev);   //注册input设备
21 }
22
23 static void _ _exit button_exit(void)
24 {
25   input_unregister_device(&button_dev);   //注销input设备
26   free_irq(BUTTON_IRQ, button_interrupt); //释放中断
27 }
本篇文章来源于:开发学院
http://edu.codepub.com   原文链接:http://edu.codepub.com/2010/0701/23935.php

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux 内核中,input_dev 结构体表示一个输入设备。它的定义在 `<linux/input.h>` 头文件中,包含了以下成员: - `char *name`:输入设备的名称。 - `struct bus_type *bus`:输入设备所连接的总线类型。 - `unsigned int id.bustype`:输入设备所连接的总线类型。 - `unsigned int id.vendor`:输入设备供应商 ID。 - `unsigned int id.product`:输入设备产品 ID。 - `unsigned int id.version`:输入设备版本号。 - `unsigned long evbit[EV_MAX/32 + 1]`:标志设备支持的事件类型,例如 EV_KEY、EV_REL、EV_ABS、EV_LED、EV_SND、EV_SW 和 EV_MSC 等。 - `unsigned long keybit[KEY_MAX/32 + 1]`:标志设备支持的键位,例如 KEY_ESC、KEY_ENTER、KEY_A 等。 - `unsigned long relbit[REL_MAX/32 + 1]`:标志设备支持的相对坐标事件,例如 REL_X、REL_Y 等。 - `unsigned long absbit[ABS_MAX/32 + 1]`:标志设备支持的绝对坐标事件,例如 ABS_X、ABS_Y 等。 - `unsigned long mscbit[MSC_MAX/32 + 1]`:标志设备支持的杂项事件,例如 MSC_SERIAL、MSC_PULSELED 等。 - `unsigned long key_len`:键位数组的长度。 - `unsigned long rel_len`:相对坐标事件数组的长度。 - `unsigned long abs_len`:绝对坐标事件数组的长度。 - `unsigned long msc_len`:杂项事件数组的长度。 - `unsigned long key_cnt`:键位个数。 - `unsigned long rel_cnt`:相对坐标事件个数。 - `unsigned long abs_cnt`:绝对坐标事件个数。 - `unsigned long msc_cnt`:杂项事件个数。 - `int (*open)(struct input_dev *dev)`:设备打开函数指针。 - `void (*close)(struct input_dev *dev)`:设备关闭函数指针。 - `int (*flush)(struct input_dev *dev, struct file *file)`:设备刷新函数指针。 - `int (*event)(struct input_dev *dev, unsigned int type, unsigned int code, int value)`:设备事件处理函数指针。 - `int (*set_keycode)(struct input_dev *dev, const struct input_keymap_entry *ke, unsigned int *old_keycode)`:设备设置键位函数指针。 - `int (*getkeycode)(struct input_dev *dev, struct input_keymap_entry *ke)`:设备获取键位函数指针。 - `int (*set_drvdata)(struct input_dev *dev, void *data)`:设备设置私有数据函数指针。 - `void *driver_data`:设备私有数据指针。 这些成员描述了输入设备的基本属性,支持的事件类型和事件处理函数等。在注册输入设备时,需要设置这些成员的值。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值