xref: /llvm-project/clang/test/CodeGenCXX/arm-pcs.cpp (revision 2c3c9ca4ba26781b6331201511a21333c91da8b3)
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