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()6 void 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()15 void 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