Multi Switch Shutdown Script!
-
@caver01 Oh yes ;) Even on a soft shutdown it is clear what happens.
ES writes a metadta and file into /TMP folder and the binary quits. After that, shutdown is initiated and then meleus service takes action. Then if multi_switch is called indeed a seconds shutdown is initiated ...But I don't understand what you mean with "race" of the scripts. If you use the
--es-systemd
parameter I don't initiate annother shutdown. -
@cyperghost It is a race because before the script in Meleu's service calls multi_switch, it first triggers my GPIO transistor. When that happens, my python script calls multi_switch. So, one or the other call is going to make sure everything closes. I don't know which one finishes first.
-
@caver01 Ahhh........!
Yes!That makes it clear. But the solution for this is very easy. If you place a script to
/lib/systemd/system-shutdown
you call from there the trigger to your transisitor then the filesystem is already set to read only. Read more about here: Linux Stack Exchange and in this (late) state the system is miliseconds away for going to powerdown. That is the right moment to send signal to GPIO to "push" the button. The service also pushes arguments to callers. So the script can decide between shutdowns, reboots and so you call the trigger just inpoweroff
state.I did it here.... Exposed Shim ON OFF and also here in my Yet annother NESPi case mod also with a Mausberry build in and so there is no race against two shutdowns ;)
So in your case remove the "GPIO trigger"-part from meleus service right to annother script that is placed to
/lib/systemd/system-shutdown/
-folder. You need sudo command for this as this files are property of root. -
@cyperghost are you saying I can just put a bash script into
/lib/systemd/system-shutdown/
and it will execute during shutdown? Why do we need meleu's service? -
@caver01 said in Multi Switch Shutdown Script!:
@cyperghost are you saying I can just put a bash script into
/lib/systemd/system-shutdown/
and it will execute during shutdown?Yes! The systemd service automatically parses shutdown status to any scripts in this folder. So $1 can be poweroff, halt, reboot and you can initiate actions by this.
Why do we need meleu's service?
Well.... I don't know if the service is still useable. Some people report is does not work proper anymore. I tried, too - but also failed for proper shutdown. So the service is sadly out of service. And imho the service is usefull not to push triggers like you (ab)use it ... more to just prober shutdown ES ;)
BUT if it will work you would never have to modify button scripts. They just initiate a shutdown and the service automatically shuts down emulators and ES. That's the great advantage.
I modified the original NESPi+ python script for example and added an if/then clause. If butto nis pressed and if ES-PID is active then use multi_switch with es-poweroff switch, else use regular shutdown.
If the service would work again the python script would be just. If button is pressed then use regular shutdown.But imho it's still a flavour what you want to do and how far you understand what you do.
-
@cyperghost I guess we have several options, but I do like your script—one script for several uses. It just makes sense.
-
@caver01 The intention to write this script is a bit more.
- It should provide an easy all in one solution for people who use several switch devices (A simple Button connected to GPIO and ground, both NESPi case types, or the Pimonori ONOFF Shim or the Mausberry switch)
- It provides a solution if people use several button to make "reset" actions. So the script can be written to just finish any emulators if they are active, or to restart ES, or to reboot the whole system if button is held down for more than 5 seconds. This is all possible if you use the regular switches.
- Personally! I'm owner of 4 of the 5 devices the script supports I have a Mausberry in a NESPi case, I've a NESPi+ case, I've a Pimonori Switch and on my old B1 I've a some single push buttons only. And the setup to perform shutdown with this script was never easier to do now. Exactly as you said...
3.1 Use the script and make calls likemulti_switch.sh --es-poweroff
from any button script.
3.2 Personally I use it several time likemulti_switch.sh --generic powerbtn=23
3.3 Sometimes I do some coding on the mashine via SSH and the TV is not powerd on so just amulti_switch.sh --es-poweroff
shutdown the system cleanly with proper quitted ES.
3.4 I setted up a Pimonori Switch on my OwnCloudSystem so there is also just a proper call tomulti_switch.sh --onoffshimm
Nevertheless I hope @meleu reactivates the shutdown service again.
-
I'd love to see this working for the Kintaro 9000 case. They've been working on the meta data issue for a while now.
-
hello, i have a question.. i have a nespi case.. but my mod made it have two buttons.. made power button work as intended.. my plan first was to solder the reset button on RUN header to have a hard reset in case of crashes and use power to soft reset..
i found your script.. and im here to ask if there is any change of using the reset button as generic too?
tldr: can i use this scrip with two generic buttons?
edit:
this solved for me
/home/pi/RetroPie/scripts/multi_switch.sh --nespicase powerbtn=3 resetbtn=4 & -
@quackwalks Well you modify the python script and integrate the arguments
multi_switch.sh
offers to get it full working with your kintaro. A way how it can be done I offered here for the NESPi+ case.. You can use the return values of--ES-PID
(= ask if EmulationStation is running) and--RC-PID
(= ask if there is a emulator running in background) to decide to do actions.As long as I don't have this case I don't do anything to integrate this in the script. It can be done, I know ... but it took several days to get the NESPi+ working ... at last I bought one then the settings were done in less then a few hours.
-
Thx to @fastpop72 he gave positive answer in getting this invoked into python script
Tired on bash scripts? Get a functional shutdown for your NESPi+ on python
Took a journey on python scripting (really easy, and the script could be improved!) but it works best.... it shows same behaviour as multi_switch as bash call.
1. If you press restart if emulator is currently running, then you will be kicked back to ES main menu 2. If you press restart in ES main screen, ES will be restartet (no reboot!), good for quick saving metadata or internal saves. 3. If you press power-off then Raspberry will shutdown All metadata is always saved Best -> cyperghost
You can install the script with
wget -O - "https://raw.githubusercontent.com/crcerror/retroflag-picase/master/install.sh" | sudo bash
-
WOAW excellent, i've receved my new NesPi+, i will try it :)
Thanks -
Hello.. i have a modification sugestion..
maybe you could integrate a save state function to the reset button.. using this!
https://github.com/GregorR/RetroArch/wiki/Network-Commands
this open doors to.. gracefully quit emulation ( retroarch compatible cores).. and other thinks like.. pressing reset for 5 seconds save state.. quick press load state..
you can even set the reset button to reset only the game you are playing.. and other thinks,
-
@dudumaroja You can do it your self. That's the whole fun of retro pie. If you are willing to do some research and get your hands dirty anything can be done.
heres a link to the recalbox help page with instructions on how to set this up.
https://github.com/recalbox/recalbox-os/wiki/RetroArch-Network-Commands-(EN) -
Hello, is there a way to get the source code so that I can add led functionality to the code. I just want it to set a GPIO to high when turned on and to LOW when turned off.
Thanks.
-
@orehruoy The source is on github, link is in the 1st post - https://github.com/crcerror/ES-generic-shutdown.
-
@orehruoy You can modify the code of the script of course. But if you just want to glow a LED for power on/off control then use the UART port. A simple solution and no script needed.
-
@cyperghost said in Multi Switch Shutdown Script!:
@orehruoy You can modify the code of the script of course. But if you just want to glow a LED for power on/off control then use the UART port. A simple solution and no script needed.
I didn't know how to access your code in the pi. I will try that other method though seems simple. Thanks.
-
I finally try your script :)
Correct a problem for me because you install the script in/home/pi/Retropie/Scripts/
and this directory is on my USB drive.
I can't have good right to execute.sh
on USB drive with the auto-mount :p
I change to use it in/home/pi/Scripts/
and it's perfect, thanks a lot :)Only one question, when i want to quit RetroArch to ES i must clic 3 time on my reset button ... Is it normal ?
The power off button working fine every time. Using Reset in ES to restart ES is not working for me.
Your PID detection is impressive, it works with emulators and also OpenBOR :p -
@darknior said in Multi Switch Shutdown Script!:
Only one question, when i want to quit RetroArch to ES i must clic 3 time on my reset button ... Is it normal ?
The power off button working fine every time. Using Reset in ES to restart ES is not working for me.
Your PID detection is impressive, it works with emulators and also OpenBOR :pWell the detection of button press is just checked every 1 second. So you might press the button for a longer time.
The PID detection is introduced by runcommand script as entry point ;) And from this point I create PID array.
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.