gpio2: gpio@fec30000 {
compatible = "rockchip,gpio-bank";
reg = <0x0 0xfec30000 0x0 0x100>;
interrupts = <GIC_SPI 279 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&cru PCLK_GPIO2>, <&cru DBCLK_GPIO2>;
gpio-controller;
#gpio-cells = <2>;
gpio-ranges = <&pinctrl 0 64 32>;
interrupt-controller;
#interrupt-cells = <2>;
};
这是一段设备树(Device Tree)的片段,用于描述一个名为gpio2的GPIO(通用输入输出)控制器的硬件信息。设备树在Linux内核中被广泛使用,尤其是在嵌入式系统中,用于描述硬件的组织结构和配置。下面是对这段设备树代码的详细解释:
-
gpio2: 这是GPIO控制器的标签名,用于在设备树中唯一标识这个节点。 -
gpio@fec30000: 这表示GPIO控制器的基地址是0xfec30000。@后面的数字是地址,gpio是节点名。 -
compatible = "rockchip,gpio-bank";: 这行指定了设备的兼容性字符串,表明这个GPIO控制器是由Rockchip公司生产的,属于gpio-bank类型。这有助于操作系统识别并加载适当的驱动程序。 -
reg = <0x0 0xfec30000 0x0 0x100>;: 这行定义了设备的寄存器地址范围。0x0和0xfec30000是起始地址,0x0和0x100表示地址长度是256字节(0x100十六进制等于256十进制)。 -
interrupts = <GIC_SPI 279 IRQ_TYPE_LEVEL_HIGH>;: 这行指定了中断的配置。GIC_SPI表示这是一个通用中断控制器(Generic Interrupt Controller)的SPI(Shared Peripheral Interrupt)中断,279是中断号,IRQ_TYPE_LEVEL_HIGH表示中断触发类型是电平高触发。 -
clocks = <&cru PCLK_GPIO2>, <&cru DBCLK_GPIO2>;: 这行指定了GPIO控制器使用的时钟源。&cru是对时钟单元(Clock Reset Unit)的引用,PCLK_GPIO2和DBCLK_GPIO2是具体的时钟信号名。 -
gpio-controller;: 这行表明这个节点是一个GPIO控制器。 -
#gpio-cells = <2>;: 这行指定了每个GPIO引脚配置所需的单元(cell)数量,这里是2个。通常,这两个单元分别用于指定引脚号和配置参数(如方向、上下拉等)。 -
gpio-ranges = <&pinctrl 0 64 32>;: 这行定义了GPIO控制器管理的引脚范围。&pinctrl是对引脚控制器的引用,0是起始引脚号,64是引脚总数,32可能是表示这个范围内的某些特定属性或分组。 -
interrupt-controller;: 这行表明这个节点也是一个中断控制器。 -
#interrupt-cells = <2>;: 这行指定了定义中断所需的单元数量,这里是2个。通常,这两个单元分别用于指定中断号和中断类型/配置。
综上所述,这段设备树代码详细描述了一个名为gpio2的GPIO控制器的硬件配置,包括其地址、中断配置、时钟源、GPIO引脚范围以及作为中断控制器的属性。这些信息对于操作系统正确识别和配置硬件至关重要。
526

被折叠的 条评论
为什么被折叠?



