目录
- 一、前置知识
- 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,表示寄存器是4个byte的长度,即是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