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

MTK Linux DRM分析(十三)- Mediatek KMS实现mtk_drm_drv.c(Part.1)

一、简介

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.xdnf.cn/news/1344979.html

相关文章:

  • chapter07_初始化和销毁方法
  • 【连接器专题】连接器接触界面的理解
  • CoreShop微信小程序商城框架开启多租户-添加一个WPF客户端以便进行本地操作--读取店铺信息(6)
  • 彩笔运维勇闯机器学习--最小二乘法的数学推导
  • 在线教育领域的视频弹题功能如何打造高互动性在线课程
  • 【Tech Arch】Hadoop YARN 大数据集群的 “资源管家”
  • 全栈开发:从LAMP到云原生的技术革命
  • Kali Linux 发布重构版Vagrant镜像:通过命令行快速部署预配置DebOS虚拟机
  • Pandas中的SettingWithCopyWarning警告出现原因及解决方法
  • DbLens:告别手动Mock数据,右键一键智能生成数据库内容
  • httpclient与hertzclient在处理Host header时的差别
  • 【GPT入门】第53课 LlamaFactory微调效果与vllm部署效果不一致问题解决
  • open webui源码分析6-Function
  • FPGA学习笔记——简单的IIC读写EEPROM
  • FPGA高端项目:图像采集+Aurora 8B10B+UDP图传架构,基于GTH高速收发器的光口转网口,提供工程源码和技术支持
  • IntelliJ IDEA 常用快捷键笔记(Windows)
  • SRE系列(二) | 从可用性到 SLI/SLO
  • 【数据结构】B 树——高度近似可”独木成林“的榕树——详细解说与其 C 代码实现
  • MySQL编程开发(了解)
  • 08高级语言逻辑结构到汇编语言之逻辑结构转换 continue break 完结汇编按逻辑结构
  • Redis---事务
  • 51单片机-驱动步进电机模块教程
  • C#_组合优于继承的实际应用
  • Kafka Broker 核心原理全解析:存储、高可用与数据同步
  • 如何从根源上理解并解决前端的CORS跨域问题
  • 【PSINS工具箱】MATLAB例程,二维平面上的组合导航,EKF融合速度、位置和IMU数据,4维观测量
  • Unreal Engine ClassName Rule
  • Python 中 SQLAlchemy 和 MySQLdb 的关系
  • IKE 与 ISAKMP 核心笔记
  • 微信扫码登陆 —— 接收消息