1 // REQUIRES: armv7a
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 
6 static volatile uint32_t u32;
7 
get_cpsr()8 void get_cpsr() {
9     // CHECK-LABEL: <get_cpsr>:
10     // CHECK: mrs {{r[0-9]+}}, apsr
11     volatile uint32_t result = __get_CPSR();
12     // CHECK: {{(bx lr)|(pop {.*pc})}}
13 }
14 
set_cpsr()15 void set_cpsr() {
16     // CHECK-LABEL: <set_cpsr>:
17     // CHECK: msr CPSR_fc, {{r[0-9]+}}
18     __set_CPSR(u32);
19     // CHECK: {{(bx lr)|(pop {.*pc})}}
20 }
21 
get_mode()22 void get_mode() {
23     // CHECK-LABEL: <get_mode>:
24     // CHECK: mrs [[REG:r[0-9]+]], apsr
25     // CHECK: and [[REG]], [[REG]], #{{31|0x1f}}
26     volatile uint32_t result = __get_mode();
27     // CHECK: {{(bx lr)|(pop {.*pc})}}
28 }
29 
set_mode()30 void set_mode() {
31     // CHECK-LABEL: <set_mode>:
32     // CHECK: msr CPSR_c, {{r[0-9]+}}
33     __set_mode(u32);
34     // CHECK: {{(bx lr)|(pop {.*pc})}}
35 }
36