在Linux中设备树是怎么和驱动程序联系起来的?

原创 嵌入式悦翔园 2023-03-21 11:40

关注星标公众号,第一时间获取信息

前言

DTS文件和内核驱动的联系通常是通过设备树机制实现的。设备树机制是一种描述系统硬件的数据结构,它以树形结构组织设备节点,并提供设备节点的属性信息,包括设备地址、中断号、寄存器地址等等。

在Linux内核启动时,内核会使用设备树机制自动加载设备驱动程序,并将设备节点和驱动程序进行匹配,从而实现设备驱动的自动加载和初始化。

什么是DTS?

设备树源码(Device Tree SourceDTS)是用来描述硬件设备信息的一种语言。它是一种中立的表示方式,用于描述硬件设备的物理特性、接口信息和驱动程序的相关信息等,与处理器架构和操作系统无关。设备树被广泛应用于嵌入式系统领域,特别是在使用Linux内核的嵌入式系统中。

设备树是一种树形结构的数据结构,通常使用.dts文件来描述。.dts文件包含了设备树节点和属性的定义,其中节点代表硬件设备,属性则包含了硬件设备的相关信息。设备树文件通常被编译成二进制格式(Device Tree BlobDTB),并通过bootloader加载到内存中,供内核驱动程序解析使用。

设备树的作用是将硬件信息与软件驱动程序分离,可以使驱动程序更加灵活,适应多种硬件平台。使用设备树可以使内核代码更具可移植性,简化了内核的开发和维护,同时也方便了硬件厂商和系统集成商进行硬件设计和系统开发。

在Linux内核中,设备树被广泛应用于各种设备的驱动程序开发。在编写驱动程序时,我们通常需要通过解析设备树文件来获取硬件设备的相关信息,并使用内核提供的接口来控制硬件设备。

驱动是如何读取DTS文件的?

驱动程序可以通过内核提供的API来读取DTS文件中的节点和属性信息,以获取硬件设备的相关信息。在Linux内核中,驱动程序通常使用以下API来读取DTS文件:

of_find_node_by_name:通过节点名字查找节点,返回设备树节点的指针。

of_property_read_u32:读取DTS文件中的一个32位整数类型的属性值,并返回读取结果。

of_property_read_string:读取DTS文件中的一个字符串类型的属性值,并返回读取结果。

of_irq_get:获取设备的中断号。

of_clk_get:获取设备的时钟信息。

of_address_to_resource:获取设备的物理地址信息。

of_device_is_available:检查设备是否可用。

以上API是设备树节点和属性的读取接口,驱动程序可以通过这些接口来获取设备树中的信息,并根据需要进行操作。

在驱动程序中,通常会在设备初始化的过程中读取设备树中的节点和属性信息,根据这些信息初始化设备并设置相关参数。例如,一个LED驱动程序可以通过读取设备树中的GPIO节点来获取LED所连接的GPIO引脚信息,从而控制LED的亮灭。

这里以i.MX6ULL为例讲解一下驱动读取DTS的过程。

首先,我们需要在设备树中定义一个设备节点,该节点包含了LED的相关信息,如下所示:

&iomuxc {
    pinctrl_leds: ledsgrp {
        fsl,pins = <
            MX6UL_PAD_GPIO1_IO03__GPIO1_IO03 0x4001b0b0
        >;
    };

    leds {
        compatible = "gpio-leds";
        pinctrl-names = "default";
        pinctrl-0 = <&pinctrl_leds>;
        led1 {
            gpios = <&gpio1 3 0>;
            label = "led1";
            default-state = "off";
        };
    };
};

在这个设备树节点中,我们首先定义了一个pinctrl组,该组用于定义LED的GPIO引脚,然后在设备树中定义了一个leds节点,该节点指定了与LED相关的设备信息,包括设备类型(compatible属性)、GPIO引脚配置(pinctrl属性)、设备节点名称(led1)、LED的GPIO编号(gpios属性)、LED的名称(label属性)和默认状态(default-state属性)。

接下来,我们需要在内核驱动程序中使用设备树中的设备节点信息来控制LED。在i.MX6ULL中,LED控制器驱动程序是通过LED框架来实现的,该驱动程序需要在probe函数中获取LED的GPIO配置信息,然后使用LED框架提供的接口来控制LED。

以下是一个简单的LED控制器驱动程序的示例代码,该驱动程序使用了设备树中定义的led1设备节点:

#include 
#include 
#include 
#include 
#include 
#include 

static struct gpio_desc *led_gpio_desc;

static int myled_probe(struct platform_device *pdev)
{
    struct device_node *np = pdev->dev.of_node;
    struct led_classdev *led_cdev;
    int ret;

    // 从设备树中获取LED的GPIO配置
    led_gpio_desc = of_get_named_gpio_desc(np, "gpios"0);
    if (!led_gpio_desc) {
        dev_err(&pdev->dev, "Failed to get GPIO\n");
        return -EINVAL;
    }

    // 将GPIO引脚设置为输出模式
    ret = gpio_direction_output(led_gpio_desc->gpio, 0);
    if (ret) {
        dev_err(&pdev->dev, "Failed to set GPIO direction\n");
        return ret;
    }

    // 注册LED设备
    led_cdev = devm_kzalloc(&pdev->dev, sizeof(*led_cdev), GFP_KERNEL);
    if (!led_cdev) {
        dev_err(&pdev->dev, "Failed to allocate memory\n");
        return -ENOMEM;
    }

    led_cdev->name = "myled";
    led_cdev->brightness_set = led_brightness_set;
    led_cdev->max_brightness = 1;

    ret = devm_led_classdev_register(&pdev->dev, led_cdev);
    if (ret) {
        dev_err(&pdev->dev, "Failed to register LED device\n");
        return ret;
    }

    return 0;
}

static int myled_remove(struct platform_device *pdev)
{
    devm_led_classdev_unregister(&pdev->dev, &led_cdev);

    return 0;
}

static const struct of_device_id myled_of_match[] = {
    { .compatible = "gpio-leds" },
    {},
};
MODULE_DEVICE_TABLE(of, myled_of_match);

static struct platform_driver myled_driver = {
    .driver = {
        .name = "myled",
        .of_match_table = myled_of_match,
    },
    .probe = myled_probe,
    .remove = myled_remove,
};

module_platform_driver(myled_driver);

MODULE_AUTHOR("Your Name");
MODULE_DESCRIPTION("Driver for myled");
MODULE_LICENSE("GPL");

probe函数中,我们首先从设备树中获取了LED的GPIO配置信息,然后将GPIO引脚设置为输出模式,接着注册了一个LED设备,并设置了该设备的名称(name属性)、亮度设置函数(brightness_set属性)和最大亮度值(max_brightness属性)。最后,我们通过调用devm_led_classdev_register函数将该LED设备注册到LED框架中。

remove函数中,我们调用devm_led_classdev_unregister函数来注销已经注册的LED设备。

设备树文件通过定义设备节点来描述硬件设备信息,内核驱动程序可以通过解析设备树文件来获取硬件设备信息,并通过LED框架提供的接口来控制LED。

推荐阅读



01

加入嵌入式交流群


02

嵌入式资源获取


03

STM32中断优先级详解


04

STM32下载程序新思路--使用串口下载程序


嵌入式悦翔园 专注于嵌入式技术,包括但不限于STM32、Arduino、51单片机、物联网、Linux等编程学习笔记,同时包含大量的学习资源。欢迎关注,一同交流学习,共同进步!
评论 (0)
  • 四、芯片封测技术及应用场景1、封装技术的发展历程 (1)DIP封装:早期分立元件封装,体积大、引脚少; (2)QFP封装:引脚密度提升,适用于早期集成电路。 (3)BGA封装:高密度互连,散热与信号传输优化; (4)3D封装:通过TSV(硅通孔)实现垂直堆叠,提升集成度(如HBM内存堆叠); (5)Chiplet封装:异质集成,将不同工艺节点的模块组合(如AMD的Zen3+架构)。 (6)SiP封装:集成多种功能芯片(如iPhone的A系列SoC整合CPU、GPU、射频模块)。2、芯片测试 (1
    碧海长空 2025-04-15 11:45 236浏览
  • 一、引言:智能化趋势下的学爬玩具开发挑战随着早教理念的普及,学爬玩具作为婴幼儿早期运动能力开发的重要工具,市场需求持续增长。然而,传统学爬玩具开发面临多重挑战:需集成红外遥控、语音交互、电机控制等多模块,开发周期长、硬件成本高;复杂的红外编解码与语音功能实现依赖工程师深度参与,技术门槛陡增。如何以更低成本、更快速度打造差异化产品,成为行业亟待解决的痛点。二、传统开发模式痛点分析硬件冗余红外接收模块、语音芯片、主控MCU分立设计,导致PCB面积增加,BOM成本攀升。开发周期长需工程师独立完成红外协
    广州唯创电子 2025-04-16 08:40 79浏览
  • 2025年4月13日(中国武汉)——在全球经济分化与地缘政治不确定性加剧的背景下,科技与金融的深度融合已成为推动创新与繁荣的关键动力。为实现科技创新、产业进步和金融发展有机结合,发挥金融对科技创新和产业进步的支持作用,国际金融论坛(IFF)科技金融委员会启动大会暨首届科技金融圆桌会议于4月13日在湖北省武汉市武汉产业创新发展研究院成功举行。同时,IFF科技金融委员会由国际金融论坛IFF与武创院联合成立。本次大会汇聚了来自政府、产业与学术研究机构及金融等多领域的精英,共同探讨科技金融如何更好地服务
    华尔街科技眼 2025-04-15 20:53 65浏览
  • 一、芯片的发展历程总结:1、晶体管的诞生(1)电子管时代 20世纪40年代,电子管体积庞大、功耗高、可靠性差,无法满足计算机小型化需求。(2)晶体管时代 1947年,贝尔实验室的肖克利、巴丁和布拉顿发明点接触晶体管,实现电子信号放大与开关功能,标志着固态电子时代的开端。 1956年,肖克利发明晶体管。(3)硅基晶体管时代 早期晶体管采用锗材料,但硅更耐高温、成本低,成为主流材料。2、集成电路的诞生与发展 1958年,德州仪器工程师基尔比用锗材料制成世界上第一块含多个晶体管的集成电路,同年仙童半导
    碧海长空 2025-04-15 09:30 143浏览
  • 二、芯片的设计1、芯片设计的基本流程 (1)需求定义: 明确芯片功能(如处理器、存储、通信)、性能指标(速度、功耗、面积)及目标应用场景(消费电子、汽车、工业)。 (2)架构设计: 确定芯片整体框架,包括核心模块(如CPU、GPU、存储单元)的协同方式和数据流路径。 (3)逻辑设计: 通过硬件描述语言(如Verilog、VHDL)将架构转化为电路逻辑,生成RTL(寄存器传输级)代码。 (4)物理设计: 将逻辑代码映射到物理布局,涉及布局布线、时序优化、功耗分析等,需借助EDA工具(如Ca
    碧海长空 2025-04-15 11:30 184浏览
  • 三、芯片的制造1、制造核心流程 (1)晶圆制备:以高纯度硅为基底,通过拉晶、切片、抛光制成晶圆。 (2)光刻:光刻、离子注入、薄膜沉积、化学机械抛光。 (3)刻蚀与沉积:使用干法刻蚀(等离子体)精准切割图形,避免侧壁损伤。 (4)掺杂:注入离子形成PN结特性,实现晶体管开关功能。2、材料与工艺创新 (1)新材料应用: 高迁移率材料(FinFET中的应变硅、GaN在射频芯片中的应用); 新型封装技术(3D IC、TSV硅通孔)提升集成度。 (2)工艺创新: 制程从7nm到3nm,设计架构由F
    碧海长空 2025-04-15 11:33 232浏览
  • 展会名称:2025成都国际工业博览会(简称:成都工博会)展会日期:4月23 -25日展会地址:西部国际博览城展位号:15H-E010科士威传动将展示智能制造较新技术及全套解决方案。 2025年4月23-25日,中国西部国际博览城将迎来一场工业领域的年度盛会——2025成都国际工业博览会。这场以“创链新工业,共碳新未来”为主题的展会上,来自全球的600+ 家参展企业将齐聚一堂,共同展示智能制造产业链中的关键产品及解决方案,助力制造业向数字化、网络化、智能化转型。科士威传动将受邀参展。&n
    科士威传动 2025-04-14 17:55 90浏览
  • 一、引言:健康管理数字化浪潮下的血压监测转型在慢性病高发与老龄化加剧的双重压力下,家庭健康监测设备正从“被动测量工具”向“主动健康管家”演进。传统血压计虽能提供基础数值,却无法解决用户的核心痛点:数据如何解读?异常如何干预?风险如何预防?WT2605C芯片方案的诞生,通过“AI对话+云端互联+个性化服务”三重技术突破,重新定义了血压计的价值边界——它不仅是一台测量仪器,更是一个全天候在线的健康管理生态系统。二、传统血压计的局限与用户需求升级1. 功能单一性困境数据孤岛:仅显示收缩压/舒张压数值,
    广州唯创电子 2025-04-16 08:55 82浏览
  • 一、智能门锁市场痛点与技术革新随着智能家居的快速发展,电子门锁正从“密码解锁”向“无感交互”进化。然而,传统人体感应技术普遍面临三大挑战:功耗高导致续航短、静态人体检测能力弱、环境适应性差。WTL580微波雷达解决方案,以5.8GHz高精度雷达感知技术为核心,突破行业瓶颈,为智能门锁带来“精准感知-高效触发-超低功耗”的全新交互范式。二、WTL580方案核心技术优势1. 5.8GHz毫米波雷达:精准感知的革命全状态人体检测:支持运动、微动(如呼吸)、静态(坐卧)多模态感知,检测灵敏度达0.1m/
    广州唯创电子 2025-04-15 09:20 106浏览
  • 一、智能语音播报技术演进与市场需求随着人工智能技术的快速发展,TTS(Text-to-Speech)技术在商业场景中的应用呈现爆发式增长。在零售领域,智能收款机的语音播报功能已成为提升服务效率和用户体验的关键模块。WT3000T8作为新一代高性能语音合成芯片,凭借其优异的处理能力和灵活的功能配置,正在为收款机智能化升级提供核心技术支持。二、WT3000T8芯片技术特性解析硬件架构优势采用32位高性能处理器(主频240MHz),支持实时语音合成与多任务处理QFN32封装(4x4mm)实现小型化设计
    广州唯创电子 2025-04-15 08:53 123浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦