linux调试技巧(1) : 基于高通平台的寄存器配置读取

Linux 调试技巧(1)

平台调试中难免需要查看底层寄存器配置,对于高通某些平台,系统提供了工具读取这些值:
举例说明(高通平台中):
可以使用**/system/bin/r** 这个工具
接下来我以一个gpio为例,去如何读取这个gpio的配置:
我们以gpio37为例:
首先查看gpio37配置的物理地址,在芯片手册中找到:
linux调试技巧(1) : 基于高通平台的寄存器配置读取
其中n可以是0-112,代表msm8909的全部gpio口的配置地址,我们要读gpio37的,那么n=37,需要注意的一点是37需要转换为16进制,十进制37,十六进制就是25,
所以gpio37的配置寄存器地址就是:
0x01000000+0x1000*25 = 0x01025000
通过工具可以读取值:
/system/bin/r 0x01025000
读取值为000002c0
转换成2进制为1011000000
接下来查看每一位代表的含义:
linux调试技巧(1) : 基于高通平台的寄存器配置读取linux调试技巧(1) : 基于高通平台的寄存器配置读取
其中 第0-1位代表的是gpio的内部上下拉,通过看结果可知0-1位都是0,代表了内部没有上下拉(No_PULL)
第2-5位代表这个gpio配置的功能,2-5位都是0,然后查看
linux调试技巧(1) : 基于高通平台的寄存器配置读取
配置的是普通gpio口功能。

6-8位代表的是gpio的驱动能力,6-8位是011 也就是0x3 ,查表得驱动能力为:
0x3: DRV_8_MA
(Sets the drive strength to 8mA. When in RFFE mode, sets output
cap to 61-79 pF)
最后第9位代表是输入还是输出,1代表是output enable:所以gpio是输出。
所以可以得出gpio37的配置:gpio_out 8ma no_pull,

接下来可以看这个口是高还是低,通过下面这个寄存器:
linux调试技巧(1) : 基于高通平台的寄存器配置读取
通过/system/bin/r 0x01025004这个寄存器得出:
00000003这个值

因为这个gpio是输出所以看bit1位,bit1是1,所以是输出为高

另外也可以读其他的配置,如中断的配置等这里不再说明,操作是一样的: