Box86 and Wine on RPi4
-
@george .
Hello so I can start the .sh fine but it won't open mugen.
Error "cant open mugen.cfg ". Seems .conf works better for me .
Also another person using scripts cant open .conf . Hes is sure he ran chmod+x on em.
Also for everyone reading this doesn't work on a 64 bit environment box86 is useless like that . -
I got the conf file method working by removing the "OPTIONS=**" from the file. It was causing a malformed command line to be passed to wine.
-
@russellb uh the .conf works fine for me with options in it.
Problem is .sh I can launch it bit it wont open mugen says error unable to open mugen.cfg.
Seems the .conf works better than .sh simpler I guess dont know for sure why -
@troopaking said in Box86 and Wine on RPi4:
Also for everyone reading this doesn't work on a 64 bit environment box86 is useless like that .
True. ptitSeb did just release Box64, but vice versa that won't work on a 32 bit system. Plus you would need to use a 64 bit Wine, and that won't work with 32 bit applications, etc.
I'm puzzled by the error you are seeing (
can't open mugen.cfg
). If you have the same directory listed in the conf file and sh file then it should work the same. I also presume that mugen.cfg is in the same directory where the exe is. You might be able to do some additional debugging by inserting a couple of lines like this and see the log output matches your expectations:pwd ls -al
@RussellB if you had a line that said
OPTIONS=**
then that would likely throw some kind of error because * is the file wildcard. -
@george
Yeah I'm puzzled as well. .conf works fine but not .sh same files same directories etc
.sh loads wine fine starts to open then says cant open mugen.cfg. with simpler games yo opens fine . Example skifree.sh plays fine.
.conf takes a min to load but works great. I have started in wine desktop same load time .
Maybe .conf is better than .sh ? I am unsure .So I modified a few things for better playing experience .
Changes/modifications
-changed wine default to windows 8
-set pi gpu memory to 128. Tested vs 256, 128 gave me more frames per second.
-installed joy2key to map keyboard to controller. Controller preferred by some. Installed through wine config. Seems hard to launch same time with .conf as you said . But cant get .sh to work . So been looking into wine programs at boot. Hard to transfer to pi wine
-told wine that my pi has max video memory 1028 (I think), in winetricks . -
@troopaking I guess other things you might be able to try are removing the
cd
command from the.sh
file or setting it to the location of the Wine prefix (like/home/pi/.wine/drive_c/
or something).Really appreciate the times on the GPU and max video memory. Those are going to be interesting to test out.
For joy2key, what you could try to do is edit the
Wine Desktop.sh
file and add the command you need. Maybe around line 80? I've never been able to get Wine to launch a Windows program when it starts up using any of the usual Windows methods, like Startup folder, etc. From my own investigation, it seems Wine doesn't utilize those standards.- George
-
@george said in Box86 and Wine on RPi4:
@troopaking said in Box86 and Wine on RPi4:
Also for everyone reading this doesn't work on a 64 bit environment box86 is useless like that .
True. ptitSeb did just release Box64, but vice versa that won't work on a 32 bit system. Plus you would need to use a 64 bit Wine, and that won't work with 32 bit applications, etc.
I'm puzzled by the error you are seeing (
can't open mugen.cfg
). If you have the same directory listed in the conf file and sh file then it should work the same. I also presume that mugen.cfg is in the same directory where the exe is. You might be able to do some additional debugging by inserting a couple of lines like this and see the log output matches your expectations:pwd ls -al
@RussellB if you had a line that said
OPTIONS=**
then that would likely throw some kind of error because * is the file wildcard.Yeah what it was doing was including all the directories in the specified mugen folder into the command line to wine. So you ended up with something like mugen.exe char data ... in the wine command that was breaking it.
Now I just need to code the escape key to a button in wine and I'll be a happy camper.
-
@russellb escape key is why we are trying to autostart joy2key that escape is left bumper for example .
George from my testing 128 gpu memory is best performance .
I'm working with a guy to write a modified version of yourscriot that installs all mugens, changes gpu, install your script and makes mugen launch files . -
@troopaking Yeah as we have discussed I tried to get a joy2key windows-based program running and I succeeded but I can't find out a way to "autostart" WITHIN the wine environment. Looks like it will have to be setup before starting wine.
-
@russellb
If you install thru wine .
Open wine desktop then joy2key then mugen works great.
But thats not what we want lolUpdate
Success kinda If you addWINEDEBUG=-all LD_LIBRARY_PATH="/opt/retropie/supplementary/mesa/lib/" setarch linux32 -L /opt/retropie/emulators/wine/bin/wine '/path/to/joykey' &
To .sh above skifrees launch script. It opens both fine .
Unfortunately thier were issues
-exiting problem. Solved below
-and I still get same mugen error
-I have two windows one wine tray the other skifree . Works if ya click on joy2key make sure controller is registered then click skifree.Exiting problem solved joy2key has a option "minimize instead of close when x is pressed" disable this option returns to retropie fine .
-
Success with a different method.
How to
1.Install qjoypad
Sudo apt-get install qjoypad
2.Configure qjoypad in Linux desktop . Pretty self explanatory.
3. Edit .sh script.
Add this line before game script line
qjoypad &Should work off rip that like did for me .
But I still have same mugen error .
I need to figure out why mugen doesn't work with .sh for me .
When I run the commands in terminal on desktop I get root access error it seems . -
@troopaking root access error? Could it possibly be an ownership or permissions error? Check to see what user owns the application, directories, and config files. They should be owned by
pi
.But I'm not sure this would explain why the
.conf
method is working and the.sh
method is not.- George
-
So I discovered the issue .
DO NOT EDIT .SH IN WINDOWS . This is was caused my issue .
I changed .sh in Linux to this to autostart qjoypad works perfect .
#!/bin/bash
xset -dpms s off s noblank
cd "/home/pi/RetroPie/roms/wine/Files/claw/"
startx &
qjoypad &
WINEDEBUG=-all LD_LIBRARY_PATH="/opt/retropie/supplementary/mesa/lib/" setarch linux32 -L /opt/retropie/emulators/wine/bin/wine '/home/pi/RetroPie/roms/wine/Files/claw/CLAW.EXE'Opens and maps the keyboard to controller perfect.
Go into pixel desktop first and setup per game or games .
If you need different profile for game add "profile name " after qjoypad example.
qjoypad "mugen" & -
@troopaking Awesome! Glad you figured it out. Nice work!
-
-
@troopaking I took it one step further. I modified "Wine Desktop.sh" so that it will try to load a qjoypad layout named the same as the folder the mugen executable is in.
This only works for .conf files. I did this because I hated to have to have a different .sh for each game that basically does the same thing.
So for example...
/home/pi/RetroPie/roms/wine/Files/M.U.G.E.N/mugen.exe
It now tries to load M.U.G.E.N.lyt after checking to see if it exists in /home/pi/.qjoypad3 folder.
If it does not exist, it checks to see if WINE.lyt exists, and if it exists it will load that.
If that doesn't exist, it loads the default layout that was setup in the XWindows desktop.
This is generic now for any game, not just MUGEN.
-
@dteam I actually changed the theme to "windows" because most themes have a "Windows" theme already setup.
-
@dteam That looks awesome! Thanks!
-
@russellb This sounds pretty cool. I've never used QJoyPad before. Can either you or @Troopaking share how you installed it? The original project on SourceForge seems fairly old (http://qjoypad.sourceforge.net/), but there is a more recent fork on GitHub (https://github.com/panzi/qjoypad). I see there is a package for qjoypad, but that seems to be for v4.1 (the SourceForge version), while on GitHub it's up to 4.3.1.
@RussellB would you mind sharing your modifications?
There doesn't seem to be a script for QJoyPad in RetroPie (please correct me if I'm wrong). There seem to be additional alternatives as well (https://askubuntu.com/questions/239176/alternative-to-qjoypad). Perhaps it's worth starting a new topic with regards to creating some scripts that install these.
Thanks!
- George
-
@george sudo apt-get install qjoypad did the trick. Installed version 4.1.
Replace the test for .conf file in "Wine Desktop.sh" with this code. If ~/.qjoypad3 folder does not exist, it ignores the call to qjoypad all together.
elif [[ "${params[0]}" == *.conf ]]; then configFile=$(cat "${params[@]}") WINEPREFIX=$(configValueForKey WINEPREFIX "$configFile") DIRECTORY=$(configValueForKey DIRECTORY "$configFile") PROGRAM=$(configValueForKey PROGRAM "$configFile") OPTIONS=$(configValueForKey OPTIONS "$configFile") QJOYPADLAYOUT=$(echo $(basename $(dirname "${PROGRAM}"))) echo "Launching with config file" echo "WINEPREFIX: $WINEPREFIX" echo "DIRECTORY: $DIRECTORY" echo "PROGRAM: $PROGRAM" echo "OPTIONS: $OPTIONS" echo "QJOYPADLAYOUT: $QJOYPADLAYOUT" if [[ "$DIRECTORY" ]]; then cd "$DIRECTORY" fi midi_synth start xset -dpms s off s noblank matchbox-window-manager & if [ -d "/home/pi/.qjoypad3" ]; then if [ -f "/home/pi/.qjoypad3/${QJOYPADLAYOUT}.lyt" ]; then qjoypad "$QJOYPADLAYOUT" & echo "Starting qjoypad with $QJOYPADLAYOUT" elif [ -f "/home/pi/.qjoypad3/WINE.lyt" ]; then qjoypad WINE & echo "Starting qjoypad with WINE" else qjoypad & echo "Starting qjoypad with default layout" fi fi setarch linux32 -L /opt/retropie/emulators/wine/bin/wine "${PROGRAM}" "${OPTIONS}" midi_synth stop fi
Contributions to the project are always appreciated, so if you would like to support us with a donation you can do so here.
Hosting provided by Mythic-Beasts. See the Hosting Information page for more information.