diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-02-05 11:21:33 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-02-05 11:21:33 +0000 |
commit | c216edbcc760e7b2dc7cb652f179f96b0bcde17c (patch) | |
tree | 77a2ad5679083d87588516889fa71fcff259fac6 | |
parent | 2fbf2f547cf23c0dd89719c2b5c5d6c6f0fa469c (diff) |
Add bare bones test that parameter passing is consistent for
scalar/complex/aggregate cases.
- Currently disabled for x86_64, triggering a misoptimization
(PR3489).
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@63864 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | test/CodeGen/parameter-passing.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/test/CodeGen/parameter-passing.c b/test/CodeGen/parameter-passing.c new file mode 100644 index 0000000000..637a2de42c --- /dev/null +++ b/test/CodeGen/parameter-passing.c @@ -0,0 +1,45 @@ +// Check the various ways in which the three classes of values +// (scalar, complex, aggregate) interact with parameter passing +// (function entry, function return, call argument, call result). + +// RUN: clang %s -triple i386-unknown-unknown -O3 -emit-llvm -o %t && +// RUN: not grep '@g0' %t && + +// FIXME: Enable once PR3489 is fixed. +// RUNX: clang %s -triple x86_64-unknown-unknown -O3 -emit-llvm -o %t && +// RUNX: not grep '@g0' %t && + +// RUN: clang %s -triple ppc-unknown-unknown -O3 -emit-llvm -o %t && +// RUN: not grep '@g0' %t && +// RUN: true + +typedef int ScalarTy; +typedef _Complex int ComplexTy; +typedef struct { int a, b, c; } AggrTy; + +static int result; + +static AggrTy aggr_id(AggrTy a) { return a; } +static ScalarTy scalar_id(ScalarTy a) { return a; } +static ComplexTy complex_id(ComplexTy a) { return a; } + +static void aggr_mul(AggrTy a) { result *= a.a * a.b * a.c; } + +static void scalar_mul(ScalarTy a) { result *= a; } + +static void complex_mul(ComplexTy a) { result *= __real a * __imag a; } + +extern void g0(void); + +void f0(void) { + result = 1; + + aggr_mul(aggr_id((AggrTy) { 2, 3, 5})); + scalar_mul(scalar_id(7)); + complex_mul(complex_id(11 + 13i)); + + // This call should be eliminated. + if (result != 30030) + g0(); +} + |