From 91d206380174ae2a31fc31962a9f04b9b813b40b Mon Sep 17 00:00:00 2001 From: Aemiii91 <44569252+Aemiii91@users.noreply.github.com> Date: Thu, 9 May 2024 23:08:11 +0200 Subject: [PATCH] FIX: Skip keymon's force shutdown if runtime is already shutting down --- src/keymon/keymon.c | 33 ++++++++++++++++++----------- static/build/.tmp_update/runtime.sh | 6 +++--- 2 files changed, 24 insertions(+), 15 deletions(-) diff --git a/src/keymon/keymon.c b/src/keymon/keymon.c index 1948249d21..703a6bef9c 100644 --- a/src/keymon/keymon.c +++ b/src/keymon/keymon.c @@ -8,13 +8,13 @@ #include #include #include +#include #include #include "system/axp.h" -#include "utils/msleep.h" -#include "system/display.h" #include "system/battery.h" #include "system/device_model.h" +#include "system/display.h" #include "system/keymap_hw.h" #include "system/osd.h" #include "system/rumble.h" @@ -29,6 +29,7 @@ #include "utils/file.h" #include "utils/flags.h" #include "utils/log.h" +#include "utils/msleep.h" #include "utils/process.h" #include "utils/str.h" @@ -176,7 +177,7 @@ void quit(int exitcode) // // Shutdown // -void shutdown(void) +void force_shutdown(void) { set_system_shutdown(); screenshot_system(); @@ -191,6 +192,14 @@ void shutdown(void) exit(0); } +void wait(int seconds) +{ + time_t t = time(NULL); + while ((time(NULL) - t) < seconds) { + sleep(1); + } +} + // // [onion] deepsleep if MainUI/gameSwitcher/retroarch is running // @@ -233,10 +242,11 @@ void deepsleep(void) terminate_drastic(); } - sleep(10); - // catch the resolution change signal on MMV4 - sleep(20); - shutdown(); + // Wait 30s before forcing a shutdown + wait(30); + if (!temp_flag_get("shutting_down")) { + force_shutdown(); + } } // @@ -327,9 +337,9 @@ void turnOffScreen(void) suspend_exec(stay_awake ? -1 : timeout); } -static void *runWritingSettingsThread(void* param) +static void *runWritingSettingsThread(void *param) { - bool *isWritingSettingsThreadActive = (bool*)param; + bool *isWritingSettingsThreadActive = (bool *)param; *isWritingSettingsThreadActive = true; settings_shm_write(); settings_save(); @@ -469,7 +479,7 @@ int main(void) else if (repeat_power >= REPEAT_SEC(5)) { short_pulse(); remove(CMD_TO_RUN_PATH); - shutdown(); // 10sec force shutdown + force_shutdown(); // 10sec force shutdown } break; } @@ -756,8 +766,7 @@ int main(void) if (settings_changed || needWriteSettings) { needWriteSettings = true; - if (!isWritingSettingsThreadActive) - { + if (!isWritingSettingsThreadActive) { needWriteSettings = false; pthread_create(&writingSettingsThread, NULL, runWritingSettingsThread, &isWritingSettingsThreadActive); } diff --git a/static/build/.tmp_update/runtime.sh b/static/build/.tmp_update/runtime.sh index 33db3006be..148a292632 100644 --- a/static/build/.tmp_update/runtime.sh +++ b/static/build/.tmp_update/runtime.sh @@ -543,6 +543,7 @@ launch_switcher() { check_off_order() { if [ -f /tmp/.offOrder ]; then + touch /tmp/shutting_down #EmuDeck - CheckOff scripts check_off_scripts=$(find "$sysdir/checkoff" -type f -name "*.sh") @@ -654,8 +655,8 @@ mute_theme_bgm() { } create_swap() { - swapfile="/mnt/SDCARD/cachefile" - if [ ! -e "$swapfile" ] ; then + swapfile="/mnt/SDCARD/cachefile" + if [ ! -e "$swapfile" ]; then log "Creating swap file" dd if=/dev/zero of="$swapfile" bs=1M count=128 mkswap "$swapfile" @@ -664,7 +665,6 @@ create_swap() { swapon "$swapfile" } - init_system() { log "\n:: Init system"