微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 手机设计讨论 > MTK手机平台交流 > SensorService发生NE分析

SensorService发生NE分析

时间:10-02 整理:3721RD 点击:
[DESCRIPTION]

在分析NE时,可能会遇到sensorService部分的NE,NE log如下:
Abort message: 'VALUE& android::KeyedVector<KEY,
VALUE>::editValueFor(const KEY&) [with KEY = int; VALUE =
android::SensorDevice::Info]: key not found'
backtrace:
#00 pc 0003d480 /system/lib/libc.so (tgkill+12)
#01 pc 00016959 /system/lib/libc.so (pthread_kill+52)
#02 pc 0001756f /system/lib/libc.so (raise+10)
#03 pc 00013ea5 /system/lib/libc.so (__libc_android_abort+36)
#04 pc 00012524 /system/lib/libc.so (abort+4)
#05 pc 000083e9 /system/lib/libcutils.so (__android_log_assert+88)
#06 pc 00007a3b /system/lib/libsensorservice.so
#07 pc 00008087 /system/lib/libsensorservice.so

[ANALYSIS]

Google默认设计的sensorService中,判定当从hal层获取到的sensorlist中有gyrosensor时,就会注册虚拟的sensor type, (这里以RotationVectorSenso为例)


虚拟的sensor type去使能的时候就会去使能acc sensor,mag sensor,gyro sensor3个实体sensor。此时若acc sensor 或者mag sensor不在HAL的sensor list中,则就会出现NE (这里以RotationVectorSenso为例)



[root CAUSE]

Case1:客户实际上没有gyro sensor,但却在ProjectConfig.mk文件中配置了gyro
sensor
Case2:客户实际上有gyro sensor,没有mag sensor。配置也正确。

[SOLUTION]

对于case1:
正确配置ProjectConfig.mk文件中的gyro sensor即可。
对于case2:
请按照下面的方法修改:
修改alps\php?mod=tag&id=6090" target="_blank" class="relatedlink">Frameworks\native\services\sensorservice\SensorService.cpp的OnFisrtRef()方法


备注:
这里的修改只是针对project中没有mag sensor的情况。

谢谢分享

谢谢分享,小编解决了我的问题!非常感谢

谢谢分享,小编解决了我的问题!非常感谢

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top