Android Sensor Input类型 (三) Sensor Class

2024-04-18 10:58

本文主要是介绍Android Sensor Input类型 (三) Sensor Class,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Sensors Class驱动

传感器类支持是一般 HAL 支持的一部分。它的主要目的是使sensorsHAL 更加通用,所有与硬件相关的配置都由kermel 提供。为了支持此功能,内核驱动程序需要遵循接口。内核驱动程序应该实现几个关键的回调。为了统一规范,抽象出了 Sensor class;

Sensors class的逻辑相对简单,与最简单led子系统逻辑相似
向用户空间提供可供访问的device读写设备节点,
向sensor设备驱动提供统一的注册接口,定义了统一的 sensors_classdev 数据结构,规范了sensor设备驱动的架构。


下面来分析下sensors class驱动主要做了哪些事情。

注册class

static int __init sensors_init(void)
{sensors_class = class_create(THIS_MODULE, "sensors");  //创建 classif (IS_ERR(sensors_class))return PTR_ERR(sensors_class);sensors_class->dev_attrs = sensors_class_attrs;        //填充 class attrsreturn 0;
}
static void __exit sensors_exit(void)
{class_destroy(sensors_class);
}
subsys_initcall(sensors_init);  //比普通driver 更早的init
module_exit(sensors_exit);

主要的内容就是创建 名为sensor的class,并且填充其dev_attrs, 这样的设置之后,在这个class中创建的每一个device都将具备 dev_attrs中设置的读写函数,
也正是因为这点才使得每一个注册到这个class中的 sensor_classdev才具备统一规范的接口、下面来看下 对dev_attrs的设置。

配置ATTRS

static struct device_attribute sensors_class_attrs[] = {__ATTR(name, 0444, sensors_name_show, NULL),__ATTR(vendor, 0444, sensors_vendor_show, NULL),__ATTR(version, 0444, sensors_version_show, NULL),__ATTR(handle, 0444, sensors_handle_show, NULL),__ATTR(type, 0444, sensors_type_show, NULL),__ATTR(max_range, 0444, sensors_max_range_show, NULL),__ATTR(resolution, 0444, sensors_resolution_show, NULL),__ATTR(sensor_power, 0444, sensors_power_show, NULL),__ATTR(min_delay, 0444, sensors_min_delay_show, NULL),__ATTR(fifo_reserved_event_count, 0444, sensors_fifo_event_show, NULL),__ATTR(fifo_max_event_count, 0444, sensors_fifo_max_show, NULL),__ATTR(max_delay, 0444, sensors_max_delay_show, NULL),__ATTR(flags, 0444, sensors_flags_show, NULL),__ATTR(enable, 0664, sensors_enable_show, sensors_enable_store),__ATTR(enable_wakeup, 0664, sensors_enable_wakeup_show,sensors_enable_wakeup_store),__ATTR(poll_delay, 0664, sensors_delay_show, sensors_delay_store),__ATTR(self_test, 0440, sensors_test_show, NULL),__ATTR(max_latency, 0660, sensors_max_latency_show, sensors_max_latency_store),__ATTR(flush, 0660, sensors_flush_show, sensors_flush_store),__ATTR(calibrate, 0664, sensors_calibrate_show, sensors_calibrate_store),__ATTR_NULL,
};

这组文件节点的创建,实现了用户用户空间对sensor 设备驱动的访问控制,我们先以mmc3416x为例看下,在文件系统中生成的实际设备节点。

msm8909:/sys/class/sensors/mmc3416x-mag # ls
calibrate enable_wakeup             flags  max_delay   min_delay  power      sensor_power uevent
device    fifo_max_event_count      flush  max_latency name       resolution subsystem    vendor
enable    fifo_reserved_event_count handle max_range   poll_delay self_test  type         version

这里以name,poll_delay 为例 分析这些接口的实现:

static ssize_t sensors_name_show(struct device *dev,struct device_attribute *attr, char *buf)
{struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);
return snprintf(buf, PAGE_SIZE, "%s\n", sensors_cdev->name);
//就是直接将 在设备驱动中填充的sensors_cdev->name 返回
}
static ssize_t sensors_enable_store(struct device *dev,struct device_attribute *attr, const char *buf, size_t size)
{struct sensors_classdev *sensors_cdev = dev_get_drvdata(dev);ssize_t ret = -EINVAL;unsigned long data = 0;ret = kstrtoul(buf, 10, &data); //把用户空间传来的时间换算成unsight longif (sensors_cdev->sensors_enable == NULL) 
ret = sensors_cdev->sensors_enable(sensors_cdev, data);//回调sensors_cdev中的 enable 函数sensors_cdev->enabled = data;return size;
}

Sensor_classdev_register

从上面两个例子可以看出,实际在class中设备节点中的操作过程很简单,就是交互sensors_cdev中填充的 设备信息与函数回调,其中 sensors_cdev的获取是通过dev_get_drvdata(dev);来获取的。

这个device就是我们注册的device,在sensor设备驱动中有将设备结构体放到 device的私有数据中,这里再来获取。

达到相同的处理函数根据不同的device信息做不同的处理,那下面就看下针对不同device的sensors_cdev的注册,这也是sensors class对设备驱动提供的注册接口。

int sensors_classdev_register(struct device *parent,struct sensors_classdev *sensors_cdev)
{sensors_cdev->dev = device_create(sensors_class, parent, 0,sensors_cdev, "%s", sensors_cdev->name);  
//创建一个devicedown_write(&sensors_list_lock);
list_add_tail(&sensors_cdev->node, &sensors_list);
//将当前注册的sensor添加到sensor list中up_write(&sensors_list_lock);pr_debug("Registered sensors device: %s\n", sensors_cdev->name);return 0;
}
EXPORT_SYMBOL(sensors_classdev_register);

在创建设备时,parent传递一个device,在mmc3416 中是传递的 inputdev,当然也可以传我们的sensor设备结构, 传递sensor_cdev为创建device的私有数据,可以使用dev_get_drvdata(dev) 来获取出来。

在各个设备节点中都是根据不同的device 取出注册时传入的sensor_cdev结构体。如此即可完成对sensor设备驱动统一的处理。

简要图示框架:

这篇关于Android Sensor Input类型 (三) Sensor Class的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/914586

相关文章

IDEA如何将String类型转json格式

《IDEA如何将String类型转json格式》在Java中,字符串字面量中的转义字符会被自动转换,但通过网络获取的字符串可能不会自动转换,为了解决IDEA无法识别JSON字符串的问题,可以在本地对字... 目录问题描述问题原因解决方案总结问题描述最近做项目需要使用Ai生成json,可生成String类型

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

Mysql 中的多表连接和连接类型详解

《Mysql中的多表连接和连接类型详解》这篇文章详细介绍了MySQL中的多表连接及其各种类型,包括内连接、左连接、右连接、全外连接、自连接和交叉连接,通过这些连接方式,可以将分散在不同表中的相关数据... 目录什么是多表连接?1. 内连接(INNER JOIN)2. 左连接(LEFT JOIN 或 LEFT

Redis的Hash类型及相关命令小结

《Redis的Hash类型及相关命令小结》edisHash是一种数据结构,用于存储字段和值的映射关系,本文就来介绍一下Redis的Hash类型及相关命令小结,具有一定的参考价值,感兴趣的可以了解一下... 目录HSETHGETHEXISTSHDELHKEYSHVALSHGETALLHMGETHLENHSET

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Python中异常类型ValueError使用方法与场景

《Python中异常类型ValueError使用方法与场景》:本文主要介绍Python中的ValueError异常类型,它在处理不合适的值时抛出,并提供如何有效使用ValueError的建议,文中... 目录前言什么是 ValueError?什么时候会用到 ValueError?场景 1: 转换数据类型场景

C# dynamic类型使用详解

《C#dynamic类型使用详解》C#中的dynamic类型允许在运行时确定对象的类型和成员,跳过编译时类型检查,适用于处理未知类型的对象或与动态语言互操作,dynamic支持动态成员解析、添加和删... 目录简介dynamic 的定义dynamic 的使用动态类型赋值访问成员动态方法调用dynamic 的

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超

提示:Decompiled.class file,bytecode version如何解决

《提示:Decompiled.classfile,bytecodeversion如何解决》在处理Decompiled.classfile和bytecodeversion问题时,通过修改Maven配... 目录问题原因总结问题1、提示:Decompiled .class file,China编程 bytecode

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo