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