====== EG STARTS USB Joystick Interface ======
{{ eg-starts.jpg?260|EG STARTS Joystick interface}}
The **EG STARTS** is a cheap (10 € in June 2022) circuit to connect a **joystick and buttons** to a PC via the **USB interface**. It is often used to build arcade-style consoles for retrogaming using the MAME software or alike, it is supported by the **GNU/Linux** operating system, but...
===== Problems with GNU/Linux: disconnect loop =====
My first attempt to connect the EG STARTS to a **Raspberry Pi** running the operating system based on **Debian 11 Bullseye** was a total failure. The kernel started an **infinite loop** detecting and disconnecting the USB device:
usb 2-1.2: new low speed USB device using ehci_hcd and address 7
usb 2-1.2: New USB device found, idVendor=0079, idProduct=0006
usb 2-1.2: New USB device strings: Mfr=1, Product=2, SerialNumber=0
usb 2-1.2: Product: Generic USB Joystick
usb 2-1.2: Manufacturer: DragonRise inc.
usb 2-1.2: configuration #1 chosen from 1 choice
input: DragonRise inc. Generic USB Joystick
as /devices/pci0000:00/0000:00:1a.0/usb2/2-1/2-1.2/2-1.2:1.0/input/input81
dragonrise 0003:0079:0006.004E: input,hidraw2: USB HID v1.10 Joystick
[DragonRise inc. Generic USB Joystick ] on usb-0000:00:1a.0-1.2/input0
dragonrise 0003:0079:0006.004E: Force Feedback for DragonRise Inc. game controllers
by Richard Walmsley
usb 2-1.2: USB disconnect, address 7
that loop was revealed also by the red **LED** on the interface **blinking** continously.
The problem occurred too using different GNU/Linux distributions: Raspberry Pi OS, Debian GNU/Linux, GRML; all running various **kernel versions** from the **4.x** and **5.x** series. The problem is caused by the kernel driver **hid_dr**, used for **DragonRise Inc. game controller**.
Running an old **2.6** version, the driver (named **hid_drff**) was stable enough to be able to read some input events from the device.
Fortunately I found a workaround for this problem in these posts:
* **[[https://retropie.org.uk/forum/topic/31488/solved-repeated-disconnect-of-zero-delay-usb-encoder-dragonrise/|Repeated disconnect of Zero Delay USB encoder (DragonRise)]]**
* **[[https://github.com/sriemer/fix-linux-mouse#usb-mouse-disconnectsreconnects-every-minute-on-linux|USB mouse disconnects/reconnects every minute on Linux]]**
It seems that the problem is caused by the driver that continously does a **buffer overflows if it is not always polled** for events. In that cases the Linux kernel offers a workaround; just add the following option on the **kernel command line**:
usbhid.quirks=0x0079:0x0006:0x00000400
In Debian and derived, just add that option into **/etc/default/grub**, at definition of **GRUB_CMDLINE_LINUX**, and execute **update-grub**. Notice that 0x79 is vendor code the and 0x06 is the product code, as revealed by **lsusb**:
Bus 002 Device 009: ID 0079:0006 DragonRise Inc. Generic USB Joystick
The bit mask 0x00000400 activates **HID_QUIRK_ALWAYS_POLL**.