window 显示驱动开发-微型端口程序的初始化(三)

初始化内存段的使用

第二次调用中,驱动程序应填充 DXGK_QUERYSEGMENTOUT 或 DXGK_QUERYSEGMENTOUT3的所有成员。 第二次调用中,驱动程序应使用驱动程序支持的段的相关信息填充DXGK_QUERYSEGMENTOUT或DXGK_QUERYSEGMENTOUT3的 pSegmentDescriptor 成员中DXGK_SEGMENTDESCRIPTOR或DXGK_SEGMENTDESCRIPTOR3结构 NbSegment 大小的数组。

在对 DxgkDdiQueryAdapterInfo 的两次调用中,DXGKARG_QUERYADAPTERINFO 的 pInputData 成员指向包含有关 AGP 光圈位置和属性信息的DXGK_QUERYSEGMENTIN结构。 如果没有 AGP 光圈可用,或者存在但未安装适当的 GART 驱动程序,则有关 AGP 光圈的信息设置为零。 如果没有 AGP 光圈,则显示微型端口驱动程序不应在DXGK_QUERYSEGMENTOUT或DXGK_QUERYSEGMENTOUT3的 pSegmentDescriptor 数组中指示它支持 AGP 类型的光圈段。 如果在这种情况下指示 AGP 类型的光圈段,适配器将无法初始化。

在初始化期间,由于内存充足,因此可以从特定段分配分页缓冲区的内存。 视频内存管理器从 DXGK_QUERYSEGMENTOUT 或 DXGK_QUERYSEGMENTOUT3 的 PagingBufferSegmentId 成员中指定的段为分页缓冲区分配内存。 驱动程序指示第二次调用 DxgkDdiQueryAdapterInfo 时分页缓冲区段的标识符。 驱动程序还应指定应在 DXGK_QUERYSEGMENTOUT 或 DXGK_QUERYSEGMENTOUT3 的 PagingBufferSize 成员中为分页缓冲区分配的大小(以字节为单位)。

一、驱动实现规范

1.1 分页缓冲区配置

段选择原则:

  • 优先选择DXGK_MEMORY_VIDEO类型段
  • 备选方案:DXGK_MEMORY_SYSTEM(需设置CACHED标志)

大小计算:

复制代码
// 示例:根据GPU能力动态计算
PagingBufferSize = max(4MB, ScreenWidth * ScreenHeight * 4 * 2);

1.2 多适配器场景处理

1.AGP段共享:

复制代码
if (AgpApertureSize > 0) {
    desc[0].Flags |= DXGK_SEGMENT_SHARED_ACROSS_ADAPTERS;
}

2.原子性保证:对共享段的操作必须使用InterlockedCompareExchange指令

二、错误处理与验证

2.1 常见初始化失败原因

误代码 根本原因 解决方案
STATUS_GRAPHICS_INSUFFICIENT_DMA_BUFFER 分页缓冲区尺寸不足 增大PagingBufferSize
STATUS_GRAPHICS_DRIVER_MISMATCH 段标志冲突 校验WDDM版本兼容性

2.2 调试技巧

使用WinDbg验证段布局

复制代码
dxgkrnl!DXGKRNL_QUERY_SEGMENT_INFO
!d3dcaps -segments

性能计数器监控

复制代码
Get-Counter "\GPU Memory(*)\*" -Continuous

三、性能优化指南

3.1 段分配策略

离散GPU:

复制代码
descriptors[0].Flags = DXGK_SEGMENT_FLAGS_VIDEO;
descriptors[1].Flags = DXGK_SEGMENT_FLAGS_SYSTEM;

集成GPU(UMA):

复制代码
descriptors[0].Flags = 
    DXGK_SEGMENT_FLAGS_SYSTEM | 
    DXGK_SEGMENT_FLAGS_CACHED;

3.2 缓存控制最佳实践

写合并优化

复制代码
movntq [edi], mm0  ; 使用非临时存储指令

预取策略:

复制代码
_mm_prefetch((char*)pMem, _MM_HINT_T0);
相关推荐
程序员JerrySUN10 小时前
驱动开发硬核特训 │ Day 23(下篇): i.MX8MP LCDIFv3 驱动中的 Regulator 系统全解
linux·驱动开发·嵌入式硬件
程序员JerrySUN2 天前
驱动开发硬核特训 · Day 25 (附加篇):从设备树到驱动——深入理解Linux时钟子系统的实战链路
linux·运维·驱动开发
程序员JerrySUN2 天前
驱动开发硬核特训 · Day 24(上篇):走进Linux内核时钟子系统 —— 硬件基础全解析
linux·驱动开发·单片机
程序员JerrySUN2 天前
驱动开发硬核特训 │ Regulator 子系统全解
linux·驱动开发·嵌入式硬件
qxqxa2 天前
dma_request_slave_channel_compat 与 dma_request_channel 的区别
linux·驱动开发
程序员JerrySUN3 天前
驱动开发硬核特训 · Day 21(上篇) 抽象理解 Linux 子系统:内核工程师的视角
java·linux·驱动开发
kuinnebula3 天前
Linux GPIO驱动开发实战:Poll与异步通知双机制详解
驱动开发
程序员JerrySUN3 天前
驱动开发硬核特训 │ 深度解析 fixed regulator 驱动与 regulator_ops
驱动开发
Blossom.1183 天前
可解释人工智能(XAI):让机器决策透明化
人工智能·驱动开发·深度学习·目标检测·机器学习·aigc·硬件架构