1 // REQUIRES: thumbv6m
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_control()6 void get_control() {
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})}}
11 }
12 
get_control_ns()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();
18 #endif
19     // CHECK: {{(bx lr)|(pop {.*pc})}}
20 }
21 
22 volatile uint32_t v32 = 0x4711u;
23 
set_control()24 void set_control() {
25     // CHECK-LABEL: <set_control>:
26     // CHECK: msr control, {{r[0-9]+}}
27     __set_CONTROL(v32);
28     // CHECK: {{(bx lr)|(pop {.*pc})}}
29 }
30 
set_control_ns()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);
36 #endif
37     // CHECK: {{(bx lr)|(pop {.*pc})}}
38 }
39 
40