Linux设备模型之input子系统详解 6.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Linux设备模型之input子系统详解 6

Linux设备模型之input子系统详解 6 Linux设备模型之input子系统详解62010-05-20 15:49十一:evdev的事件处理 经过上面的分析.每当input device上报一个事件时,会将其交给和它匹配的handler的event函数处理.在evdev中.这个event函数对应的代码为: static void evdev_event(struct input_handle*handle, unsigned int type,unsigned int code,int value) { struct evdev*evdev=handle-private; struct evdev_client*client; struct input_event event; do_gettimeofday(event.time); event.type=type; event.code=code; event.value=value; rcu_read_lock(); client=rcu_dereference(evdev-grab); if(client) evdev_pass_event(client,event); else list_for_each_entry_rcu(client,evdev-client_list,node) evdev_pass_event(client,event); rcu_read_unlock(); wake_up_interruptible(evdev-wait); } 首先构造一个struct input_event结构.并设备它的type.code,value为处理事件的相关属性.如果该设备被强制设置了handle.则调用如之对应的client. 我们在open的时候分析到.会初始化clinet并将其链入到evdev-client_list.这样,就可以通过evdev-client_list找到这个client了. 对于找到的第一个client都会调用evdev_pass_event().代码如下: static void evdev_pass_event(struct evdev_client*client, struct input_event*event) { spin_lock(client-buffer_lock); client-buffer[client-head++]=*event; client-head=EVDEV_BUFFER_SIZE-1; spin_unlock(client-buffer_lock); kill_fasync(client-fasync,SIGIO,POLL_IN); } 这里的操作很简单.就是将event保存到client-buffer中.而client-head就是当前的数据位置.注意这里是一个环形缓存区.写数据是从client-head写.而读数据则是从client-tail中读. 十二:设备节点的read处理 对于evdev设备节点的read操作都会由evdev_read()完成.它的代码如下: static ssize_t evdev_read(struct file*file,char __user*buffer, size_t count,loff_t*ppos) { struct evdev_client*client=file-private_data; struct evdev*evdev=client-evdev; struct input_event event; int retval; if(count evdev_event_size()) return-EINVAL; if(client-head==client-tailevdev-exist (file-f_flagsO_NONBLOCK)) return-EAGAIN; retval=wait_event_interruptible(evdev-wait, client-head!=client-tail||!evdev-exist); if(retval) return retval; if(!evdev-exist) return-ENODEV; while(retval+evdev_event_size()=count evdev_fetch_next_event(client,event)){ if(evdev_event_to_user(buffer+retval,event)) return-EFAULT; retval+=evdev_event_size(); } return retval; } 首先,它判断缓存区大小是否足

文档评论(0)

2017meng + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档