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()6void 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()13void 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()24void 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()31void 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