0


终于搞懂Linux 设备树中的#address-cells,#size-cells 和reg 属性

目录

  • 一、前置知识 - 1. 处理器平台- 2. reg 属性的基本格式- 3. reg 属性的作用 - reg 用法
  • 二、#address-cells 和 #size-cells 属性 - 1. 示例1 - 2. 示例2- 3. 示例3

一、前置知识

要理解

#address-cells

#size-cell

这两个属性,就要先了解

reg

属性。

1. 处理器平台

下面的介绍,主要基于

IMX6ULL

进行

2. reg 属性的基本格式

reg = <address1 length1 address2 length2 address3 length3 ...>

3. reg 属性的作用

reg

属性一般用于描述设备地址空间资源的信息,一般都是某个外设的寄存器地址范围信息。

reg 用法

imx6ull.dtsi

文件中

      qspi: qspi@021e0000 {#address-cells = <1>;#size-cells = <0>;
        compatible ="fsl,imx6ull-qspi", "fsl,imx6ul-qspi";
        reg =<0x021e0000 0x4000>, <0x60000000 0x10000000>;...
      };

二、#address-cells 和 #size-cells 属性

#address-cells

#size-cells

都是

32

位的整形数据,用来表示当前节点和子节点 的

reg

属性的地址信息(

address

)和 长度信息

length

的所占用的字长(32位)。

1. 示例1

    aips1: aips-bus@02000000 {
      compatible ="fsl,aips-bus", "simple-bus";#address-cells = <1>;#size-cells = <1>;
      reg =<0x02000000 0x100000>;
      ranges;...
      }

这里

address-cells = 1

,

size-cells = 1

, 表示

reg

属性中,地址信息的长度是

1

个字长,地址长度信息也是

1

个字长,即是:

address = 0x02000000, length = 0x100000

(1M)

刚好跟参考手册 system memory map 中的AIPS1 的地址一致。

在这里插入图片描述

2. 示例2

  alphaled {#address-cells = <1>;#size-cells = <1>;
    compatible ="atkalpha-led";
    status ="okay";
    reg =< 0X020C406C 0X04    /* CCM_CCGR1_BAE       */
        0X020E0068 0X04    /* SW_MUX_GPIO1_IO03_BASE   */
        0X020E02F4 0X04    /* SW_PAD_GPIO1_IO03_BASE  */
        0X0209C000 0X04    /* GPIO1_DR_BASE       */
        0X0209C004 0X04>;  /* GPIO1_GDIR_BASE       */
  };

这里

address-cells = 1

,

size-cells = 1

, 表示

reg

属性中,地址信息的长度是

1

个字长,地址长度信息也是

1

个字长。

按照

reg = <address length>

这样的规则解析:

  • address = 0X020C406C 刚好是寄存器 CCM_CCGR1的起始地址;
  • length = 0x04 ,表示寄存器是4byte的长度,即是32bits

所以上述reg 属性的第一行

0X020C406C 0X04

描述的是寄存器

CCM_CCGR1

的地址信息。

在这里插入图片描述

3. 示例3

在内核源码的

falconfalls.dts

      pci@1,0 {#address-cells = <3>;#size-cells = <2>;
        compatible ="intel,ce4100-pci", "pci";
        device_type ="pci";
        bus-range =<11>;
        reg =<0x0800 0x0 0x0 0x0 0x0>;...
        }

这里

address-cells = 3

,

size-cells = 2

, 表示

reg

属性中,地址信息的长度是

3

个字长,地址长度信息是

2

个字长,即是:

address = 0x0800 0x0 0x0, length = 0x00 0x00

本文转载自: https://blog.csdn.net/gdut_liujiangyi/article/details/138921632
版权归原作者 gdut_llkkyy 所有, 如有侵权,请联系我们删除。

“终于搞懂Linux 设备树中的#address-cells,#size-cells 和reg 属性”的评论:

还没有评论