-
-
Notifications
You must be signed in to change notification settings - Fork 187
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
VMUs and Rumble Packs with Original Dreamcast Controllers #1810
Conversation
I can try it with the DreamConn S for possible issues. Can you please provide a Windows build? |
you can grab it here: https://github.com/flyinghead/flycast/actions/runs/12806671980/artifacts/2440333360 |
Thanks for your work on this to get this integrated with DreamcastControllerUsbPico! Using the CDC interface is certainly the easiest way to go about it 🤣 It was originally only meant to be a debug tool, but I don't see any harm in using it this way! Keep it simple, right? I did get the PID/VID assigned through pidcodes.github.com, so no one else should be using that address. FYI The storage device implementation is very basic, essentially a proof-of-concept, and I never hardened it to allow for random access of data (only copy or paste of an entire vmu). It would be interesting to see an emulator working directly off of the data somehow though. I'd be interested in helping with that if it seems like a useful feature. |
Awesome work! This is really cool! |
Just tested with DreamConn S, and everything seems to be working fine. |
@chrisvcpp Thanks for checking!
@Tails86 This was the low hanging fruit :D My initial idea was to use a Pi Pico with WIFI and extend DreamcastControllerUsbPico with a TCP Server to piggyback on the existing TCP-to-localhost stuff from DreamConn - but the CDC makes it way easier.
@Tails86 Maybe this can also be addressed by DreamcastControllerUsbPico. Unfortunately I don't have a Debug Kit available so I couldn't figure out why the USB HID seems to be exposed differently on MacOS/Windows vs Linux (Linux has the "correct" mapping). But I guess this is related to how the OSes interpret the HID - any thoughts on this? |
I'm using a descriptor that is very similar descriptor to what TinyUSB recommends. The only tweak I made is the minimum is -128 instead of -127 to better match up with the Dreamcast controller. It seemed like TinyUSB followed a standard recommended by the Linux community, so that tracks. Conversion from Dreamcast controller input happens here: Button indices are defined here: I can of course tweak the descriptor and/or conversions to be whatever is most compatible. Do you have any idea what layout this needs to be? I'm sort of wondering if the analog trigger range [-128,127] is a problem. |
@Tails86 thanks for the pointers!
For future reference, its stated here https://github.com/hathach/tinyusb/blob/880aae4be2556704abd4dae9c707c9fa87603cf1/src/class/hid/hid.h
By default on Linux, or when manually configuring the Controller on MacOS/Windows, the triggers work fine. Sega Rally 2 has a nice test for this - there is an option menu for configuring the deadzone. To my feeling, the triggers need to be pressed quite a bit before they are recognized. I am not sure if this is the default behaviour of the controller on the original DC, or something which is due to DreamcastControllerUsbPico. I briefly tested a trigger range of [-127, 127] which did not change my perception of this. I currently cannot test this with a real DC - maybe you have something available to compare this with?
The problem seems to be that MacOS and Windows use different input event codes, hence those OS by default do not or do only falsely recognize the buttons/axis. So it seems that there is no one-fits-all solution from what I could find. To my mind, the button mapping issue can be worked around by either
From what I can tell, for 1. we need to figure out the correct input event codes and probably do some heavy lifting in DreamcastControllerUsbPico - what is your take on this @Tails86? |
I second that! |
Aha! I knew I remember seeing a reference to Linux, but I couldn't find it.
I tested Sega Rally 2 with a real Dreamcast, and there wasn't very much deadzone on the triggers. I've been trying to locate my maple bus host adapter I created, but it seems it walked off. I haven't had a chance to really test things out yet. Thankfully it's a fairly simple circuit, so I'm putting a new one together now. What I want to try is maybe setting the range to [0,255] just for the triggers. I have a feeling the manual interpretation is using only [0, 127] portion of the triggers because it's only binding to
I'm not completely opposed to 1, but I'd like to limit build configurations if possible. |
Thanks, I followed up in OrangeFox86/DreamcastControllerUsbPico#123
I gave 2. another look, the changes are straightforward - I'll push them tomorrow |
@Tails86 @flyinghead |
I ran into lockups on subsequent execution when Besides this issue, I confirmed on my end that VMU/jump pack with |
Thanks for confirming. Lockup should be fixed in the latest commit which dynamically selects the serial device based on VID/PID |
@flyinghead Thanks for fixing this, I wasn't sure why the checks failed. Current status:
|
We usually upgrade SDL regularly but we probably don't need to wait for a new release that includes your PR. I think we can add custom game controller mappings with |
Good point, thanks - probably here? I'll take a look tomorrow. |
Yes |
Done @Tails86 Can you please test the latest build once the workflow completes? @flyinghead Open questions:
|
It can be done on linux by looking at |
@kosekmi cool, I didn't think you'd like that blocking |
The only documentation available for Flycast is https://github.com/TheArcadeStriker/flycast-wiki/wiki. I can add a link to your documentation, or add it there directly. |
Please disregard the comment I just deleted. My issue was entirely because I somehow had incorrect firmware loaded. Reflashing was all I needed to do. My apologies! Everything seems to be working for me except I have to manually map the keys (testing on Windows). |
@flyinghead Thanks for merging!
Should I push this to |
@Tails86 The key mapping issue should be fixed in the latest build, works for me on Windows and MacOS. Can you please check if you have a manuel override active? I.e., |
you'll have to open a new PR for additional changes. |
I'm experiencing some odd behavior with this. Here's what I'm doing.
Resetting the mapping just sets all to the global defaults rather than the known profile's defaults. |
This PR enables the usage of VMUs and Rumble Packs with original Dreamcast Controllers connected to MacOS/Linux/Windows using the DreamcastControllerUsbPico Raspberry Pi Pico-based USB-Adapter.
By default, the USB-Adapter provides the following devices:
Using the USB CDC serial device, this PR piggybacks on the handler for DreamConn+ Controllers as discussed here. It currently provides a working implementation of VMUs and Rumble Packs using MapleIO with support for MacOS/Linux/Windows.
Demo: https://youtu.be/Nj4dRMZ_jB0
Usage:
/dev/ttyACM*
) is owned by root. Change permission of the device to your user, or startup Flycast with superuser permissionsNotes:
Todos:
async_write()
finishes. As such, the disconnection of a serial device can currently not be detected reliably since the device will report being open despite being disconnected. As a consequence, theDreamConn
instance is not deconstructed correctly until a new game is started/dev/ttyACM0
,COM1
) changes. Currently, the first serial device found is used. This should probably be exposed to a config file or the UI for proper handlingcheckKeyCombo()
is not working since leftTrigger and rightTrigger seem to be not correctly wired within theSDLGamepad
handler - I couldn't figure out why. This can probably be hardcoded? The mapping is:Credits go to @Tails86 for DreamcastControllerUsbPico, @flyinghead for Flycast, and @chrisvcpp for DreamConn+. Thanks to @Marcel43367 for helping on serial device debugging!