From 554fd8c5195424bdbcabf5de30fdc183aba391bd Mon Sep 17 00:00:00 2001 From: upstream source tree Date: Sun, 15 Mar 2015 20:14:05 -0400 Subject: obtained gcc-4.6.4.tar.bz2 from upstream website; verified gcc-4.6.4.tar.bz2.sig; imported gcc-4.6.4 source tree from verified upstream tarball. downloading a git-generated archive based on the 'upstream' tag should provide you with a source tree that is binary identical to the one extracted from the above tarball. if you have obtained the source via the command 'git clone', however, do note that line-endings of files in your working directory might differ from line-endings of the respective files in the upstream repository. --- gcc/testsuite/gcc.dg/fixed-point/func-vararg.c | 115 +++++++++++++++++++++++++ 1 file changed, 115 insertions(+) create mode 100644 gcc/testsuite/gcc.dg/fixed-point/func-vararg.c (limited to 'gcc/testsuite/gcc.dg/fixed-point/func-vararg.c') diff --git a/gcc/testsuite/gcc.dg/fixed-point/func-vararg.c b/gcc/testsuite/gcc.dg/fixed-point/func-vararg.c new file mode 100644 index 000000000..9f517ae52 --- /dev/null +++ b/gcc/testsuite/gcc.dg/fixed-point/func-vararg.c @@ -0,0 +1,115 @@ +/* { dg-do run } */ +/* { dg-options "-std=gnu99" } */ + +/* C99 6.5.2.2 Function calls. + Test passing varargs of fixed-point types. + Based on the test from ../dfp/. */ + +#include + +extern void abort (void); + +#define FUNC(TYPE, NAME) \ +static TYPE \ +vararg_ ## NAME (unsigned arg, ...) \ +{ \ + int i; \ + va_list ap; \ + TYPE result; \ + va_start (ap, arg); \ + for (i = 0; i <= arg; i++) \ + result = va_arg (ap, TYPE); \ + va_end (ap); \ + return result; \ +} + +FUNC (short _Fract, sf) +FUNC (_Fract, f) +FUNC (long _Fract, lf) +FUNC (long long _Fract, llf) +FUNC (unsigned short _Fract, usf) +FUNC (unsigned _Fract, uf) +FUNC (unsigned long _Fract, ulf) +FUNC (unsigned long long _Fract, ullf) +FUNC (_Sat short _Fract, Ssf) +FUNC (_Sat _Fract, Sf) +FUNC (_Sat long _Fract, Slf) +FUNC (_Sat long long _Fract, Sllf) +FUNC (_Sat unsigned short _Fract, Susf) +FUNC (_Sat unsigned _Fract, Suf) +FUNC (_Sat unsigned long _Fract, Sulf) +FUNC (_Sat unsigned long long _Fract, Sullf) +FUNC (short _Accum, sa) +FUNC (_Accum, a) +FUNC (long _Accum, la) +FUNC (long long _Accum, lla) +FUNC (unsigned short _Accum, usa) +FUNC (unsigned _Accum, ua) +FUNC (unsigned long _Accum, ula) +FUNC (unsigned long long _Accum, ulla) +FUNC (_Sat short _Accum, Ssa) +FUNC (_Sat _Accum, Sa) +FUNC (_Sat long _Accum, Sla) +FUNC (_Sat long long _Accum, Slla) +FUNC (_Sat unsigned short _Accum, Susa) +FUNC (_Sat unsigned _Accum, Sua) +FUNC (_Sat unsigned long _Accum, Sula) +FUNC (_Sat unsigned long long _Accum, Sulla) + +int main() +{ +#define TEST(NAME,PF) \ + if (vararg_ ## NAME (0, 0.0 ## PF, 0.1 ## PF, 0.2 ## PF, 0.3 ## PF, \ + 0.4 ## PF, 0.5 ## PF) != 0.0 ## PF) \ + abort (); \ + if (vararg_ ## NAME (1, 0.0 ## PF, 0.1 ## PF, 0.2 ## PF, 0.3 ## PF, \ + 0.4 ## PF, 0.5 ## PF) != 0.1 ## PF) \ + abort (); \ + if (vararg_ ## NAME (2, 0.0 ## PF, 0.1 ## PF, 0.2 ## PF, 0.3 ## PF, \ + 0.4 ## PF, 0.5 ## PF) != 0.2 ## PF) \ + abort (); \ + if (vararg_ ## NAME (3, 0.0 ## PF, 0.1 ## PF, 0.2 ## PF, 0.3 ## PF, \ + 0.4 ## PF, 0.5 ## PF) != 0.3 ## PF) \ + abort (); \ + if (vararg_ ## NAME (4, 0.0 ## PF, 0.1 ## PF, 0.2 ## PF, 0.3 ## PF, \ + 0.4 ## PF, 0.5 ## PF) != 0.4 ## PF) \ + abort (); \ + if (vararg_ ## NAME (5, 0.0 ## PF, 0.1 ## PF, 0.2 ## PF, 0.3 ## PF, \ + 0.4 ## PF, 0.5 ## PF) != 0.5 ## PF) \ + abort (); + + TEST(sf, hr) + TEST(f, r) + TEST(lf, lr) + TEST(llf, llr) + TEST(usf, uhr) + TEST(uf, ur) + TEST(ulf, ulr) + TEST(ullf, ullr) + TEST(Ssf, hr) + TEST(Sf, r) + TEST(Slf, lr) + TEST(Sllf, llr) + TEST(Susf, uhr) + TEST(Suf, ur) + TEST(Sulf, ulr) + TEST(Sullf, ullr) + TEST(sa, hk) + TEST(a, k) + TEST(la, lk) + TEST(lla, llk) + TEST(usa, uhk) + TEST(ua, uk) + TEST(ula, ulk) + TEST(ulla, ullk) + TEST(Ssa, hk) + TEST(Sa, k) + TEST(Sla, lk) + TEST(Slla, llk) + TEST(Susa, uhk) + TEST(Sua, uk) + TEST(Sula, ulk) + TEST(Sulla, ullk) + + return 0; +} -- cgit v1.2.3