Linux DRM平台驱动匹配和探测的方法是什么

技术Linux DRM平台驱动匹配和探测的方法是什么本篇内容介绍了“Linux DRM平台驱动匹配和探测的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这

本文介绍了“Linux数字版权管理平台的驱动匹配和检测方法是什么”的知识。很多人在实际案例操作中都会遇到这样的困难。接下来,让边肖带领大家学习如何应对这些情况!希望大家认真阅读,学点东西!

Linux内核通过module _ platform _ driver(rock chip _ DRM _ platform _ driver)函数注册RK3399 DRM框架驱动程序代码。宏展开如下:

static int _ initrock chip _ DRM _ platform _ driver _ init(void){ return platform _ driver _ register(rock chip _ DRM _ platform _ driver);} .下面通过分析函数platform_driver_register()的调用过程,展示RK3399 DRM框架platform_device和platform_driver的匹配过程和驱动程序检测过程。

具体通话流程如下:

rock chip _ DRM _ platform _ driver _ init()-# # rock chip _ DRM _ drv . cplatform _ driver _ register()-# # platform _ device . h _ _ platform _ driver _ register()-# # platform . cdriver _ register()-# # driver . cbus _ add _ driver()-n

bsp;    ## bus.c                    driver_attach()->                                      ## dd.c                        bus_for_each_dev()->                               ## bus.c                            __driver_attach()->                            ## dd.c                                1.driver_match_device()->                  ## base.h match                                    platform_match()                       ## platform.c        开始match                                2.driver_probe_device()->                  ## dd.c probe                                    really_probe()->                       ## dd.c                                        platform_drv_probe()->             ## platform.c        开始probe                                            rockchip_drm_platform_probe()  ## rockchip_drm_drv.c

一、match实现

在注册Linux内核platform总线时,相关的总线类型定义如下:

struct bus_type platform_bus_type = {    .name       = "platform",    .dev_groups = platform_dev_groups,    .match      = platform_match,    .uevent     = platform_uevent,    .pm     = &platform_dev_pm_ops,};EXPORT_SYMBOL_GPL(platform_bus_type);

bus_type结构体中定义了platform deviceplatform driver的匹配函数platform_match(),具体实现如下:

static int platform_match(struct device *dev, struct device_driver *drv){    struct platform_device *pdev = to_platform_device(dev);    struct platform_driver *pdrv = to_platform_driver(drv);    /* When driver_override is set, only bind to the matching driver */    if (pdev->driver_override)        return !strcmp(pdev->driver_override, drv->name);    ## 1.设备树匹配    /* Attempt an OF style match first */    if (of_driver_match_device(dev, drv))        return 1;    ## 2.ACPI类型匹配(无)    /* Then try ACPI style match */    if (acpi_driver_match_device(dev, drv))        return 1;    ## 3.id table匹配    /* Then try to match against the id table */    if (pdrv->id_table)        return platform_match_id(pdrv->id_table, pdev) != NULL;    ## 4.device和driver名字匹配    /* fall-back to driver name match */    return (strcmp(pdev->name, drv->name) == 0);}

platform deviceplatform driver的匹配方法包括:

1、设备树匹配

匹配方法:比较dts设备节点的compatible属性定义和驱动文件中of_device_id中的compatible定义是否相同。

注:RK3399 DRM驱动使用的是设备树匹配.

#1. rockchip_drm_drv.c compatible定义static const struct of_device_id rockchip_drm_dt_ids[] = {    { .compatible = "rockchip,display-subsystem", },    ...};MODULE_DEVICE_TABLE(of, rockchip_drm_dt_ids);static struct platform_driver rockchip_drm_platform_driver = {    ...    .driver = {        .name = "rockchip-drm",        .of_match_table = rockchip_drm_dt_ids,        ...    },};#2. rk3399.dtsi compatible定义    display_subsystem: display-subsystem {        compatible = "rockchip,display-subsystem";        ...    };

2、ACPI类型匹配 (无)

3、id table匹配

4、device和driver名字匹配

二、probe实现

在实现了DRM的platform deviceplatform driver匹配后,会进入Linux内核的platform_driver中的probe探测函数进行DRM驱动探测函数的调用。platform_driver初始化如下:

int __platform_driver_register(struct platform_driver *drv,                struct module *owner){    drv->driver.owner = owner;    drv->driver.bus = &platform_bus_type;    drv->driver.probe = platform_drv_probe;    drv->driver.remove = platform_drv_remove;    drv->driver.shutdown = platform_drv_shutdown;    return driver_register(&drv->driver);}

platform_drv_probe实现如下:

static int platform_drv_probe(struct device *_dev){    struct platform_driver *drv = to_platform_driver(_dev->driver);    struct platform_device *dev = to_platform_device(_dev);    int ret;    ...    ret = dev_pm_domain_attach(_dev, true);    if (ret != -EPROBE_DEFER) {        if (drv->probe) {            ## 调用各驱动的probe函数(例:DRM的rockchip_drm_platform_driver())            ret = drv->probe(dev);            if (ret)                dev_pm_domain_detach(_dev, true);        } else {            /* don't fail if just dev_pm_domain_attach failed */            ret = 0;        }    }    ...}

“Linux DRM平台驱动匹配和探测的方法是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/113128.html

(0)

相关推荐

  • Hibernate对象持久化怎么理解

    技术Hibernate对象持久化怎么理解本篇内容介绍了“Hibernate对象持久化怎么理解”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅

    攻略 2021年12月4日
  • 如何在几分钟内实现Kubernetes入口控制器配置

    技术如何在几分钟内实现Kubernetes入口控制器配置本篇文章给大家分享的是有关如何在几分钟内实现Kubernetes入口控制器配置,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说

    攻略 2021年11月24日
  • 兰色妖姬,蓝色妖姬是什么花

    技术兰色妖姬,蓝色妖姬是什么花蓝色妖姬是一种加工花卉,颜色为蓝色兰色妖姬。 由月季和蔷薇多种杂交及研制所得。它通常是用一种染色剂和助染剂调合成着色剂,将鲜花喷染成型,最早来自荷兰。据花卉专家介绍,世界上极少有自然生长的蓝

    生活 2021年11月1日
  • 阅读笔记:程序员修炼之道4

    技术阅读笔记:程序员修炼之道4 阅读笔记:程序员修炼之道4让你的用户参与权衡通常你是为别人编写软件。你常常需要记得从他们那里获取需求2﹒们你是否常t他们、他们想要他们的软件有多好有时候选择并不存在:如果

    礼包 2021年11月29日
  • ARC128 A-D简要题解

    技术ARC128 A-D简要题解 ARC128 A-D简要题解ARC128 A-D简要题解
    A
    题意
    初始给定\(1\)个物品1,\(0\)个物品2 给定序列\(A_i\),每次可以把所有物品1变为\(

    礼包 2021年10月20日
  • Bytom如何使用PAT树

    技术Bytom如何用PAT树本篇内容介绍了“Bytom如何用PAT树”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!为什么

    攻略 2021年12月20日