Windows Display Driver Model
Windows Display Driver Model (WDDM, также WVDDM в эпоху Vista) — это архитектура графических драйверов для видеокарты под управлением Microsoft Windows, начиная с Windows Vista[1]. Она является заменой для архитектуры видеодрайверов Windows XP и нацелена на повышение производительности графики и новую функциональность[1].
WDDM предоставляет функциональность, необходимую для отображения рабочего стола и приложений с помощью диспетчера окон рабочего стола — диспетчера составных окон, работающего поверх Direct3D. Она также поддерживает интерфейсы новой инфраструктуры DXGI (DirectX Graphics Infrastructure), необходимые для основных операций создания и управления устройством. Спецификация WDDM требует видеокарту, поддерживающую по меньшей мере Direct3D 9, и должна реализовывать интерфейсы до Direct3D 9 для совместимости со старыми приложениями Direct3D; по желанию она может реализовывать интерфейсы для Direct3D 10/10.1 и выше.
Возможности, привнесённые моделью WDDM
Драйверы WDDM открывают новые функциональные области, которые не предоставлялись на унифицированной основе более ранними моделями графических драйверов:
Виртуализованная видеопамять
В контексте графики виртуализация означает, что отдельные процессы (в пользовательском пространстве) не могут видеть память соседних процессов даже путём вставки фальшивых команд в командный поток. Драйверы WDDM позволяют делать виртуализацию видеопамяти[2] и подстановку страниц видеопамяти в системную память. Если окажется, что доступной видеопамяти недостаточно для хранения всех видеоданных и текстур, данные, не используемые в текущий момент, перемещаются в системную память или на диск. Если вытесненные данные становятся нужны, они загружаются обратно. Виртуализация была в некоторой степени возможна в драйверах, рассчитанных на предыдущие модели построения (такие, как модель драйверов Windows XP), но это была целиком зона ответственности драйвера, а не системы.
Диспетчеризация
Исполняемый модуль управляет диспетчеризацией (планированием) конкурирующих между собой графических контекстов.[3] Каждый список команд помещается в очередь для исполнения графическим процессором, и может быть выгружен исполняемым модулем, если появляется более важная задача и если выполнение списка ещё не началось. Такое поведение отличается от потоков центрального процессора, где задача не может быть прервана и поэтому занять больше времени, чем нужно и заставить компьютер медленнее отвечать на запросы. Гибридный алгоритм планирования между родными и лёгкими потоками со взаимодействием потоков даёт бесшовный параллелизм. Важно заметить, что планирование — это не новая идея, но ранее была сферой ответственности разработчиков драйверов. WDDM пытается унифицировать опыт разных разработчиков, управляя выполнением задач графического процессора.
Межпроцессное совместное использование поверхностей Direct3D
Графическая поверхность Direct3D — это область памяти, содержащая информацию о текстурированных ячейках, используемых для просчёта двумерной или трёхмерной сцены. WDDM позволяет процессам совместно использовать поверхности Direct3D[4]. Поэтому приложение может включить ячейку, созданную другим приложением, в рассчитываемую сцену. Совместное пользование текстур процессами до WDDM было сложной задачей, поскольку требовало копирования данных из видеопамяти в системную память и назад, в видеопамять нового устройства.
Расширенная отказоустойчивость
Если драйвер WDDM зависнет или встретит сбой, графический стек перезапустит драйвер.[1] При сбое графической аппаратуры произойдёт перехват этого события и, если необходимо, драйвер будет перезапущен.
Драйверы для Windows XP были вольны реагировать на аппаратные сбои на своё усмотрение, либо уведомлением пользователя, либо попыткой устранить ошибку молча. С драйвером WDDM все сбои аппаратуры вызывают перезапуск драйвера, а пользователь получает всплывающее сообщение; это унифицирует поведение драйверов разных разработчиков.
Предыдущие драйверы реализовывались полностью в режиме ядра, в то время как WDDM частично реализован в пользовательском режиме. Если область пользователя даст невосстановимую ошибку, это в худшем случае неожиданно прервёт работу приложения вместо синего экрана, как это было в предыдущих моделях драйверов.
WDDM также позволяет перезапускать или вытаскивать графическую аппаратуру без надлежащей перезагрузки. На практике, обновление драйвера не должно требовать перезагрузки.
Необходима новая модель драйверов
Одним из основных сценариев, которые делает возможным Windows Display Driver Model, является Desktop Window Manager. Поскольку рабочий стол и окна приложений, управляемые DWM, являются приложениями Direct3D, количество открытых окон напрямую влияет на требуемый объём видеопамяти. Поскольку нет ограничения на количество открытых окон, доступной видеопамяти может оказаться недостаточно, и потребуется виртуализация. Поскольку содержимое окон, которые DWM объединяет в конечный рабочий стол, создаётся разными процессами, необходимо межпроцессное совместное использование графических поверхностей. Также, поскольку одновременно с DWM на рабочем столе могут работать другие приложения DirectX, приложения должны иметь возможность совместного доступа к графическому процессору, что требует диспетчеризации.
Однако сказанное справедливо для Майкрософтовской реализации составного рабочего стола под Windows Vista, с другой стороны, составной рабочий стол теоретически не нуждается в новой модели графических драйверов. Успешные реализации составных рабочих столов существовали до Windows Vista на других платформах, таких, как Quartz, Compiz, WindowFX. Своим подходом Microsoft попытался сделать надёжный WDDM как обобщение опыта по разным графическим процессорам от различных производителей, как стандартизацию их свойств и качеств. Программные свойства, отсутствующие у других моделей драйверов, можно было бы сделать несущественными с помощью дополнений или если бы была доступна менее ограничивающая или просто другая модель драйверов.
Ограничения
Новая модель драйверов требует, чтобы графическая аппаратура поддерживала, по крайней мере, Shader Model 2.0 (fixed function pipeline is now translated to 2.0 shaders). Однако, по информации Microsoft, на 2009 год только около 1—2 процентов аппаратуры использовало модель драйверов Windows XP[5], а остальные уже являются WDDM-совместимыми. Модель также требует наличия некоторых других аппаратных возможностей (по этой причине, например, аппаратура, поддерживающая SM 2.0, такая, как Intel GMA 900, не проходит сертификацию на WDDM[6]).
Одно из ограничений драйвера WDDM версии 1.0 в том, что он не поддерживает одновременно несколько драйверов в многоадаптерном многомониторном окружении. Если у многомониторной системы более одного графического адаптера, оба адаптера должны использовать один и тот же драйвер WDDM. Если используется более одного драйвера, Windows выключит один из них.[7]. У WDDM 1.1 уже нет такого ограничения.[8]
В WDDM 1.0/1.1 отсутствуют некоторые режимы, ранее обслуживавшиеся непосредственно драйвером, такие, как растяжка рабочего стола на несколько мониторов[9][10], хотя режим Dual View[11] по-прежнему доступен.[12]
WDDM 1.1
Windows 7 поддерживает важные дополнения к WDDM, известные как WDDM 1.1; подробности этой новой версии были раскрыты на WinHEC 2008. Новые возможности включают[5]:
- DXGI 1.1, что характеризует возвращение аппаратного ускорения двумерного графического интерфейса пользователя для использования системой GDI[13] и Direct2D/DirectWrite (но не GDI+)
- BitBlt, StretchBlt, TransparentBlt
- AlphaBlend, ColorFill
- Поддержка шрифтов ClearType
- Интерфейс драйвера устройства Direct3D 11 (DDI)
- DXVA-HD DDI[14]
- Hardware video overlay DDI[15]
- Необязательное шифрование AES 128
- Необязательное декодирование зашифрованного графического содержимого
- Поддержка нескольких драйверов в многоадаптерном многомониторном окружении
Аппаратное ускорение операций GDI и Direct2D/DirectWrite помогает уменьшить расход памяти в Windows 7, поскольку системе компоновки DWM больше не нужно держать копию системной памяти для всех графических поверхностей, используемых GDI/GDI+, как это было в Windows Vista.[16][17]
WDDM 1.1, Direct3D 11, Direct2D и DirectWrite также будут доступными с выходом Windows Vista Platform Update; однако, GDI/GDI+ в Vista будет по-прежнему полагаться на программный просчёт, и Desktop Window Manager будет продолжать использовать Direct3D 9Ex.
Драйверы WDDM 1.1 обратно совместимы со спецификацией WDDM 1.0; как драйверы 1.0, так и 1.1 можно использовать в Windows Vista с Platform Update или без него.[5]
WDDM 1.2
Windows 8 включает WDDM 1.2[18][19] и DXGI 1.2.[19][20] Новые функции были представлены на конференции Build 2011 и включают улучшения производительности и так же поддержку для стереоскопического 3D рендеринга, а также видео воспроизведения.
Другие главные изменения включают вытесняющую многозадачность для GPU вместе с лучшей степенью параллельных вычислений (DMА буфера, примитивов, треугольников, пикселей, или на уровне инструкций),[21] уменьшено потребление памяти, улучшено разделение ресурсов, и более быстрое обнаружение и восстановление. 16-бит цветовой формат поверхностей (565, 5551, 4444) являются обязательными в Windows 8, и Direct3D 11. Поддержка YUV 4:4:4/4:2:2/4:2:0/4:1:1 видео формата с 8, 10, и 16-бит точностью, а также 4 и 8-бит формат палитры.[22]
WDDM 1.2 поддерживаются только WDDM-драйверами, такими как Microsoft Basic Display Driver[23] и WARP-основанный Microsoft Basic Render Driver который заменяет видео драйвер уровня ядра.
На WinHEC 2006 Microsoft говорил о своих планах сделать значительное изменение WDDM для улучшения многозадачности применительно к графическим процессорам. Согласно информации Microsoft, WDDM 1.0 позволяет выполнять лишь элементарное планирование задач с просчётом «batch queue» granularity. WDDM 2.0 и WDDM 2.1', которые планировались после выхода Vista[24] но относительно которых Microsoft не огласил дату выхода в свет (Windows 8 поддерживает лишь WDDM 1.2), могли бы предложить вытесняющую многозадачность на уровне мелких структурных единиц и потребовали бы нового поколения графических процессоров.[25][26]
Поддерживается в Windows 10.
WDDM 1.3
Windows 8.1 включает WDDM 1.3[27] и DXGI 1.3.[28] Новые улучшения включают возможность уменьшения потребления памяти DXGI адаптера, многоплановые наложения, перекрытия цепочки переключений и масштабируемые цепочки переключений, выбор экранного буфера субрегиона для цепочки переключений и меньшей задержки цепочки переключений отображения. Функции драйвера могут включать поддержку беспроводных дисплеев (Miracast), формат YUV диапазона, кросс-адаптерные ресуры и GPU движок перечислений возможностей. Улучшения в производительности графического ядра системы.[29]
WDDM 2.0
Windows 10 включает WDDM 2.0, он был спроектирован таким образом, чтобы значительного уменьшить нагрузку на драйвер уровня ядра для GPU с поддержкой виртуальной адресации памяти,[30] для улучшения многозадачности в пользовательском режиме драйвера и как результат снижения нагрузки на центральный процессор.[31][32][33][34] Windows 10 так же включает DXGI 1.4.[35]
Direct3D 12 API, анонсированный на Build 2014, требует WDDM 2.0. Новый API позволяет автоматически управлять ресурсами, выполнять конвейеризацию запросов и позволяет получить разработчикам более низкоуровневое управление над памятью адаптера и стадиями рендеринга.
WDDM 2.1
Windows 10 Anniversary Update (версия 1607) включает WDDM 2.1, обеспечивает поддержку Shader Model 6.0 (обязательную для уровня функций DirectX12 12_0 и 12_1),[36] а также DXGI 1.5 с HDR10 — 10-бит High Dynamic Range Rendering, формат широкого диапазона цветов[37] принятый ITU-T Rec. 2100/Rec.2020 — и переменную частоту обновления.[38]
WDDM 2.2
Windows 10 Creators Update (версия 1703) включает WDDM 2.2, который адаптирован для виртуальной, дополненной и смешанной реальности с стереоскопическим рендерингом для платформы Windows Mixed Reality, и DXGI 1.6.[39]
WDDM 2.3
Windows 10 Fall Creators Update (версия 1709) включает WDDM 2.3.
- Аппаратная очередь
- Поддержка блока управления памятью (MMU) для операций ввода-вывода
- Поддержка чёрного списка
- Поверхности цепочек буферов
- Просмотр GUID устройства
- Опрос версий (bios/архитектурной информации)
- Опрос производительности (значение частоты (текущая/макс/разгон), напряжение (текущая/макс/разгон), частота памяти, скорость памяти, пропускная способность PCIE, обороты кулера, потребление энергии, температура (макс/внимание), переопределение состояния питания)
WDDM 2.4
Windows 10 April 2018 Update (версия 1803) включает WDDM 2.4.
- Дополнительные d3d типы распределения памяти
- SDR Регулировка уровня белого
- Паравиртуализация адаптера
- Произвольная защита ядра
- Настраиваемые тайминги рендеринга дисплея
- Поддержка съемных адаптеров
- Поддержка конфигурации дисплея
- Поддержка источника-владельца
- Перенаправление дисплея
- Поддержка трансформации цветового пространства
- Защищенная сессия устройства
- Процесс удаления устройства (проверяет, может ли процесс, использующий адаптер, восстанавливаться после удаления графического устройства)
С момента появления Windows 10 April 2018 Update и благодаря изменениям в WDDM, стало возможным использовать функцию аналогичную двойной графики в ноутбуках. Например, что позволяет запускать программы\игры на более мощной видеокарте, а выводить изображение через встроенную графику напрямую по внутренней (PCI-E) или внешней шине, без необходимости подключать монитор к мощной видеокарте. Так же может выступать в качестве решения проблемы, если на видеокарте нет VGA видеовыхода, а в материнской плате он присутствует.
Важно: Такую поддержку гарантировано обеспечивают процессоры Intel не ниже поколения Haswell и видеокарты nVidia поколения Kepler (600 серия). Для оптимальной производительности cross-adapter clone mode (по описанию в документации nVidia) настоятельно рекомендуется последняя актуальная версия Windows 10, а так же свежие драйверы как на видеоядро, так и на дискретную видеокарту.
Ранее такую возможность предоставлял аппаратно-программный комплекс как LucidLogix, но материнские платы с ее наличием встречались реже и были значительно дороже. Так же все выше указанное может способствовать повышению производительности игр и тяжелых 3D приложений как CAD, и прочих. Плюс использование этого функционала способно снизить энергопотребление и нагрев системы в целом.
Предварительные версии
SDK для Oculus Rift включает DXGI 2 предварительно для Windows 10.
WDDM 2.5
Windows 10 October 2018 Update (версия 1809) включает в себя поддержку WDDM 2.5.
- Поддержка Shader Model 6.3
- Трассировка лучей
- Требования к универсальной модели драйверов
- SRV-Only Tiled Resource Tier 3
- Проход визуализации
- Мета-команды
- HDR Компенсация яркости
- Поддержка HDR Pixel Format
- SDR Уровень белого
WDDM 2.6
Windows 10 May 2019 Update (версия 1903/1909) добавляет поддержку WDDM 2.6.
- Поддержка Shader Model 6.4
- Супер мокрые чернила
- Переменный шейдинг
- Сбор информации для диагностики
- Фоновая обработка
- Горячая замена драйвера
WDDM 2.7
Windows 10 May 2020 Update (версия 2004) привносит поддержку WDDM 2.7.
В данный момент доступно в Windows 10 с использованием драйверов Nvidia версии 451.48[40], Intel 27.20.100.8280 и AMD 27.20.1017.1011, начиная с версии 10.0.19041.
- Планирование графического процессора с аппаратным ускорением: Позволяет видеокарте непосредственно управлять своей видеопамятью, что в свою очередь значительно улучшает плавность игрового процесса и\или скорость отклика тяжелых 3D приложений из-за подъема FPS по минимальному и среднему значению, и тем самым это позволяет снижать задержки в работе. Работает независимо от используемого API для игр и приложений таких как DirectX/Vulkan/OpenGL.[41][42] Поддерживается видеокартами nVidia GeForce начиная с поколения Pascal\10 серии, а поддержка у AMD Radeon возможна только с поколения RDNA/RX 5000 серии или новее в обоих случаях (Это связанно с тем, что функция имеет аппаратную зависимость от наличия Shader Model 6.3 в железе, что можно проверить через Aida64, но не через GPU-Z из-за неправильного отображения информации). Intel временно отключила поддержку в финальных драйверах, но возможно использование тестового драйвера 29.20.100.8674[43] для активации этой функции с видеоядрами от HD 600 модели. Так же данная функция исправляет ошибку со снижением частоты кадров в DWM при работе с разными мониторами, которая проявляется при перетаскивании окон с одного рабочего стола на другой.[44] Возможно еще так, то что данная технология связана с описанием из этого патента. Стоит отметить, что многие сайты по ошибке предлагают принудительно включить эту опцию через реестр c ключем HwSchMode, но этот способ не будет работать из-за отсутствия поддержки драйвером или железом и это можно легко проверить тестами производительности. Сама опция включается пользователем по желанию через параметры Windows 10 в настройках графики по ссылке Ms-settings: display-advancedgraphics или пути: Параметры->Система->Дисплей->Настройка Графики->Планирование графического процессора с аппаратным ускорением. И стоит учитывать, что если кнопка не отображается, то драйвер или видеокарта\видеоядро не имеет поддержки этой функций. (Но можно проверить поддержку драйвером через GPU-Z в разделе WDDM) Плюс, активация этой функции применяется ко всем графическим устройствам в системе, если они поддерживают HAGS (Сокращение от Hardware-accelerated GPU scheduling в английской версии Windows 10 May 2020 Update) и не может быть задана индивидуально для каждого ГП.
- Поддержка Shader Model 6.5
- API DirectX 12 Ultimate
- DirectX 12 Sampler Feedback[45]
- DirectX Raytracing (DXR) Tier 1.1[46]
- Direct3D 12 Mesh Shaders and Amplification Shaders[47]
- Direct3D 12 improved memory allocation control[48]
- Direct3D 12 and Direct3D 9 resource interop[49]
- Direct3D 12 Video Protected Resource support[50]
WDDM 3.0
Windows 11 привносит поддержку WDDM 3.0.
На данный момент доступно в Windows 11 с использованием драйверов NVIDIA начиная с версии 30.0.14.7141 (пакет 471.41) и AMD начиная с версии 30.0.13017.1004 (пакет 21.9.1).
Примечания
- Windows Vista Display Driver Model
- Graphics Memory Reporting in WDDM
- The role of the Windows Display Driver Model in the DWM
- Cross Process Resource Sharing
- WHDC: Graphics Guide for Windows 7 . Microsoft (12 июня 2009). Архивировано 30 апреля 2012 года.
- Intel excuse for no GMA900 WDDM driver: no «HW Scheduler» no driver, Beyond3D, October 26, 2006.
- MultiMonitor Support and Windows Vista . Дата обращения: 20 октября 2007. Архивировано 30 апреля 2012 года.
- Working With the Windows 7 Graphics Architecture: WinHEC 2008 Архивировано 20 октября 2013 года.
- Are there Control Panel features that were available under Windows XP that are no longer available on Windows Vista?
- Stretched Desktop or Spanning Mode Not Available in Catalyst Control Center Under Windows Vista
- Description of DualView in Windows XP
- MultiMonitor Support and Windows Vista
- Windows DDK - GDI Hardware Acceleration . MSDN. Дата обращения: 14 июня 2009. Архивировано 30 апреля 2012 года.
- Windows DDK - DXVA-HD DDI . MSDN. Дата обращения: 13 июня 2009. Архивировано 30 апреля 2012 года.
- Windows DDK - Overlay DDI . MSDN. Дата обращения: 13 июня 2009. Архивировано 30 апреля 2012 года.
- Greg Schechter’s Blog: Redirecting GDI, DirectX, and WPF applications
- Engineering Windows 7 Graphics Performance
- Windows Developer Preview - New for Display devices . MSDN. Microsoft (16 ноября 2013). Дата обращения: 9 декабря 2013.
- Windows Display Driver Model Enhancements in Windows Developer Preview . MSDN. Microsoft (28 сентября 2012). Дата обращения: 9 декабря 2013.
- DXGI 1.2 Improvements . MSDN. Microsoft (16 ноября 2013). Дата обращения: 9 декабря 2013.
- DXGI_Graphics_Preemption_Granularity Enumeration . MSDN. Microsoft (16 ноября 2013). Дата обращения: 9 декабря 2013.
- DXGI_FORMAT enumeration . MSDN. Microsoft (16 ноября 2013). Дата обращения: 9 декабря 2013.
- Microsoft Basic Display Driver — Windows drivers | Microsoft Docs
- WinHEC 2006: Display Driver Logistics And Testing
- WinHEC 2006: Windows Display Driver Model (WDDM) v2 And Beyond
- Dan Warne. Windows graphics system to be overhauled (недоступная ссылка). APC Magazine (June 1, 2006). Дата обращения: 2 июня 2006. Архивировано 15 июня 2006 года.
- What's new for Windows 8.1 Preview display drivers (WDDM 1.3) . MSDN. Microsoft (16 ноября 2013). Дата обращения: 9 декабря 2013.
- DXGI 1.3 Improvements . MSDN. Microsoft (16 ноября 2013). Дата обращения: 9 декабря 2013.
- nabazan-microsoft. Graphics kernel performance improvements (англ.). docs.microsoft.com. Дата обращения: 15 января 2018.
- What's new for Windows 10 Insider Preview display drivers (WDDM 2.0) . Microsoft. Дата обращения: 3 июня 2015.
- McMullen, Max. Direct3D 12 API Preview. MSDN.
- Moreton, Henry DirectX 12: A Major Stride for Gaming | NVIDIA Blog . Blogs.nvidia.com (20 марта 2014). Дата обращения: 26 марта 2014.
- DirectX 12 - DirectX Developer Blog - Site Home - MSDN Blogs . Blogs.msdn.com (20 марта 2014). Дата обращения: 26 марта 2014.
- Smith, Ryan The DirectX 12 Performance Preview: AMD, NVIDIA, & Star Swarm . AnandTech. Purch (6 февраля 2015).
- MSDN — DXGI 1.4 Improvements
- HLSL Shader Model 6.0 — Windows applications | Microsoft Docs
- High Dynamic Range and Wide Color Gamut — Windows applications | Microsoft Docs
- Variable refresh rate displays — Windows applications | Microsoft Docs
- PC Gaming | WinHEC December 2016 | Channel 9
- К будущим играм готова: NVIDIA представила драйвер с полной поддержкой DirectX 12 Ultimate и Vulkan 1.2 . 3DNews - Daily Digital Digest. Дата обращения: 25 июня 2020.
- GPU virtual memory in WDDM 2.0 — Windows drivers (англ.). docs.microsoft.com. Дата обращения: 12 января 2020.
- Windows 10 20H1: Аппаратный планировщик графического процессора . MSReview. Дата обращения: 12 января 2020.
- 29.20.100.8674 - 10th, 9th, 8th and 7th generation (Ice Lake, Comet Lake, Whiskey Lake, Amber Lake, Coffee Lake, Kaby Lake), Windows 10 (англ.). LaptopVideo2Go Forums. Дата обращения: 23 августа 2020.
- Microsoft занялась «тормозами» в Windows 10 при работе с несколькими дисплеями с разной частотой . 3DNews - Daily Digital Digest. Дата обращения: 16 июня 2020.
- Coming to DirectX 12 — Sampler Feedback: some useful once-hidden data, unlocked . devblogs.microsoft.com. Дата обращения: 4 ноября 2019.
- DirectX Raytracing (DXR) Tier 1.1 . devblogs.microsoft.com. Дата обращения: 6 ноября 2019.
- Coming to DirectX 12 — Mesh Shaders and Amplification Shaders: Reinventing the Geometry Pipeline . devblogs.microsoft.com. Дата обращения: 8 ноября 2019.
- Coming to DirectX 12: More control over memory allocation . devblogs.microsoft.com. Дата обращения: 11 ноября 2019.
- Coming to DirectX 12: D3D9On12 and D3D11On12 Resource Interop APIs . devblogs.microsoft.com. Дата обращения: 13 ноября 2019.
- D3D12 Video Protected Resource Support . microsoft.github.io. Дата обращения: 29 мая 2019.
Ссылки
- MSDN — WDDM Introduction Архивировано 6 мая 2010 года.
- List of GPUs supporting WDDM