- About
- Installation
- Uninstallation
- Usage
- My controller doesn't work!
- I'm using a driver from the Tattiebogle website
- My controller doesn't work with a game!
- Original Xbox Controllers
- Wired Xbox 360 Controllers
- Wireless Xbox 360 Controllers
- Wired Xbox One Controllers
- Wireless Xbox One Controllers
- Wireless Xbox One Controllers (Bluetooth)
- Developer Info
- Building
- Building the .pkg
- Disabling signing requirements
- Re-Enabling signing requirements
- Debugging the driver
- Debugging the preference pane
- Licence
This driver supports the Microsoft Xbox series of controllers including those for the original Xbox, Xbox 360, and Xbox One. Xbox 360 controllers work both wired and wirelessly, while Xbox One controllers only work wired for now. The driver provides developers with access to both force feedback and the LEDs of the controllers. Additionally, a preference pane has been provided so that users can configure their controllers and ensure that the driver has been installed properly.
Controller support includes ALL devices that work with an Xbox series piece of hardware. All wheels, fight sticks, and controllers should work. This includes things like the Xbox One Elite controller. If your hardware does not work with an Xbox console we cannot support it. Sorry.
This project is a fork of the Xbox360Controller project originally created by Colin Munro.
See the releases page for the latest compiled and signed version of the driver. Most users will want to run this installer.
In order to uninstall the driver: navigate to the preference pane by opening your "System Preferences," navigating to the "Xbox 360 Controllers" pane, clicking on the "Advanced" tab and pressing the "Uninstall" button. This will prompt you to enter your password so that the uninstaller can remove all of the bundled software from your machine.
The driver exposes a standard game pad with a number of standard controls, so any game that supports gaming devices should work. In some cases, this may require an update from the developer of the game. The preference pane uses the standard Mac OS X frameworks for accessing HID devices in addition to access of Force Feedback capabilities. This means that the preference pane is a good indicator that the driver is functional for other programs.
It is important to note that this driver does not work, and can never work, with Apple's "Game Controller Framework." This GCController framework corresponds to physical gamepads that have been offically reviewed by Apple and accepted into the mFi program. Due to the fact that we are not Microsoft, we cannot get their gamepad certified to be a GCController. This is an unfortunate oversight on Apple's part. If you would like to discuss this, please do so at this location.
Users have been maintaining a partial list of working and non-working games. Please contribute your findings so that you can help others debug their controller issues.
The Tattiebogle driver is NOT the same driver as this Github project. We do NOT support that driver. Under NO circumstances will we support that driver. If you download the latest version of this driver from the releases page we will do our best to help you out. This driver will install over the Tattiebogle driver. You don't have to worry about uninstalling the Tattiebogle driver first.
We cannot fix game specific issues. This driver does its absolute best to put out a standardized format for games to use. If they don't take advantage of that, there is ABSOLUTELY NOTHING we can do. The best we can do for you is give you the "Pretend to be an Xbox 360 Controller" option in the "Advanced" tab. This will make any wired Xbox 360 or wired Xbox One controller appear to games as if it were an official Microsoft Xbox 360 Controller. That way if the game is only looking for Xbox 360 controllers and isn't looking for other devices like third party Xbox 360 controllers or Xbox One controllers, you should be able to trick the game. If you experience an issue with a game that this toggle does not fix, we cannot help you, sorry. That is just the nature of drivers.
Make an issue describing your problem.
If you have a third party controller, make an issue with the "Product ID" and "Vendor ID" of the controller. These can be found by accessing the Apple menu, selecting "About this Mac", and then selecting "System Report..." on the "Overview" tab. On the left hand side of the new window, select the "USB" option under "Hardware". If the controller is plugged in, there should be an entry in this window called "Controller".
Remember that wireless controllers must be connected using a wireless adapter. Plugging a "Play and Charge" kit into a wireless controller does not make it a wired controller.
If you have a third party controller, make an issue with the "Product ID" and "Vendor ID" of the controller. These can be found by accessing the Apple menu, selecting "About this Mac", and then selecting "System Report..." on the "Overview" tab. On the left hand side of the new window, select the "USB" option under "Hardware". If the controller is plugged in, there should be an entry in this window called "Controller".
Wireless Xbox One controllers are currently not supported. Please be patient as we figure out this complicated protocol.
The Xbox One controller works with OS X automatically when connected over Bluetooth. Only specific Xbox One controllers have Bluetooth capability. Due to the fact that this controller works by default, it will not be supported by this driver. However, in order to get force feedback through the controller, you will need to install this driver. It will enable force feedback to the controller. Additionally, if you choose to plug this controller in via USB, the driver will support this configuration. Any problems with game compatibility in Bluetooth mode are completely out of our control and are up to you to solve in conjunction with the game developer.
Drivers inherently modify the core operating system kernel. Using the driver as a developer can lead to dangerous kernel panics that can cause data loss or other permanent damage to your computer. Be very careful about how you use this information. We are not responsible for anything this driver does to your computer, or any loss it may incur. Normal users will never have to worry about the developer section of this README.
Apple has recently changed how drivers work in Xcode 7. In order to build the driver, you will need Xcode 6.4 or earlier.
Additionally, to use the included build scripts, you will need to change your preferred Xcode installation using xcode-select
.
You must have a signing certificate to install a locally built driver. Alternatively, you can disable driver signing on your machine, however this is a major security hole and the decision should not be taken lightly.
You will need a full installation of Xcode to build this project. The command line tools are not enough.
The project consists of three main parts: The driver (implemented in C++, as an I/O Kit C++ class), the force feedback plugin (implemented in C, as an I/O Kit COM plugin) and the preference pane (implemented in Objective C as a preference pane plugin). To build, use the standard Xcode build for Deployment on each of the 3 projects. Build Feedback360 before 360Controller, as the 360Controller project includes a script to copy the Feedback360 bundle to the correct place in the .kext to make it work.
To debug the driver, sudo cp -R 360Controller.kext /tmp/ to assign the correct properties - note that the Force Feedback plugin only seems to be found by OSX if the driver is in /System/Library/Extensions so it can only be debugged in place. Due to the fact that drivers are now stored in /Library/Extenions, this means that you must create a symlink between the location of the driver and /System/Library/Extensions so that the force feedback plugin can operate properly.
In order to build the .pkg, you will need to install Packages.app.
- Open
360 Driver.xcodeproj
using Xcode. - Select the
360 Driver
project in the Navigator. - Select the
360Daemon
target from the top right corner. - Select the
Build Settings
tab from the top of the screen. - In the
Code Signing
section, findCode Signing Identity
section and expand it. - In the
Release
section, change the selection toDon't Code Sign
. - Set the code signing identity for
360Daemon
,Feedback360
,360Controller
,DriverTool
,Pref360Control
,Wireless360Controller
,WirelessGamingReceiver
andWhole Driver
. - Run
./build.sh
to build the .pkg. This .pkg can be found in theInstall360Controller
directory.
- Open
360 Driver.xcodeproj
using Xcode. - Select the
360 Driver
project in the Navigator. - Select the
360Daemon
target from the top right corner. - Select the
Build Settings
tab from the top of the screen. - In the
Code Signing
section, findCode Signing Identity
section and expand it. - In the
Release
section, change the selection to yourDeveloper ID Application
certificate. - Set the code signing identity for
360Daemon
,Feedback360
,360Controller
,DriverTool
,Pref360Control
,Wireless360Controller
,WirelessGamingReceiver
andWhole Driver
. - Run
./build.sh
to build the .pkg. This .pkg can be found in theInstall360Controller
directory.
Since Yosemite (Mac OS X 10.10) all global kexts are required to be signed. This means if you want to build the drivers and install locally, you need a very specific signing certificate that Apple closely controls. If you want to disable the signing requirement from OS X, you will need to do several things.
First, execute these commands in your terminal:
sudo nvram boot-args="kext-dev-mode=1"
sudo kextcache -m /System/Library/Caches/com.apple.kext.caches/Startup/Extensions.mkext /System/Library/Extensions
Next, you must disable System Integrity Protection. To do this, boot into recovery mode by holding down CMD + R
while the computer is starting. Once recovery mode has been loaded, open the terminal from the Utilites
menu item. Execute the following command:
csrutil disable
From recovery mode, execute the following command:
csrutil enable
Reboot into OS X like normal. You can reset the boot arguments by executing this command:
sudo nvram -d boot-args
This will remove ALL boot-args. If you have previously manipulated your boot-args, those changes will be erased as well!
Debugging the driver depends on which part you intend to debug. For the 360Controller driver itself, it uses IOLog
to output to the system.log
which can be accessed using Console.app. Feedback360 uses fprintf(stderr, ...)
, which should appear within the console of the program attempting to use force feedback.
These instructions work for Xcode 6.4, the most recent version of Xcode that can still build the driver. Most of these instructions are pulled directly from this blog post. Please visit it for futher information.
First, edit your build scheme for Pref360Control, and select the "Run" scheme, and make sure you are editing "Debug" (A). In the environment variables section, click on "+" to add a new environment variable (B). Name the new variable OBJC_DISABLE_GC, and set its value to YES.
Next, click the little disclosure triangle for the run scheme to reveal its detailed settings. Then select pre-actions. Click the "+" at the bottom to add a run script action. Enter /bin/sh as the shell, make sure that your target is selected to provide build settings, and type a shell command line to install the newly compiled pref pane in your personal Library folder:
cp -Rf ${CONFIGURATION_BUILD_DIR}/Pref360Control.prefPane ~/Library/PreferencePanes
Finally, select the run step, choose "other" from the executable drop-down menu, and select System Preferences in the Applications folder. Verify that "Debug executable" and "Automatically" are both checked.
Copyright (C) 2006-2013 Colin Munro
This driver is licensed under the GNU Public License. A copy of this license is included in the distribution file, please inspect it before using the binary or source.