1:高通文档说明
通过直接读取gpio相应配置寄存器的值来分析对应gpio的配置情况;
高通提供如下方式:
上面说明的是寄存器每位代表的含义,是以msm8994为例的,对于我们的msm8909可以参考msm8909的芯片手册
《80-NP408-2X_MSM8909_MSM8209_MSM8208 HARDWARE REGISTER DESCRIPTION
DOCUMENT FOR OEMS_R.pdf》
第134 TLMM_CSR这章节的说明
2读取方法:
有了这些寄存器配置的说明,接下来说明如何读取这些寄存器:
7.4 Check GPIO configuration
Android default command /system/bin/r can be used to check the TLMM_GPIO registers.
The examples use GPIO 12 and are based on the MSM8994 platform.
1. Check GPIO configuration with TLMM_GPIO_CFG_n
Register – TLMM_GPIO_CFGn, n=[0..145]: 0xFD510000 + 0x00001000 (0xFD511000) + 0x10 * (n)
For GPIO_12, TLMM_GPIO_CFG12 is: 0xFD510000+0x1000+0x10*0xC = 0xFD5110C0
adb root
adb shell
#/system/bin/r 0xFD5110C0
/system/bin/r 0xFD5110C0
fd5110c0: 00000200
bit[1:0] is0, that means NO-PULL
bit[5:2] is 0, that means FUNC_0 (normal GPIO)
bit[8:6] is 0, that means DRV_2_MA( 2mA drive strength)
bit[9] is 1, that means output enabled(GPIO behaves as output).
/system/bin/r can be used to change the register’s value as well:
#/sytem/bin/r 0xFD5110C0 0x0 /*Disable the output of GPIO_12, it makes the GPIO_12 as an input
gpio */
/system/bin/r 0xFD5110C0 0
fd5110c0: 00000000
2. Check GPIO status with TLMM_GPIO_IN_OUT_n
Register – TLMM_GPIO_IN_OUTn, n=[0..145]: 0xFD510000 + 0x00001004 (0xFD511004) + 0x10 * (n)
For GPIO_12, TLMM_GPIO_IN_OUT_12 is: 0xFD510000+0x1004+0x10*0xC = 0xFD5110C4
# /system/bin/r 0xFD5110C4
/system/bin/r 0xFD5110C4
fd5110c4: 00000000
Bit [1] is 0, which means GPIO_12 is output low.
3. Check GPIO interrupt settings with TLMM_GPIO_INTR_CFG_n
Register – TLMM_GPIO_IN_OUTn, n=[0..145]: 0xFD510000 + 0x00001004 (0xFD511004) + 0x10 * (n)
For GPIO_12, TLMM_GPIO_IN_OUT_12 is: 0xFD510000+0x1008+0x10*0xC = 0xFD5110C8
# /system/bin/r 0xFD5110C8
/system/bin/r 0xFD5110C8
fd5110c8: 000000e2
Bit[0] is 0, which means interrupt is not enabled for GPIO_12; it is not used as an interrupt pin.
简单概括下,上面的说明,高通提供了一个工具,这个工具在系统启动后的/system/bin/r目录下,用法是这样的:
/system/bin/r 地址
(这个地址就是需要读取寄存器的物理地址,详细地址可以看
《80-NP408-2X_MSM8909_MSM8209_MSM8208 HARDWARE REGISTER DESCRIPTION
DOCUMENT FOR OEMS_R.pdf》第134 TLMM_CSR这章节的说明)
3:实例说明
接下来我以一个gpio为例,去如何读取这个gpio的配置:
我们以gpio37为例:
首先查看gpio37配置的物理地址,在《80-NP408-2X_MSM8909_MSM8209_MSM8208 HARDWARE REGISTER DESCRIPTION DOCUMENT FOR OEMS_R.pdf》第134章:
其中n可以是0-112,代表msm8909的全部gpio口的配置地址,我们要读gpio37的,那么n=37,需要注意的一点是37需要转换为16进制,十进制37,十六进制就是25,
所以gpio37的配置寄存器地址就是:
0x01000000+0x1000*25 = 0x01025000
通过工具可以读取值:
/system/bin/r 0x01025000
读取值为000002c0
转换成2进制为1011000000
接下来查看每一位代表的含义:
其中 第0-1位代表的是gpio的内部上下拉,通过看结果可知0-1位都是0,代表了内部没有上下拉(No_PULL)
第2-5位代表这个gpio配置的功能,2-5位都是0,然后查看table134-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,
接下来可以看这个口是高还是低,通过下面这个寄存器:
通过/system/bin/r 0x01025004这个寄存器得出:
00000003这个值
因为这个gpio是输出所以看bit1位,bit1是1,所以是输出为高
另外也可以读其他的配置,如中断的配置等这里不再说明,操作是一样的: