终于搞懂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 = <1 1>;
        reg = <0x0800 0x0 0x0 0x0 0x0>;
        ...
        }

这里address-cells = 3,size-cells = 2 , 表示 reg属性中,地址信息的长度是3个字长,地址长度信息是2个字长,即是:address = 0x0800 0x0 0x0, length = 0x00 0x00

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

gdut_llkkyy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值