aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.9/gcc/testsuite/gcc.dg/fixed-point/func-vararg.c
diff options
context:
space:
mode:
Diffstat (limited to 'gcc-4.9/gcc/testsuite/gcc.dg/fixed-point/func-vararg.c')
-rw-r--r--gcc-4.9/gcc/testsuite/gcc.dg/fixed-point/func-vararg.c115
1 files changed, 115 insertions, 0 deletions
diff --git a/gcc-4.9/gcc/testsuite/gcc.dg/fixed-point/func-vararg.c b/gcc-4.9/gcc/testsuite/gcc.dg/fixed-point/func-vararg.c
new file mode 100644
index 000000000..9f517ae52
--- /dev/null
+++ b/gcc-4.9/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 <stdarg.h>
+
+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;
+}