您的位置:首页 > 其它

设备树中address-cells和size-cells的含义

2017-03-27 14:47 946 查看
出处:http://blog.csdn.net/violet089/article/details/53670758

#address-cells = <1>;基地址、片选号等绝对起始地址所占字长(32位)
#size-cells = <1>; 长度所占字长(32位)

譬如

[cpp] view
plain copy

 





cpus {  

        #address-cells = <1>;  

        #size-cells = <0>;  

        cpu@0 {  

            compatible = "arm,cortex-a9";  

            reg = <0>;  

        };  

        cpu@1 {  

            compatible = "arm,cortex-a9";  

            reg = <1>;  

        };  

    };  

  

#address-cells 设置为 1,#size-cells 设置为 0。这意味着子节点的 reg 值是一个单一的 uint32,这是一个不包含大小字段的地址,为这两个 cpu 分配的地址是 0 和 1。cpu 节点的 #size-cells 为 0 是因为只为每个 cpu 分配一个单独的地址。  

[cpp] view
plain copy

 





#address-cells = <1>;  

    #size-cells = <1>;  

  

    ...  

  

    serial@101f0000 {  

        compatible = "arm,pl011";  

        reg = <0x101f0000 0x1000 >;  

    };  

  

    serial@101f2000 {  

        compatible = "arm,pl011";  

        reg = <0x101f2000 0x1000 >;  

    };  

  

    gpio@101f3000 {  

        compatible = "arm,pl061";  

        reg = <0x101f3000 0x1000  

               0x101f4000 0x0010>;  

    };  

每个设备都被分配了一个基址以及该区域的大小。这个例子中为 GPIO 分配了两个地址范围:0x101f3000...0x101f3fff 和 0x101f4000..0x101f400f。  

[cpp] view
plain copy

 





#address-cells = <2>  

        #size-cells = <1>;  

  

        ethernet@0,0 {  

            compatible = "smc,smc91c111";  

            reg = <0 0 0x1000>;  

        };  

外部总线的地址值使用了两个 cell,一个用于片选号;另一个则用于片选基址的偏移量。而长度字段则还是单个 cell,这是因为只有地址的偏移部分才需要一个范围量。所以,在这个例子中,每个 reg 项都有三个 cell:片选号、偏移量和长度。  
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  device tree