RetroPie, the multi system game console emulator, is definitely one of the most popular applications for the Raspberry Pi.
Installing should be super easy. And it is. Or not... There are two chances: you get the installation right in one go and everything works fine. Or something fails, and it will take a lot of effort to fix it. Lots of kudos to the RetroPie team, who definitely gone to the max to make it as user friendly as possible. At the time of writing the just released version 3, which again is a huge step forward in user-friendliness. But it is still Linux in the background and that means that almost every unexpected glitch in the installation requires the terminal screen to solve it.
No need to describe the standard installation, as this is already done in many places. Unfortunately there is lot that can go wrong so let's focus on that.
Creating the SD card
Most people will probably start from a Windows PC,
download the standard image and and use something like the
Win32DiskImager or
Fedora ARM Installer create a bootable SD card. Again, this may work for you, it did not for me. Somehow creating the card on a windows machine seems problematic. I had the same problem when I just wanted to create a Raspbian card: it just does not boot. The two LEDs on the board stay on, and nothing happens.
Since it is a Linux system after all I suppose it may be more reliable to create the card on a Linux computer. So I plugged into an old laptop on which I previously installed Xubuntu.
So far the best description of the installation using a Linux computer I've found is the
RetroPie Installation Guide at LibreGeek. And even that was problematic. I still prefer the the 'easy' GUI-based solutions so I opted for 'GParted' and 'Unetbootin'. Which failed. The firtst time it actually seemed to work. The card booted, but the process ended with a fatal error and that's it.
Somehow the second time Unetbootin only created some files (each containing 0 bytes) but still nothing useable.
So finally I used Gparted to force the whole card to a single partition and formatted it to FAT32. Then I used the terminal and
the 'dd' tool to actually create a bootable card.
And, just in case this site ever disappears, here is the required command:
sudo dd bs=4M if=2016-03-12-jessie-minibian.img of=/dev/mmsblk0
'2016-03-12-jessie-minibian.img' is the name of the image.
Display settings (what to do if there's nothing on the screen)
My Pi is connected to a VGA monitor, using a HDMI to VGA converter. So after I finally got a card to boot (which I could see because the LED's on the board were blinking) my monitor did not show anything but an 'Input not Supported' message. Apparently the Pi uses a resolution that my monitor (an ACER 1912, 1280x1024) does not support. I quickly found that the monitor settings are stored in the 'config.txt' file which can be found in the 'boot' section of the SD card. The first two lines of this file :
# uncomment if you get no picture on HDMI for a default "safe" mode
#hdmi_safe=1
And indeed, after removing the # from the second line the card boots, and the monitor shows the 'Retropie' logo.
The gamepad
Obviously real gaming is only possible using a gamepad or joystick. A Super Nintendo-like gamepad seemed a nice solution, so I bought a (super cheap) USB gamepad...
.. which turned out also to be super-crappy. The D-Pad requires a lot of pressure, and often even fails to detect any movement to the left. Which is very frustrating in almost every game.
So I bought the Logitech F310 gamepad. Almost three times as expensive, but so much better.
Only one problem: it works fine with the EmulationStation interface, but not in any game. This turned out to be the hardest problem so far. Several forums and the wiki have some information regarding this problem, but nothing seemed to work with RetroPie Version 3.0.
UPDATE 2019: RetroPie 4 and up seem to have solved this problem. If you set
the the switch on the Logitech to 'X', everything will work out of the
box !
With version 3 it requires some modifications. ( Thanks to
'GhostTree3' )
In version 3 the main configuration of the emulators is stored in the file:
/opt/retropie/configs/all/retroarch.cfg
And it contains the following lines:
# Input device driver. (Valid: linuxraw, sdl, dinput)
input_joypad_driver = sdl2
The tricky part is that the 'comment' is incorrect (or at least incomplete).
After changing
input_joypad_driver = sdl2
to
input_joypad_driver = xinput
Then it works !. (if you set the gamepad to 'xinput' using the switch on the back)
And if the gamepad still does not work...
One additional pitfall: often the gamepad still does not work,even though the emulator says it is correctly initialized. It seems that the it somehow remains in some 'stale' state when switching from game to game. The solution is to press both the lower (analogue) shoulder buttons simultaneously. Somehow this seems to reset the pad to it's initial state and all buttons will now respond.
MadLittlePixel Complete images
Much easier than installing everything by hand are the complete images as created by the man that probably never sleeps :
MadLittlePixel. On the
download page of Arcade Punks you can find links to huge collection of images that offer a complete setup, included hundreds or even thousands of games. So far I only tried one of his 16GB images and it seems to work fine for all console games. Somehow it fails on the Arcade games, but since that is less relevant to me I have not tried to solve this yet.