summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.dg/fixed-point/func-vararg.c
blob: 9f517ae52630963d7b8ce2de8ec7ae38ece6cfb1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
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;
}