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

window 显示驱动开发-提供视频解码功能(三)

​D3DDDICAPS_GETDECODERTFORMATCOUNT和D3DDDICAPS_GETDECODERTFORMATS请求类型

Direct3D 运行时指定D3DDDIARG_GETCAPSpInfo 成员指向的变量中特定 DirectX VA 解码类型的 GUID。 UMD 返回数字,然后返回它为特定 DirectX VA 解码类型支持的呈现目标格式列表。

查询流程概述

对于解码器渲染目标(RT)格式的查询,Direct3D运行时采用两级查询机制:

  1. 查询格式数量:首先获取特定解码器支持的RT格式总数
  2. 获取格式列表:然后获取具体的格式列表

数据结构与参数说明
关键数据结构

typedef struct _D3DDDIARG_GETCAPS {D3DDDICAPS_TYPE Type;     // 请求类型VOID* pInfo;              // 指向包含解码器GUID的结构体VOID* pData;              // 指向返回数据的缓冲区UINT DataSize;            // 缓冲区大小(输入)/返回数据大小(输出)
} D3DDDIARG_GETCAPS;typedef struct _DXVA2_DDI_GET_RT_FORMAT_COUNT {GUID DecodeGuid;          // 要查询的解码器GUID
} DXVA2_DDI_GET_RT_FORMAT_COUNT;

详细查询流程

第一步:查询支持的RT格式数量 (D3DDDICAPS_GETDECODERTFORMATCOUNT)
运行时调用:

DXVA2_DDI_GET_RT_FORMAT_COUNT getRtCountInfo = {DXVA2_ModeH264_E  // 示例:查询H264解码器
};D3DDDIARG_GETCAPS getCapsArgs = {};
getCapsArgs.Type = D3DDDICAPS_GETDECODERTFORMATCOUNT;
getCapsArgs.pInfo = &getRtCountInfo;  // 包含解码器GUID
getCapsArgs.pData = &formatCount;     // 指向UINT变量
getCapsArgs.DataSize = sizeof(UINT);pUMD->GetCaps(&getCapsArgs);

UMD响应要求:

  1. 解析pInfo指向的DXVA2_DDI_GET_RT_FORMAT_COUNT结构
  2. 返回指定解码器支持的RT格式数量
  3. 通过pData返回计数值
  4. 设置DataSize为实际写入的数据大小

第二步:查询RT格式列表 (D3DDDICAPS_GETDECODERTFORMATS)
运行时调用:

std::vector<D3DDDIFORMAT> formatList(formatCount);DXVA2_DDI_GET_RT_FORMAT_COUNT getRtFormatInfo = {DXVA2_ModeH264_E  // 与上一步相同的GUID
};D3DDDIARG_GETCAPS getCapsArgs = {};
getCapsArgs.Type = D3DDDICAPS_GETDECODERTFORMATS;
getCapsArgs.pInfo = &getRtFormatInfo;
getCapsArgs.pData = formatList.data();
getCapsArgs.DataSize = formatCount * sizeof(D3DDDIFORMAT);pUMD->GetCaps(&getCapsArgs);

UMD响应要求:

  • 验证pInfo中的GUID与之前查询一致
  • 填充pData缓冲区所有支持的格式
  • 格式按D3DDDIFORMAT枚举值排列
  • 设置DataSize为实际写入的数据总字节数

常见渲染目标格式

UMD可能返回的典型D3DDDIFORMAT值:

格式值描述
D3DDDIFMT_NV12最常用的YUV 4:2:0格式
D3DDDIFMT_YUY2打包的YUV 4:2:2格式
D3DDDIFMT_A8R8G8B832位ARGB格式
D3DDDIFMT_P01010位精度4:2:0格式
D3DDDIFMT_AYUV4:4:4格式带Alpha通道

错误处理规范

UMD应当正确处理以下情况:

无效GUID:

  • 当pInfo包含不支持的GUID时
  • 应返回0个格式或错误码

缓冲区不足:

if (pArgs->DataSize < requiredSize) {pArgs->DataSize = requiredSize;  // 告知需要的大小return E_INVALIDARG;
}

参数验证:

  • 检查pInfo是否为NULL
  • 验证GUID结构完整性

实现示例代码

UMD侧实现伪代码

HRESULT UMD::GetCaps(D3DDDIARG_GETCAPS* pArgs) {if (!pArgs || !pArgs->pInfo) return E_INVALIDARG;auto* pGuidInfo = (DXVA2_DDI_GET_RT_FORMAT_COUNT*)pArgs->pInfo;switch (pArgs->Type) {case D3DDDICAPS_GETDECODERTFORMATCOUNT: {if (pArgs->DataSize < sizeof(UINT)) return E_INVALIDARG;UINT count = GetSupportedFormatCount(pGuidInfo->DecodeGuid);*(UINT*)pArgs->pData = count;pArgs->DataSize = sizeof(UINT);return S_OK;}case D3DDDICAPS_GETDECODERTFORMATS: {UINT count = GetSupportedFormatCount(pGuidInfo->DecodeGuid);size_t requiredSize = count * sizeof(D3DDDIFORMAT);if (pArgs->DataSize < requiredSize) {pArgs->DataSize = requiredSize;return E_INVALIDARG;}GetSupportedFormats(pGuidInfo->DecodeGuid, (D3DDDIFORMAT*)pArgs->pData);pArgs->DataSize = requiredSize;return S_OK;}// ...其他类型处理}
}

高级注意事项

格式优先级:

  • 建议将最常用/性能最好的格式放在列表前面
  • 运行时通常会选择列表中的第一个支持格式

动态能力:

  • 某些驱动可能根据系统状态返回不同格式
  • 如内存紧张时可能减少支持的格式

多适配器协调:

  • 在混合GPU环境中,格式支持可能不同
  • 需要针对每个适配器单独查询
http://www.xdnf.cn/news/11834.html

相关文章:

  • 飞算JavaAI 炫技赛重磅回归!用智能编码攻克老项目重构难题
  • oracle从表B更新拼接字段到表A
  • 链表题解——环形链表【LeetCode】
  • MySQL 索引:为使用 B+树作为索引数据结构,而非 B树、哈希表或二叉树?
  • mysql 悲观锁和乐观锁(—悲观锁)
  • MySQL 关联查询速查笔记
  • MySQL 事务深度解析:面试核心知识点与实战
  • nginx配置
  • 机器学习基础相关问题
  • vue2 项目中 npm run dev 运行98% after emitting CopyPlugin 卡死
  • QT聊天项目DAY13
  • 掌握 MotionLayout:交互动画开发
  • 用户 xxx is not in the sudoers file.
  • 基于Gemini 2.5 Pro打造的AI智能体CanvasX上线,绘制常见图表(折线图、柱状图等),国内直接使用
  • FreeCAD:开源世界的三维建模利器
  • (每日一道算法题)求根节点到叶节点数字之和
  • HTML基础学习
  • MYSQL之表的内连和外连
  • ABP-Book Store Application中文讲解 - Part 8: Authors: Application Layer
  • 解决Java项目NoProviderFoundException报错
  • C++课设:银行账户管理系统
  • 【Golang笔记04】Go语言中文件操作的学习笔记
  • tauri2项目中自定义执行cmd命令界面卡死以及中文出错问题
  • Elasticsearch中的监控(Monitoring)功能介绍
  • 【Redis】笔记|第8节|大厂高并发缓存架构实战与优化
  • 八:操作系统设备管理之I/O 操作方法
  • AI编程规范失控?三大策略用Cursor Rules精准约束
  • 电子手机商城源码+springboot+vue3(带用户协同过滤个性化推荐算法)
  • DexUMI:以人手为通用操作界面,实现灵巧操作
  • 平面上的最接近点对