1 // REQUIRES: thumbv8m.base 2 // RUN: %cc% %ccflags% %ccout% %T/%basename_t.o %s; llvm-objdump --mcpu=%mcpu% -d %T/%basename_t.o | FileCheck --allow-unused-prefixes --check-prefixes %prefixes% %s 3 4 #include "cmsis_compiler.h" 5 get_sp_ns()6void get_sp_ns() { 7 // CHECK-LABEL: <get_sp_ns>: 8 #if __ARM_FEATURE_CMSE == 3 9 // CHECK-S: mrs {{r[0-9]+}}, sp_ns 10 volatile uint32_t result = __TZ_get_SP_NS(); 11 #endif 12 // CHECK: {{(bx lr)|(pop {.*pc})}} 13 } 14 set_sp_ns()15void set_sp_ns() { 16 // CHECK-LABEL: <set_sp_ns>: 17 #if __ARM_FEATURE_CMSE == 3 18 // CHECK-S: msr sp_ns, {{r[0-9]+}} 19 __TZ_set_SP_NS(0x0815u); 20 #endif 21 // CHECK: {{(bx lr)|(pop {.*pc})}} 22 } 23