目录
- 一、前置知识
- 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