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
4 #include "cmsis_compiler.h"
7 // CHECK-LABEL: <get_control>:
8 // CHECK: mrs {{r[0-9]+}}, control
9 volatile uint32_t result = __get_CONTROL();
10 // CHECK: {{(bx lr)|(pop {.*pc})}}
13 void get_control_ns() {
14 // CHECK-LABEL: <get_control_ns>:
15 #if __ARM_FEATURE_CMSE == 3
16 // CHECK-S: mrs {{r[0-9]+}}, control_ns
17 volatile uint32_t result = __TZ_get_CONTROL_NS();
19 // CHECK: {{(bx lr)|(pop {.*pc})}}
22 volatile uint32_t v32 = 0x4711u;
25 // CHECK-LABEL: <set_control>:
26 // CHECK: msr control, {{r[0-9]+}}
28 // CHECK: {{(bx lr)|(pop {.*pc})}}
31 void set_control_ns() {
32 // CHECK-LABEL: <set_control_ns>:
33 #if __ARM_FEATURE_CMSE == 3
34 // CHECK-S: msr control_ns, {{r[0-9]+}}
35 __TZ_set_CONTROL_NS(v32);
37 // CHECK: {{(bx lr)|(pop {.*pc})}}