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"
6 static volatile uint32_t u32;
9 // CHECK-LABEL: <get_sp>:
10 // CHECK: mov {{r[0-9]+}}, sp
11 volatile uint32_t result = __get_SP();
12 // CHECK: {{(bx lr)|(pop {.*pc})}}
16 // CHECK-LABEL: <set_sp>:
17 // CHECK: mov sp, {{r[0-9]+}}
19 // CHECK: {{(bx lr)|(pop {.*pc})}}
23 // CHECK-LABEL: <get_sp_usr>:
24 // CHECK: mrs [[REG:r[0-9]+]], apsr
25 // CHECK: cps #{{31|0x1f}}
26 // CHECK: mov {{r[0-9]+}}, sp
27 // CHECK: msr CPSR_{{f?}}c, [[REG]]
28 volatile uint32_t result = __get_SP_usr();
29 // CHECK: {{(bx lr)|(pop {.*pc})}}
33 // CHECK-LABEL: <set_sp_usr>:
34 // CHECK: mrs [[REG:r[0-9]+]], apsr
35 // CHECK: cps #{{31|0x1f}}
36 // CHECK: mov sp, {{r[0-9]+}}
37 // CHECK: msr CPSR_{{f?}}c, [[REG]]
39 // CHECK: {{(bx lr)|(pop {.*pc})}}