Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3109019
  • 博文数量: 396
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 4209
  • 用 户 组: 普通用户
  • 注册时间: 2016-07-04 13:04
文章分类

全部博文(396)

文章存档

2022年(1)

2021年(2)

2020年(8)

2019年(24)

2018年(135)

2017年(158)

2016年(68)

我的朋友

分类: 嵌入式

2018-12-10 21:25:47

1.介绍


为了初始化和引导计算机系统,需要各种软件组件进行交互。在将控制权交给软件(如操作系统,引导加载程序或虚拟机监控程序)之前,固件可能会执行系统硬件的低级初始化。bootloader程序或管理程序可以加载和转移控制全给操作系统。而一致的接口和约定有助于这些软件组件之间的交互。在该文档中,引导加载程序一般是指初始化系统状态并将程序执行控制器交给操作系统的软件。引导程序的示例包括:固件,bootloader程序和管理程序。客户端程序的示例包括:引导加载程序,管理程序,操作系统和专用程序。一个软件可以是客户端程序和引导程序(例如,管理程序)。


该规范,Devicetree规范(DTSpec),为客户端程序接口定义提供了完整的引导程序,并结合了促进各种系统开发的最低系统要求。


该规范针对嵌入式系统的要求设计。嵌入式系统通常由系统硬件,操作系统和应用软件组成,这些软件是定制设计用于执行固定的特定任务集。这与通用计算机不同,通用计算机设计为由具有各种软件和I/O设备的系统定制。嵌入式系统的其他特性包括:


一组固定的I/O设备,可能是针对应用程序定制的;
针对尺寸和成本进行优化的系统板;
有限的用户界面;
资源限制,如有限的内存和有限的非易失性存储;
实时约束;
使用各种操作系统,包括Linux,实时操作系统以及定制或专有操作系统;
32位和64位系统的支持


DTSpec规范支持具有32位和64位寻址功能的CPU。在适用的情况下,DTSpec规范的各个部分描述了32位和64位寻址的要求或注意事项。


术语的定义


AMP:非对称多处理。计算机可用的CPU被分区为组,每个组运行不同的操作系统映像。CPU可能不相同;
boot CPU:引导程序指向客户端程序入口点的第一个CPU;
boot program:一般是指代初始化系统状态并执行称为客户端程序软件。例如,bootloader程序;
client program:通常包含应用程序或操作系统软件的程序;
cell:由32位组成的信息单元;
DMA:直接内存访问;
DTB:设备树blob;设备数的二进制表示;
DTC:设备树编译器;用于将DTS文件编译成DTB文件的开源工具;
DTS:Devicetree语法;DTC用来描述硬件设备的文本文件;
effective address:由处理器存储访问或指令计算的内存地址;
physical address:处理器用于访问外部设备的地址,通常是内存控制器;
interrupt specifier:描述中断的属性值;通常包括指定中断号以及触发机制的信息;
SMP:对称多处理;一种计算机体系结构,其中两个或多个相同的CPU可以共享内存和IO并在单个操作系统下运行;
unit address:节点名称的一部分,用于指定在父节点的地址空间中的节点地址;
2.设备树的详细介绍


2.1.概述


DTSpec规范指定了一个名为devicetree的树状结构来描述系统硬件。bootloader将DTB文件加载到的内存中,并将指向DTB文件地址的指针(R2)传递给操作系统(kernel)。


本章描述了设备树节点的逻辑结构,并指定了用于描述设备树节点的基本属性集。第3章描述了符合DTSpec的设备树节点所需的某些属性。


devicetree是一种树数据结构,其中包含描述系统中设备树的节点。每个节点都有属性/值(键值对)对组成,用于描述所表示设备的特征。每个节点只有一个父节点,但根节点除外,它没有父节点。


符合DTSpec规范的设备树描述了系统中的硬件设备信息,该信息不一定由客户端程序动态检测。例如,PCI的体系结构客户端能够探测和检测连接的设备,因此可能不需要描述PCI设备的设备节点。但是,如果无法通过自动检测到硬件设备,则需要设备节点来描述系统中的PCI主桥设备。


示例:


图2.1显示了一个简单的设备树的示例,该设备几乎完全足以启动一个简单的操作系统,包含平台类型,CPU,内存和一个UART。在每个设备节点内都有属性和值。






图2.1. 设备树示例


2.2.设备树的结构和约定


2.2.1.节点名称


设备树中的每个节点都应遵守以下的约定命名:


node-name@unit-address
node-name指定节点的名称。它的长度应为1到31个字符,并且应该只包含表2.1中所示的字符。


表2.1:节点名称的有效字符


字符 描述
0-9 数字
a-z 小写字母
A-Z 大写字母
, 逗号
. 句号
_ 下划线
+ 加号
- 短斜杠
节点名称应以小写或大写字符开头,并应描述设备的常规类型。


名称中的单元地址组件特定于节点所在的总线类型。它由表2.1中的一组字符中的一个或多个ASCII字符组成。unit-address必须与节点的reg属性中指定的第一个地址匹配。如果节点没有reg属性,则必须省略@unit-address,并且节点名称将节点与树中同一级别的其他节点区分开来。特定总线的绑定可以为reg属性和unit-address的格式指定更多,更具体的要求。


根节点没有节点名和unit-address。它由正斜杠(/)标识。






图2.2:节点名称的示例


在图2.2中,名称为cpu的节点通过其unit-address值0和1来区分。名称为ethernet的节点由其unit-address值fe002000和fe003000来区分。


2.2.2.通用名称建议


节点的名称应该有些通用的,反映设备的功能。如果合适,名称应该是以下选项之一:


adc
accelerometer
atm
audio-codec
audio-controller
backlight
bluetooth
bus
cache-controller
camera
can
charger
clock
clock-controller
compact-flash
can
cpu
cpus
crypto
disk
display
dma-controller
dsp
eeprom
efuse
endpoint
ethernet
ethernet-phy
fdc
flash
gpio
gpu
gyrometer
hdmi
i2c
ide
interrupt-controller
isa
keyboard
key
keys
lcd-controller
led
leds
led-controller
light-sensor
magnetometer
mailbox
mdio
memory
memory-controller
mmc
mmc-slot
mouse
nand-controller
nvram
oscillator
parallel
pc-card
pci
pcie
phy
pinctrl
pmic
pmu
port
ports
pwm
regulator
reset-controller
rtc
sata
scsi
serial
sound
spi
sram-controller
ssi-controller
syscon
temperature-sensor
timer
touchscreen
usb
usb-hub
usb-phy
video-codec
vme
watchdog
wifi
2.2.3.路径名称


通过指定从根节点到所有子节点的完整路径,可以唯一地标识设备树中的节点。表示设备路径的约定是:


/node-name-1/node-name-2/node-name-N
例如,在图2.2中,cpu#1的设备路径为:


/cpus/cpu@1
根节点的路径是"/"。


如果节点的完整路径是明确的,则可以省略unit-address。如果内核发现某个不明确的路径,则表示为未定义节点。


2.2.4.属性


设备树中的每个节点都具有描述节点特征的属性。属性由属性名和值组成(键值对)。


属性名称:属性名称是表2.2中所示的1到31个字符的字符串组成。


表2.2:属性名称的有效字符


字符 描述
0-9 数字
a-z 小写字符
A-Z 大写字符
, 逗号
. 句号
_ 下划线
+ 加号
? 问号
 非标准属性名称应指定唯一的字符串前缀,例如股票代码符号,用于标识定义该属性的公司或组织的名称。例如:


fsl,channel-fifo-len
ibm,ppc-interrupt-server#s
linux,network-index
属性值:属性值是包含零个或多个字节的数组,其中包含与属性关联的信息。如果传递真假信息,属性可能具有空值。在这种情况下,属性的存在与否是充分描述性的。表2.3描述了DTSpec规范定义的属性基本值集合。


表2.3:属性值


属性值 描述
空值 属性值为空,用来表示真假信息;
property=<32> 大端格式的32位整数;
u64 表示big-endian格式的64位整数
string 字符串是可打印的并且以空值终止;例如:"hello"
phandle 一个u32的值;标定phandle值是引用设备树中另一个节点的方法;
stringlist 连接在一起的值列表;例如:"hello","world"
prop-encoded-array 格式特定于属性;请参阅属性定义;
2.3.标准属性


DTSpec规范为设备树节点指定一组标准属性。本节将详细介绍这些属性。DTSpec规范定义的设备树节点可以指定有关标准属性使用的附加要求或约束。第4章描述了特定设备的表示,还可以指定其他要求。


备注:本文档中的所有devicetree节点示例都使用DTS(Devicetree Source)格式来指定节点和属性。


2.3.1.compatible属性


属性名称:compatible


属性值类型: (字符串)


描述:compatible属性的值由一个或多个字符串组成,这些字符串定义设备的特定编程模型。linux内核应使用此字符串列表来选择匹配特定的设备驱动程序。属性值由一系列字符串组成,从最具体到最常见。它们允许设备表达与一系列类似设备的兼容性,可能允许单个设备驱动程序与多个设备匹配。推荐的格式是"manufacturer,model",其中manufacturer是描述制造商名称的字符串(例如股票代码),model指定型号。


示例:


compatible = "fsl,mpc8641", "ns16550";
在此示例中,操作系统将首先尝试查找支持"fsl,mpc8641"属性的设备驱动程序。如果找不到具体驱动程序,它将尝试找到支持更通用的ns16550属性设备类型的驱动程序。


2.3.2.model属性


属性名称:model


属性值:string(字符串)


描述:model属性值是类型,它指定制造商的设备型号。建议的格式为"manufacturer,model",其中manufacturer是描述制造商名称的字符串,model指定型号。


示例:


model = "fsl,MPC8349EMITX";
2.3.3.phandle属性


属性名称:phandle


属性值:u32类型


描述:


phandle属性指定在devicetree中唯一的节点的数字标识符。phandle属性值由需要引用与该属性关联的节点的其他节点使用。


示例:


请参阅以下devicetree摘录:


pic@10000000 {
phandle = <1>;
interrupt-controller;
};
定义了一个phandle值为1的节点, 另一个设备节点可以引用具有1的phandle值的pic节点:


another-device-node {
interrupt-parent = <1>;
};
备注:DTS中的大多数设备节点不明确的包含phandle属性。当DTS编译为二进制DTB格式时,DTC工具会自动插入phandle属性。


2.3.4.status属性


属性名称:status


属性值:string(字符串)


描述:


status属性用来指示设备的运行状态。表2.4列出了status属性的有效值。


表2.4:status属性的值


属性值 描述
"okay" 表示设备正在运行;
"disabled" 表示设备当前不可运行,但将来可能会运行;
"fail" 表示设备无法运行,设备中检测到严重错误,未经修复就不可能运行;
"fail-sss" 表示设备无法运行,在设备中检测到严重错误,未经修复就不可能运行;值的sss部分特定于设备并指示检测到的错误条件;
2.3.5.#address-cells和#size-cells属性


属性名称:#address-cells,#size-cells


属性值:u32


描述:


#address-cells和#size-cells属性可用于在设备树层次结构中具有子节点的任何设备节点,并描述应如何寻址子设备节点。#address-cells属性定义用于编写子节点的reg属性中的地址字段的单元的数量。#size-cells属性定义用于对子节点的reg属性中的size字段进行编写的单元的数量。


#address-cells和#size-cells属性不是从devicetree中的祖先继承的。它们应明确定义。


符合DTSpec规范标准的程序应在所有有子节点的父节点上提供#address-cells和#size-cells。如果缺少,程序对#address-cells假定默认值为2,对于#size-cells应该为1。


示例:


请参阅以下devicetree摘录:


soc {
#address-cells = <1>;
#size-cells = <1>;
serial {
compatible = "ns16550";
reg = <0x4600 0x100>;
clock-frequency = <0>;
interrupts = <0xA 0x8>;
interrupt-parent = <&ipic>;
};
};
在此示例中,soc节点的#address-cells和#size-cells属性的值都设置为1。此设置指定需要一个cell表示子节点的地址,并且需要一个cell来表示此节点的子节点的地址大小。串行(serial)设备reg属性必须遵循在父(soc)节点中的设置,此节点的地址由一个cell(0x4600)表示,并且地址大小由一个cell(0x100)表示。


2.3.6.reg属性


属性名称:reg


属性值:为任意数量的


描述:


reg属性描述了由其父总线定义的地址空间内设备资源的地址。最常见的是,这意味着内存映射IO寄存器块的偏移量和长度,但在某些总线类型上可能有不同的含义。根节点定义的地址空间中的地址是CPU能够访问的实际地址。


由任意数量的地址和长度对组成,;指定地址和长度所需的 cell的数量是特定于总线的,并由设备节点的父节点中的#address-cells和#size-cells属性指定。如果父节点为#size-cells指定值0,则应省略reg中的长度字段。


示例:


假设片上系统内的器件有两个寄存器块,SOC中偏移量为0x3000的32字节块和偏移量为0xFE00的256字节块。reg属性如下所示:


reg = <0x3000 0x20 0xFE00 0x100>;
2.3.7.virtual-reg


属性名称:virtual-reg


属性值:u32


描述:


virtual-reg属性指定一个有效虚拟地址,该地址映射到设备节点的reg属性中指定的第一个物理地址。此属性使引导程序能够为客户端程序提供已设置的虚拟地址到物理地址映射。


2.3.8.ranges属性


属性名称:ranges


属性值: 


描述:


ranges属性提供了一种定义总线地址空间和总线节点父节点的地址空间之间的映射或转换的方法。range属性值的格式是(子总线地址,父总线地址,长度)的任意数量的三元组


子总线地址是子总线地址空间中的物理地址。表示地址的单元数取决于总线,可以从该节点的#address-cells(出现范围属性的节点)确定。


父总线地址是父总线地址空间内的物理地址。表示父地址的单元数取决于总线,可以从定义父地址空间的节点的#address-cells属性中确定。


长度指定子地址空间中范围的大小。 表示大小的单元数可以从该节点的#size-cells(出现ranges属性的节点)确定。


如果使用值定义属性,则它指定父地址空间和子地址空间相同,并且不需要地址转换。


如果该属性不存在于总线节点中,则假定该节点的子节点与父地址空间之间不存在映射。


地址转换示例:


soc {
compatible = "simple-bus";
#address-cells = <1>;
#size-cells = <1>;
ranges = <0x0 0xe0000000 0x00100000>;
serial {
device_type = "serial";
compatible = "ns16550";
reg = <0x4600 0x100>;
clock-frequency = <0>;
interrupts = <0xA 0x8>;
interrupt-parent = <&ipic>;
};
};
soc节点指定ranges属性:


<0x0 0xe0000000 0x00100000>;
此属性值指定对于1024KB范围的地址空间,在物理地址0x0处寻址的子节点映射到父节点物理地址0xe0000000处。 通过此映射,可以通过地址0xe0004600处的加载或存储来寻址串行设备节点,偏移量为0x4600(在reg中指定)加上范围中指定的0xe0000000映射。
--------------------- 
作者:晴天_QQ 
来源:CSDN 
原文:https://blog.csdn.net/caihaitao2000/article/details/83960823 
版权声明:本文为博主原创文章,转载请附上博文链接!
阅读(3600) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~