Known Issues

  • The firmware defaults to spying on controller 1 of the Pippin.  If for some reason you wanted to spy on the second controller you can change the line #define PIPPIN_SPY_ADDRESS 0xF to #define PIPPIN_SPY_ADDRESS 0xE.

What You Need

  1. One of the following boards:
  2. USB cable to connect the Teensy to your computer
  3. Make you own RetroSpy Pippin cable using the instructions under Wiring.
    • Wires to solder into the controller extension cable to go to the Arduino, like these
    • Wire cutters/strippers
    • Soldering iron and solder
    • Electrical tape and/or heat shrink tubing
    • Digital multimeter or a cheap continuity tester

Software

  1. The latest Arduino software
  2. Firmware for the Arduino
  3. Paul Stoffregen’s TimerOne library, found here
  4. PC software to connect to the Arduino and display the controller

#2 and #4 above are included in the release package of RetroSpy. The firmware is located in the firmware folder and is called firmware.ino. Just run RetroSpy.exe to launch the display software.

Instructions

Wiring – Soldering Required

This is the most time consuming piece, especially if you have never done any wiring/soldering before.  Unfortunately Pippin extension cables or P-ADB to ADB adapters are incredibly rare. One option is to harvest an s-video extension cable and the extension port of a broken Game Gear to build adapters so that you could use a 4 pin Mini-Din breakout board, the only other option is to cut into the actual controller cable. This is non-ideal, but if building your own P-ADB to ADB converters is not possible there really isn’t another option.

  1. First you will need to cut your controller extension cable so you can splice into the wires (consider which spot in the extension cable to cut, game system side, controller side, middle)

  1. Use your exacto knife or box cutters to very carefully cut away and peel back the plastic covering on both halves, about 2-3 inches should be good enough.
  2. Use wire strippers to strip back about 1/2 an inch of the plastic covering on each wire. In my case I had to carefully use my exacto knife because the wires were too small for the stripper, I rotated the wire against the blade until I could pull the plastic off the end.

  1. Next you will need to use a digital multimeter or continuity tester to figure out which pin on your controller plugin goes to which wire in the extension cable, make sure to write down your findings. Do NOT trust the color of the wires, the colors will vary from cable to cable.
  2. For the Pippin you need to splice the ADB Data (pin 1), GND (pin 4) based on this pinout.

  3. Figure out the length you need between your controller extension cable/Arduino and cut and strip a wire for each wire you are going to splice into.
  4. Solder each wire back together with your spliced wires, here’s what mine looked like when finished I soldered them this way (instead of end-to-end) because this will provide more strain relief against the small controller extension wires possibly breaking with use.

  1. After soldering everything back together, test out your extension cable with your game system to see that it still works before proceeding.
  2. Use electrical tape to tape up each wire separately.

  1. Again use electrical tape to tape all the wires back together, make sure to tape all the way back up to where the extension cable covering starts.

Hooking it up

  1. Download and install the latest release of RetroSpy.
  2. Install the latest Arduino software, download the Windows Installer option.  If you are not programming your own board you can skip this step.
  3. Hook up the RetroSpy cable to your Arduino according to this pinout.
    Pippin PinArduino Digital Pin
    1 (ADB Data)2
    2Not Connected
    3Not Connected
    4 (GND)GND
    5Not Connected
    6Not Connected
    7Not Connected
    8Not Connected
    9Not Connected
    10Not Connected
  4. Plug the controller into the RetroSpy cable.
  5. Plug the RetroSpy cable into the Pippin.
  6. Plug the USB cable into the Arduino.
  7. Plug the other end of the USB cable into the display PC.

Software Setup

Once the wiring is done and everything is hooked up to your game system and computer, now for the easy part.

  1. Make sure the the USB cable between your Arduino and PC is connected and if you are not going to program your own board you can now skip to Step 10.
  2. Open the Arduino software that you installed above.
  3. You should see “Arduino on COMX” at the bottom right corner if everything is working. If not, you may need to restart and/or replug the USB connector.

  1. Install Paul Stoffregen’s TimerOne library from here.
  2. Open common.h in the RetroSpy installation directory (by default this is C:\Program Files (x86)\RetroSpy\firmware) with any available text editor and uncomment the line //#define TP_TIMERONE to enable the use of the library in the RetroSpy firmware.
  3. In the Arduino software select File->Open from the menubar and open the firmware.ino file from the firmware folder of the installed RetroSpy release (by default this is C:\Program Files (x86)\RetroSpy\firmware).
  4. Now uncomment the option for MODE_PIPPIN.  Note that MODE_SNES is uncommented in this image.
  5. Hit the upload button (right pointing arrow) located just under the ‘Edit’ menu, this will upload and run the software on the Arduino. It should look like the following image. Once successfully uploaded, you won’t have to upload software again to the Arduino again unless you want to change controller modes.
  6. Power on the console.
  7. Run RetroSpy.exe.
  8. The selection here should be pretty straightforward, select the ‘COMX’ port that the Arduino is on, select the controller you are using, select a skin, and hit ‘Go’. If everything is hooked up correctly you should see your controller and inputs displaying.