# ViGEm Bus Driver Windows kernel-mode driver emulating well-known USB game controllers. [![Build status](https://ci.appveyor.com/api/projects/status/rv74ufluwib52dq2?svg=true)](https://ci.appveyor.com/project/nefarius/vigembus) [![GitHub All Releases](https://img.shields.io/github/downloads/ViGEm/ViGEmBus/total)](https://somsubhra.github.io/github-release-stats/?username=ViGEm&repository=ViGEmBus) [![Discord](https://img.shields.io/discord/346756263763378176.svg)](https://discord.vigem.org) [![Website](https://img.shields.io/website-up-down-green-red/https/vigem.org.svg?label=ViGEm.org)](https://vigem.org/) [![GitHub followers](https://img.shields.io/github/followers/nefarius.svg?style=social&label=Follow)](https://github.com/nefarius) [![Twitter Follow](https://img.shields.io/twitter/follow/nefariusmaximus.svg?style=social&label=Follow)](https://twitter.com/nefariusmaximus) (This project is available under a free and permissive license, but needs financial support to sustain its continued improvements. In addition to maintenance and stability there are many desirable features yet to be added. If your company is using components of ViGEm, please consider reaching out.) Businesses: support continued development via invoiced technical support, maintenance, sponsoring contracts:
  _E-mail: vigem @ nefarius dot at_ Individuals: support continued maintenance and development via [PayPal](https://paypal.me/NefariusMaximus) donations. ---- ## 🚨 FEATURE-FREEZE 🚨 This project will not receive any new features (e.g. additional emulated devices) besides stability improvements and bugfixes [in favour to focus on a successor solution](https://github.com/ViGEm/ViGEmBus/issues/139). More news to come, stay tuned 😁 --- ## About The `ViGEmBus` driver and `ViGEmClient` libraries represent the core of the Virtual Gamepad Emulation Framework (or `ViGEm` , for short). `ViGEm` aims for a 100% accurate [emulation]() of well-known gaming peripherals as pure software-based devices at kernel level. As it mimics "the real thing" games and other processes require no additional modification whatsoever to detect `ViGEm`-based devices (no Proxy-DLLs or API-Hooking) and simply work out of the box. While the (now obsolete) [Scarlett.Crush Productions Virtual Bus Driver]() is the spiritual father of this project, `ViGEm` has been designed and written from the ground up utilizing Microsoft's [Kernel-Mode Driver Framework](https://en.wikipedia.org/wiki/Kernel-Mode_Driver_Framework). ### Emulated devices Emulation of the following USB Gamepads is supported: - [Microsoft Xbox 360 Controller](https://en.wikipedia.org/wiki/Xbox_360_controller) - [Sony DualShock 4 Controller](https://en.wikipedia.org/wiki/DualShock#DualShock_4) ## Use cases A few examples of the most common use cases for `ViGEm` are: - You have an unsupported input device you'd like to use within games without modifying said game. - You want the freedom to use a different controller of your choice in [PS4 Remote Play](). - You encountered a game not compatible with [x360ce]() (prior to version 4.x). - You want to extend the reach of your input device (like send traffic to a different machine over a network). - You want to test/benchmark your game and need a replay mechanism for your user inputs. - You want to work around player slot assignment order issues in `XInput`. ## Supported Systems ### Version 1.16 and below The driver is built for Windows 7/8.1/10/Server 2016/Server 2019 (x86 and amd64). ### Version 1.17 and above The driver is built for Windows 10/Server 2016/Server 2019 only (x86 and amd64). ## License The ViGEm Bus Driver is licensed under the **BSD-3-Clause**, see [LICENSE](./LICENSE.md) for more information. ## How to build ### Prerequisites - [Step 1: Install Visual Studio 2019](https://docs.microsoft.com/en-us/windows-hardware/drivers/other-wdk-downloads#step-1-install-visual-studio) - [Step 2: Install WDK for Windows 10, version 2004](https://docs.microsoft.com/en-us/windows-hardware/drivers/other-wdk-downloads#step-2-install-the-wdk) - [Step 3: Clone the Driver Module Framework (DMF)](https://github.com/microsoft/DMF) into the same parent directory. - Build the `DmfK` project with Release and Debug configurations for all architectures (x64 and Win32). You can build directly within Visual Studio. Do bear in mind that you'll need to **sign** the driver to use it without [test mode](https://docs.microsoft.com/en-us/windows-hardware/drivers/install/the-testsigning-boot-configuration-option#enable-or-disable-use-of-test-signed-code). ## Contribute ### Bugs & Features Found a bug and want it fixed? Open a detailed issue on the [GitHub issue tracker](../../issues)! Have an idea for a new feature? Let's have a chat about your request on [Discord](https://discord.vigem.org). ### Questions & Support Please respect that the GitHub issue tracker isn't a helpdesk. We offer a [range of support resources](https://vigem.org/Community-Support/) you're welcome to check out! ## Installation Pre-built production-signed binaries are provided by `Nefarius Software Solutions e.U.` and [available as an all-in-one setup](../../releases/latest). ## Sponsors Sponsors listed here have helped the project flourish by either financial support or by gifting licenses: - [3dRudder](https://www.3drudder.com/) - [Parsec](https://parsec.app/) - [Rainway, Inc](https://rainway.com/) - [JetBrains](https://www.jetbrains.com/resharper/) - [Advanced Installer](https://www.advancedinstaller.com/) - [ICAROS](https://www.icaros.com/) ## Known users of ViGEm A brief listing of projects/companies/vendors known to build upon the powers of ViGEm. This list is non-exhaustive, if you'd like to see your project included, contact us! - [3dRudder](https://www.3drudder.com/) - [Parsec](https://parsec.app/) - [GloSC](https://github.com/Alia5/GloSC) - [UCR](https://github.com/Snoothy/UCR) - [InputMapper](https://inputmapper.com/) - [Oculus VR, LLC.](https://www.oculus.com/) - [Rainway, Inc](https://rainway.com/) - [WiimoteHook](https://forum.cemu.info/showthread.php/140-WiimoteHook-Nintendo-Wii-Remote-with-Motion-Rumble-and-Nunchuk-support) - [XJoy](https://github.com/sam0x17/XJoy) - [HP](https://www8.hp.com/us/en/gaming/omen.html) - [DS4Windows](https://ryochan7.github.io/ds4windows-site/) - [XOutput](https://github.com/csutorasa/XOutput) - [RdpGamepad](https://github.com/microsoft/RdpGamepad) - [Touchmote](https://github.com/Ryochan7/Touchmote/tree/ryochan7) - [Mi-ViGEm](https://github.com/grayver/mi-vigem) - [BetterJoy](https://github.com/Davidobot/BetterJoy) - [Regame](https://github.com/ksyun-kenc/liuguang) - [NetInput](https://github.com/usertoroot/NetInput)