[update]
Meanwhile I have validated these instructions on a different machine, testing it on a desktop PC running openSuSE 42.2. Everything worked as expected and I was able to remap the keys of my PS3 controller with QJoyPad in order to ‘translate’ the PS3 input to keyboard commands.
The instructions above also worked on Raspbian/Pi2 with an updated version of Retropie (3.7 -> 3.8, as well as 3.8 -> 4.1 ). Many users reported problems with the internal Pi3 bluetooth device. It appears to be fixed on Raspbian, but other distributions may still fail. In any case you have to make sure that your system is up-to-date (sudo apt-get update && apt-get upgrade).
In case that you follow the discussion thread on the RetroPie forum, you probably have read, that there are some issues with other brands of PS3 controllers. The instructions above do not work for SZMY-POWER PS3 clones. However, these controllers seem to work with the sixaxis-sixad daemon.
[Troubleshooting]
I receive a lot of messages from users, telling me that the instructions above do not work and their PS3 controllers do not pair. As I’ve been in touch with many users (see discussion below), most problems are related to previous pairing attempts using the RetroPie configuration script.
Therefore, I strongly recommend to start from scratch, i.e. to work on a freshly installed Raspbian image. Follow the guide above to install blueZ, then install Retropie using the RetroPie setup script. However, do not use the setup script to pair your PS3 controller! Retropie makes use of the sixaxis-sixad daemon. Be aware that sixad and blueZ cannot not run at the same time!
Please include console output of the step you got stuck with, otherwise troubleshooting will be difficult.
[Debugging]
For debugging you should collect as much information as possible about your controller. Run ‘hcidump -x’ and press the PS3 button on your controller. With a Shanwan controller, I can see the following output (when pairing was successful):
HCI sniffer - Bluetooth packet analyzer ver 5.41 device: hci0 snap_len: 1500 filter: 0xffffffff > HCI Event: Connect Request (0x04) plen 10 bdaddr 01:B6:52:85:63:25 class 0x000540 type ACL > HCI Event: Command Status (0x0f) plen 4 Accept Connection Request (0x01|0x0009) status 0x00 ncmd 1 > HCI Event: Connect Complete (0x03) plen 11 status 0x00 handle 11 bdaddr 01:B6:52:85:63:25 type ACL encrypt 0x00 > HCI Event: Command Status (0x0f) plen 4 Read Remote Supported Features (0x01|0x001b) status 0x00 ncmd 1 > HCI Event: Read Remote Supported Features (0x0b) plen 11 status 0x00 handle 11 Features: 0xff 0xff 0x8d 0x7a 0x98 0x1f 0x78 0x83 > HCI Event: Command Status (0x0f) plen 4 Read Remote Extended Features (0x01|0x001c) status 0x00 ncmd 1 > HCI Event: Read Remote Extended Features (0x23) plen 13 status 0x00 handle 11 page 1 max 1 Features: 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 > HCI Event: Command Status (0x0f) plen 4 Remote Name Request (0x01|0x0019) status 0x00 ncmd 1 > HCI Event: Remote Name Req Complete (0x07) plen 255 status 0x00 bdaddr 01:B6:52:85:63:25 name 'PLAYSTATION(R)3Conteroller-PANHAI'
Please note that I have rearranged this thread to show latest comments on top.
I still have problems pairing my gasia controllers with this guide. I did everything step by step and still no connection.
sudo bluetoothctl gives me the following:
[NEW] Controller 00:15:83:6D:34:6C retropie [default]
[NEW] Device 00:26:5C:10:53:A7 PLAYSTATION(R)3 Controller
[NEW] Device 00:26:5C:10:57:B6 PLAYSTATION(R)3 Controller
I think the controllers are being recognized, but they won’t pair.
Any idea?
Please have a look at the other user comments above! Check the output of bluetoothctl after pressing and/or hcidump -x. Since your controllers are recognized correctly (bluetoothctl displays their HW address), it might be an authentication problem. First, make sure that patched blueZ runs on your Pi (make install overwrites the deb package that is already present on your distribution). Then, you could try to ‘trust’ your controllers using bluetoothctl. If it doesn’t help try to remove the controllers using bluetoothctl and start over. Note that there are still some issues with the internal BT on Pi3. If you are… Read more »
Thanks for your reply. I am on a pi2 model b using an usb dongle already. I also tried to trust the controllers, tried to remove them and pair them again, that didn’t work. I don’t know if i’m doing something wrong, or if it’s just the controllers (maybe newer version than supported or whatever). All i can say is that this guide didn’t work for me.
OK, I see. Can you check with dmesg/ or bluetoothctl for the exact brand name of your controller and post it here?
And what is your distribution? Raspbian? It is know that devices labeled with ‘SZMY-POWER’ are unable to pair.
It would be valuable information other users having similar problems with their controllers.
Hi again, i got 2 gasia controllers, exact name as shown in dmesg is ” Gasia Co.,Ltd PS(R) Gamepad”. Strange thing is that i was able to pair 1 controller, that one now works like a charm. Still struggeling with the second one, it won’t pair no matter what i try. This is going to drive me crazy, because one controller is working. Forgot to say that I’m on raspbian.
Glad to hear that you were able to connect at least one controller. I’m sure that you will be able to pair your second controller as well. Please check before pairing the first controller that the mode is “Up Running PSCAN”, if you run “hciconfig”. After pairing the first controller the bluetooth adapter might exit the “discovery mode” and hciconfig then only reads “up running”. If you change the mode to PISCAN by running “sudo hciconfig hci0 piscan” after pairing the first controller the bluetooth stays in the discovery mode and it works as expected for the pairing of the… Read more »
Thanks for your advise, but i think i found the reason why the second one isn’t connecting. I shouldn’t have put my trust in chinese products, so i opened the faulty controller and what i saw was clear. There was a short due to a bad solder joint.
Oh, what a crap! However, I’m pretty sure that genuine controllers are also manufactured in China.
So far, I’ve been lucky with devices purchased at Aliexpress. Have you been able to fix the bad joint?
Hi, i’ve been able to fix the joint, the controller connected once but no chance to pair it again. “sudo bluetoothctl” shows the mac-adress correctly as before, but it won’t pair. I really have no idea what to try next.
Did you add “hciconfig hci0 piscan” to rc.local? I guess that your BT dongle is not in “discoverable mode” and therefore invisible
for your controller. “hcidump -x” might give a clue whats going on after pressing the PS3 button.
The dongle is working and doesn’t go into standby, i ended up buying 2 Sony DS3 Controllers, already spent too much time on this. Thanks for your kind help, but i think the controller is defective in some way.
Hi Luetzel, First of all I would like to thank you for the some much effort you put in creating this guide. I wanted to create a fresh installation from scratch on my Pi3 with Retropie and pairing my bluetooth PS3 controller to it via the onboard BT of Pi3. I have started the procedure with upgrading Retropie to the latest version. After that I have followed your step-by-step procedure which worked fine in most cases. Whoever there were some steps where I got stuck with the compilation of QtSixA. Google told me that the errors are referring to that… Read more »
Hi phody, thanks for giving your elaborate feedback. I’m sure that it’ll help other users for pairing their controllers. I’ll include
your comments at the respective steps in the tutorial.
Cheers, Martin.
Hi luetzel,
Your guide is fantastic! Thank you very-very much! 🙂
I’ve just made it to connect via BT to my Ubuntu machine.
I just have one question. I have a Shanwan controller and the mapping is really messed up in Steam. What would you suggest I use to properly remap the controller?
Hi Alex, good to see that it works for you. I used the PS3 controller mostly with RetroPie.
You probably could try to remap the buttons using ‘qjoypad’ which can be found
at http://qjoypad.sourceforge.net/ On OpenSuSe Leap 42.2 it did not compile, but I was able
to find a precompiled binary for my distribution. With qjoypad you should be able to map
keys to the PS3 controller buttons, which works fine for most keyboard-controlled games.
It is possible to configure profiles for each game. Cheers, Martin.
Thanks for the quick reply.
I figured out how to do the remapping in Steam. And probably because it’s not an original one, all games have it either not mapped at all or in a wrong way. Anyway, it’s something I can figure out.
Again, thanks a lot! Your guide is actually the only one on the Internet that is helpful. I thought I was screwed with this Shanwan gamepad. 🙂
If I do an install from scratch starting with rasbian. Do I follow your instructions and only install retropie after completing your instructions. I have a pi 2 and a Shanwan controller.
It is fine to install blueZ from scratch on a Pi2 with fresh Raspbian image. You can install RetroPie either before or after installing blueZ. The order is not important,
but be aware that future updates of Raspbian (apt-get upgrade or apt-get dist-upgrade) may overwrite patched blueZ. In this case you must re-install (sudo make install) patched
blueZ. Furthermore, avoid pairing your controllers by using the RetroPie setup script/ setup menu. This will enable the sixad daemon which might interfere with blueZ.
Instead, try to pair your controllers using ‘sixpair’ as described in the tutorial. Good luck,
Martin
If I download your patched blues source code do I still need to do steps 1-3? or can I just start with step 4?
With my patched blueZ you can start from step 4. In case that compilation fails, make sure to install missing header files‘. Cheers, Martin
using ‘apt-get install
When doing step 4 I get the message
Configure: error: libical is required.
What is libical and how do I aquire it?
Hi Duncan,
some dependencies are missing on your system. Enter: ‘sudo apt-get install libical-dev’ on the console to install missing header files.
Cheers,
Martin
I tried linking /etc/firmware but that doesn’t seem to be the problem. I still get aa:aa:aa:aa:aa:aa. Also it worked the first time its only after the restart that it fails. Since I already paired once I can see it in bluetoothctl it’s just no able to reconnect when I hit the PS button.
In my ignorance it feels like something hasn’t restarted correctly. This was a vanilla install of Rasbian (2016-11-25), on a PI 3 using the built in bluetooth. I wonder if something changed in that version.
Hi Max,
I would suggest to remove your device using sudo bluetoothctl. Within bluetoohctl shell, the ‘help’ command reveals some useful programs to trust devices permanently
and to set your dongle discoverable. In case that you have LXDE running, the Bluetooth app might interfere with your pairing attempts. You should try it only from the console.
If this doesn’t help, remove the device and try to run sixpair again. Also check hciconfig, if the dongle is up. (PSCAN/ ICSAN). In case that it still fails, contact me
at webmaster_at_raspberryblog.de for further troubleshooting.
Cheers,
/luetzel
Thanks for the excellent work. The instructions worked and I was able to set up two controllers on a fresh install of raspbian. However after reboot the controllers failed to reconnect.
After reboot hciconfig is not showing ISCAN, my two controllers are shown as paired in bluetoothctl and the service is running your patched bluez (I have tried repeating make install just to be sure). Here is the formatted output of a few commands. At the end if I try hcidump -x and press try to pair from the controllers I see no pairing attempt made.
http://pastebin.com/5m2N1xCE
Hi Max,
thanks for your feedback. The line
BD Address: AA:AA:AA:AA:AA:AA ACL MTU: 1021:8 SCO MTU: 64:1"
Indicates that something might be wrongwith your bluez firmware. Please check – as described in Step 6 – whether your firmware is present at the proper location.
Cheers,
/luetzel
Hi all,
i use an old netbook, toshiba NB505 2GB/Ram and Intel Atom N455,
i use Lakka for retrogaming, i have a P3 shanwan that i wold like to use through bluetooth, is it possible to apply this pach in that system?
I haven’t tried Lakka, yet, but you probably don’t have to apply these patches yourself. According to the github repo, they are already present. Thus there is a good chance, that your Shanwan controller will work out of the box. Simply follow the tutorial from Step 4, make sure that bluetoothd is up and running (and disable sixad, if present). In case that sixad is already installed, skip Step 6 and try to pair your controller using ./sixpair while its being connected via USB. And please report the outcome – it might be helpful for other users.