// REQUIRES: arm-registered-target // RUN: %clang -target arm-none-none-eabihf -mcpu=cortex-r5 -mfpu=vfpv3-d16 -marm -S -o - %s \ // RUN: | FileCheck %s --check-prefix=CHECK-R // RUN: %clang -target arm-none-none-eabihf -mcpu=cortex-r5 -mfpu=vfpv3-d16 -mthumb -S -o - %s \ // RUN: | FileCheck %s --check-prefix=CHECK-R // RUN: %clang -target arm-none-none-eabihf -mcpu=cortex-r4 -mfpu=vfpv3-d16 -marm -S -o - %s \ // RUN: | FileCheck %s --check-prefix=CHECK-R // RUN: %clang -target arm-none-none-eabihf -mcpu=cortex-r4 -mfpu=vfpv3-d16 -mthumb -S -o - %s \ // RUN: | FileCheck %s --check-prefix=CHECK-R // RUN: %clang -target arm-none-none-eabihf -mcpu=cortex-m4 -mfpu=fpv4-sp-d16 -S -o - %s \ // RUN: | FileCheck %s --check-prefix=CHECK-M // RUN: %clang -target arm-none-none-eabihf -mcpu=cortex-m33 -mfpu=fpv5-sp-d16 -S -o - %s \ // RUN: | FileCheck %s --check-prefix=CHECK-M void bar(); __attribute__((interrupt_save_fp)) void test_generic_interrupt() { // CHECK-R: vmrs r4, fpscr // CHECK-R-NEXT: vmrs r5, fpexc // CHECK-R-NEXT: .save {r4, r5} // CHECK-R-NEXT: push {r4, r5} // ..... // CHECK-R: pop {r4, r5} // CHECK-R-NEXT: vmsr fpscr, r4 // CHECK-R-NEXT: vmsr fpexc, r5 // CHECK-M: vmrs r4, fpscr // CHECK-M-NEXT: .save {r4} // CHECK-M-NEXT: push {r4} // ..... // CHECK-M: pop {r4} // CHECK-M-NEXT: vmsr fpscr, r4 bar(); }