aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGravatar bors[bot] <26634292+bors[bot]@users.noreply.github.com> 2020-03-15 23:32:44 +0000
committerGravatar GitHub <noreply@github.com> 2020-03-15 23:32:44 +0000
commit66c83bb0342833394aa7a1a63a0987aa7cb72938 (patch)
tree97f3d745015a6841abc305e2296a5e4096d29a8c /src
parent8c5030ebcaf26af6f3882221670a4aaa2eb48fab (diff)
parent715e59506e3a4482500f252270b42f12e2498849 (diff)
downloadcortex-m-66c83bb0342833394aa7a1a63a0987aa7cb72938.tar.gz
cortex-m-66c83bb0342833394aa7a1a63a0987aa7cb72938.tar.zst
cortex-m-66c83bb0342833394aa7a1a63a0987aa7cb72938.zip
Merge #201
201: Add UDF instruction. Closes #199. r=jonas-schievink a=adamgreig Co-authored-by: Adam Greig <adam@adamgreig.com>
Diffstat (limited to 'src')
-rw-r--r--src/asm.rs29
1 files changed, 29 insertions, 0 deletions
diff --git a/src/asm.rs b/src/asm.rs
index 3d84341..b7ff19e 100644
--- a/src/asm.rs
+++ b/src/asm.rs
@@ -81,6 +81,35 @@ pub fn nop() {
}
}
+
+/// Generate an Undefined Instruction exception.
+///
+/// Can be used as a stable alternative to `core::intrinsics::abort`.
+#[inline]
+pub fn udf() -> ! {
+ match () {
+ #[cfg(all(cortex_m, feature = "inline-asm"))]
+ () => unsafe {
+ asm!("udf" :::: "volatile");
+ core::hint::unreachable_unchecked();
+ },
+
+ #[cfg(all(cortex_m, not(feature = "inline-asm")))]
+ () => unsafe {
+ extern "C" {
+ fn __udf();
+ }
+
+ __udf();
+
+ core::hint::unreachable_unchecked();
+ },
+
+ #[cfg(not(cortex_m))]
+ () => unimplemented!(),
+ }
+}
+
/// Wait For Event
#[inline]
pub fn wfe() {