aboutsummaryrefslogtreecommitdiff
path: root/asm
diff options
context:
space:
mode:
authorGravatar Jonas Schievink <jonasschievink@gmail.com> 2020-08-31 23:19:01 +0200
committerGravatar Jonas Schievink <jonasschievink@gmail.com> 2020-10-13 21:31:36 +0200
commitd01bdda2fd40728810c2a989b248dd4f5d369a7b (patch)
tree9458e40d5f5c9dac727f25afbc34989971d333c6 /asm
parent10b29d3a4fc43503c25fb2c7ffbeaad44c2fb103 (diff)
downloadcortex-m-d01bdda2fd40728810c2a989b248dd4f5d369a7b.tar.gz
cortex-m-d01bdda2fd40728810c2a989b248dd4f5d369a7b.tar.zst
cortex-m-d01bdda2fd40728810c2a989b248dd4f5d369a7b.zip
Add __syscall assembly
Diffstat (limited to 'asm')
-rw-r--r--asm/inline.rs7
-rw-r--r--asm/lib.rs5
2 files changed, 10 insertions, 2 deletions
diff --git a/asm/inline.rs b/asm/inline.rs
index 9a0c66e..688604e 100644
--- a/asm/inline.rs
+++ b/asm/inline.rs
@@ -175,6 +175,13 @@ pub unsafe fn __wfi() {
asm!("wfi");
}
+/// Semihosting syscall.
+#[inline(always)]
+pub unsafe fn __syscall(mut nr: u32, arg: u32) -> u32 {
+ asm!("bkpt #0xab", inout("r0") nr, in("r1") arg);
+ nr
+}
+
// v7m *AND* v8m.main, but *NOT* v8m.base
#[cfg(any(armv7m, armv8m_main))]
pub use self::v7m::*;
diff --git a/asm/lib.rs b/asm/lib.rs
index 93d56fb..ec46d5b 100644
--- a/asm/lib.rs
+++ b/asm/lib.rs
@@ -46,7 +46,7 @@ macro_rules! shims {
pub unsafe extern "C" fn $name(
$($arg: $argty),*
) $(-> $ret)? {
- crate::inline::$name($($arg)*)
+ crate::inline::$name($($arg),*)
}
)+
};
@@ -72,9 +72,10 @@ shims! {
fn __udf();
fn __wfe();
fn __wfi();
+ fn __syscall(nr: u32, arg: u32) -> u32;
}
-// v7m *AND* v8m.main, but *NOT* v8m.base
+// v7m *AND* v8m.main, but *NOT* v8m.base
#[cfg(any(armv7m, armv8m_main))]
shims! {
fn __basepri_max(val: u8);