高通msm mdm 总结

时间:2022-01-23 05:00:16

1. svn 获取工程代码命令:svn co svn+ssh://10.20.30.18/svn-repos/msm8916/branches/LA1.1-CS-r113502.2

2. 如何确定那些dtsi文件实际会用到。          修改代码 kernel/arch/arm/kernel/devtree.c中的函数 setup_machine_fdt 中以下这行:          pr_info("Machine: %s, model:%s\n", mdesc_best->name, model); 为          pr_err("Machine: %s, model:%s\n", mdesc_best->name, model);          并在 kenel log中查找关键字"Machine", 找到对应的module。          在目录 kernel/arch/arm/boot/dts下用以下命令查找dts  文件          grep model *.dts | grep "8916 MTP" ,其中 "8916 MTP" 就是以上 kernel log中找到的 model 名字。          用命令 grep include XXXX 查找 dtsi 文件,XXXX就是 上步查找到的dts 文件。

3. 解决JAVA 版本不对导致编译 java 原文件出错的问题。       Ubuntu 原先安装的JAVA版本是 1.6.0_24, 编译android 4.4 时导致编译JAVA文件出错。       需要重新安装版本为1.6.0_26版本的JAVA,方法如下:       (1). 把sun-java-jdk拷贝到unbuntu,给该目录下的3个文件添加可执行权限。 (2). 用以下命令安装:      sudo dpkg -i sun-java6-bin_6.26-0squeeze1_amd64.deb sun-java6-jdk_6.26-0squeeze1_amd64.deb sun-java6-jre_6.26-0squeeze1_all.deb

4. 调试质量不好的SD卡一般方法:       (1). 打开宏 MMC_DEBUG 可以查看以下LOG信息。       (2). 在函数 mmc_init_card 中每个发送命令之间加延时。       (3). 增加命令 cmd->cmd_timeout_ms 与 数据 data->timeout_ns 的超时时间。       (4). 增加GPIO的驱动能力,比如修改 msm8916.dtsi, msm8916-pinctrl.dtsi, 增加GPIO的驱动电流。

5. 获取工程代码,编译出错,错误信息:zip error: Invalid command arguments (cannot repeat names in zip file)    原因:svn 版本较低,需要升级 svn 版本到 1.7.9    解决方案:How to build svn 1.7.9,any puzzle pls contact zhanghongliang:       1, download subversion-1.7.9.tar.bz2 from http://subversion.apache.org/download/ 2, download apr-1.4.6.tar.bz2 & apr-util-1.5.2.tar.bz2 from http://apr.apache.org/download.cgi 3, download sqlite-autoconf-3071602.tar.gz from http://www.sqlite.org/download.html 4, un-tar sqlite-autoconf and make install it:   cd  sqlite-autoconf-3071602 ./configure sudo make sudo make install 5, un-tar apr-1.4.6 apr-util-1.5.2 into subversion folder, rename them to apr & apr-util 6, run ./configure, make, make install

6. 解决Ubuntu 下 adb 权限问题。         连接手机到 Ubuntu 系统,adb devices 提示:         List of devices attached                    ????????????    no permissions 这是因为访问adb设备需要root权限。 用以下命令修改 adb 权限可以解决问题。 sudo chown root:root adb sudo chmod a+x adb sudo chmod a+s adb adb kill-server

7. 用QCAT工具修改手机来电铃声音量。       (1). 在线修改            a. 打开QACT,点击 connect to phone, 连上手机。            b. 在 Audio use case 拦选 Audio PlayBack, Device us case 选 SPKR_PHONE_MONO            c. 在 CODEC_GAIN 栏选相应的增益值,比如9DB            d. 在手机端的设置菜单的铃声音量调节里面可以确认调整后的结果。            e. 可以在file菜单中把结果保存为文件。        (2). 离线修改文件,把改后的文件push 到手机            a. 打开QACT, 电击 Open File            b. 按以上b,c步骤修改增益值。            c. 在 file 菜单中保存文件结果。            d. 用adb 命令把结果文件 QRD_Speaker_cal.acdb push 到目录 /etc/acdbdata/QRD 下。

8. 解决 Ubuntu 系统上 VM VirtualBox 虚拟机识别USB设备问题。          需要修改组配置文件 /etc/group, 把用户加到组 vboxusers 里面去。          比如:vboxusers:x:126:topwise,zxc          vboxsuers是虚拟机的组,zxc是用户。

9. 把RAMDUMP抓到SD卡。           1. 确认2个宏是否定义在boot_proc代码中, FEATURE_BOOT_RAMDUMPS_TO_SD_CARD, SD_PATH           2. 在SD的根目录下创建文件 rdcookie.txt           3. 模拟一个死机条件,可以抓取RAMDUMPS,抓取的RAMDUMPS放在SD卡根目录的数字标号的目录下,抓完RAMDUMPS后手机自动重启。

10. 解析RAMDUP命令:  python ramparse.py --vmlinux /home/zxc/share/ramdump/1/vmlinux --auto-dump /home/zxc/share/ramdump/1 --gdb-path /usr/bin/gdb --nm-path  /usr/bin/nm --print-rtb 输出所有信息 python ramparse.py --vmlinux /home/zxc/share/ramdump/1/vmlinux --auto-dump /home/zxc/share/ramdump/1 --gdb-path /usr/bin/gdb --nm-path  /usr/bin/nm -x 把结果输出到一个目录,比如目录 dumpresult python ramparse.py --vmlinux /home/zxc/share/ramdump/1/vmlinux --auto-dump /home/zxc/share/ramdump/1 --gdb-path /usr/bin/gdb --nm-path /usr/bin/nm -x -o dumpresult

11. 通过 adb 发命令来触发 kernel panic 抓ramdump     adb shell     echo c > /proc/sysrq-trigger          设置 ramdump 属性为1,才能抓ramdump     setprop persist.sys.dload.enable 1          通过QXDM模拟死机抓DUMP,连上QXDM, 在command 里面输入以下命令:     send_data 75 37 03 00          可以用QPST Configuration 来抓RAMDUMP     RAMDUMP保存在目录 C:\Documents and Settings\All Users\Application Data\Qualcomm\QPST\Sahara\ 下.

1. 修改I2C_4的驱动能力解决I2C通信不稳定问题。         由于I2C_4的通信不稳定导致SMB1360充电功能不正常,         解决方案是修改文件msm8916-pinctrl.dtsi 中代码:         i2c_4_active: i2c_4_active {  drive-strength = <4>;  /* 4 MA */  bias-disable = <0>;  /* No PULL */  };

把驱动电流改成4mA, 基本可以解决I2C通信不稳定问题。

2. 功耗相关NV项: 1027 = 0 1895 = 0 1892 = 0 1962 = 0 4679 = 16 4201 = 0 3851 = 0 3852 = 6 7157 = 1 69745 rxd_enable = 0

3. 修改系统默认时间,现在默认时间是1970-1-1, 可以改成别的时间,比如:2010-1-1   修改内核代码中文件 Rtc-lib.c 中的函数 rtc_time_to_tm ,把1970改成2010即可。   8916平台的内核rtc控制文件为 qpnp-rtc.c

4. 解决项目P9388睡眠底电流过大问题。        测试发现睡眠时底电流有9.3mA,跟踪发现系统睡眠时陀螺仪没有进入睡眠模式,        即函数 mpu3050_suspend 没有调用 mpu3050_set_power_mode 进入睡眠模式,        修改函数 mpu3050_suspend, 屏蔽掉语句if (sensor->enable) ,        调用 mpu3050_set_power_mode(client, 0); 让陀螺仪进入睡眠,        底电流可以达到3mA以下。

5. 解决接近传感器睡眠唤醒后不能工作问题。        跟踪代码发现这个问题跟接近传感器tmd2772驱动的suspend/resume的电源控制有关,        原代码并没有实现电源控制的代码,需要在睡眠/唤醒函数 taos_suspend/taos_resume 加上disable/enable vreg_l17的代码。        调用的核心函数为:regulator_disable(data->vdd); regulator_enable(data->vdd);        在resume函数里面还需要调用函数 flush_regs 来恢复 tmd2772 到初始状态。

6. 在内核里面测试一个函数的调用时间。    (1). 先在函数的开头调用 ktime_t starttime = ktime_get(); 得到开始时间。    (2). 在函数的末尾再调用函数 calltime = ktime_get(); 得到结束时间。    (3). 调用函数 ktime_sub(calltime, starttime) 得到时间差。    (4). 用函数 ktime_to_ns 把时间差的单位转成nS级别。    (5). 再用函数 do_div(usecs64, NSEC_PER_USEC); 转成微秒级。    (6). 调用printk打印时间。具体的可以参考函数 dpm_show_time    (7). 完整的例子代码:    ktime_t starttime; ktime_t endtime; u64 usecs64; int usecs; starttime = ktime_get(); //you call your function here ... endtime = ktime_get(); usecs64 = ktime_to_ns(ktime_sub(endtime, starttime)); do_div(usecs64, NSEC_PER_USEC); usecs = usecs64; if (usecs == 0) usecs = 1; printk("%s: after %ld.%03ld msecs\n", __FUNCTION__, usecs / USEC_PER_MSEC, usecs % USEC_PER_MSEC);

7. 把函数改为宏定义,并在宏定义中打印文件名,函数名及行数,    可以确定函数是在哪个文件,函数中调用。   比如把函数 dpm_resume 原来定义的函数名改为 _dpm_resume,   然后在声明的文件 pm.h 中 把声明函数也改为 _dpm_resume,   并且在这个文件中定义宏 #define dpm_resume(state)do{printk("file = %s, func = %s, line = %d\n", __FILE__, __FUNCTION__, __LINE__); _dpm_resume(state);}while(0)   通过打印的LOG就可以确定是在 main.c 的函数 dpm_resume_end 的 866 行调用了这个函数。

8. 按20点所说的方法定位到内核睡眠/唤醒的调用函数为:  state_store->pm_suspend(/kernel/kernel/power/suspend.c)->enter_state->suspend_devices_and_enter->dpm_resume_end->dpm_resume->device_resume  睡眠函数调用流程:  (1). suspend_devices_and_enter (kernel/kernel/power/suspend.c) (2). suspend_enter (kernel/kernel/power/suspend.c) (3). error = suspend_ops->enter(state); (suspend_ops-->lpm_suspend_ops) (4). lpm_suspend_enter (kernel/drivers/cpuidle/lpm_levels.c) (5). lpm_enter_low_power (kernel/drivers/cpuidle/lpm_levels.c) (6). msm_cpu_pm_enter_sleep (kernel/drivers/power/qcom/msm-pm.c) (7). exit_stat = execute[mode](from_idle); (mode=3, execute[mode]=msm_pm_power_collapse) (8). msm_pm_power_collapse (kernel/drivers/power/qcom/msm-pm.c) (9). msm_pm_spm_power_collapse (kernel/drivers/power/qcom/msm-pm.c) (10). cpu_suspend (kernel/arch/arm/kernel/suspend.c) (11). __cpu_suspend (kernel/arch/arm/kernel/sleep.s)

9. 恢复某个文件的老的版本,比如恢复文件 frameworks/base/api/current.txt 的 744 版本。           (1). cd msm8916/branches/LA1.1-CS-r113502.2/LINUX/android/frameworks/base           (2). svn co -r 744 svn+ssh://10.20.30.18/svn-repos/msm8916/branches/LA1.1-CS-r113502.2/LINUX/android/frameworks/base/api

10. 改变USB组合配置,使手机能用DIAG口抓QXDM LOG           1. 登陆ADB              adb shell              su           2. 修改USB配置属性              setprop persist.sys.usb.config mtp,diag,adb              需要组合值需要参考文件 init.qcom.usb.rc, 需要找到这个文件里面定义的值。

11. 设置虚拟电池电量, 比如设置90%的电量      修改文件 init.qcom.post_boot.sh,加上这行代码:      echo 90 > /sys/module/qpnp_bms/parameters/bms_fake_battery

12. 在应用层修改代码调整重力传感器的工作频率。      修改文件 SensorManager.java中的方法 getDelay, 一般用的是 SENSOR_DELAY_UI 对应的值。

13. 控制背光API接口调用流程: LightsService(LightsService.java) ---> setBrightness(JAVA api 方法) ---> setLightLocked(JAVA api 方法)  ---> setLight_native(JNI 接口) ---> set_light(HAL 层接口) ---> set_light_backlight(HAL 层接口) ---> write_int(LCD_FILE, brightness);(打开文件 /sys/class/leds/lcd-backlight/brightness,写相应的值)

14. 修改电池参数配置,使项目能显示线性充电的电量百分比.      (1). 修改项目的配置dtsi文件,加上battery-data, 比如hy506项目的文件 msm8916-qrd-506.dtsi, 加上代码:       / { hy506_batterydata: qcom,battery-data { qcom,rpull-up-kohm = <100>; qcom,vref-batt-therm = <1800000>; #include "batterydata-hy506-4v2-2000mah.dtsi" }; }; (2). 修改项目 dts 文件,比如 msm8916-qrd-506.dts 在 pm8916_bms 里面加上 battery-data, 代码如下: &pm8916_bms { status = "ok"; qcom,force-bms-active-on-charger; qcom,battery-data = <&hy506_batterydata>; };

15. 用SVN查看版本1到版本2之间的修改的文件. svn log -r v1:v2 -v 比如查看 r867 到 r1152之间的修改: svn log -r 867:1152 -v