一、简介

MediaTek (MTK) 的DRM驱动(基于mtk_drm_drv.c)是为MediaTek SoC(如MT6985、MT6895等)设计的显示子系统(Display Subsystem)驱动程序。它实现了Linux DRM/KMS框架,支持多CRTC、多平面(plane)、连接器(connector)和编码器(encoder)的显示管道。驱动处理硬件组件如OVL(Overlay)、RDMA(Read DMA)、WDMA(Write DMA)、RSZ(Resize)、PQ(Picture Quality)模块(AAL、CCORR等)、DSI/DPI/DP接口等。

关键特点:
  • 硬件支持:集成MediaTek显示硬件,包括双管道(dual-pipe)支持、缩放(RSZ)、PQ增强(AAL、GAMMA等)、MML(Multi-Media Layer,可能用于多媒体处理)。支持DSI、DPI、DP接口。
  • 原子模式设置:使用DRM原子API(drm_atomic_helper_*)处理显示状态更新,支持doze模式(低功耗显示)、安全层(secure layers)、电源管理。
  • 组件化设计:使用Linux component框架动态绑定子组件(如OVL、RDMA等),通过DT绑定兼容节点。
  • 扩展功能:支持AOD(Always-On Display)与SCP(System Control Processor)集成、PMIC电源控制、MMQOS(多媒体QoS)、ESD检查、fence同步等。包含自定义扩展如MML提交(用于PQ处理)。
  • 电源与时钟:使用runtime PM、top clk控制、IOMMU支持。
  • 平台兼容:支持多种SoC(如MT6985、MT6895),通过DT配置(如dispsys_num、ovlsys_num)。

二、代码分析

https://github.com/oppo-source/android_kernel_oppo_mt6985/blob/oppo/mt6985_t_13.1_find_x6/drivers/gpu/drm/mediatek/mediatek_v2/mtk_drm_drv.chttps://github.com/oppo-source/android_kernel_oppo_mt6985/blob/oppo/mt6985_t_13.1_find_x6/drivers/gpu/drm/mediatek/mediatek_v2/mtk_drm_drv.c驱动入口是mtk_drm_probe,出口是mtk_drm_remove。整体基于DRM框架,但添加了MTK特定钩子(如mtk_atomic_*函数)来处理硬件特定逻辑,如RSZ计算、doze切换、PQ旁路等

主要流程介绍

1. 驱动初始化流程(Probe阶段)
  • 解析DT节点,映射MMIO资源(config_regs、side_config_regs等)。
  • 初始化helper_opt(DRM选项,如MMQOS支持)。
  • 获取top clk、AOD-SCP配置、电源域。
  • 迭代DT子节点,添加组件匹配(OVL、RDMA等)。
  • 注册component master(mtk_drm_ops),绑定子组件。
  • 初始化fence、debugfs、disp_plat_dbg等。
  • 启用runtime PM。
2. 绑定与KMS初始化(Bind阶段)
  • 创建DRM设备(drm_dev_alloc)。
  • 初始化KMS(mtk_drm_kms_init):配置mode_config、vblank、plane/connector/encoder。
  • 注册DRM设备(drm_dev_register)。
  • 初始化CRTC(mtk_drm_crtc_create),添加自定义属性(如DOZE_ACTIVE)。
3. 原子更新流程(用户空间配置显示状态时)
  • 检查阶段(drm_atomic_helper_check -> mtk_atomic_check):
    • 计算RSZ ROI(mtk_atomic_disp_rsz_roi,处理缩放和双管道)。
    • 检查平面启用数、安全状态、doze切换。
    • 处理MML平面(_mtk_atomic_mml_plane,用于PQ提交)。
    • 跳过自刷新更新如果在doze模式。
  • 提交阶段(mtk_atomic_commit):
    • 等待fence(mtk_atomic_wait_for_fences)。
    • 调度工作(mtk_atomic_schedule -> mtk_atomic_work)。
    • 在工作中:应用状态(mtk_atomic_complete),更新CRTC(mtk_crtc_atomic_flush)。
    • 处理doze准备/完成(mtk_atomic_doze_preparation/finish,包括PQ旁路、DSI状态更新)。
    • 启用触发(mtk_drm_enable_trig)。
4. 电源与挂起/恢复流程
  • 使用runtime PM(pm_runtime_enable)。
  • 挂起(mtk_drm_sys_suspend):poll禁用,原子挂起。
  • 恢复(mtk_drm_sys_resume):原子恢复,poll启用。
  • AOD/doze特定:与SCP集成,PMIC控制低功耗。
5. 卸载流程(Remove阶段)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/96859.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/96859.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/96859.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Wireshark笔记-DHCP流程与数据包解析

背景DHCP从大学上网络课时就开始知道了,当时只知道,能让计算机上网,要不就静态配IP,要不就DHCP获取,就能上网。2021年时,毕业好几年了,想学习下网络知识,就准备考一个软考网工。按要…

Coze用户账号设置修改用户头像-前端源码

概述 Coze Studio的用户头像修改功能是用户账号设置中的重要组成部分,允许用户上传和更新个人头像。本文将深入分析该功能的前端实现,包括组件架构、文件上传处理、API设计和用户体验优化等方面。 技术架构 整体架构设计 Coze Studio采用现代化的前端架构…

新手Github提交PR(Pull requests)详细教程

一、什么是Pull requests? Pull Requests(PR)是代码协作平台(如 GitHub、GitLab 等)中的一种功能,用于提议将某分支的代码变更合并到另一个分支(通常是主分支)。它允许开发者在合并…

本地通过跳板机连接无公网IP的内网服务器

本地环境:SSH client 堡垒机:有公网IP,有连接内网服务器的秘钥 SSH配置: Host jmsHostName [堡垒机的公网IP]Port 22User rootIdentityFile ~/.ssh/id_rsaHost appHostName 10.0.0.14Port 22User rootIdentityFile ~/.ssh/svc-p…

B树,B+树,B*树

下面我们来详细讲解一下 B树、B树、B*树 这三种非常重要的多路平衡查找树。它们在数据库和文件系统中有着极其广泛的应用。一、为什么需要这些树结构?在开始之前,我们先思考一个问题:为什么已经有了二叉搜索树(BST)、A…

汽车零部件工厂ESOP系统工业一体机如何选型

在汽车零部件工厂的生产管理中,ESOP 系统发挥着至关重要的作用。而工业一体机作为 ESOP 系统的关键硬件支撑,其选型的合理性直接关系到生产效率的提升、生产过程的精准控制以及生产数据的可靠采集与分析。因此,为汽车零部件工厂选择一款适合的…

​维基框架 (Wiki Framework) 1.1.0 版本发布​ 提供多模型AI辅助开发

介绍 多模型AI辅助开发​ 维基框架1.1.0集成了主流AI引擎的统一接口,支持开发者按需调用不同模型的优势能力: ​DeepSeek​:专注代码生成与重构,擅长复杂业务逻辑实现 ​ChatGPT​:多模态推理能力,适用于…

LabVIEW调用MATLAB 的分形生成

LabVIEW 调用 MATLAB,可借前者可视化流程与硬件交互优势,结合后者强数值计算、算法能力,复用成熟算法提速开发,还能灵活改代码。但需匹配版本、装运行环境,数据传递有性能损耗,脚本出错需跨软件调试。​优点…

ubuntu20.04开发ros2,使用docker安装部署的详细教程

学习docker的教程:可以直接在菜鸟教程上学习即可阶段 0:系统检查| 内容 | 建议 | |------|------| | 操作系统 | Ubuntu 22.04(与 ROS2 Humble 最匹配) | | 用户权限 | 能执行 sudo |🧩 阶段 1:在 Ubuntu 上…

SQL Server缩小日志文件.ldf的方法(适用于开发环境)

SQL Server缩小日志文件.ldf的方法(适用于开发环境) 核心概念:为什么日志文件会变大? 首先,理解原因至关重要。事务日志文件在以下情况下会增长: 大量操作:执行了大批量插入、更新或删除操作&am…

2.3零基础玩转uni-app轮播图:从入门到精通 (咸虾米总结)

还在uni-app中的轮播图组件头疼吗?看完这篇,让你轻松掌握swiper的所有秘密!轮播图的重要性 在现代移动应用开发中,轮播图(Swiper)已成为展示焦点内容、广告推广和产品展示的首选组件。无论是电商平台的商品…

FPGA学习笔记——AHT20温湿度读取并在串口显示(IIC协议)

目录 一、任务 二、分析 1.需要了解的 2.需要用到的模块 3.流程分析 三、Visio图 四、代码 五、实验现象 一、任务 使用IIC协议通信的AHT20,将温湿度数据读取出来,并在串口助手上显示。 二、分析 1.需要了解的 需要了解IIC协议简介 也可以看看E…

Pycharm SSH连接

添加远程服务器文件——>设置——>项目下的Python解释器——>添加解释器——>SSH在弹出的弹窗中,输入远程的主机、端口和用户名、一直下一步,得到如下图所示的结果:选择Conda 环境:第一步选择Conda环境;第…

c# 读取xml文件内的数据

好多大型的项目&#xff0c;把一些固定的参数都存在 xml文件里。创建c# winfom 项目&#xff0c;test_xml创建resources文件夹存放xml文件创建parameters.xml文件<root><test_xml><param name "threshold" value "128"/><param name …

Legion Y7000P IRX9 DriveList

Legion Y7000P IRX9 DriveList 联想Y7000P驱动列表 驱动列表 intelwlan-TYY5057FK6MQBRF0.exe NVVGA-TYY5057F3M0H9RF0.exe RTKwlan-TYY5077FFSNECRF0.exe audio-TYY5057F4N1JARF0.exe chipset-TYY5037FB10X3RF0.exe hdr-TYY5027FXNF9AWF0.exe intelVGA-TYY5057F5R9J7RF…

编程与数学 02-017 Python 面向对象编程 23课题、测试面向对象的程序

编程与数学 02-017 Python 面向对象编程 23课题、测试面向对象的程序一、单元测试&#xff08;Unit Testing&#xff09;使用 unittest 模块使用 pytest二、集成测试&#xff08;Integration Testing&#xff09;三、模拟对象&#xff08;Mocking&#xff09;四、测试驱动开发&…

[React]Antd Cascader组件地区选择

前言表单中添加一个地区选择功能&#xff0c;要求支持增删改查功能。Cascader 使用Cascader组件动态加载地区选项。使用 loadData 实现动态加载选项&#xff0c;&#xff08;loadData 与 showSearch 无法一起使用&#xff09;。 这里使用了Form.Item组件。 <Form.Itemlabel{…

深度学习-----《PyTorch神经网络高效训练与测试:优化器对比、激活函数优化及实战技巧》

一、训练过程并行批量训练机制一次性输入64个批次数据&#xff0c;创建64个独立神经网络并行训练。所有网络共享参数&#xff08;Ω&#xff09;&#xff0c;更新时计算64个批次的平均损失&#xff0c;统一更新全局参数。梯度更新策略使用torch.no_grad()上下文管理器清理反向传…

Matplotlib 可视化大师系列(五):plt.pie() - 展示组成部分的饼图

目录Matplotlib 可视化大师系列博客总览Matplotlib 可视化大师系列&#xff08;五&#xff09;&#xff1a;plt.pie() - 展示组成部分的饼图一、 饼图是什么&#xff1f;何时使用&#xff08;何时避免&#xff09;&#xff1f;二、 函数原型与核心参数三、 从入门到精通&#x…