aboutsummaryrefslogtreecommitdiff
path: root/cortex-m-rt/tests/compile-fail/exception-bad-signature-1.rs
diff options
context:
space:
mode:
authorGravatar bors[bot] <bors[bot]@users.noreply.github.com> 2018-09-06 00:44:19 +0000
committerGravatar bors[bot] <bors[bot]@users.noreply.github.com> 2018-09-06 00:44:19 +0000
commit7854e96f69f98570504c701ae860175efc7a25d9 (patch)
treeeaf897d43263606e24b6cca9f5f6620498648dc6 /cortex-m-rt/tests/compile-fail/exception-bad-signature-1.rs
parent0fb051055a0340ad6c5b59d18183c260468e455f (diff)
parent31713aba3f4a4aacd55d12b8a3435334ae61986a (diff)
downloadcortex-m-7854e96f69f98570504c701ae860175efc7a25d9.tar.gz
cortex-m-7854e96f69f98570504c701ae860175efc7a25d9.tar.zst
cortex-m-7854e96f69f98570504c701ae860175efc7a25d9.zip
Merge #90
90: turn macros into attributes r=adamgreig a=japaric This is a PoC implementation of RFC #82. Assuming that we are OK with this implementation we should add some compile fail tests (e.g. using a function with the wrong signature as the entry point) before landing this. Look at the diff of the examples to get an overview of the changes. cc @rust-embedded/cortex-m Co-authored-by: Jorge Aparicio <jorge@japaric.io>
Diffstat (limited to 'cortex-m-rt/tests/compile-fail/exception-bad-signature-1.rs')
-rw-r--r--cortex-m-rt/tests/compile-fail/exception-bad-signature-1.rs16
1 files changed, 16 insertions, 0 deletions
diff --git a/cortex-m-rt/tests/compile-fail/exception-bad-signature-1.rs b/cortex-m-rt/tests/compile-fail/exception-bad-signature-1.rs
new file mode 100644
index 0000000..966493e
--- /dev/null
+++ b/cortex-m-rt/tests/compile-fail/exception-bad-signature-1.rs
@@ -0,0 +1,16 @@
+#![no_main]
+#![no_std]
+
+extern crate cortex_m_rt;
+extern crate panic_semihosting;
+
+use cortex_m_rt::{entry, exception};
+
+#[entry]
+fn foo() -> ! {
+ loop {}
+}
+
+#[exception] //~ ERROR custom attribute panicked
+//~^ HELP `#[exception]` functions other than `DefaultHandler` and `HardFault` must have signature `[unsafe] fn() [-> !]`
+fn SysTick(undef: u32) {}