1 // REQUIRES: thumb-2, thumbv7m 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_basepri()6void get_basepri() { 7 // CHECK-LABEL: <get_basepri>: 8 // CHECK: mrs {{r[0-9]+}}, basepri 9 volatile uint32_t result = __get_BASEPRI(); 10 // CHECK: {{(bx lr)|(pop {.*pc})}} 11 } 12 get_basepri_ns()13void get_basepri_ns() { 14 // CHECK-LABEL: <get_basepri_ns>: 15 #if __ARM_FEATURE_CMSE == 3 16 // CHECK-S: mrs {{r[0-9]+}}, basepri_ns 17 volatile uint32_t result = __TZ_get_BASEPRI_NS(); 18 #endif 19 // CHECK: {{(bx lr)|(pop {.*pc})}} 20 } 21 set_basepri()22void set_basepri() { 23 // CHECK-LABEL: <set_basepri>: 24 // CHECK: msr basepri, {{r[0-9]+}} 25 __set_BASEPRI(0x0815u); 26 // CHECK: {{(bx lr)|(pop {.*pc})}} 27 } 28 set_basepri_ns()29void set_basepri_ns() { 30 // CHECK-LABEL: <set_basepri_ns>: 31 #if __ARM_FEATURE_CMSE == 3 32 // CHECK-S: msr basepri_ns, {{r[0-9]+}} 33 __TZ_set_BASEPRI_NS(0x0815u); 34 #endif 35 // CHECK: {{(bx lr)|(pop {.*pc})}} 36 } 37 set_basepri_max()38void set_basepri_max() { 39 // CHECK-LABEL: <set_basepri_max>: 40 // CHECK: msr basepri_max, {{r[0-9]+}} 41 __set_BASEPRI_MAX(0x0815u); 42 // CHECK: {{(bx lr)|(pop {.*pc})}} 43 } 44