Gpio配置读取

1:高通文档说明

通过直接读取gpio相应配置寄存器的值来分析对应gpio的配置情况;

 

高通提供如下方式:

 Gpio配置读取_第1张图片

 Gpio配置读取_第2张图片

 

上面说明的是寄存器每位代表的含义,是以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章:

 Gpio配置读取_第3张图片

其中n可以是0-112,代表msm8909的全部gpio口的配置地址,我们要读gpio37的,那么n=37,需要注意的一点是37需要转换为16进制,十进制37,十六进制就是25,

所以gpio37的配置寄存器地址就是:

0x01000000+0x1000*25 = 0x01025000

通过工具可以读取值:

/system/bin/r   0x01025000  

读取值为000002c0

转换成2进制为1011000000   

接下来查看每一位代表的含义:

 Gpio配置读取_第4张图片

 Gpio配置读取_第5张图片

其中 0-1位代表的是gpio的内部上下拉,通过看结果可知0-1位都是0,代表了内部没有上下拉(No_PULL

2-5位代表这个gpio配置的功能,2-5位都是0,然后查看table134-1

 Gpio配置读取_第6张图片

配置的是普通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

 

接下来可以看这个口是高还是低,通过下面这个寄存器:

 Gpio配置读取_第7张图片

 

通过/system/bin/r   0x01025004这个寄存器得出:

  00000003这个值

 

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

 

 

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

 

 Gpio配置读取_第8张图片

 

你可能感兴趣的:(Gpio配置读取)