1 // REQUIRES: thumb-2, thumbv7m
2 // RUN: %cc% %ccflags% %ccout% %s.o %s; llvm-objdump --mcpu=%mcpu% -d %s.o | FileCheck --allow-unused-prefixes --check-prefixes %prefixes% %s
4 #include "cmsis_compiler.h"
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})}}
13 void 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();
19 // CHECK: {{(bx lr)|(pop {.*pc})}}
23 // CHECK-LABEL: <set_basepri>:
24 // CHECK: msr basepri, {{r[0-9]+}}
25 __set_BASEPRI(0x0815u);
26 // CHECK: {{(bx lr)|(pop {.*pc})}}
29 void 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);
35 // CHECK: {{(bx lr)|(pop {.*pc})}}
38 void 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})}}