I am a newbie learning how to write WDM device drivers for USB devices and found that the materials available are all too hard to comprehend (the DDK online doc is one of the most difficult to read, and the WDM Device driver book by Oney isn’t anything better).
So, I’ve got a simple question. Where do I start if I want to create a virtual USB device (for example, a virtual USB mouse which looks like a real USB mouse attached to a USB port) for testing/learning.
So far what I understand is the HIDClass driver (hidclass.sys) has a minidriver for the usb bus (hidusb.sys) that carries out the enumeration of attached USB hardware. So, if I want to hijack the hardware enumeration process and creates my own virtual hardware, should I include a filter driver somewhere to intercept some IRPs related to the hardware enumeration process?
Sorry if the above does not make sense at all since I am still in the learning stage and this is actually one of the exercise I think could help me learn about writing USB device drivers better.
Windows uses a Plug and Play Architecture.
When you insert a USB device, It sends low level USB request to the device and then based on the response from a device decides what driver to load. Matching is done by comparing vendor id, product id and etc to inf files sections. Drivers come in the form of a compiled xxx.sys with xxx.inf file and is loaded to kernel space. Windows decides which xxx.sys to load based on the *.inf file that comes with the device’s driver.
These files have sections like this:
(a more detailed description on what’s in
inffiles can be found over on https://learn.microsoft.com/en-us/windows-hardware/drivers/install/inf-manufacturer-section)A detailed look at the USB enumeration process (Use USB Logger):
For any connected USB device you can see these strings using the Device Manager:
For example, I have a USB storage device with
Device Id = usb\class_08&subclass_06&prot_50hooked up, and this string can be matched to an.inffile that was added to the list of known devices after first enumeration. This file has a stringService = USBSTOR, and so we know thatusbstor.sysis used to interface with this USB Mass Storage Device.Let’s continue with matching process.
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Enum\USBFor disk on key, you can see something like:
For writing drivers my advice is: