0

我使用的是 Xavier AGX,在启动时我在 dmesg 上发现了以下输出:

[    0.963531] mc-err: mcerr ops are set to t19x
[    0.971308] iommu: Adding device 2600000.dma to group 57
[    0.978632] GPIO line 490 (pcie-reg-enable) hogged as output/high
[    0.978710] GPIO line 289 (pcie-reg-enable) hogged as output/high

如何在设备树(tegra194-p2888-0000-a00.dtsi)中写成:

  gpio@2200000 {
          pcie-reg-enable {
                  gpio-hog;
                  gpios = <TEGRA194_MAIN_GPIO(Z, 2) GPIO_ACTIVE_HIGH
                           TEGRA194_MAIN_GPIO(A, 1) GPIO_ACTIVE_LOW>;
                  label = "pcie-3v3-reg", "pcie-12v-reg";
                  output-high;
                  status = "okay";
          }; 

Dtc 解码 (/boot/dtb/tegra194-p2888-0001-p2822-0000.dtb) 给出:

pcie-reg-enable {
    gpio-hog;
    gpios = <0xca 0x0 0x1 0x1>;
    label = "pcie-3v3-reg", "pcie-12v-reg";
    output-high;
    status = "okay";
};

我很困惑为什么两者的输出都设置为 HIGH ?是不是一低一高?PS:我对设备树不熟悉,请帮助我。

4

1 回答 1

0

GPIO_ACTIVE_LOW设置意味着数据值在写入硬件之前将在软件中进行逻辑反转,并且来自硬件的原始数据值将在返回给调用者之前进行逻辑反转。(也有绕过这种逻辑反转的 GPIO 访问函数的“原始”变体。)

DTS 属性意味着 GPIO 线将output-high;被配置为具有高信号电平的输出。

对于两个 GPIO,两者都将配置为具有高信号电平的输出,但具有GPIO_ACTIVE_LOW设置的一个将具有逻辑值 0(除非您进行“原始”读取),而具有该GPIO_ACTIVE_HIGH设置的一个将具有逻辑值值 1。如果您使用设置将值 1 写入(但不是“原始”写入)GPIO GPIO_ACTIVE_LOW,其输出将变为低信号电平。

于 2020-04-29T11:07:10.113 回答