Skip to content

USB mouse and joystick to Amiga, Atari ST & C64 Adapter

License

Notifications You must be signed in to change notification settings

Slamy/Yaumataca

Repository files navigation

Yet another USB mouse and joystick to Amiga, Atari ST & C64 Adapter

Or in short Yaumataca. This device allows to use modern USB input devices on 80s style home computer controller ports. Being mechanical in nature, old gamepads and mouses degrade over time and replacements using modern variants might be required.

This solution makes use of the Raspberry Pi Pico board (RP2040) which offers a dedicated USB host controller and can be bought at a rather low price (5-8€ per unit). Cheap NPN transistors are used for level shifting as the RP2040 is not 5V tolerant.

How to use

The Yaumataca acts as both Joystick and Mouse. Plug both output ports into both controller ports of the target machine. Plug a USB OTG Hub into the Micro-USB port of the Pico board. Insert USB gamepad and USB mouse.

As multiple modes are supported, the user manual provides more detail.

Features

  • Cheap to build
  • Uses "off the shelf" hardware
  • Multiple USB devices on 2 Atari type controller ports using a single unit
  • Primary joystick on left port
  • Primary mouse on right port
  • Amiga mouse with wheel using WheelBusMouse driver
  • Commodore 1351 in proportional mode
  • Atari ST mouse
  • Automatic switch between mouses and joysticks
  • Swap of controller ports (useful for C64 games)
  • Supports 2 mouses and 2 joysticks (useful for Lemmings and Marble Madness)
  • Supports secondary fire button (Amiga and C64 style)
  • Auto fire
  • Configured mouse type is saved in flash

Restrictions

  • Only dedicated Joysticks are supported.
    • PS3 DualShock
    • PS4 DualShock
    • Nintendo Switch Pro Controller
    • Xbox 360 Wireless Receiver (1 or 2 controllers with one receiver)
    • Xbox One Controller
    • Xbox Series S/X Controller
    • Mega World International - USB Game Controllers (07b5:0314)
    • DragonInc Hizue Gamepad (0079:0011)

TODO

  • Amiga Mode: Add support for newmouse or Micromys protocol
    • Avoids necessity for manipulation of the unrelated joystick port
  • Add 3. Fire button for more gamepads
  • HID Descriptor Parsing (generic USB joystick support, eventually)
  • Bluetooth (eventually)
  • Explain C1351 calibration using C64 tool

How to construct

The project is constructable via perfboard or PCB.

Manual for construction on a perfboard

For the PCB, please use the KiCad files. If you order your parts from Reichelt, you may use the attached ordering lists which can be imported on the website.

In case the PCB is chosen, there is also a 3D model of a case available, which can be used for 3D printing.

To operate the unit, one OTG Hub is recommended which provides multiple USB A ports attached to a USB micro port. If only one USB device is to be attached, a simple USB micro to USB A adapter will also work, but I suggest to go for the Hub.

Example hardware design

Here an example of the PCB inside the case. Photo of Yaumataca in 3d printed case

Here the PCB side by side with the prototype. Photo of Yaumataca build from PCB and perfboard

How to build the firmware

Ensure that the submodules are also cloned.

git submodule update --init --recursive
mkdir build
cd build
cmake ..
make

Alternatively there is also a small script which builds and packages the software as a zip file for upload.

./scripts/build_release.sh

How to flash

Integrated USB bootloader

The RP2040 can be flashed using SWD or using the integrated USB bootloader. As not everyone might have a debugger lying around, flash the Pico as so:

  • Don't have the Pico board powered and connected.
  • Press and hold the BOOTSEL button
  • Connect the Pico to your PC while holding the button
  • The Pico should be detected as mass storage device
  • Copy yaumataca.uf2 from the build folder to the device
  • The LED of the Pico should start blinking

The Yaumataca is now ready for operation

With SWD

This assumes that you are using a CMSIS-DAP compatible programmer. It is suggested to use a second Pico board as one. This is possible using the Picoprobe firmware. Keep in mind that an st-link cannot be used with the RP2040, even so both speak SWD.

openocd -f interface/cmsis-dap.cfg -f target/rp2040.cfg -c "adapter speed 20000; program build/yaumataca.elf verify reset exit"

Connect the picoprobe like so, to flash and debug the Yaumataca in standalone operation:

Example picture of an attached picoprobe to the Yaumataca

Keep in mind to only connect 5V (purple wire) when operating the Yaumataca without any home computer attached! The 5V power supply is usually provided by the controller port and not from the PC! It must not be delivered by both the developer PC and the homecomputer at the same time!

Recommended IDE

Please use vscode and open the root folder with it. This gives access to the already existing debugging targets.

System architecture

uml diagram

Doxygen and Unittests

It is my goal to have everything properly documented and tested

scripts/check_doxygen.sh
scripts/unittest.sh

FAQ

My gamepad is not supported. What can I do?

It depends. Some USB Gamepads are not following the HID standard, which is a huge issue. The PS4 Controller is one rare exception which just works. Bad examples are the Xbox One Controller and the Nintendo Switch Pro Controller.

Both require some sort of handshaking to activate the data transfer.

If you are lucky, you have a USB input device which just follows the HID standard.

Please follow this guide to add additional gamepads

I can see PRINTF all over the place. Where is the output going to?

This project makes use of "Segger RTT" which stores printed characters inside a small buffer which can be displayed over SWD. It has advantages compared to the UART as no additional GPIOs have to be reserved for this.

I don't recommend to use rtthost as it is slow. Please use VSCode instead.

rtthost -c rp2040

There is also pyocd available, which is faster:

pyocd rtt --target rp2040

SWD is failing with "Info : DAP init failed"

You have accidentally downloaded debugprobe and not picoprobe. This project uses the CMSIS-DAP variant of the picoprobe! One working version is this one.

I can't use the C1351 mouse on "Final Cartridge III"

The design of the Yaumataca circuit might not be optimal, as it causes issues with the way the FC3 software is using the SID muxes in desktop mode. For some reason, both Controller Ports are muxed at the same time to the SIDs POT lines, so it can accept a mouse at either of the ports without additional configuration. This however means that no two mice are allowed to be connected at the same time.

The Yaumataca design is not aware of this and uses a 10k pullup on POT X and POT Y to charge the measurement capacitor. This alone is not an issue. However, with the addition of the secondary fire buttons on the C64, this indeed causes issues as the high state is the pressed state while the grounded state is not pressed. This is opposite to how the Amiga handles its buttons.

If this issue occurs, just disconnect one of the controller ports.

Why is this not written in Rust?

Because USB Host Support for the RP2040 is not yet awesome

Isn't this yet another USB mouse and joystick to Amiga, Atari ST & C64 adapter

Exactly

Funny anecdote

The popularity of this project was increased dramatically just becausean Atari ST user was missing a mouse on a Commodore 64 party. This happened on the DoReCo (Dortmund Retro Computer) Party 2024 in Anröche, Germany.

Sources of Inspiration

My old project this here needs to surpass:
http://slamyslab.blogspot.com/2013/02/pcbs-for-usb-datasette-and.html

Infos about Mouse Wheels on the Amiga:
http://bax.comlab.uni-rostock.de/en/hardware/amiga-usb-mouse/

For the pinout:
https://www.c64-wiki.de/wiki/Maus

Information about the Commodore 1351:
http://sensi.org/~svo/%5Bm%5Douse/

Micromys C64 and Amiga Mouse Protocol:
https://wiki.icomp.de/wiki/Micromys_Protocol

About

USB mouse and joystick to Amiga, Atari ST & C64 Adapter

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages