目录
- 一、前置知识 - 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 =<11>;
reg =<0x0800 0x0 0x0 0x0 0x0>;...
}
这里
address-cells = 3
,
size-cells = 2
, 表示
reg
属性中,地址信息的长度是
3
个字长,地址长度信息是
2
个字长,即是:
address = 0x0800 0x0 0x0, length = 0x00 0x00
版权归原作者 gdut_llkkyy 所有, 如有侵权,请联系我们删除。