内核输入子系统之evdev_open和evdev_read介绍
内核输入子系统之evdev_open和evdev_read介绍
在分配evdev后其中还有一个队列成员就是client,记录input_dev上报的数据,实际看下client的描述:
可以看出确实是一个队列,有头有尾。其中由于一个设备节点对应一个cdev(cdev是evdev的成员),一个evdev对应要给input_dev,一个input_dev对应一个input_handler,一个handler对应多个input_dev,有container_of技术可以通过inode节点获取到evdev,evdev中的成员就有上面的client队列,以及记录了三者关系,以及cdev等。可以认为evdev是一个全局的设备对象。可以了解到在evdev_open中做的就是分配一个client对象,并分配缓冲区大小,最终注册到evdev中去,同时会记录到file中去,方便其他接口使用。例如这里再open的时候记录了,那么read,write的时候就直接使用。
接下来说明evdev_read所做的事:
当我们应用层open的时候已经记录了fops到file中所以,在read的时候直接使用,调用的一个过程是read(fd, &event, sizeof(struct input_event))àVFS: sys_read();file->f_ops->read();àstaticconst struct file_operations evdev_fops = {.read=evdev_read,},这样就调用了read,那么read做了什么呢?如果没有数据就休眠等待,如果有数据就冲缓冲区client->buffer[client->tail++]拿数据,最终是还是通过copy_to_user上报给用户的,具体实现如下:
这样实现后,应用层就可以通过read读取数据了,那么需要注意的在evdev_read中是通过input_report_key(inputdev, pdesc->key_code, 0);将数据存放到缓冲区,同时使用input_sync(inputdev);唤醒等待队列!!!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】