[SOLVED] - N64 - something overriding my emu choice...?
-
Thanks for replying Mitu. :-) Yes I'm sure I'm starting the same ROM...dunno how I could be selecting a different one in any case. My emulators.cfg is detailed below:
mupen64plus-GLideN64 = "/opt/retropie/emulators/mupen64plus/bin/mupen64plus.sh mupen64plus-video-GLideN64 %ROM% 320x240" mupen64plus-gles2rice = "/opt/retropie/emulators/mupen64plus/bin/mupen64plus.sh mupen64plus-video-rice %ROM% 320x240" mupen64plus-GLideN64-highres = "/opt/retropie/emulators/mupen64plus/bin/mupen64plus.sh mupen64plus-video-GLideN64 %ROM% 640x480" mupen64plus-gles2rice-highres = "/opt/retropie/emulators/mupen64plus/bin/mupen64plus.sh mupen64plus-video-rice %ROM% 640x480" mupen64plus-gles2n64 = "/opt/retropie/emulators/mupen64plus/bin/mupen64plus.sh mupen64plus-video-n64 %ROM%" mupen64plus-auto = "/opt/retropie/emulators/mupen64plus/bin/mupen64plus.sh AUTO %ROM%" default = "lr-mupen64plus" lr-mupen64plus = "/opt/retropie/emulators/retroarch/bin/retroarch -L /opt/retropie/libretrocores/lr-mupen64plus/mupen64plus_libretro.so --config /opt/retropie/configs/n64/retroarch.cfg %ROM%"
You can see my default is lr-mupen64plus, but for many ROMs I change this in runcommand and Yoshi is one of them. Thanks again for your help.
-
@Ranma I remember some time ago there were problems with corrupted
emulators.cfg
, can you check if there isn't anything funny/strange characters in the file where the override is saved ? I'll try to reproduce the problem also. -
By this I think you mean /configs/all location? I've had a quick look and it all looks OK to me, no obvious corruption. I'll apologise now if I take a while to respond as I have to be up for work in the morning, but I will definitely reply here as I really appreciate your help Mitu.
Like I say it seemed to work great at first but after playing a couple of different N64 games, changing one or two of their default emus, and then rebooting the system it seemed to reset the choice for Yoshi. See how you get on Mitu and thanks again. :-)
-
@Ranma did you update mupen64plus recently?
Edit: so I just tried to run Yoshi's story on my pi and even when I choose gles2n64 it forces me to use gliden64. Very likely the Yoshi's story was added to the gles2n64 blacklist. You can remove it from the blacklist by editing your mupen64plus.sh file located at: /opt/retropie/emulators/mupen64plus/bin
Though I suspect there was a good reason for it to be put on that list
-
@quicksilver is almost right, Yoshi is part of the blacklist for
glesn64rice
(defined here), but notgles2n64
. I haven't got around testing it, but will try tonight to give it a go. -
@mitu are u sure? I just checked and "story" is on my gles2n64 blacklist. Or is that referencing a different game?
-
@quicksilver Not sure yet, haven't got around testing on the Pi. A cursory look (hence the reply and the link) shows
# these games do not run with rice local glesn64rice_blacklist=( yoshi rogue squadron gauntlet )
I don't see any entries for story in any blacklist present in the default
mupen64plus.sh
(https://github.com/RetroPie/RetroPie-Setup/blob/master/scriptmodules/emulators/mupen64plus/mupen64plus.sh). -
@mitu that's really odd. I'll check mine again. I may have updated from source a week or two ago but that wouldn't affect the mupen64plus.sh file right? That's maintained as part of retro pie correct?
-
@quicksilver said in N64 - something overriding my emu choice...?:
That's maintained as part of retro pie correct?
Yes, that's part of the
mupen64plus
emulator package, it's not part of the upstream source. -
@mitu I just checked and Yoshi's story is not on my gles2n64 blacklist (could have sworn I saw it on there as "story", guess I'm losing it). However my list doesn't match what you posted, I have about 9 games on my gles2n64 blacklist.
-
@quicksilver I posted the list for glesn64rice, the glesn64 list has indeed more entries:
local glesn64_blacklist=( zelda paper kazooie tooie instinct beetle rogue squadron gauntlet )
-
@mitu man I'm just out of it today. I'm going to stop trying to help now haha
-
@Ranma ok, so the problem seems that
yoshi
appears in theglesn64rice_blacklist
list, but the startup script tests the ROM blacklist for bothglesn64rice
andglesn64
altogether. Sinceyoshi
appears in one of them, the video plugin is overriden and switched tomupen64plus-video-GLideN64
(which is what you noticed).From the startup script
"mupen64plus-video-n64"|"mupen64plus-video-rice") for game in "${glesn64_blacklist[@]}"; do if [[ "${ROM,,}" == *"$game"* ]]; then VIDEO_PLUGIN="mupen64plus-video-rice" fi done for game in "${glesn64rice_blacklist[@]}"; do if [[ "${ROM,,}" == *"$game"* ]]; then VIDEO_PLUGIN="mupen64plus-video-GLideN64" fi done
It looks like a bug, but there may be another reason why this was coded this way. @gizmo98 was this on purpose or it's just a bug ? If we switch the test for the video plugin blacklist individually, when starting with
mupen64plus-video-64
, the ROM would not be tested withglesn64rice_blacklist
and the video plugin override would not be applied. -
That is very interesting. All I can tell you is that when it did work at first, Yoshi ran extremely well on gles2n64. The best I'd ever seen it run tbh, so I'm sad this has been coded this way. Can I change this manually? Also, thanks again to Mitu for your Holmesian work here. :-)
-
The thing is, I don't understand how it run in the first place ? If my 'analysis' is correct, you wouldn't have been able to run it - when I started it myself it would still load the Glide64 plugin.
-
You can change
"mupen64plus-video-n64"|"mupen64plus-video-rice") for game in "${glesn64_blacklist[@]}"; do if [[ "${ROM,,}" == *"$game"* ]]; then VIDEO_PLUGIN="mupen64plus-video-rice" fi done for game in "${glesn64rice_blacklist[@]}"; do if [[ "${ROM,,}" == *"$game"* ]]; then VIDEO_PLUGIN="mupen64plus-video-GLideN64" fi done
to
"mupen64plus-video-n64") for game in "${glesn64_blacklist[@]}"; do if [[ "${ROM,,}" == *"$game"* ]]; then VIDEO_PLUGIN="mupen64plus-video-rice" fi done ;; "mupen64plus-video-rice") for game in "${glesn64rice_blacklist[@]}"; do if [[ "${ROM,,}" == *"$game"* ]]; then VIDEO_PLUGIN="mupen64plus-video-GLideN64" fi done
and it should work - no more GLideN64 override.
The file is/opt/retropie/emulators/mupen64plus/bin/mupen64plus.sh
. It will be overwritten when you update themupen64plus
package, but hopefully we can find a fix for it and update the package - if it's just a bug. -
@mitu Hmmm, yeah that is odd. Maybe I'm mistaken but it definitely did not run the Gliden64 plugin on my first play. I got to about level three (lightweight!), chuffed to bits with the performance, before powering down for the evening. I had also tried other emulators before settling on gles2n64.
Thanks so much for your fix above Mitu and all the assistance you have given me here on Retropie Forums. You are always one of the first to reply and always get it sorted for me. :-)
-
@Ranma so I removed Yoshi's story from the rice blacklist and I was able to run it with gles2n64 but it runs terribly. Missing textures and backgrounds make it pretty much unplayable. Are you sure it was gles2n64 you were using?
-
Well I feel like a right wally. I applied your code above and it works! However, I must have been mistaken as Yoshi runs awfully with gles2n64 as the emu. I imagine this is why the author blacklisted it. Most of the screen is black, and when you can see elements you only get bits here and there.
God only knows what I was thinking. Apologies to Mitu for taking up your valuable time with this. :-(
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.