aboutsummaryrefslogtreecommitdiff
path: root/ctr-std/src/sys_common/util.rs
diff options
context:
space:
mode:
authorRonald Kinard <[email protected]>2017-03-11 23:20:34 -0600
committerGitHub <[email protected]>2017-03-11 23:20:34 -0600
commit368ee624e72342db4b142946ae0f4e3443bdf0d4 (patch)
tree8ed882bdd90d8d7a7f00cef25a99e06ed0ed2cc6 /ctr-std/src/sys_common/util.rs
parentMerge pull request #24 from FenrirWolf/unit_type (diff)
parentBump minimum thread stack size (diff)
downloadctru-rs-368ee624e72342db4b142946ae0f4e3443bdf0d4.tar.xz
ctru-rs-368ee624e72342db4b142946ae0f4e3443bdf0d4.zip
Merge pull request #26 from FenrirWolf/thread
Initial thread support
Diffstat (limited to 'ctr-std/src/sys_common/util.rs')
-rw-r--r--ctr-std/src/sys_common/util.rs49
1 files changed, 49 insertions, 0 deletions
diff --git a/ctr-std/src/sys_common/util.rs b/ctr-std/src/sys_common/util.rs
new file mode 100644
index 0000000..aad0680
--- /dev/null
+++ b/ctr-std/src/sys_common/util.rs
@@ -0,0 +1,49 @@
+// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+use fmt;
+use io::prelude::*;
+use sync::atomic::{self, Ordering};
+use sys::stdio::Stderr;
+
+pub fn min_stack() -> usize {
+ static MIN: atomic::AtomicUsize = atomic::AtomicUsize::new(0);
+ match MIN.load(Ordering::SeqCst) {
+ 0 => {}
+ n => return n - 1,
+ }
+
+ // NOTE: We don't have env variable support on the 3DS so let's just use the
+ // default minimum
+
+ // let amt = env::var("RUST_MIN_STACK").ok().and_then(|s| s.parse().ok());
+ // let amt = amt.unwrap_or(2 * 1024 * 1024);
+
+ let amt = 2 * 1024 * 1024;
+
+ // 0 is our sentinel value, so ensure that we'll never see 0 after
+ // initialization has run
+ MIN.store(amt + 1, Ordering::SeqCst);
+ amt
+}
+
+pub fn dumb_print(args: fmt::Arguments) {
+ let _ = Stderr::new().map(|mut stderr| stderr.write_fmt(args));
+}
+
+// Other platforms should use the appropriate platform-specific mechanism for
+// aborting the process. If no platform-specific mechanism is available,
+// ::intrinsics::abort() may be used instead. The above implementations cover
+// all targets currently supported by libstd.
+
+pub fn abort(args: fmt::Arguments) -> ! {
+ dumb_print(format_args!("fatal runtime error: {}\n", args));
+ unsafe { ::sys::abort_internal(); }
+}