高通 8x26 andorid light sensor(TSL258x) 开发

前言
8926平台的sensor架构与之前的平台完全不同,实际上已经脱离了linux。此平台所有的sensor由adsp芯片控制,代码在modem端,编译和烧录也完全不同,下面以TSL2581为例进行说明。

一、 驱动
集成光传感器TSL2581
    1. 驱动程序结构可以参考高通默认的光感驱动文件sns_dd_als_bh1721.c或sns_dd_als_max44009.c或sns_dd_alsprx_tmd277x.c,主要是填充结构体 sns_ddf_driver_if_s;其成员:
         init,
         reset,
         get_data,
         set_attrib,
         get_attrib,
         必须填充,因为sns_smgr_dd_init()对这它们进行检查;
     另外probe成员也要填充,因为sns_smgr_parse_reg_devinfo_resp()中代码逻辑有问题,当probe为NULL时,只会填充第一个此类型的sensor的配置。

    2. 寄存器配置,电路参考设计要查看 TSL2581的数据手册;

    3. TSL2581 和 TMD277X都是TAOS公司的,参考它写最好。如果可以从fae获取驱动代码更好,基本不需要修改,改正编译错误之后就可以使用。
       由于芯片在电路板的方向不同,G-sensor,gyro和compass需要调换x、y、z轴的映射,只需在sensor_def_qcomdev.conf文件中修改。

二、 移植
   参考高通文档“80-N7635-1_E_Snapdragon_Sensors_Core_New_Sensor_Driver_Integration_LA.pdf”
1. Add the entry function for the new driver in adsp_proc\sensors\dd\qcom\inc\sns_dd.h:
     extern sns_ddf_driver_if_s sns_als_tsl2581_driver_fn_list;

2. Add the new driver files in adsp_proc\sensors\dd\qcom\src in the ADSP build
    sns_dd_als_tsl2581.h
    sns_dd_als_tsl2581.c

3. update the adsp_proc\sensors\dd\qcom\build\dd_qcom.scons file;  

      "${BUILDPATH}/sns_dd_als_tsl2581.c",

4. Configure Sensors.scons to compile the new files. To include the driver, in adsp_proc\sensors\build\Sensors.scons, add:

        env.Append(CPPDEFINES = ["CONFIG_SUPPORT_TSL2581"])

5.Update the sns_reg_common.h files on both the ADSP and APSS builds to add UUID:

     UUID可以使用在终端使用命令生成:uuidgen
    ADSP – adsp_proc\Sensors\common\inc\sns_reg_common.h
    APSS – android\vendor\qcom\proprietary\sensors\dsps\sensordaemon\common\inc\ sns_reg_common.h
    #define SNS_REG_UUID_TSL2581 \

      {0x84,0x2a,0xad,0xa7,0xc5,0x9b,0x4c,0x07,0xa2,0xf9,0xc8,0x2a,0xe4,0x03,0x43,0xa6}

   APSS端主要是为了调试使用,实际的驱动中不加也可以。
6. Update the SMGR function pointer map so that the SMGR can associate the new UUID with the new DD function pointer.
   In adsp_proc/Sensors/smgr/src/common/sns_smgr_init.c,update smgr_sensor_fn_ptr_map[]:
    #ifdef CONFIG_SUPPORT_TSL2581
    { SNS_REG_UUID_TSL2581, &sns_als_tsl2581_driver_fn_list},

    #endif

7. Update the configuration file "sensor_def_qcomdev.conf":

    在对应的硬件、平台后面修改,1966,1967是ALS/PROX sensor的UUID,1976是从设备地址,一般添加新sensor只修改这三项,其它项使用默认值。
    1967 0xa64303e42ac8f9a2   0x00010001
    1966 0x074c9bc5a7ad2a84  0x00010001
    1976 0x39               0x00010001

     例如:sensor_def_qcomdev.conf的内容形如:

########################################################################

:hardware 8974
:platform
:property
:soc_id

1903 0x8d79ae42524820ad 0x00010001
1902 0xcc4575757b462d60 0x00010001
1906 12 0x00010001

:hardware 8226
:platform

1903 0x8d79ae42524820ad 0x00010001
1902 0xcc4575757b462d60 0x00010001
1906 12 0x00010001
:platform SKUG

1903 0x8d79ae42524820ad 0x00010001
1902 0xcc4575757b462d60 0x00010001
1906 12 0x00010001

########################################################################

我的hardware 属于8226,platform属于 SKUG,我就要在最下面添加。
关于sensor_def_qcomdev.conf中每一项代表的内容定义在vendor/qcom/proprietary/sensors/dsps/api/sns_reg_api_v02.h中。
下面列举常用项:
700,701,702 G-sensor的轴映射
800,801,802 gyro的轴映射
900,901,902 compass的轴映射
3801 是否使用高通compass校准库,1表示使用,0表示不使用
1900 是否支持兼容,0表示支持,1表示不支持
不支持兼容时的配置起始地址:
1902 Accelerometer            
1918 Gyroscope                
1934 Magnetometer             
1950 Pressure                 
1966 Proximity/Ambient Light
兼容时的配置起始地址:
以ALS/PROX为例:
2300 1 //这一项配置为1,表示支持距离光感兼容功能
2301 2 //这一项配置为2,表示支持两种距离光感芯片
2302-2312 这是第一种芯片的配置
2313-2323 这是第二种芯片的配置  
注意:这里的选项顺序和只支持一个芯片的顺序的不同
可以参看vendor/qcom/proprietary/sensors/dsps/api/sns_reg_api_v02.h,里面的代码比较易懂。

三、编译下载
0. 只需要在modem端编译,先编译adsp_proc,再编译NON-HLOS。
1. Push the updated sensor_def_qcomdev.conf file to the /etc/ directory of the hardware:
    >>adb push sensor_def_qcomdev.conf /etc/
    >>adb shell chmod 644 /etc/sensor_def_qcomdev.conf

2. remove the existing registry file "sns.reg" from the /data/misc/sensors/ directory
    >>adb shell rm /data/misc/sensors/sns.reg
    >>adb shell sync
    >>adb reboot

3. compilation completes successfully,
    (1)To load the ADSP image(adsp.b00...adsp.mdt) to the /firmware/image/ directory of the hardware
       >>adb root
       >>adb remount
       >>adb shell mount -o remount rw /firmware
       >>adb push adsp.b00 firmware/image

       :

       :

       >>adb push adsp.mdt firmware/image
      开始我按照高通文档下载到/etc/frimware/,也起作用,后来高通工程师告诉我应该下载到firmware/image/
      需要强制修改权限:
    >>adb shell mount -o remount rw /firmware

    (2)第一种下载方法太麻烦,直接下载NON-HLOS.bin:
       >>adb reboot bootloader
       >>fastboot flash modem NON-HLOS.bin
       >>fastboot reboot

四、调试
 1.调试主要依靠QXDM抓取log,由于init函数和probe函数是在手机与QXDM建立连接之前完成的,QXDM无法打印里面的log,所以我们一般加入全局变量,然后在其他已确定肯定会执行的函数中打印出来,比如其它已正常工作的sensor的get data函数,记得打开打印log的宏。

 2.    编译下载完成后开机,先导出sns.reg,
     >>adb pull data/misc/sensors/sns.reg
       然后使用 Ultraedit 打开sns.reg查看是否将sensor_def_qcomdev.conf中添加的UUID解析成功。

       对应关系如下:
       sensor     sensor_def_qcomdev.conf              sns.reg           
       accel          1903 1902                         1710h
       gyro           1918 1919                         1740h
       Magnetometer   1934 1935                         1770h
       Pressure       1951 1950                         17a0h
       als+prox       1967 1966                         17d0h

       没成功的原因:
       1. sensor_def_qcomdev.conf的权限没有修改。 请重新执行步骤三的2和3
       2. 在移植第7步中添加位置错误,请确认硬件,平台

3.   使用sns_cm_test工具测试:

      >>adb shell
      >>cd /system/bin/
      >>sns_cm_test -r 20 -d 1 -s 40 -t 1
 
      参数说明: -r代表rate,
      其它sensor测试命令:
      sns_cm_test -r 20 -d 1 -s 40 -t 0 测试prox
      sns_cm_test -r 20 -d 1 -s 0  测试G-sensor
      sns_cm_test -r 20 -d 1 -s 10 测试GYRO
      sns_cm_test -r 20 -d 1 -s 20 测试MAG
      sns_cm_test -r 20 -d 1 -s 30 测试PRESS

      (1) 如果提示没有sns_cm_test命令,可能是被你们公司去掉默认编译了,可以手动编译,然后倒入手机的/system/bin/
      执行如下命令:
       >>. build/envsetup.sh
       >>choosecombo 1 1 2
       >>make sns_cm_test -j4
       其中第二条命令是我们公司这个项目的选项,没有可以不执行

     (2) 如果提示参数不正确,那就需要修改vendor/qcom/proprietary/sensors/dsps/test/src/sns_cm_test.c 文件,将光感的测试添加进去,按下面修改,重新编译即可,然后执行(1)

int main( int argc, char * const argv[])
{
sensor1_handle_s *hndl1;
int rate = 30;
int duration = 1;
int sensor_id = SNS_SMGR_ID_ACCEL_V01;
int data_type = SNS_SMGR_DATA_TYPE_PRIMARY_V01;
int opt;

// socketpair( AF_UNIX, SOCK_SEQPACKET, 0, socket_pair );

while( (opt = getopt(argc, argv, "r:h:d:s:t:" ))!= -1 ) {
switch(opt) {
...
case 's':
sensor_id = atoi(optarg);
break;
case 't':
data_type = atoi(optarg);
break;
case '?':
fprintf(stderr, usage_fmt, argv[0]);
exit(0);
default:
break;
}
}
...
smgr_req->Item[0].SensorId = sensor_id;
printf("Asking sensor data with type %d",data_type);
smgr_req->Item[0].DataType = data_type;
...

  (3)此命令 会测试光sensor,打印出ID,TYPE和数值等,如果没有说明集成失败。可能原因,硬件或驱动代码问题。
  (4)软件检查:
       a.初始化是否成功;
       b.i2c地址冲突;
       c.读写寄存器是否成功,数值是否正确;
       d.相关函数是否调用,执行;
  (5)硬件检查,根据datasheet检查电路图,测量相应引脚电压,测量I2C引脚波形,光和距离传感器的探头是否因为装机不适被遮挡。
       实例:
       调试GYRO mpu3050时,初始化成功,读写寄存器也全部返回成功,但是读取的测量数据全是0。最后发现硬件供电电压偏低,原因是缺少上拉电阻。
 
五、其它       
1. snesor_def_qcomdev.conf解析可以查看ap端代码 sns_reg_la.c
2. compass使用供应商提供的校准库,conf文件中3801置0,然后把供应商提供的校准库(形如libAKM8975.so)放到手机/system/vendor/lib/
3. 开启CIT菜单中gyro,compass测试项:
   修改: device/qcom/br01/overlay/packages/odm/apps/Tools/res/values/config_cit.xml
   编译: make clean-Tools;  make Tools;
   push: adb push Tools.apk  /system/app
4. 使用AndroSensor测试sensor:
   安装:>>adb install AndroSensor_com.fivasim.androsensor_45.apk
5. 没有屏幕时,使用神器调试
   打开神器:>>python arobot3.1.py   

你可能感兴趣的:(驱动开发)