Training
Module
Troubleshoot device driver failures - Training
This module focuses on the role of device drivers and troubleshooting problems that pertain to them.
This browser is no longer supported.
Upgrade to Microsoft Edge to take advantage of the latest features, security updates, and technical support.
This topic lists versions of User-Mode Driver Framework (UMDF), the corresponding versions of the Windows operating system, and the changes made in each release.
The following table shows the release history of the UMDF library. You can use the In this article sidebar on the right to navigate quickly to a specific version.
UMDF version | Initial release | Included in | Drivers using this UMDF version run on |
---|---|---|---|
2.33 | Windows 11, version 21H2 WDK; WDK for Windows Server 2022 | Windows 11, version 24H2; Windows 11, version 23H2; Windows 11, version 22H2; Windows 11, version 21H2; Windows Server 2022 | Windows 11, version 21H2 and later; Windows Server 2022 and later |
2.31 | Windows 10, version 2004 WDK | Windows 10, version 2004 (May 2020 Update, Vibranium) | Windows 10, version 2004 and later |
2.29 | Not released in WDK | Windows 10, version 1903 (March 2019 Update, 19H1) | Windows 10, version 1903 and later |
2.27 | Windows 10, version 1809 WDK | Windows 10, version 1809 (October 2018 Update, Redstone 5) | Windows 10, version 1809 and later |
2.25 | Windows 10, version 1803 WDK | Windows 10, version 1803 (April 2018 Update, Redstone 4) | Windows 10, version 1803 and later |
2.23 | Windows 10, version 1709 WDK | Windows 10, version 1709 (Fall Creators Update, Redstone 3) | Windows 10, version 1709 and later |
2.21 | Windows 10, version 1703 WDK | Windows 10, version 1703 (Creators Update, Redstone 2) | Windows 10, version 1703 and later |
2.19 | Windows 10, version 1607 WDK | Windows 10, version 1607 (Anniversary Update, Redstone 1) | Windows 10, version 1607, Windows Server 2016 and later |
2.17 | Windows 10, version 1511 WDK | Windows 10, version 1511 (November Update, Threshold 2) | Windows 10, version 1511, Windows Server 2016 and later |
2.15 | Windows 10 WDK | Windows 10, version 1507 (Threshold 1) | Windows 10, version 1507, Windows Server 2016 and later |
2.0 | Windows Driver Kit (WDK) 8.1 | Windows 8.1 | Windows 8.1 and later |
1.11 | Windows Driver Kit (WDK) 8 | Windows 8 | Windows Vista and later |
1.9 | Windows 7 WDK | Windows 7 | Windows XP and later |
1.7 | Windows Server 2008 WDK | Windows Vista with Service Pack 1 (SP1), Windows Server 2008 | Windows XP and later |
1.5 | Windows Vista WDK | Windows Vista | Windows XP and later |
You can use the Windows Driver Kit (WDK) with Microsoft Visual Studio 2022 to build drivers that run on Windows 10 and later.
For help determining what version of WDF to use, see Which framework version should I use?.
For information about the new features for UMDF drivers in Windows 10, see What's New for WDF Drivers.
For each UMDF version section below, the Windows version in which it was released is listed in parentheses.
Unchanged from version 2.27.
There are no changes or additions for UMDF Version 2.19.
This version adds UMDF support for the following existing interfaces:
For more information, see Dispatching IRPs to I/O Queues.
In addition to the shared functionality described in Getting Started with UMDF, UMDF version 2.0 adds:
Support for timers that do not wake the system if they expire when the system is in a low-power state. For more information, see Using Timers.
Added CanWakeDevice member to WDF_INTERRUPT_CONFIG structure to support interrupts that can be used to bring a device from a low-power Dx state back to its fully on D0 state. For more information, see Using an Interrupt to Wake a Device.
Single-component, single-state (F0) power management for UMDF drivers. For more information, see WdfDeviceAssignS0IdleSettings.
Several debugger extension commands in Wdfkd.dll can now be used for UMDF 2.0 drivers as well. The extension library also contains the following new extension commands designed specifically for debugging UMDF 2.0 drivers:
For a list of extension commands and framework applicability, see Debugger Extensions.
The framework's event logger, or In-flight Recorder (IFR) has been updated to work for UMDF 2.0 drivers.
Other WDF debugger extensions have been updated to work with UMDF 2.0 drivers. For a full list of extension commands, including information about which ones apply to which framework, see Debugger Extensions for WDF Drivers.
Added WdfIoTargetOpenLocalTargetByFile to WDF_IO_TARGET_OPEN_TYPE to allow UMDF drivers to send driver-created requests to lower targets that require an associated file object. For more information, see the Remarks of WDF_IO_TARGET_OPEN_TYPE.
The following UMDF-only routines:
The following KMDF/UMDF methods described in Accessing the Unified Device Property Model:
Support for the following USB configuration types in WdfUsbTargetDeviceSelectConfigType:
Support for querying the following capability types in WdfUsbTargetDeviceQueryUsbCapability:
Version 1.11 adds the following driver-supplied callback interfaces and event callback functions:
Version 1.11 adds the following framework-supplied interfaces:
Version 1.11 adds the following capabilities to UMDF-based drivers:
Added UmdfHostProcessSharing, UmdfDirectHardwareAccess, UmdfRegisterAccessMode, UmdfFileObjectPolicy, and UmdfFsContextUsePolicy directives, described in Specifying WDF Directives in INF Files
Unified property store support, described in Using the Registry in UMDF-based Drivers
IoGetDeviceObjectPointer is integrated to work with UMDF. In prior versions, this routine closes the handle to the device object after taking a reference on the device’s handle. This behavior was incompatible with UMDF’s expectation that the cleanup request on the device object won’t occur until after all the I/O is complete.
Enhanced support for Supporting Idle Power-Down in UMDF-based Drivers. The framework can now put the device in the D3cold power state when the idle timeout period expires. The framework can also cause the device to return to its working (D0) state when the system returns to its working (S0) state.
The following samples are new in UMDF 1.11: WudfVhidmini, NetNfpProvider.
Version 1.9 adds the following driver-supplied callback interfaces:
Version 1.9 adds the following framework-supplied interfaces:
These interfaces add the following capabilities to UMDF-based drivers:
The direct I/O buffer access method
Continuous readers for USB devices
Enhanced support for device interfaces
Enhanced ability to cancel I/O requests
Enhanced access to the registry
Training
Module
Troubleshoot device driver failures - Training
This module focuses on the role of device drivers and troubleshooting problems that pertain to them.
Documentation
KMDF Version History - Windows drivers
This topic lists versions of Kernel-Mode Driver Framework (KMDF), the corresponding versions of the Windows operating system, and the changes made in each release.
Building and Loading a WDF Driver - Windows drivers
This topic describes how to select a target operating system and framework version for a driver project in Visual Studio. It also describes the co-installer and how to determine if you should include this component in your driver package.
Using WDF to Develop a Driver - Windows drivers
This topic provides a high-level overview of the framework objects you'll use to develop a Kernel-Mode Driver Framework (KMDF) driver.