The WdfUsbTargetDeviceResetPortSynchronously method resets the USB port that is associated with the specified USB device.
NTSTATUS WdfUsbTargetDeviceResetPortSynchronously( [in] WDFUSBDEVICE UsbDevice );
- UsbDevice [in]
A handle to a USB device object that was obtained from a previous call to WdfUsbTargetDeviceCreate.
WdfUsbTargetDeviceResetPortSynchronously returns the USB I/O target's completion status value if the operation succeeds. Otherwise, this method can return one of the following values:
The caller's IRQL was invalid.
This method also might return other NTSTATUS values.
A bug check occurs if the driver supplies an invalid object handle.
The WdfUsbTargetDeviceResetPortSynchronously method resets the USB port by sending an IOCTL_INTERNAL_USB_RESET_PORT request.
Before the framework resets the I/O target's USB port, it cancels all I/O requests that remain in the I/O target's queue. The driver must not send additional I/O requests to the I/O target until WdfUsbTargetDeviceResetPortSynchronously returns.
After a successful reset operation, the bus driver reselects the configuration and any alternate interface settings that the device had before the reset operation occurred.
For more information about the WdfUsbTargetDeviceResetPortSynchronously method and USB I/O targets, see USB I/O Targets.
The following code example resets a specified device's USB port.
NTSTATUS status; status = WdfUsbTargetDeviceResetPortSynchronously(UsbDevice);
|Available in version 1.0 and later versions of KMDF.|
|Wdf<MajorVersionNumber>000.sys (see Framework Library Versions.)|