From 0a070b8ba99924e723684516aa60551c1e6caeb8 Mon Sep 17 00:00:00 2001 From: Fenrir Date: Sat, 29 Jul 2017 18:07:22 -0600 Subject: [PATCH] Trigger reboot after panicking --- ctr-std/src/panicking.rs | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/ctr-std/src/panicking.rs b/ctr-std/src/panicking.rs index 8d28317..26914ce 100644 --- a/ctr-std/src/panicking.rs +++ b/ctr-std/src/panicking.rs @@ -111,7 +111,8 @@ pub fn begin_panic(msg: M, file_line_col: &(&'static st let (file, line, col) = *file_line_col; // 3DS-specific code begins here - use libctru::{errorInit, errorText, errorDisp, svcExitProcess, threadGetCurrent, + use libctru::{errorInit, errorText, errorDisp, + APT_HardwareResetAsync, svcExitProcess, threadGetCurrent, errorConf, errorType, CFG_Language}; use libc; @@ -135,7 +136,10 @@ pub fn begin_panic(msg: M, file_line_col: &(&'static st errorDisp(&mut error_conf); // Now that we're all done printing, it's time to exit the program. - // We don't have stack unwinding yet, so we just forcibly end the process + // We don't have stack unwinding yet, so let's just trigger a reboot + APT_HardwareResetAsync(); + + // If rebooting fails for some reason, we extra-forcibly end the program svcExitProcess() } }