1*2c3c9ca4SCarey Williams // Covers a bug fix for ABI selection with homogenous aggregates:
2*2c3c9ca4SCarey Williams // See: https://bugs.llvm.org/show_bug.cgi?id=39982
3*2c3c9ca4SCarey Williams
4*2c3c9ca4SCarey Williams // REQUIRES: arm-registered-target
5*2c3c9ca4SCarey Williams // RUN: %clang -mfloat-abi=hard --target=armv7-unknown-linux-gnueabi -O3 -S -o - %s | FileCheck %s -check-prefixes=HARD,CHECK
6*2c3c9ca4SCarey Williams // RUN: %clang -mfloat-abi=softfp --target=armv7-unknown-linux-gnueabi -O3 -S -o - %s | FileCheck %s -check-prefixes=SOFTFP,CHECK
7*2c3c9ca4SCarey Williams // RUN: %clang -mfloat-abi=soft --target=armv7-unknown-linux-gnueabi -O3 -S -o - %s | FileCheck %s -check-prefixes=SOFT,CHECK
8*2c3c9ca4SCarey Williams
9*2c3c9ca4SCarey Williams struct S {
10*2c3c9ca4SCarey Williams float f;
11*2c3c9ca4SCarey Williams float d;
12*2c3c9ca4SCarey Williams float c;
13*2c3c9ca4SCarey Williams float t;
14*2c3c9ca4SCarey Williams };
15*2c3c9ca4SCarey Williams
16*2c3c9ca4SCarey Williams // Variadic functions should always marshal for the base standard.
17*2c3c9ca4SCarey Williams // See section 5.5 (Parameter Passing) of the AAPCS.
variadic(S s,...)18*2c3c9ca4SCarey Williams float __attribute__((pcs("aapcs-vfp"))) variadic(S s, ...) {
19*2c3c9ca4SCarey Williams // CHECK-NOT: vmov s{{[0-9]+}}, s{{[0-9]+}}
20*2c3c9ca4SCarey Williams // CHECK: mov r{{[0-9]+}}, r{{[0-9]+}}
21*2c3c9ca4SCarey Williams return s.d;
22*2c3c9ca4SCarey Williams }
23*2c3c9ca4SCarey Williams
no_attribute(S s)24*2c3c9ca4SCarey Williams float no_attribute(S s) {
25*2c3c9ca4SCarey Williams // SOFT: mov r{{[0-9]+}}, r{{[0-9]+}}
26*2c3c9ca4SCarey Williams // SOFTFP: mov r{{[0-9]+}}, r{{[0-9]+}}
27*2c3c9ca4SCarey Williams // HARD: vmov.f32 s{{[0-9]+}}, s{{[0-9]+}}
28*2c3c9ca4SCarey Williams return s.d;
29*2c3c9ca4SCarey Williams }
30*2c3c9ca4SCarey Williams
baz(float x,float y)31*2c3c9ca4SCarey Williams float __attribute__((pcs("aapcs-vfp"))) baz(float x, float y) {
32*2c3c9ca4SCarey Williams // CHECK-NOT: mov s{{[0-9]+}}, r{{[0-9]+}}
33*2c3c9ca4SCarey Williams // SOFT: mov r{{[0-9]+}}, r{{[0-9]+}}
34*2c3c9ca4SCarey Williams // SOFTFP: vmov.f32 s{{[0-9]+}}, s{{[0-9]+}}
35*2c3c9ca4SCarey Williams // HARD: vmov.f32 s{{[0-9]+}}, s{{[0-9]+}}
36*2c3c9ca4SCarey Williams return y;
37*2c3c9ca4SCarey Williams }
38*2c3c9ca4SCarey Williams
foo(S s)39*2c3c9ca4SCarey Williams float __attribute__((pcs("aapcs-vfp"))) foo(S s) {
40*2c3c9ca4SCarey Williams // CHECK-NOT: mov s{{[0-9]+}}, r{{[0-9]+}}
41*2c3c9ca4SCarey Williams // SOFT: mov r{{[0-9]+}}, r{{[0-9]+}}
42*2c3c9ca4SCarey Williams // SOFTFP: vmov.f32 s{{[0-9]+}}, s{{[0-9]+}}
43*2c3c9ca4SCarey Williams // HARD: vmov.f32 s{{[0-9]+}}, s{{[0-9]+}}
44*2c3c9ca4SCarey Williams return s.d;
45*2c3c9ca4SCarey Williams }
46*2c3c9ca4SCarey Williams
bar(S s)47*2c3c9ca4SCarey Williams float __attribute__((pcs("aapcs"))) bar(S s) {
48*2c3c9ca4SCarey Williams // CHECK-NOT: vmov.f32 s{{[0-9]+}}, s{{[0-9]+}}
49*2c3c9ca4SCarey Williams // CHECK: mov r{{[0-9]+}}, r{{[0-9]+}}
50*2c3c9ca4SCarey Williams return s.d;
51*2c3c9ca4SCarey Williams }
52