# Mission Control Use controllers from other consoles natively on your Nintendo Switch via Bluetooth. No dongles or other external hardware neccessary. ### Features * Supports all Switch firmware versions. * Connect up to 8 non-switch Bluetooth controllers simultaneously without any additional hardware. * Make use of native HOS menus for controller pairing, button remapping (firmware 10.0.0+) etc. * Rumble support* * Low input lag. * File-based virtual controller memory allowing for data such as analog stick calibration to be stored and retrieved. * Spoofing of host Bluetooth adapter name and address. * `mc.mitm` module adds extension IPC commands that can be used to interact with the `bluetooth` process without interfering with the state of the system. **Rumble not currently implemented for all compatible controllers* ### Supported Controllers Currently, the following controllers are supported. If you have a third-party variant of one of the below, or a Bluetooth controller that isn't listed, consider submitting an issue with the controller details, including vid/pid, to request support. * __Nintendo Wii Remote + extensions (Nunchuck, Classic Controller, Classic Controller Pro, SNES Mini, TaTaCon (Taiko drum))__ * __Nintendo WiiU Pro Controller__ * __Sony DualShock4 Controller__ * __Sony Dualsense Controller__ * __Microsoft Xbox One S/X Controller (not to be confused with Series S/X controllers - these use Bluetooth LE, which isn't currently supported)__* * __Microsoft Xbox Elite Wireless Controller Series 2__ * __NVidia Shield Controller (2017 Model)__ * __Ouya Controller__ * __Gamestick Controller__ * __Gembox Controller__ * __iCade Controller__ * __Ipega Controllers (9017s, 9023, 9055, 9062S, 9076, 9078, 9087 9096 confirmed working. Others may also work)__ * __Xiaomi Mi Controller__ * __Steelseries Free__ * __Steelseries Nimbus__ * __Steelseries Stratus Duo__ * __GameSir G3s__ * __GameSir G4s__ * __GameSir T1s__ * __GameSir T2a__ * __Hori Onyx__ * __8bitDo SN30 Pro Xbox Cloud Gaming Edition__ * __8BitDo ZERO (Most other 8BitDo controllers have a Switch mode available. May require firmware update)__ * __PowerA Moga Hero__ * __PowerA Moga Pro__ * __PowerA Moga Pro 2__ * __Mad-Catz C.T.R.L.R__ * __Razer Raiju Tournament__ * __Razer Serval__ * __Mocute 050__ * __Gen Game S3__ * __AtGames Legends Pinball Controller__ * __Hyperkin Scout__ **Not all Xbox One wireless controllers support Bluetooth. Older variants use a proprietary 2.4Ghz protocol and cannot be used with the Switch. See [here](https://support.xbox.com/help/hardware-network/accessories/connect-and-troubleshoot-xbox-one-bluetooth-issues) for information on identifying the Bluetooth variant.* ### Requirements * Hackable Nintendo Switch running an up-to-date version of [Atmosphère](https://github.com/Atmosphere-NX/Atmosphere/releases) custom firmware. Other custom firmwares are ***not supported***. * Compatible Bluetooth controller ### Installation Download the [latest release](https://github.com/ndeadly/MissionControl/releases) .zip and extract to the root of your SD card, allowing the folders to merge and overwriting any existing files. A console reboot is required in order for Mission Control to become active. ***IMPORTANT: Atmosphère >= 1.2.5 is required to run the latest release of Mission Control. Using an older Atmosphère version will cause Mission Control to crash or freeze the system on boot. Users upgrading from version 0.1.0 of Mission Control are also advised to wipe their pairing database and re-pair controllers running the latest version. Failure to wipe the old entries may result in non-switch controllers being detected incorrectly.*** ### Usage Install Mission Control to your SD card and reboot the console. Mission Control runs as a background process and makes use of the system's native UI to handle controllers. The controller pairing dialog can be accessed from the home screen via `Controllers->Change Grip/Order`. While sitting on this screen, place your controller in pairing mode (see below) and wait for it to connect to the console. Once paired, controllers will reconnect automatically when woken up. There is no need to re-pair them every time. Controllers that successfully pair but haven't been supported yet will display with red buttons on the `Controllers` menu to indicate their controls are not being mapped. Please open an issue to request support for such controllers. Your controller's buttons are mapped as closely as possible to the physical layout of a Switch Pro controller. This means that A/B and X/Y buttons will be swapped for controllers that use an Xbox style button layout rather than using what is printed on the button. The button combos `MINUS + DPAD_UP` and `MINUS + DPAD_DOWN` are provided for all controllers to function as an alternative for `CAPTURE` and `HOME` buttons in cases where there are not enough face buttons available. Most native features *should* just work (with the exception of things like firmware update). If you find something that's broken please open a support issue on this github page. ### Pairing controllers The supported controllers each have their own methods to enter pairing/sync mode. Below are instructions on entering this mode for each supported type. ***Nintendo Wii(U) Controllers*** Press the red sync button on the back of the controller. The controller LEDs will blink rapidly. ***Sony Dualshock4/Dualsense Controllers*** Press and hold the `PS` + `share` buttons simultaneously until the lightbar starts blinking. When done correctly the blink pattern will resemble a heartbeat, otherwise it will blink periodically. If you have difficulty getting the controller to pair to the console, press the reset button on the back of the controller and keep trying. It should eventually connect. ***Microsoft Xbox One Controllers*** Press and hold the `guide`(`X`) button until the LED starts blinking. Then press and hold the small sync button on the back near the charging port until the LED starts blinking more rapidly. You should also ensure your controller firmware is up to date, as old firmwares were known to have flakey Bluetooth. ***Other Controllers*** Please refer to your controller's user manual for information on how to put it in sync mode. Note that many generic Bluetooth controllers can be started in one of several modes. Usually you want to choose something like HID, PC or Android mode for it to work correctly. ### Module configuration A template for the config .ini file will be installed to `/config/MissionControl/missioncontrol.ini.template`. To modify the default module settings, copy the template to `/config/MissionControl/missioncontrol.ini` and uncomment/modify any settings you want to change. The file is only parsed on startup, so any changes you make will require a reboot to take effect. Currently there is only a small set of configuration settings, but this will be expanded upon in future releases. - `[general]` These are general settings for mission control features. - `enable_rumble` Enables/disables rumble support for unofficial controllers. - `enable_motion` Enables/disables motion controls support. Not currently used - `[bluetooth]` These settings can be used to spoof your switch bluetooth to appear as another device. This may be useful (in conjunction with a link key) if you want to use your controller across multiple devices without having to re-pair every time you switch. Note that changing these settings will invalidate your console information stored in any previously paired controllers and will require re-pairing. - `host_name` Override the bluetooth host adapter name - `host_address` Override the bluetooth host adapter address ### Removal To functionally uninstall Mission Control and its components, all that needs to be done is to delete the following directories from your SD card and reboot your console. * `/atmosphere/contents/010000000000bd00` * `/atmosphere/exefs_patches/bluetooth_patches` If you wish to completely remove all traces of the software ever having been installed (telemetry excepted), you may also want to follow these additional steps * Remove the following directory from your SD card * `/config/MissionControl` * Wipe the Bluetooth pairing database via `System Settings->Controllers and Sensors->Disconnect Controllers` ### Planned/In-progress Features Below is a list of features I am currently working on or would like to look into in the future, roughly in descending order of priority. Requests are welcome if you have an idea you think would make a useful feature. * ~~Rumble support~~ * Motion controls support * Bluetooth LE support * Per-controller configurations * Rumble on/off * Motion controls on/off * Identify as Pro Controller or Joycon * Set controller body/button colours * Invert analog stick axes * Analog stick deadzones * Companion application * Pairing database management * View paired controller information * Clear database * Export database to file * Import existing database from file * Controller management/diagnostics * Manage controller configurations * View raw HID report data * Test buttons/analog sticks * Dump SPI flash (official controllers only) * Controller discovery/pairing reimplementation * Tesla overlay * Keyboard and mouse support * Gamecube mode (analog trigger support) * USB wired controllers ### Known Issues and Limitations * Motion controls currently unsupported. * Non-Switch controllers cannot be used to wake the system from sleep. * Controllers using the Bluetooth LE (BLE) standard are currently not supported and will not connect to the system. * Xbox One, Wii/WiiU and (especially) some Dualshock v1 controllers can take some time to be detected and subsequently pair with the Console. Be patient and re-enter the sync mode of the controller several times if neccessary. Once synced, controllers should work as usual. * Xbox One controllers cannot be shut off and will attempt to reconnect to the console after being disconnected. This is a limitation of the controller's bluetooth firmware. * ~~Xbox One button layout was changed at some point in a firmware update. Please ensure your controller firmware is up to date if you have issues with incorrect button mappings.~~ Both layouts are now supported. * Reported controller battery levels may not be correct. I'm relying entirely on reverse engineering notes found on the internet for these. In many cases I don't own the controller and there is simply no information available, so these controllers will always show full battery. Any help in improving this is most welcome. * Several users have reported knockoff WiiU and Dualshock4 controllers that cannot be detected by the console during Bluetooth discovery. Unfortunately I think they're using an incompatible Bluetooth chipset. ### Frequently Asked Questions ***Does this run on \