当前位置: 首页 > article >正文

【Linux驱动开发】第11天:设备树(Device Tree)超详细全解:从诞生背景到工作原理

一、设备树的诞生背景传统驱动的致命痛点在设备树出现之前Linux 3.0之前Linux内核采用硬编码的方式描述所有硬件信息。这意味着每一个开发板的寄存器地址、中断号、GPIO号都直接写死在驱动代码里换一个开发板哪怕只是GPIO号变了也要修改驱动代码重新编译为了支持不同的开发板内核里充斥着大量重复的、针对特定硬件的代码最直观的例子ARM内核的灾难ARM架构有上百种不同的芯片、上千种不同的开发板。在设备树出现之前每一个开发板都需要在内核里添加一份自己的硬件描述代码内核代码量爆炸式增长变得无比臃肿维护成本极高每一个新开发板都需要内核开发者手动添加支持一个内核镜像只能支持一个开发板无法做到一个镜像跑遍所有开发板设备树的诞生2011年Linux 3.1内核正式引入设备树机制彻底解决了这个问题。设备树的核心思想非常简单把硬件描述信息从内核代码中完全抽离出来用一个独立的、通用的文件来描述硬件。内核只需要一份通用的驱动代码通过读取这个文件来识别不同的硬件。二、设备树的核心定义设备树Device Tree简称DT是一种描述硬件资源的数据结构它用树形结构来描述一个计算机系统的所有硬件设备包括CPU内存总线控制器I2C、SPI、USB等外设LED、按键、传感器、显示屏等中断、时钟、电源等硬件资源设备树的本质设备树本质上是一个硬件的清单它告诉内核这个板子上有哪些硬件它们的地址在哪里它们用了哪个中断它们的工作频率是多少注意设备树不是驱动它只描述硬件是什么不描述怎么操作硬件。操作硬件的逻辑仍然在驱动代码里。三、设备树的三大核心组件DTS、DTB、DTC设备树体系由三个核心部分组成三者分工明确缺一不可。1. DTS设备树源文件Device Tree Source文件后缀.dts主文件、.dtsi头文件文件类型纯文本文件人类可读可编辑作用用C语言风格的语法描述硬件的所有信息编辑方式任何文本编辑器都可以编辑什么是.dtsi文件.dtsi是设备树头文件相当于C语言的.h头文件用于存放多个DTS文件共享的公共硬件信息。比如同一个芯片的所有开发板芯片内部的外设CPU、内存、UART、I2C控制器等是完全相同的这些公共信息可以放在一个.dtsi文件中如stm32mp157.dtsi每个开发板自己的.dts文件只需要#include这个.dtsi然后添加自己独有的硬件信息如LED、按键、外接传感器等大大提高了代码复用性减少了重复代码2. DTC设备树编译器Device Tree Compiler文件类型可执行程序作用将人类可读的DTS文本文件编译成内核能够识别和解析的二进制DTB文件同时也可以将DTB二进制文件反编译成DTS文本文件用于调试3. DTB设备树二进制文件Device Tree Blob文件后缀.dtb文件类型二进制文件人类不可读作用内核启动时加载并解析的最终文件特点体积小、解析速度快适合嵌入式系统使用三者的关系和编译流程开发者编写DTS源文件#include 公共.dtsi头文件DTC编译器编译生成DTB二进制文件烧录到开发板bootloader加载DTB到内存内核解析DTB识别硬件四、设备树的树形结构设备树采用树形结构来描述硬件和计算机的文件系统结构非常相似。4.1 基本结构/ 根节点 ├── cpu0 CPU节点 ├── memory80000000 内存节点 ├── soc0 片上系统节点 │ ├── uart12340000 串口节点 │ ├── i2c12341000 I2C控制器节点 │ │ ├── sensor48 I2C传感器节点 │ │ └── eeprom50 I2C EEPROM节点 │ └── gpio12342000 GPIO控制器节点 └── led12343000 LED节点4.2 核心概念节点Node每个硬件设备对应设备树中的一个节点节点格式节点名地址 { ... };节点名描述设备的类型如cpu、memory、uart、led地址设备的寄存器基地址用于区分同类型的不同设备如uart12340000和uart12341000是两个不同的串口4.3 核心概念属性Property每个节点包含多个属性用于描述设备的具体信息属性格式属性名 属性值;属性值可以是字符串、32位无符号整数、整数数组、字节数组等4.4 最常用的核心属性驱动开发每天都会用到属性名作用示例compatible最重要的属性用于和驱动匹配格式为厂商,设备名compatible st,stm32-uart;reg描述设备的寄存器地址范围格式为基地址 长度reg 0x12340000 0x1000;interrupts描述设备使用的中断号interrupts 5;status描述设备状态okay表示启用disabled表示禁用status okay;model设备的人类可读名称model STM32MP157 Development Board;五、设备树的完整工作流程设备树从编写到最终驱动硬件会经历以下6个完整阶段。阶段1编写设备树源文件开发者根据开发板的硬件原理图编写DTS文件描述所有硬件信息。阶段2编译生成DTB文件使用DTC编译器将DTS文件编译成DTB二进制文件。阶段3bootloader加载DTB系统启动时bootloader如U-Boot会将内核镜像zImage加载到内存将DTB文件加载到内存的另一个位置启动内核并将DTB的内存地址传递给内核阶段4内核解析DTB内核启动时根据bootloader传递的地址解析DTB文件遍历DTB中的所有节点为每个节点创建一个对应的platform_device结构体将platform_device注册到platform总线阶段5总线匹配设备和驱动platform总线会遍历所有已注册的platform_driver比较设备的compatible属性和驱动的of_device_id表如果字符串完全一致则匹配成功阶段6调用驱动的probe函数匹配成功后总线自动调用驱动的probe函数驱动从platform_device中获取硬件信息地址、中断号等初始化硬件注册字符设备/块设备/网络设备创建设备文件对外提供服务六、设备树的核心优势对比传统硬编码驱动设备树具有以下不可替代的优势1. 硬件描述与驱动代码完全分离驱动代码通用不需要针对特定开发板修改一个驱动可以支持所有符合compatible属性的设备新增硬件只需要修改设备树不需要修改驱动代码2. 一个内核镜像支持多个开发板内核镜像不再包含任何特定硬件的信息同一个内核镜像可以在所有支持设备树的开发板上运行只需要更换不同的DTB文件即可3. 大大降低内核维护成本内核不再需要包含大量针对特定开发板的硬编码代码内核代码量大幅减少更加简洁和通用新开发板的支持变得非常简单只需要添加一个DTS文件4. 支持热插拔设备树可以动态描述热插拔设备的信息设备插入时内核动态解析设备树节点创建设备并匹配驱动设备拔出时自动调用驱动的remove函数释放资源七、常见误区澄清❌ 误区1设备树可以代替驱动错误。设备树只描述硬件是什么不描述怎么操作硬件。操作硬件的逻辑仍然在驱动代码里。没有驱动设备树只是一个没用的文本文件。❌ 误区2设备树是ARM架构特有的错误。设备树最早用于PowerPC架构现在已经被所有主流架构采用包括ARM、x86、RISC-V、MIPS等。❌ 误区3设备树只能描述片上外设错误。设备树可以描述系统中的所有硬件包括CPU、内存、总线控制器、外接设备、甚至电源和时钟。❌ 误区4设备树的compatible属性可以随便写错误。compatible属性必须严格按照厂商,设备名的格式编写并且必须和驱动中的of_device_id表完全一致否则无法匹配。八、总结设备树是现代Linux驱动开发的基础它的核心价值在于实现了硬件描述与驱动代码的彻底分离解决了传统硬编码驱动的所有致命痛点。对于驱动开发者来说你只需要记住设备树是硬件的清单告诉内核有什么硬件驱动是硬件的操作手册告诉内核怎么操作硬件compatible属性是两者之间的配对暗号暗号对上了驱动才能工作面试必背考点什么是设备树它解决了什么问题DTS、DTB、DTC分别是什么三者的关系是什么什么是.dtsi文件它的作用是什么设备树的基本结构是什么什么是节点和属性compatible属性的作用是什么格式是什么内核解析设备树的完整流程是什么bootloader在设备树启动过程中起到什么作用设备树和platform驱动是怎么配合工作的

相关文章:

【Linux驱动开发】第11天:设备树(Device Tree)超详细全解:从诞生背景到工作原理

一、设备树的诞生背景:传统驱动的致命痛点 在设备树出现之前(Linux 3.0之前),Linux内核采用硬编码的方式描述所有硬件信息。这意味着: 每一个开发板的寄存器地址、中断号、GPIO号,都直接写死在驱动代码里换…...

【Linux驱动开发】第10天:设备树零基础入门——DTS/DTB/DTC全解+编译流程

目录 为什么需要设备树?传统驱动的终极痛点DTS/DTB/DTC 大白话定义核心区别三者关系完整编译流程图最简单的DTS示例语法解析设备树编译与反编译实操命令内核如何加载和使用设备树核心总结面试必背考点 1. 为什么需要设备树?传统驱动的终极痛点 在设备树…...

TowerPersonalProperty.cs

TowerPersonalProperty 是塔的标准化攻击组件,攻击节奏(CD管理)子弹发射(从对象池获取并配置)视觉表现(旋转、动画、音效、特效)经济交互(升级/出售价格计算与金币变更)它…...

[工具] 数学题库生成器(小学,初中,高中全包括) 面向中小学数学教学的自动出题工具,覆盖从小学一年级到高中三年级共 7 个学段、33 种题型

数学题库生成器(小学,初中,高中全包括) 基本覆盖各个年级的重点题型生成,并导出为word,可以显示解题步骤。# 数学题库生成器 MathMaster 数学题库生成器(MathMaster)是一款面向中小学…...

硬件工程师,每天5分钟(5)——为什么 DDR5 最怕地不好?回流路径,才是高速设计真正的灵魂

讲透: 回流路径 为什么 Split Plane 最危险 为什么加地孔有时候能救命 为什么 GPS 会被 DDR 干扰 为什么 EMC 挂的根因常是地 🚗《硬件工程师,每天5分钟》第5篇 🔥《为什么 DDR5 最怕地不好?回流路径,才是高…...

11.三层网络VXLAN

先把之前基于flat模式创建的虚机,全部删除 控制节点配置:1.修改配置文件/etc/neutron/neutron.conf 将[DEFAULT]区域 core_plugin ml2 service_plugins 修改为 core_plugin ml2 service_plugins router allow_overlapping_ips True2.修改/etc/neutro…...

数采网关的应用与特点

摘要在工业自动化、智能制造和物联网(IoT)快速发展的背景下,数据采集网关(数采网关)作为连接现场设备与上层管理系统的关键枢纽,发挥着至关重要的作用。它能够实现工业设备数据的实时采集、协议转换、边缘计…...

第2章:文档加载与智能分块——RAG的第一步

本章你将收获:支持PDF(含表格)、Word、Markdown、网页、CSV等10+格式的完整加载代码;五种分块策略的深度对比(固定大小、递归字符、语义、文档结构、按标题);元数据保留与增强的工程方法;处理100页混合格式技术手册的完整实战;以及分块参数调优的最佳实践。 📌 本章…...

西门子PLC对接须知:从通信到编程的实战指南

在工业自动化领域,西门子S7系列PLC凭借强大的功能和广泛的兼容性,成为众多企业的首选。无论是设备集成、数据采集还是系统升级,掌握PLC对接的核心要点,是保障项目高效落地的关键。本文将从通信连接、编程架构、数据处理三个维度&a…...

ComfyUI全面掌握-知识点详解——ComfyUI 开发与扩展基础(开发指南+环境搭建)

本文为「ComfyUI 全面掌握」系列第 23 篇,是高阶进阶章节的第一篇知识点详解博客。作为开发系列的起点,本文将带你系统了解 ComfyUI 社区贡献流程,并手把手搭建完整的自定义节点开发环境,为后续的节点开发与发布奠定坚实的技术基础…...

STM32矩阵按键详解——4×4行列扫描与非阻塞消抖(硬件总结六)

前言 独立按键虽然简单,但当产品需要十几个按键时,每个按键独占一个GPIO的接法就变得很不经济。矩阵按键通过“行列”的交叉结构,仅用NM个GPIO即可驱动NM个按键。以最常见的44矩阵为例,16个按键仅需8个GPIO,引脚利用率…...

鸿蒙中的自由流转

鸿蒙自由流转是 ‌HarmonyOS(鸿蒙系统)‌ 实现多设备协同的核心能力之一,旨在打破设备边界,让应用和服务在不同终端间无缝流转,提升用户体验。‌什么是鸿蒙自由流转?‌鸿蒙自由流转是指用户在多个搭载 Harm…...

RUST编程学习.2语法

目录 前言 一、思维导图 二、Rust语法专属 1.迭代器 2.生命周期 总结 前言 在进行编译器下载后,就可以写代码进行编译调试了,在这之前就是要学习rust语法,在学习的过程中我整理了一版思维导图,最直观的感觉就是rust的语法很…...

【SSD】闪存1

闪存的特点 闪存是非易失存储器,掉电了数据也不会丢失,但是闪存不能够覆写,必须按块擦除,按页写入。 闪存的基本单元 闪存的基本单元是Cell,一种类Nmos的双层浮栅MOS管 MOS管 首先理解什么是MOS管:(金…...

性价比高的国产PLM软件公司

在制造业领域,不少企业都面临着研发效率低下、协同困难等问题。比如某电子制造企业,研发部门与生产部门之间信息沟通不畅,图纸版本管理混乱,导致产品研发周期延长,生产成本增加,新品上市时间比预期晚了近30…...

分布式团队的代码协作规范:从分支策略到提交信息格式

在分布式团队模式下,代码协作的地域分散、时区差异和沟通成本,给版本控制和质量保障带来了严峻挑战。作为软件测试从业者,我们不仅是代码质量的“守门员”,更需要深入理解并推动执行规范的代码协作流程,从分支管理到提…...

几十万买的数字孪生低代码平台集体落灰?被隐瞒的落地真相,终于说透了

在政企数字化采购圈子里,一直有个特别讽刺、且年年重复上演的现象。很多企业、政府单位,手握专项数字化预算,毫不犹豫花几十万重金购入数字孪生、3D可视化低代码平台。采购前被厂商的宣传话术打动:零代码拖拽、人人上手、无需专业…...

在家办公效率低?试试这个“空间切换”技巧

一、软件测试从业者居家办公的效率困境对于软件测试从业者而言,居家办公看似摆脱了办公室的嘈杂与束缚,实则面临着诸多独特的效率挑战。测试工作本身就需要高度的专注与严谨,从需求分析、用例设计到缺陷跟踪,每一个环节都容不得半…...

SMARTFORM不同模板一起打印

一、背景由于客户提出发货单要加上条形码打印,条形码单独一个模板,加在后面打印,输出PDF并发送邮件。二、效果展示不同模板一起打印效果如下,建立smartforms的表单时,也使用了两个不同的模板三、smartforms建立表单&am…...

远程技术面试的潜规则:摄像头角度可能影响你的录用

一、摄像头角度:被忽视的专业细节在软件测试的工作中,我们习惯用严谨的态度去排查代码里的每一个bug,用精准的测试用例去验证产品的每一项功能。但在远程技术面试这个特殊的“测试场景”里,很多人却忽略了一个看似无关紧要&#x…...

Spec-Kit + Superpowers 实战:Go语言博客论坛系统的规范驱动开发

从“凭感觉写代码”到“按规范做工程”,一套完整的AI驱动开发方法论落地 一、引言:AI编程的“效率陷阱” 2024年Google DORA报告揭示了一个令人困惑的数据:AI编码助手采用率每提升25%,软件交付稳定性反而下降7.2%。问题出在哪?研究表明,当上下文从1K Token扩展到32K Tok…...

微波遥感杂谈五(微波辐射计)

前言微波辐射计是通过被动的接收各个高度传来的温度辐射的微波信号来判断温度、 湿度曲线,能定量测量目标(如地物和大气各成分)的低电平微波辐射的高灵敏度接收装置。目前机载微波辐射计实测温度分辨率达0.02K,星载微波辐射计温度分辨率达 0.2&#xff5…...

适配多层级组织管理,科学运用 360 度反馈打造公平高效绩效文化

360度绩效反馈评估是一种从上级、下属、同事、客户等多个维度收集反馈的综合绩效评估方法,通过多源数据消除单一评价者的主观偏差,帮助企业获得更全面、客观的员工能力画像。相比传统的上级单向评价,360度反馈能将评估准确度提升40%以上&…...

鸿蒙备考题库页面构建:错题本、小组榜单与备考提示模块详解

鸿蒙备考题库页面构建:错题本、小组榜单与备考提示模块详解 前言 在 HarmonyOS 6.0 应用开发中,教育类应用的错题管理、学习排行榜和系统提示是提升用户粘性的关键功能模块。本文将以“备考题库”应用中的“错题本”高频错题列表、“小组榜单”学习排名和…...

中文编程语言的开创性语法,言律:一门以汉语为思维内核的原生中文编程语言

在对母语作为思维原生载体的深层结构、语言相对论与神经认知机制的探讨基础上,我们不再满足于“把英文关键字翻译成中文”的表层汉化,而是要开创一种真正根植于汉语思维逻辑的编程语法体系—— 🌿「言律」(Yn Lǜ)&…...

leetcode思路-236 二叉树的最近公共祖先

给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的…...

把SAC model的数据导出到BW的ADSO中

目录 1. SAC 侧的准备 1.1 OData连接要做好 1.2 SAC里的model设置要配置好允许导出到Odata 2. BW侧要做的准备(先跟着SAP的note走) 3. SAC 模型数据导出 一般都是把planning model的数据导出到一个ADSO中,然后再用Composite Provider里…...

Word文档保护技巧:防止内容被轻易复制

Word文档如何防止复制呢?其实,Word根本没有真正意义上的禁止复制,因为用户按一下手机截图,或者拍张照片,内容照样能拿走。但是,我们可以提高复制门槛,也就是让其他用户通过“CtrlC”无法直接复制…...

计算机毕业设计 | SpringBoot+vue医院药品管理系统(附源码+论文)

1,绪论 1.1课题背景 身处网络时代,随着网络系统体系发展的不断成熟和完善,人们的生活也随之发生了很大的变化。目前,人们在追求较高物质生活的同时,也在想着如何使自身的精神内涵得到提升,而读书就是人们…...

机器学习之逻辑回归算法

一、逻辑回归简介 1. 定义 逻辑回归(Logistic Regression)是一种有监督学习算法,主要用于解决二分类问题的统计学习方法。尽管名字中带有“回归”,但它实际上是一种分类算法。 大白话解释 逻辑回归就是一种“做判断题”的算法&…...