10

我一直在学习 linux 设备树,我们一直在尝试开始移植一些旧代码以使用它们。我在使用 gpio 控制器节点时遇到了一点问题:

gpio1: gpio-controller@c00 {
    #gpio-cells = <2>;
    compatible = "cavium,octeon-3860-gpio";
    reg = <0xc00 0x100>;
    gpio-controller;
    /* Interrupts are specified by two parts:
     * 1) GPIO pin number (0..15)
     * 2) Triggering (1 - edge rising
     *                2 - edge falling
     *                4 - level active high
     *                8 - level active low)
     */
    interrupt-controller;
    interrupt-cells = <2>;
    interrupts = <0 24>, <1 25>, <2 26>, <3 27>;

};

我正在尝试将某些 IRQ 映射到 GPIO 引脚,但是,它似乎只将第一个 <0 24> IRQ 24 映射到 gpio 引脚 0。我查看了源代码,它似乎永远不会交互'中断',尽管设备树绑定文本文件似乎暗示它会(devicetree/bindings/gpio/cavium-octeon-gpio.txt)。有谁知道我如何将一些中断映射到不同的 gpio 引脚?

4

2 回答 2

6

平台之间的gpio处理仍然不是100%相同,所以我会给你它的要点,你可能需要适应你的平台(找到一个使用相同或相似SoC的dts)。我的平台是 Freescale imx.6 这是它的要点:

第一:不理gpio1节点。(它可能在您从上游供应商处获得的 dtsi 中正确设置)

第二:如果你想.eg gpio 1 15 是一个中断,在你想消耗gpio中断的设备节点中高电平有效,添加

interrupt-parent = <&gpio1>;
interrupts = <15 IRQ_TYPE_LEVEL_HIGH>;

例如:来自 arch/arm/boot/dts/imx6qdl-gw52xx.dtsi

touchscreen: egalax_ts@04 {
        compatible = "eeti,egalax_ts";
        reg = <0x04>;
        interrupt-parent = <&gpio7>;
        interrupts = <12 2>;
        wakeup-gpios = <&gpio7 12 GPIO_ACTIVE_LOW>;
};
于 2015-01-05T18:05:47.360 回答
1

我不熟悉你的机器,但如果你看这里:

https://elinux.org/Device_Tree_Usage#How_Interrupts_Work

您将看到中断说明符用于定义它们的节点的中断控制器(即父中断控制器),而不是用于节点本身。

由于您甚至没有显示在何处以及是否实际启用了中断(引脚,触发器),我假设您不知道这一点。

那么gpio1的中断控制器节点长什么样子呢?

它真的期望以 (pin, irq) 的形式从同一个源接收多个中断吗?

例如,在 am335x 上,gpio1 上的所有中断都映射到 OMAP35 INTC 控制器上的特定索引,这意味着在 gpio1 节点中只定义了 1 个中断,通知 INTC 是否在 gpio1 上发生了中断。

于 2014-06-25T14:04:39.720 回答