WinDriver is a cross-platform, kernel-independent development toolkit that allows developers to create user-mode drivers for USB, PCI, and PCI Express devices. It supports a wide range of platforms including Windows, Linux, macOS, and ARM architectures (including Windows ARM and Linux ARM), making it a compelling choice for embedded and desktop applications alike.
For USB devices, WinDriver handles the low-level USB protocol stack including enumeration, endpoint management, and data transfer letting developers write high-level application code that directly interfaces with the hardware. This means that even developers without prior kernel-mode experience can create efficient, stable drivers in significantly less time.
WinDriver also includes DriverWizard, a GUI tool that scans connected devices, reads USB descriptors, and generates fully functional code skeletons in languages like C, C#, .NET, Python, Java & Powershell, tailored to your device’s interface. These templates handle initialization, communication, and error management out-of-the-box, enabling developers to focus on the unique features of their hardware rather than boilerplate code.
WinDriver is ideal for rapid prototyping, production deployment, and long-term maintenance of USB device drivers in both commercial and industrial settings, offering an efficient, low-risk path to robust driver implementation.
Some of the many challenges associated to USB driver development include:
Even minor bugs can cause system-wide failures, making reliability paramount. Furthermore, regulatory requirements (e.g., WHQL certification) often necessitate detailed documentation and testing. This is where Jungo’s WinDriver shines.
Plug your USB device into the host system.
Verify device detection.
Note your device’s Vendor ID and Product ID — required for identification.
Open DriverWizard, scan for USB devices.
Select your device and configure its endpoints and transfer types (control, bulk, interrupt, isochronous).
Generate a custom driver project.
Test communication with basic transfer operations.
Optionally, generate a Windows INF driver file.
Use the generated project or start from WinDriver’s USB API documentation.
Identify the USB endpoints (IN/OUT) used for your device’s communication.
Determine required transfer types (control, bulk, etc.) based on your device.
Build the application using Visual Studio (Windows) or Makefiles (Linux).
Confirm proper integration with WinDriver’s USB handling functions.
Run your application with admin/root privileges.
Verify USB transfers (e.g., data read/write) work as expected.
Use WDDEBUG or logs to monitor traffic and diagnose issues.
For Windows:
For Linux:
In terms of licensing; Jungo offers:
Windows
Developing PCI device drivers on Windows can be complex, requiring knowledge of the Windows Driver Model (WDM) or Windows Driver Frameworks (WDF).
Jungo WinDriver removes these challenges, offering a powerful user-mode solution that speeds up device driver development while ensuring compatibility with various Windows versions, including Windows 10 and 11.
Linux
Developing drivers on Linux requires in-depth knowledge of the kernel, device tree configurations, and system-level APIs, often necessitating direct interaction with low-level hardware interfaces.
Jungo WinDriver makes the process much easier by allowing user-mode driver development. As a result, developers can avoid complex kernel modifications and reduce system crashes. Available across x86, AMD64 and ARM architectures.
macOS
Developing drivers for macOS involves navigating Apple’s I/O Kit framework, which requires proficiency in Objective-C or C++ and a solid grasp of the macOS kernel environment.
Jungo WinDriver simplifies macOS driver development by eliminating the need to work directly with the complex I/O Kit framework and kernel-level code, enabling stable user-mode development using standard C/C++ APIs.
IMPORTANT – READ CAREFULLY: THIS SOFTWARE LICENSE AGREEMENT (“AGREEMENT”) IS A LEGAL AGREEMENT BETWEEN YOU AND JUNGO CONNECTIVITY LTD. (“JUNGO”), FOR THE WINDRIVER SOFTWARE PRODUCT ACCOMPANYING THIS LICENSE (THE “SOFTWARE”). BY INSTALLING, COPYING OR OTHERWISE USING THE SOFTWARE, YOU AGREE TO BE LEGALLY BOUND BY THE TERMS AND CONDITIONS OF THIS AGREEMENT. IF YOU DO NOT AGREE TO THE TERMS AND CONDITIONS OF THIS AGREEMENT, DO NOT INSTALL, COPY, OR OTHERWISE USE THE SOFTWARE.
– Individuals: Jungo grants you, as an individual, a personal, non-exclusive, “single-user” license to use the Software on a single computer, in the manner provided below, at the site for which the license was given.
– Entities: If you are an entity, Jungo grants you the right to designate one individual within your organization (and only one) to have the right to use the Software on a single computer, in the manner provided below, at the site for which the license was given.
– License Scope: A single user license allows usage of WinDriver and redistribution of certain components (as defined below) within a single end product SKU, for a single device (identified by its VID/PID (USB) or VID/DID (PCI)), and without SDK/API capabilities. If you need extended license or distribution rights, please contact Jungo.
RESTRICTIONS ON USE AND TRANSFER
(a) You may not distribute, or otherwise transfer or assign, any portion of the Software, including any of the headers or source files that are included in the Software, unless otherwise expressly permitted in this Agreement, subject to the provisions of Section 4 above.
(b) Subject to your full and continued compliance with the terms of this Agreement, including the ongoing payment of annual license fees, you may distribute the following files:
Windows:
-windrvr1640.sys
-windrvr1640_legacy.sys
-windrvr1640.inf
-windrvr1640.cat
-wdapi1640.dll
-wdapi1640_32.dll
-wdapi1640_arm64.dll
-wdapi_dotnet1640.dll
-wdapi_dotnet1640_32.dll
-wdapi_netcore1640.dll
-wdapi_java1640.dll
-wdapi_java1640.jar
-wdreg.exe
-difxapi.dll
-devcon.exe
-windrvr1630.sys
-windrvr1630.inf
-wd1630.cat
-wdapi1630.dll
-wdapi_dotnet1630.dll
-wdapi_java1630.dll wdapi_java1600.jar
-windrvr1220.dll
-wdapi1220.dll
Linux:
-windrvr_gcc_v3.o_shipped
-windrvr_gcc_v3_regparm.o_shipped
-kp_linux_gcc_v3.o
-kp_linux_gcc_v3_regparm.o
-libwdapi1640.so libwdapi1640_32.so
-libwdapi_java1640.so
-libwdapi_java1640_32.so
-wdapi_java1640.jar
-wdapi_netcore1640.dll
-kp_wdapi1640_gcc_v3.o_shipped
-kp_wdapi1640_gcc_v3_regparm.o_shipped
-linux_wrappers.c
-linux_wrappers.h
-wdusb_linux.c
-wdusb_interface.h
-wd_ver.h
-linux_common.h
-windrvr.h
-windrvr_usb.h
-wdsriov_interface.h
-wdsriov_linux.c
-wdreg
-configure makefile.in
-configure.wd makefile.wd.in
-makefile.wd.kbuild.in
-configure.usb
-makefile.usb.in
-makefile.usb.kbuild.in
-setup_inst_dir
-windrvr_gcc_v2.a windrvr_gcc_v3.a windrvr_gcc_v3_regparm.a
-kp_linux_gcc_v2.o kp_linux_gcc_v3.o kp_linux_gcc_v3_regparm.o
-libwdapi1630.so
-libwdapi_java1630.so wdapi_java1600.java
-kp_wdapi1630_gcc_v2.a kp_wdapi1600_gcc_v3.a kp_wdapi1600_gcc_v3_regparm.a
-linux_wrappers.c linux_wrappers.h wdusb_linux.c
-wdusb_interface.h wd_ver.h linux_common.h windrvr.h windrvr_usb.h
-configure.wd makefile.wd.in makefile.wd.kbuild.in
-configure.usb makefile.usb.in makefile.usb.kbuild.in
macOS:
-libwdapi1640.dyld
-libwdapi_java1640.jar
-libwdapi_java1640.dyld
-wdapi_netcore1640.dll
-WinDriver1640.kext
-WinDriver1640.dext
-wd_mac_install.sh
-wd_mac_uninstall.sh
(c) The files listed in Section 5.b above may be distributed only as part of a complete application that you distribute under your organization name, and only if they significantly contribute to the functionality of your application. For avoidance of doubt, each organization distributing these files as part of the organization products is required to have valid license(s) under the organization name/VID, irrespective of the party who actually performed the product development. Licenses granted to subcontractors do not grant distribution or other rights to the organizations for which they are developing.
(d) The distribution of the windrvr.h header file is permitted only on Linux.
(e) You may not modify the distributed files specified in Section 5.b of this Agreement.
(f) You may not distribute any header file that describes the WinDriver functions, or functions that call the WinDriver functions and have the same basic functionality as that of the WinDriver functions.
Web site: https://www.jungo.com
Email: [email protected]
Use, duplication, or disclosure by the Government is subject to restrictions set forth in subparagraph (c)(1) of The Rights in Technical Data and Computer Software clause at DFARS 252.227-7013 or subparagraphs (c)(1)(ii) and (2) of Commercial Computer Software – Restricted Rights at 48 CFR 52.227-19, as applicable.