aboutsummaryrefslogtreecommitdiff
path: root/ctr-std
diff options
context:
space:
mode:
authorFenrir <[email protected]>2017-07-29 18:07:22 -0600
committerFenrir <[email protected]>2017-07-29 18:07:22 -0600
commit0a070b8ba99924e723684516aa60551c1e6caeb8 (patch)
tree5af143959da835901a59cdeffd4c2ac4ef39cb83 /ctr-std
parentMerge pull request #40 from FenrirWolf/thread-fix (diff)
downloadctru-rs-0a070b8ba99924e723684516aa60551c1e6caeb8.tar.xz
ctru-rs-0a070b8ba99924e723684516aa60551c1e6caeb8.zip
Trigger reboot after panicking
Diffstat (limited to 'ctr-std')
-rw-r--r--ctr-std/src/panicking.rs8
1 files 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<M: Any + Send + Display>(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<M: Any + Send + Display>(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()
}
}