间接显示驱动程序概述

间接显示驱动程序 (IDD) 模型是一种简单的用户模式驱动程序模型,用于支持未连接到 GPU 显示输出的监视器。 需要 IDD 的一些典型方案包括:

  • 通过网络将显示输出流式传输到远程客户端(远程显示器)。
  • 为虚拟桌面环境(虚拟显示器)等应用程序创建虚拟监视器。
  • 通过 USB 将硬件保护装置连接到具有常规监视器(VGA、DVI、HDMI、DP 等)的电脑。

IDD 实现

IDD 是设备的第三方提供的 UMDF 驱动程序。 可以使用 IddCx(间接显示驱动程序类 eXtension)公开的功能开发 IDD,以下列方式与 Windows 图形子系统进行交互:

  • 创建表示间接显示设备的图形适配器。
  • 报告监视器与系统的连接和断开。
  • 提供所连接监视器的说明。
  • 提供可用的显示模式。
  • 支持其他显示功能,例如硬件鼠标光标、伽马、I2C 通信和受保护内容。
  • 处理桌面图像以在显示器上显示。

由于 IDD 是 UMDF 驱动程序,因此它还负责实现所有 UMDF 功能,例如设备通信、电源管理、即插即用等。

IDD 在会话 0 中运行,用户会话中没有运行任何组件,因此任何驱动程序不稳定都不会影响整个系统的稳定性。

下图提供了体系结构概述。

显示 UMDF 体系结构中的间接显示驱动程序的示意图。

用户模式模型

IDD 是仅用户模式模型,不支持内核模式组件。 因此,驱动程序可以使用任何 DirectX API 来处理桌面图像。 事实上,IddCx 提供了在 DirectX 图面中编码的桌面图像。

驱动程序不应调用不适合驱动程序使用的用户模式 API,例如 GDI、窗口化 API、OpenGL 或 Vulkan。

IDD 应生成为通用 Windows 驱动程序,以便在多个 Windows 平台上使用。

在生成时:

  • UMDF IDD 声明了它所针对的 IddCx 版本。
  • OS 可确保在加载驱动程序时加载正确版本的 IddCx。

IddCx 回调和函数命名约定

Prefix 类型 备注
EVT_IDD_CX_XXX IDD 回调函数 IDD 实现特定于 IddCx 的回调,例如 EVT_IDD_CX_ADAPTER_COMMIT_MODES,以及相关的 WDF 回调(如 EVT_WDF_DEVICE_D0_EXIT)。
IddCxXxx 函数 IDD 可以调用的系统提供的 IddCx 类扩展函数;例如,IddCxAdapterInitAsync
PFN_IDDCX_XXX 指向 IddCx 函数的指针 IDD 不使用这些指针。 相反,驱动程序使用等效的 IddCxXxx 函数。

代码示例

Microsoft 在 Windows 驱动程序示例 GitHub 上提供了示例 IDD 实现。 此示例演示如何连接监视器、如何响应模式集以及如何接收帧。