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

出处:http://blog.csdn.net/violet089/article/details/53670758

 

 

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

#size-cells = <1>; 长度所占字长(32位)

 

譬如

 

[cpp] view plain copy  在CODE上查看代码片派生到我的代码片

  1. cpus {  
  2.         #address-cells = <1>;  
  3.         #size-cells = <0>;  
  4.         cpu@0 {  
  5.             compatible = "arm,cortex-a9";  
  6.             reg = <0>;  
  7.         };  
  8.         cpu@1 {  
  9.             compatible = "arm,cortex-a9";  
  10.             reg = <1>;  
  11.         };  
  12.     };  
  13.   
  14. #address-cells 设置为 1,#size-cells 设置为 0。这意味着子节点的 reg 值是一个单一的 uint32,这是一个不包含大小字段的地址,为这两个 cpu 分配的地址是 0 和 1。cpu 节点的 #size-cells 为 0 是因为只为每个 cpu 分配一个单独的地址。  

 

[cpp] view plain copy  在CODE上查看代码片派生到我的代码片

  1. #address-cells = <1>;  
  2.     #size-cells = <1>;  
  3.   
  4.     ...  
  5.   
  6.     serial@101f0000 {  
  7.         compatible = "arm,pl011";  
  8.         reg = <0x101f0000 0x1000 >;  
  9.     };  
  10.   
  11.     serial@101f2000 {  
  12.         compatible = "arm,pl011";  
  13.         reg = <0x101f2000 0x1000 >;  
  14.     };  
  15.   
  16.     gpio@101f3000 {  
  17.         compatible = "arm,pl061";  
  18.         reg = <0x101f3000 0x1000  
  19.                0x101f4000 0x0010>;  
  20.     };  
  21. 每个设备都被分配了一个基址以及该区域的大小。这个例子中为 GPIO 分配了两个地址范围:0x101f3000...0x101f3fff 和 0x101f4000..0x101f400f。  

 

 

[cpp] view plain copy  在CODE上查看代码片派生到我的代码片

  1. #address-cells = <2>  
  2.         #size-cells = <1>;  
  3.   
  4.         ethernet@0,0 {  
  5.             compatible = "smc,smc91c111";  
  6.             reg = <0 0 0x1000>;  
  7.         };  
  8. 外部总线的地址值使用了两个 cell,一个用于片选号;另一个则用于片选基址的偏移量。而长度字段则还是单个 cell,这是因为只有地址的偏移部分才需要一个范围量。所以,在这个例子中,每个 reg 项都有三个 cell:片选号、偏移量和长度。  

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值