uevent事件机制

Linux设计了一种uevent的机制。当有新的设备加入的时候,将设备的信息发送消息到用户态。而用户态有一个udev的进程监听这个信息。当收到信息后做一定的解析,根据解析到的结果和用户程序的配置做一些处理,也包括加载驱动程序。

内核部分,Uevent是Kobject的一部分,用于在Kobject状态发生改变时,例如增加、移除等,通知用户空间程序,主要涉及kobject.h和kobject_uevent.c两个文件,如下:

include/linux/kobject.h
lib/kobject_uevent.c
  • 内核上报事件,调用kobject_uevent_env函数进行上报事件

  • int kobject_uevent_env(struct kobjectkobj, enum kobject_action action,charenvp_ext[])

    static const char *kobject_actions[] ={
    [KOBJ_ADD] = “add”,
    [KOBJ_REMOVE] = “remove”,
    [KOBJ_CHANGE] = “change”,
    [KOBJ_MOVE] = “move”,
    [KOBJ_ONLINE] = “online”,
    [KOBJ_OFFLINE] = “offline”,
    };

比如下面的一个HDMI插拔的uevent字符串

 {SUBSYSTEM=extcon, SEQNUM=2706, ACTION=change, DEVTYPE=hdmi_audio, STATE=HDMI=1, DEVPATH=/devices/virtual/amhdmitx/amhdmitx0/hdmi_audio, NAME=hdmitx_extcon_audio}

android层面去读取uevent事件

frameworks/base/core/jni/android_os_UEventObserver.cpp
uevent_init()  //open socket for UEventObserver
uevent_next_event(buffer, sizeof(buffer) //读取uevent事件for (;;) {int length = uevent_next_event(buffer, sizeof(buffer) - 1);if (length <= 0) {return NULL;}buffer[length] = '\0';ALOGV("Received uevent message: %s", buffer);if (isMatch(buffer, length)) {// Assume the message is ASCII.jchar message[length];for (int i = 0; i < length; i++) {message[i] = buffer[i];}return env->NewString(message, length);}
}frameworks/base/core/java/android/os/UEventObserver.java
创建一个UEventThread线程不停的读取消息while (true) {String message = nativeWaitForNextEvent();if (message != null) {if (DEBUG) {Log.d(TAG, message);}sendEvent(message);}}

amlogic平台调试的例子

  • 这里主要是添加了gpio按键的uevent事件上报给android,下面是一个上报的简单例子,主要是传输字符串,这里可以任意指定

    char data[64];
    char *envp[] = { data, NULL };
    snprintf(data, sizeof(data), “code=%d,state=up”, key->code);
    kobject_uevent_env(&kp->config_dev->kobj, KOBJ_CHANGE, envp);

  • app里面的修改

      mObserver.startObserving("DEVPATH=/devices/virtual/gpio_keyboard/gpio_keyboard");mObserver.startObserving("DEVPATH=/devices/adc_keypad.13/input/input1");private UEventObserver mObserver = new UEventObserver() {@Overridepublic void onUEvent(UEventObserver.UEvent event) {Log.i("onUEvent","event:"+event +"  code = "+event.get("code"));}};
    
  • 注意点startObserving这个里面传入的是设备的驱动路径,必须填写正确,onUEvent接收到的就是回调的时间信息

      09-11 00:08:59.942  7450  7474 I onUEvent: event:{DEVNAME=gpio_keyboard, SUBSYSTEM=gpio_keyboard, SEQNUM=4095, MAJOR=222, ACTION=change, DEVPATH=/devices/virtual/gpio_keyboard/gpio_keyboard, MINOR=0, code=473,state=down}  code = 473,state=down09-11 00:09:00.151  7450  7474 I onUEvent: event:{DEVNAME=gpio_keyboard, SUBSYSTEM=gpio_keyboard, SEQNUM=4096, MAJOR=222, ACTION=change, DEVPATH=/devices/virtual/gpio_keyboard/gpio_keyboard, MINOR=0, code=473,state=up}  code = 473,state=up09-11 00:08:55.147  7450  7474 I onUEvent: event:{PROP=0, SUBSYSTEM=input, PRODUCT=10/1/1/100, SEQNUM=4091, EV=100003, ACTION=change, DEVPATH=/devices/adc_keypad.13/input/input1, PHYS="adc_keypad/input0", KEY=3c000000 0 0 0 0 0 40000 0, NAME="adc_keypad", MODALIAS=input:b0010v0001p0001e0100-e0,1,14,k1DA,1DB,1DC,1DD,ramlsfw, code=477,state=down}  code = 477,state=down09-11 00:08:55.291  7450  7474 I onUEvent: event:{PROP=0, SUBSYSTEM=input, PRODUCT=10/1/1/100, SEQNUM=4092, EV=100003, ACTION=change, DEVPATH=/devices/adc_keypad.13/input/input1, PHYS="adc_keypad/input0", KEY=3c000000 0 0 0 0 0 40000 0, NAME="adc_keypad", MODALIAS=input:b0010v0001p0001e0100-e0,1,14,k1DA,1DB,1DC,1DD,ramlsfw, code=477,state=up}  code = 477,state=up
    

驱动举例说明:

+++ b/drivers/gtinput/gtinput.c
@@ -344,11 +344,37 @@ static ssize_t gtinputdev_det_power_store(struct device *gtinput_class_dev,return size;}
+/* add by caizd for AC power detecte */
+static ssize_t gtinputdev_power_det_show(struct device *gtinput_class_dev,
+                               struct device_attribute *attr, char *buf)
+{+       return sprintf(buf, "%s\n", "gtinput_power_det_show: sysfs test read");
+}
+
+static ssize_t gtinputdev_power_det_store(struct device *gtinput_class_dev,
+                               struct device_attribute *attr,
+                               const char *buf, size_t size)
+{+       unsigned int usdata;
+       char kdata[64];
+       char *envp[] = {kdata, NULL};
+       int ret;
+
+       ret = sscanf(buf, "%d", &usdata);
+
+       snprintf(kdata, sizeof(kdata), "AC_power_det=%d", usdata);
+       kobject_uevent_env(&gtinput_class_dev->kobj, KOBJ_CHANGE, envp);
+//     printk("\n #####-czd-: AC_power_det=%d #####\n", usdata);
+
+       return size;
+}
+/* add end */static DEVICE_ATTR(gtinputdev_det_power, 0664, gtinputdev_det_power_show, gtinputdev_det_power_store);
+static DEVICE_ATTR(gtinputdev_power_det, 0664, gtinputdev_power_det_show, gtinputdev_power_det_store); /* add by caizd for AC power detecte */static const struct file_operations gtinput_fops = {.owner = THIS_MODULE,
@@ -403,6 +429,7 @@ static int gtinput_init(void)device_create_file(gtinput_class_dev, &dev_attr_gtinputdev_bat);device_create_file(gtinput_class_dev, &dev_attr_gtinputdev_bat_dc);device_create_file(gtinput_class_dev, &dev_attr_gtinputdev_det_power);
+       device_create_file(gtinput_class_dev, &dev_attr_gtinputdev_power_det); /* add by caizd for AC power detecte */

Linux的uevent事件机制相关推荐

  1. linux 内核uevent事件,Linux的uevent事件机制

    uevent事件机制 Linux设计了一种uevent的机制.当有新的设备加入的时候,将设备的信息发送消息到用户态.而用户态有一个udev的进程监听这个信息.当收到信息后做一定的解析,根据解析到的结果 ...

  2. Linux--内核Uevent事件机制 与 Input子系统【转】

    阅读目录 Uevent在kernel中的位置 Uevent的内部逻辑解析 转自:http://blog.csdn.net/lxl584685501/article/details/46379453 [ ...

  3. uevent 驱动_Linux--内核Uevent事件机制 与 Input子系统【转】

    一.Uevent机制 1.前提摘要 (1)Sysfs文件系统 内核设备模型主要的模块和用户之间能看到的相关部分就是sysfs文件系统了.内核在启动的时候会注册sysfs文件系统,并且在启动系统的初期. ...

  4. Linux内核抢占实现机制分析【转】

    Linux内核抢占实现机制分析 转自:http://blog.chinaunix.net/uid-24227137-id-3050754.html [摘要]本文详解了Linux内核抢占实现机制.首先介 ...

  5. 10.QT事件机制源码时序分析(中)

    接上一篇文章https://blog.csdn.net/Master_Cui/article/details/109162220,上篇文章已经说过,在Ubuntu18.04,QT的事件机制实际上是采用 ...

  6. linux 信号没有被处理方法,[计算机]Linux 信号signal处理机制.doc

    [计算机]Linux 信号signal处理机制 Linux 信号signal处理机制 信号是Linux编程中非常重要的部分,本文将详细介绍信号机制的基本概念.Linux对信号机制的大致实现方法.如何使 ...

  7. 哪些是Linux内核的同步机制,Linux内核的同步机制(1)

    Linux内核的同步机制(1) yanqin | 2009-04-16 14:51:09    阅读:791 发布文章 一. 引言 %A %A 在现代操作系统里,同一时间可能有多个内核执行流在执行,因 ...

  8. Linux阻塞和同步机制

    Linux阻塞和同步机制 阻塞和非阻塞 阻塞和非阻塞是设备访问的两种基本方式.使用这两种方式,驱动程序可以灵活地支持阻塞与非阻塞的访问. 阻塞调用是指调用结果返回之前,当前线程被挂起.函数只有在得到结 ...

  9. gtest之断言宏的使用以及三种事件机制

    前面简单的介绍了一下gtest以及在Windows下如何安装gtest,今天再介绍一下在Linux下该如何安装. 本文重点: 在Linux下如何安装gtest: gtest下断言宏的介绍: gtest ...

  10. linux kobject-uevent(热插拔事件)

    sysfs文件系统主要功能是将系统中所有的设备通过一个拓扑结构全部展示出来,在系统启动的初期,系统通过mount命令将syfs文件系统挂载到/sys节点上, mount -t sysfs sysfs  ...

最新文章

  1. OpenCV中泛洪填充算法解析与应用
  2. [转](总结)Linux/UNIX的scp命令用法详解
  3. vGPU作为主流平台的进化之路
  4. mysql集群和主从区别_搭建MySQL主从集群,主从复制过程中同步延迟问题
  5. java视频压缩 lz4_一种视频序列帧的压缩方法、解压方法及装置与流程
  6. java为学生s1的age属性_求解java程序,题目如下
  7. 微信小程序——组件(二)
  8. siteweaver android动易客户端,动易SiteFactory实现SiteWeaver置顶功能
  9. 本科生学计算机视觉实际吗,成电信通学院本科生在全球计算机视觉顶会CVPR上发表研究成果...
  10. DEDECMS织梦后台更新网站栏目无反应一键更新无响应的解决方法
  11. Dango Web 开发指南 学习笔记 3
  12. Python学习笔记-数据分析-Pandas02-Dataframe
  13. 管家婆物流配货单快速实现批量拣货
  14. SpringBoot 自动配置初探
  15. 使用muscle进行多序列比对
  16. Codeforces Round #797 (Div. 3) F. Shifting String题解
  17. SSL/TLS - 什么是SSL?
  18. 数据挖掘实战(3)——时间序列预测ARIMA模型(附踩坑日志)
  19. 美通社企业新闻汇总 | 2019.2.14 | 燃石医学完成8.5亿融资;伊蒂之屋情人节携手中国区品牌大使黄明昊...
  20. IT产品是计算机类产品吗,IT产品是什么

热门文章

  1. 网站日志分析工具:WebLog Expert Lite
  2. 数据分类是否一定要求样本均衡
  3. 【论文分享】PathQG: 基于事实的神经问题生成
  4. 【小知识】二分类问题,应该选择sigmoid还是softmax?
  5. BERT 的演进和应用
  6. 谈谈我在自然语言处理进阶上的一些个人拙见
  7. 机器学习面试-处理聚类问题
  8. 表妹即将去读研,我送了她11个建议
  9. PyTorch自定义CUDA算子教程与运行时间分析
  10. 每日一题[LeetCode 689]三个无重叠子数组的最大和