1、1Linux设备树概述Linux设备树是一个包含节点和属性的简单树状结构。属性是基于key-va造婷用痃lue对的,而节点可以同时包含属性和子节点。下面这个树就是一个典型结构:/ { node1 { a-string-property = "A string"; a-string-list-property = "first string", "second string"; a-byte-data-property = [0x01 0x23 0x34 0x56]; child-node1 { first-child-property; second-child-property = <1>; a-string-property = "Hello, world"; }; child-node2 { }; }; node2 { an-empty-property; a-cell-property = <1 >; /* each number (cell) is a uint32 */ child-node1 { }; };};这棵树没有描述任何东西,但是它体现了节点的一些属性:l一个单独的根节点:“/”l两个子节点:“node1”和“node2”l两个 node1 的子节点:“child-node1”和“child-node2”l一堆分散在树里的属性可以这么简单理解:节点就是树枝,属性就是树叶;树枝上可以有再长树枝也可以长树叶,而树叶上则不会再长树枝。属性是基于key-value结构的,value可以为空或者特定格式的字符串内容。由于数据类型并不被编码到最终的数据结构中,设备树源代码中仅能支持有限的几种基本数据类型,如下:l文本字符串(无结束符)可以用双引号表示:string-property = "a string"l'Cells'是 32 位无符号整数,用尖括号表示:cell-property = <0xbeef xabcd>l二进制数据用方括号表示:binary-property = [0x01 0x23 0x45 0x67];l不同表示形式的数据可以使用逗号连在一起:mixed-property = "a string", [0x01 0x23 0x45 0x67], <0x12345678>;l逗号也可用于创建字符串列表:string-list = "red fish", "blue fish";
2、2.1初始结构第一步就是构建一个基本结构,这是一个设备树最基本的结构。在这个阶段,需要一个唯一的标参萝治璃识该机器。/ {compatible = "gpio-leds";};compatible指定了系统的名称。它包含了一个“<>,<>”形式的字符串。重要的是要指定一个确切的设备,并且包括制造商的名字,以避免命名空间冲突。由于操作系统会使用 compatible的值来决定如何在机器上运行,所以正确的设置这个属性十分重要。1.2.2中央处理器第二步就是描述CPU。先添加一个名为“cpus”的容器节点,然后为每个CPU分别添加子节点,以TI AM437x平台为例:/ {compatible = "ti,am437x-gp-evm";cpus {cpu@0 {compatible = "ti,am4372";};cpu@1 {compatible = "ti,am4372";};};};每个cpu节点compatible属性是一个“<>,<>”形式的字符串,并指定了确切的cpu,就像顶层的compatible属性一样。
3、2.1节点名称每个节点必须有一个“<>[@<>]”形式的名字。l<< span>名称>就是一个不超过31位的简单ascii字符串。通常,节点的命名应该根据它所体现的是什么样的设备。比如一个3com以太网适配器的节点就应该命名为 ethernet,而不应该是3com509。l如果该节点描述的设备有一个地址的话,还应该加上设备地址(unit-address)。通常,设备地址就是用来访问该设备的主地址,并且该地址也在节点的reg属性中列出。l同级节点命名必须是唯一的,但只要地址不同,多个节点也可以使用一样的通用名,例如serial@101f1000和serial@101f2000。