设备树(Device Tree)

设备树介绍:

设备树是一个描述设备硬件资源的文件,该文件是由节点组成的树形结构。如下:

/ {

node1 {

a-string-property = "A string";

a-string-list-property = "first string", "second string";

// hex is implied in byte arrays. no ‘0x‘ prefix is required

a-byte-data-property = [01 23 34 56];

child-node1 {

first-child-property;

second-child-property = <1>;

a-string-property = "Hello, world";

};

child-node2 {

};

};

node2 {

an-empty-property;

a-cell-property = <1 2 3 4>; /* each number (cell) is a uint32 */

child-node1 {

};

};

};

① “/”是根节点,node1和node2,是其子节点;

② “child-node1” 和 “child-node2”,是node1的子节点;

③ a-string-property,是字符串属性;

④ a-string-list-property,字符串列表属性;

⑤ a-byte-data-property,是字节数据属性;

节点与属性:

节点的定义:

[label:][@unit-address] {

properties;

child-node {

[...]

};

};

常见属性:

compatible,用来匹配驱动,一般有"供应商,产品"

#address-cells,决定子节点reg属性的地址cell数,cell是u32

#size-cells,决定子节点reg属性的地址长度cell数,cell是u32

reg,一般为设备寄存器地址及范围,如

设备树实例:

添加LED节点:

$ vim arch/arm/boot/dts/exynos4412-fs4412.dts

fs4412-led {

compatible = "farsight,fs4412-led";

reg = <0x114001E0 0x8>;

};

$ cd ../../../..

$ make dtbs

$ cp arch/arm/boot/dts/exynos4412-fs4412.dtb /tftpboot

代码:

1 #include

2 #include

3 #include

4 #include

5 #include

6

7 #define GPF3CON 0x0

8 #define GPF3DAT 0x4

9

10

11 void __iomem *led_va;

12 int led_probe(struct platform_device *pdev)

13 {

14 unsigned int regval;

15 struct resource *res;

16

17 printk("led probe\n");

18 /* 1. 获取资源,中断或者内存 */

19 res = platform_get_resource(pdev, IORESOURCE_MEM, 0);

20 if (!res) {

21 printk("get platform resource failure\n");

22 return -EINVAL;

23 }

24

25 /* 2. 内存映射,并初始化设备 */

26 led_va = ioremap(res->start, resource_size(res)); /* 内存映射得到虚拟地址 */

27 regval = readl(led_va + GPF3CON); /* (led_va + GPF3CON) 寄存器的虚拟地址*/

28 regval &= ~(0xf<<20); /* GPFCON[23:20]清零 */

29 regval |= 0x1<<20; /* 配置GPF3_5引脚功能为输出 */

30 writel(regval, led_va + GPF3CON);

31 regval = readl(led_va + GPF3DAT);

32 regval |= 0x1<<5; /* 控制GPF3_5输出高电平 */

33 writel(regval, led_va + GPF3DAT);

34 return 0; /* 0表示成功,<0表示失败 */

35 }

36

37 int led_remove(struct platform_device *pdev)

38 {

39 unsigned int regval;

40 printk("led remove\n");

41 regval = readl(led_va + GPF3CON); /* (led_va + GPF3CON) 寄存器的虚拟地址*/

42 regval &= ~(0xf<<20); /* GPFCON[23:20]清零 */

43 writel(regval, led_va + GPF3CON);

44 iounmap(led_va);

45 return 0;

46 }

47

48 /* 用来匹配平台设备的列表 */

49 const struct of_device_id of_device_table[] = {

50 {.compatible = "farsight,fs4412-led"},

51 {}

52 };

53

54 struct platform_driver pdrv = {

55 .probe = led_probe,

56 .remove = led_remove,

57 .driver = {

58 .owner = THIS_MODULE,

59 .name = "fs4412-led",

60 .of_match_table = of_match_ptr(of_device_table),

61 },

62 };

63

64 static int hello_init(void)

65 {

66 printk("Hello, Kernel!\n");

67 return platform_driver_register(&pdrv);

68 }

69

70 static void hello_exit(void)

71 {

72 printk("Goodbye, Kernel!\n");

73 platform_driver_unregister(&pdrv);

74 }

75

76 module_init(hello_init); /* 声明模块加载函数 */

77 module_exit(hello_exit); /* 声明模块卸载函数 */

78

79 MODULE_LICENSE("GPL"); /* 声明模块遵守的开源协议 */

80 MODULE_AUTHOR("zhufeng "); /* 模块作者 */

81 MODULE_DESCRIPTION("hello module"); /* 模块描述信息 */

时间: 2024-10-16 01:05:37

设备树(Device Tree)的相关文章

内核如何解析设备树Device Tree

1) 首先将从u-boot 传递过来的映像基地址和dtb 文件映像基地址保存通用寄存器r30,r31: 2) 通过调用machine_init() --> early_init_devtree()函数来获取内核前期初始化所需的bootargs,cmd_line等系统引导参数: 3) 调用start_kernel() --> setup_arch() -->unflatten_device_tree()函数来解析dtb文件,构建一个由device_node结构连接而成的单项链表,并使用全局

我眼中的Linux设备树(一 概述)

一 概述 设备树(Device tree)是一套用来描述硬件属相的规则.ARM Linux采用设备树机制源于2011年3月份Linux创始人Linus Torvalds发的一封邮件,在这封邮件中他提倡ARM平台应该参考其他平台如PowerPC的设备树机制描述硬件.因为在此之前,ARM平台还是采用旧的机制,在kernel/arch/arm/plat-xxx目录和kernel/arch/arm/mach-xxx目录下用代码描述硬件,如注册platform设备,声明设备的resource等.因为这些代

ARM Linux 3.x的设备树(Device Tree)【转】

转自:http://blog.csdn.net/21cnbao/article/details/8457546 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[-] ARM Device Tree起源 Device Tree组成和结构 DTS device tree source DTC device tree compiler Device Tree Blob dtb Binding Bootloader Device Tree引发的BSP和驱动变更 常用OF API 总结

ARM Linux 3.x的设备树(Device Tree)

1.    ARM Device Tree起源 在过去的ARM Linux中,arch/arm/plat-xxx和arch/arm/mach-xxx中充斥着大量的垃圾代码,相当多数的代码只是在描述板级细节,而这些板级细节对于内核来讲,不过是垃圾,如板上的platform设备.resource.i2c_board_info.spi_board_info以及各种硬件的platform_data.读者有兴趣可以统计下常见的s3c2410.s3c6410等板级目录,代码量在数万行.社区必须改变这种局面,

【转】ARM Linux 3.x的设备树(Device Tree)

原文网址:http://blog.csdn.net/21cnbao/article/details/8457546 1.    ARM Device Tree起源 Linus Torvalds在2011年3月17日的ARM Linux邮件列表宣称“this whole ARM thing is a f*cking pain in the ass”,引发ARM Linux社区的地震,随后ARM社区进行了一系列的重大修正.在过去的ARM Linux中,arch/arm/plat-xxx和arch/a

设备树(device tree)学习笔记一

如何查看编译生成的设备树的内容? 在设备树学习的时候,如果可以看到最终生成的设备树的内容,对于我们学习设备树以及分析问题有很大帮助.这里我们需要使用设备树生成工具dtc的反汇编功能 [email protected]:~/tq2440/Linux/linux-4.0.1# ./scripts/dtc/dtc -h Usage: dtc [options] <input file> Options: -[qI:O:o:V:d:R:S:p:fb:i:H:sW:E:hv] -q, --quiet Q

关于linux ARM device tree设备树

关于linux ARM device tree设备树 关于linux device tree .dtb文件是如何加载到内核并解析的.见下图: 关于arm device tree的phandle的处理原理,见下图: 详细情况,见下面我的ARM device tree原理视频课程:https://edu.51cto.com/course/17175.html 具体请参考我的免费的linux各种驱动开发课程如下:https://edu.51cto.com/course/17138.html 另外我的相

由MTK平台 mtkfb 设备注册疑问引发的知识延伸--ARM Device Tree

问题: 在kernel-3.10\drivers\misc\mediatek\videox\mt6735\mtkfb.c里面int __init mtkfb_init(void) 有看到 platform_driver_register(&mtkfb_driver)注册, 但在kerne l整体代码目录搜索,没有搜到 mtkfb_driver 对应的设备名为“mtkfb”设备注册, ,唯一搜到:kernel-3.10\drivers\misc\mediatek\mach\mt6735\mt_de

设备树API

设备树API通常以of_开头,实现代码位于drivers/of目录下. 参考: 1. linux设备树语法 2. ARM Linux 3.x的设备树(Device Tree)