mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-28 19:31:58 +00:00
7a3c3f3a96
If the original FPU specification involved a restricted VFP unit (d16), ensure that we reset the functionality when we encounter a new FPU type. In particular, if the user specified vfpv3-d16, but switched to a VFPv3 (which has 32 double precision registers), we would fail to reset the D16 feature, and treat it as being equivalent to vfpv3-d16. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@227603 91177308-0d34-0410-b5e6-96231b3b80d8
38 lines
1.2 KiB
ArmAsm
38 lines
1.2 KiB
ArmAsm
@ RUN: llvm-mc -triple armv4t-eabi -mattr +d16 -filetype asm -o - %s 2>&1 | FileCheck %s
|
|
|
|
.text
|
|
.thumb
|
|
|
|
.p2align 2
|
|
|
|
.fpu vfpv3
|
|
vldmia r0, {d16-d31}
|
|
@ CHECK: vldmia r0, {d16, d17, d18, d19, d20, d21, d22, d23, d24, d25, d26, d27, d28, d29, d30, d31}
|
|
@ CHECK-NOT: error: register expected
|
|
|
|
.fpu vfpv4
|
|
vldmia r0, {d16-d31}
|
|
@ CHECK: vldmia r0, {d16, d17, d18, d19, d20, d21, d22, d23, d24, d25, d26, d27, d28, d29, d30, d31}
|
|
@ CHECK-NOT: error: register expected
|
|
|
|
.fpu neon
|
|
vldmia r0, {d16-d31}
|
|
@ CHECK: vldmia r0, {d16, d17, d18, d19, d20, d21, d22, d23, d24, d25, d26, d27, d28, d29, d30, d31}
|
|
@ CHECK-NOT: error: register expected
|
|
|
|
.fpu neon-vfpv4
|
|
vldmia r0, {d16-d31}
|
|
@ CHECK: vldmia r0, {d16, d17, d18, d19, d20, d21, d22, d23, d24, d25, d26, d27, d28, d29, d30, d31}
|
|
@ CHECK-NOT: error: register expected
|
|
|
|
.fpu neon-fp-armv8
|
|
vldmia r0, {d16-d31}
|
|
@ CHECK: vldmia r0, {d16, d17, d18, d19, d20, d21, d22, d23, d24, d25, d26, d27, d28, d29, d30, d31}
|
|
@ CHECK-NOT: error: register expected
|
|
|
|
.fpu crypto-neon-fp-armv8
|
|
vldmia r0, {d16-d31}
|
|
@ CHECK: vldmia r0, {d16, d17, d18, d19, d20, d21, d22, d23, d24, d25, d26, d27, d28, d29, d30, d31}
|
|
@ CHECK-NOT: error: register expected
|
|
|