高通gpio配置读取分析

2019-01-27 20:40

Gpio配置

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/r0x01025000 读取值为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/r0x01025004这个寄存器得出: 00000003这个值

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

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


高通gpio配置读取分析.doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:保洁服务外包合同协议

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: