ARpiCADE_5 - for Pi4 or Pi5
Moderator: dee2eR
Re: ARpiCADE_5 - for Pi4 or Pi5
Can confirm. It looks like I forgot to copy /home/pi/.mame/cfg/default.cfg from my testing builld to the release build. Not sure why some games seem fine... I'll upload a quick fix for it and add it to the first post of the thread [EDIT: it's done now].
Occasional not loading I really am not sure about. I'll have to keep an eye out for it to figure that one out.
Occasional not loading I really am not sure about. I'll have to keep an eye out for it to figure that one out.
Re: ARpiCADE_5 - for Pi4 or Pi5
Slowly going through the game list to make sure everything is working, still on the letter A!
I've got another strange control issue in 0.251.
Normally, the input devices are:
1. RaspberryJAMMA_P1
2. RaspberryJAMMA_P2
When it's like this, everything works fine.
Occasionally, when loading up a ROM I'll have an extra input device:
1. Xbox Gamepad (userspace driver)
2. RaspberryJAMMA_P1
3. RaspberryJAMMA_P2
And the controls are all messed up, Joy1 becomes Joy 2 and Joy2 becomes Joy 3.
I just loaded another game and now I have:
1. Xbox Gamepad (userspace driver)
2. Xbox Gamepad (userspace driver)
3. RaspberryJAMMA_P1
4. RaspberryJAMMA_P2
And, just loaded Andro Dunos and now I have:
1. Xbox Gamepad (userspace driver)
2. RaspberryJAMMA_P1
3. RaspberryJAMMA_P2
4. Xbox Gamepad (userspace driver)
Rebooting fixes this and restored the normal 2 RaspberryJAMMA input devices, any ideas?!
Also, more worryingly, if I restart my cab, the Pi5 seems to frequently not boot, I'm wondering if this is a voltage tweak needed?
I've got another strange control issue in 0.251.
Normally, the input devices are:
1. RaspberryJAMMA_P1
2. RaspberryJAMMA_P2
When it's like this, everything works fine.
Occasionally, when loading up a ROM I'll have an extra input device:
1. Xbox Gamepad (userspace driver)
2. RaspberryJAMMA_P1
3. RaspberryJAMMA_P2
And the controls are all messed up, Joy1 becomes Joy 2 and Joy2 becomes Joy 3.
I just loaded another game and now I have:
1. Xbox Gamepad (userspace driver)
2. Xbox Gamepad (userspace driver)
3. RaspberryJAMMA_P1
4. RaspberryJAMMA_P2
And, just loaded Andro Dunos and now I have:
1. Xbox Gamepad (userspace driver)
2. RaspberryJAMMA_P1
3. RaspberryJAMMA_P2
4. Xbox Gamepad (userspace driver)
Rebooting fixes this and restored the normal 2 RaspberryJAMMA input devices, any ideas?!
Also, more worryingly, if I restart my cab, the Pi5 seems to frequently not boot, I'm wondering if this is a voltage tweak needed?
Re: ARpiCADE_5 - for Pi4 or Pi5
Not sure re. the sometimes not restarting (do you mean when restarting from the service menu/command line/software in some way or the cab itself?). I experienced some similar behaviour rebooting when I was playing with overclocking and ended up with a slight underclock in config.txt as it seemed to improve stability in some situations when powered via GPIO (pretty sure Pi5 is pushing how much power can be delivered via ribbon cable). Could be power related, may be something else. What is your 5v reading at the JAMMA edge? Also what model Pi5? I've been swapping between the 3 diff Pi5s I own and Pi4s during testing pretty randomly, it's possible there's some subtle behaviour differences I'm missing in testing. If you haven't been already and do have the Pi5 not restart again try pressing the little reset button on it near the SD card slot - not really a fix but should save you power cycling the whole cab.
The xbox driver thing is the hotkeys... that said, what you're experiencing shouldn't be happening (obviously). Especially the 2 instances at once shouldn't happen because they should be stopped after exiting the emulator, something weird must have happened there. Currently the hotkeys start after a sleep timer so the emulator can start up before them in an attempt to work around this sort of thing. It is probably worth trying a longer timer in /usr/local/bin/hotkeys (it is currently: 'sleep 6').
I will do some more testing. Hopefully I can find some better answers than that.
Thank you for all the feedback.
The xbox driver thing is the hotkeys... that said, what you're experiencing shouldn't be happening (obviously). Especially the 2 instances at once shouldn't happen because they should be stopped after exiting the emulator, something weird must have happened there. Currently the hotkeys start after a sleep timer so the emulator can start up before them in an attempt to work around this sort of thing. It is probably worth trying a longer timer in /usr/local/bin/hotkeys (it is currently: 'sleep 6').
I will do some more testing. Hopefully I can find some better answers than that.
Thank you for all the feedback.
Re: ARpiCADE_5 - for Pi4 or Pi5
The voltage was nearly 5.5v so I've dialled it back to 5.1, maybe that was the issue there. Thanks for the reset button tip, I didn't even know that was there
As for the controls, I altered sleep=6 to sleep=12 in /usr/local/bin/hotkeys and it made the rom loading issue a lot worse. Dialled it back to 8 and I'm still seeing the Xbox Gamepad (userspace driver) taking over position 1 and on one occasion it was the first 3 input devices before RaspberryJAMMA in positions 4 and 5.
This is still all on MAME251 and makes it pretty unusable.
Hoping you can find the cause and fix!
As for the controls, I altered sleep=6 to sleep=12 in /usr/local/bin/hotkeys and it made the rom loading issue a lot worse. Dialled it back to 8 and I'm still seeing the Xbox Gamepad (userspace driver) taking over position 1 and on one occasion it was the first 3 input devices before RaspberryJAMMA in positions 4 and 5.
This is still all on MAME251 and makes it pretty unusable.
Hoping you can find the cause and fix!
Re: ARpiCADE_5 - for Pi4 or Pi5
Didn't have any luck replicating the xboxdrv appearing in MAME issue. Possibly didn't load enough games for it to happen, possibly it's just happening when [unknown] occurs. Hopefully whatever it is I can figure it out.
Could you try adding:
to the mame251 launcher, put it on the line before the line that starts the hotkeys. In theory it should stop any extra instances of xboxdrv that are already running.
I did find a couple of config.txt settings worth trying if you have the active cooler on your Pi5. I noticed the fan was barely ever running and am trying it running more often (hoping to keep the heat out of the ribbon cable as the resistance in the cable goes up with the temp). My [pi5] section of config.txt currently looks like:
On my test bench these settings don't give me any issue with rebooting, however, if I comment out the GPU underclock I get the reboot doesn't reboot issue you are experiencing (at least when using my 4gig Pi5, haven't tested the other 2 yet). The CPU underclock I had in the release config.txt doesn't seem necesary, at least on my test bench and 4gig Pi5. Haven't yet, but I'll try running the fan full speed all the time as it's not like it has to be silent when mounted in a cab (it's probably quieter than my CPS2s fan).
5.5v was definately too high, if it actually ran better this high it suggests your JAMMA loom power wiring is inadequate. What is the 5v and GND wire on your JAMMA loom like? (single aluminium wire (most new JAMMA harness'), 4x copper (most older JAMMA harness')?) Unless the difference is our individual Pi5s I can't think of why else we would have different results on the same settings (unless it's the weather itself, it's pretty cold here - if it's hot where you are maybe it's more borderline due to that... if so I'm sure I'll find out in a couple of months).
Could you try adding:
Code: Select all
hotkeys stop
I did find a couple of config.txt settings worth trying if you have the active cooler on your Pi5. I noticed the fan was barely ever running and am trying it running more often (hoping to keep the heat out of the ribbon cable as the resistance in the cable goes up with the temp). My [pi5] section of config.txt currently looks like:
Code: Select all
[pi5]
## use fan at lower temps
dtparam=fan_temp0=30000
dtparam=fan_temp1=45000
## experimental overclocking
#arm_freq=3000
#gpu_freq=1000
## underclock good for stability if powering via GPIO
#arm_freq=2200
gpu_freq=600
5.5v was definately too high, if it actually ran better this high it suggests your JAMMA loom power wiring is inadequate. What is the 5v and GND wire on your JAMMA loom like? (single aluminium wire (most new JAMMA harness'), 4x copper (most older JAMMA harness')?) Unless the difference is our individual Pi5s I can't think of why else we would have different results on the same settings (unless it's the weather itself, it's pretty cold here - if it's hot where you are maybe it's more borderline due to that... if so I'm sure I'll find out in a couple of months).
- cool_factor
- Legendary Contributor
- Posts: 337
- Joined: Tue Sep 26, 2017 10:55 am
- Location: Fort Worth TX
Re: ARpiCADE_5 - for Pi4 or Pi5
dee2eR wrote: ↑Mon Sep 16, 2024 3:50 amNot sure re. the sometimes not restarting (do you mean when restarting from the service menu/command line/software in some way or the cab itself?). I experienced some similar behaviour rebooting when I was playing with overclocking and ended up with a slight underclock in config.txt as it seemed to improve stability in some situations when powered via GPIO (pretty sure Pi5 is pushing how much power can be delivered via ribbon cable). Could be power related, may be something else. What is your 5v reading at the JAMMA edge? Also what model Pi5? I've been swapping between the 3 diff Pi5s I own and Pi4s during testing pretty randomly, it's possible there's some subtle behaviour differences I'm missing in testing. If you haven't been already and do have the Pi5 not restart again try pressing the little reset button on it near the SD card slot - not really a fix but should save you power cycling the whole cab.
The xbox driver thing is the hotkeys... that said, what you're experiencing shouldn't be happening (obviously). Especially the 2 instances at once shouldn't happen because they should be stopped after exiting the emulator, something weird must have happened there. Currently the hotkeys start after a sleep timer so the emulator can start up before them in an attempt to work around this sort of thing. It is probably worth trying a longer timer in /usr/local/bin/hotkeys (it is currently: 'sleep 6').
I will do some more testing. Hopefully I can find some better answers than that.
Thank you for all the feedback.
Out of curiosity is there a sleep timer for the usb ports? my grs star wars yoke freaks out the settings unless i wait about 10 seconds while booting and then plug it into the usb ports. results are inline with Mappys. this is on the pi4, im sure the pi5 will be the same results.
Re: ARpiCADE_5 - for Pi4 or Pi5
I do have the active cooler, so I've set my config.txt the same as yours. The cab was probably at 5.5v due to an old JAMMA arcade board that needed the extra volts. It's a 90s JAMMA cab with good, solid 4xcopper wires on the 5v line.
Anyway, my mame251.sh contains this now:
and set the /usr/local/bin/hotkeys back to sleep 6
Games still sometimes take 2-5 attempts to load and when they do load I've been checking the Input settings. Most of the time, the xboxdriver isn't there at all.
Sometimes the xboxdriver is in position 3, so the controls still work OK, but occasionally it's in position 1 which means the controls no longer work correctly.
See this video of me trying to launch the game "Bay Route", it takes two attempts to launch and then starts witht the xboxdriver in position 1:
https://photos.app.goo.gl/ho2e6H6LyEndp9L79
Anyway, my mame251.sh contains this now:
Code: Select all
# launch hotkeys late in background so xboxdrv not picked up by mame
hotkeys stop
hotkeys start &
mame $1 $aconfig $ror
Games still sometimes take 2-5 attempts to load and when they do load I've been checking the Input settings. Most of the time, the xboxdriver isn't there at all.
Sometimes the xboxdriver is in position 3, so the controls still work OK, but occasionally it's in position 1 which means the controls no longer work correctly.
See this video of me trying to launch the game "Bay Route", it takes two attempts to launch and then starts witht the xboxdriver in position 1:
https://photos.app.goo.gl/ho2e6H6LyEndp9L79
Re: ARpiCADE_5 - for Pi4 or Pi5
No, USB items that follow the standards are handled automatically by the kerrnel. If you had to run a driver for them (eg. a Sinden gun) then you could add a delay, anything using standards won't need a driver though as it's already in the Linux kernel. I can only put the timer on the hotkeys startup because it's all scripted start/stop xboxdrv.cool_factor wrote: ↑Tue Sep 17, 2024 8:47 pmOut of curiosity is there a sleep timer for the usb ports? my grs star wars yoke freaks out the settings unless i wait about 10 seconds while booting and then plug it into the usb ports. results are inline with Mappys. this is on the pi4, im sure the pi5 will be the same results.
It is possible that there will be things we haven't been able to use before that may help as there is a lot more GUI based OS in the background than on earlier ARpiCADE builds. The random numbering of peripherals has to be one of my least favourite things about Linux... UDEV rules etc. tend to get broken with updates over time.
weird, it's like something is slowing down MAMEs startup or causing it not to start properly. I'll keep testing and see if I can replicate it, haven't been able to yet. Is it only 251 that does it for you?mappy24 wrote: ↑Tue Sep 17, 2024 9:17 pmGames still sometimes take 2-5 attempts to load and when they do load I've been checking the Input settings. Most of the time, the xboxdriver isn't there at all.
Sometimes the xboxdriver is in position 3, so the controls still work OK, but occasionally it's in position 1 which means the controls no longer work correctly.
See this video of me trying to launch the game "Bay Route", it takes two attempts to launch and then starts witht the xboxdriver in position 1:
Re: ARpiCADE_5 - for Pi4 or Pi5
I've only copied over the 251 romset at this point, just going through the list to see what works and what doesn't.
Re: ARpiCADE_5 - for Pi4 or Pi5
OK, I'm not sure if this helps, but I've discovered that I can exit attract mode which gives me a terminal, then if I enter 'attract' the terminal stays open and shows me a log. In this log below, I launched Cabal, which ran fine, then quit the game. This is what's logged when a game runs OK:
Then I ran the game below it in the menu, Dino something-or-other (can't remember the exact title) this game failed to load and this is what was logged:
Does this help at all?! Is it something to do with the segmentation fault at line 70 which causes the game not to load, but then the mame251 script isn't completing and causes the controls to be messed up when loading the next game? Just guessing.
Code: Select all
*** Running: /boot/firmware/launchers/mame251.sh cabal
/boot/firmware/launchers/mame251.sh: line 55: [: ==: unary operator expected
xboxdrv: no process found
xkbcommon: ERROR: /usr/share/X11/locale/iso8859-1/Compose:39:34: string literal is not a valid UTF-8 string
xkbcommon: ERROR: /usr/share/X11/locale/iso8859-1/Compose:40:29: string literal is not a valid UTF-8 string
xkbcommon: ERROR: /usr/share/X11/locale/iso8859-1/Compose:41:29: string literal is not a valid UTF-8 string
xkbcommon: ERROR: /usr/share/X11/locale/iso8859-1/Compose:42:29: string literal is not a valid UTF-8 string
xkbcommon: ERROR: /usr/share/X11/locale/iso8859-1/Compose:43:29: string literal is not a valid UTF-8 string
xkbcommon: ERROR: /usr/share/X11/locale/iso8859-1/Compose:44:27: string literal is not a valid UTF-8 string
xkbcommon: ERROR: /usr/share/X11/locale/iso8859-1/Compose:45:27: string literal is not a valid UTF-8 string
xkbcommon: ERROR: /usr/share/X11/locale/iso8859-1/Compose:46:27: string literal is not a valid UTF-8 string
xkbcommon: ERROR: /usr/share/X11/locale/iso8859-1/Compose:47:27: string literal is not a valid UTF-8 string
xkbcommon: ERROR: /usr/share/X11/locale/iso8859-1/Compose:48:29: string literal is not a valid UTF-8 string
xkbcommon: ERROR: /usr/share/X11/locale/iso8859-1/Compose:49:29: string literal is not a valid UTF-8 string
xkbcommon: ERROR: /usr/share/X11/locale/iso8859-1/Compose:49:29: too many errors
xkbcommon: ERROR: /usr/share/X11/locale/iso8859-1/Compose:49:29: failed to parse file
warning: queue 0xfe142f0 destroyed while proxies still attached:
wl_callback@44 still attached
wl_surface@31 still attached
- Loaded layout: /usr/local/share/attract/layouts/Basic/ (layout.nut)
! Unexpectedly lost focus to: Unknown
- Working directory: /boot/firmware/launchers
Code: Select all
*** Running: /boot/firmware/launchers/mame251.sh dino
/boot/firmware/launchers/mame251.sh: line 55: [: ==: unary operator expected
/boot/firmware/launchers/mame251.sh: line 70: 10007 Segmentation fault mame $1 $aconfig $ror
xboxdrv: no process found
- Loaded layout: /usr/local/share/attract/layouts/Basic/ (layout.nut)
Failed to get vendor ID of joystick /dev/input/js2
Failed to get product ID of joystick /dev/input/js2
! Unexpectedly lost focus to: Unknown
Failed to get vendor ID of joystick /dev/input/js3
Failed to get product ID of joystick /dev/input/js3