1 // REQUIRES: armv7a
2 // UNSUPPORTED: fpu
3 // 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
4
5 #include "cmsis_compiler.h"
6
7 static volatile uint32_t u32;
8
get_fpexc()9 void get_fpexc() {
10 // CHECK-LABEL: <get_fpexc>:
11 // CHECK-NOT: vmrs
12 // CHECK: mov {{r[0-9]+}}, #0
13 volatile uint32_t result = __get_FPEXC();
14 // CHECK: {{(bx lr)|(pop {.*pc})}}
15 }
16
set_fpexc()17 void set_fpexc() {
18 // CHECK-LABEL: <set_fpexc>:
19 // CHECK-NOT: vmsr
20 __set_FPEXC(u32);
21 // CHECK: {{(bx lr)|(pop {.*pc})}}
22 }
23