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 | 3b2dd4368af13a861bb80591495afb68a40ad808 (patch) | |
| tree | 188a086d5afb10b8b6cdabcf2829609cd2204bfa /clang/test/CodeGen/parameter-passing.c | |
| parent | 5d3dbd64e116f858dbc2b7d24e5cdaa19d076ed5 (diff) | |
| download | bcm5719-llvm-3b2dd4368af13a861bb80591495afb68a40ad808.tar.gz bcm5719-llvm-3b2dd4368af13a861bb80591495afb68a40ad808.zip | |
Add bare bones test that parameter passing is consistent for
scalar/complex/aggregate cases.
- Currently disabled for x86_64, triggering a misoptimization
(PR3489).
llvm-svn: 63864
Diffstat (limited to 'clang/test/CodeGen/parameter-passing.c')
| -rw-r--r-- | clang/test/CodeGen/parameter-passing.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/clang/test/CodeGen/parameter-passing.c b/clang/test/CodeGen/parameter-passing.c new file mode 100644 index 00000000000..637a2de42c8 --- /dev/null +++ b/clang/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(); +} + |

