1 /* Area: ffi_call
2 Purpose: Check return value float, with many arguments
3 Limitations: none.
4 PR: none.
5 Originator: From the original ffitest.c */
6
7 /* { dg-do run } */
8 #include "ffitest.h"
9
10 #include <float.h>
11
many(float f1,float f2,float f3,float f4,float f5,float f6,float f7,float f8,float f9,float f10,float f11,float f12,float f13)12 static float many(float f1,
13 float f2,
14 float f3,
15 float f4,
16 float f5,
17 float f6,
18 float f7,
19 float f8,
20 float f9,
21 float f10,
22 float f11,
23 float f12,
24 float f13)
25 {
26 #if 0
27 printf("%f %f %f %f %f %f %f %f %f %f %f %f %f\n",
28 (double) f1, (double) f2, (double) f3, (double) f4, (double) f5,
29 (double) f6, (double) f7, (double) f8, (double) f9, (double) f10,
30 (double) f11, (double) f12, (double) f13);
31 #endif
32
33 return ((f1/f2+f3/f4+f5/f6+f7/f8+f9/f10+f11/f12) * f13);
34 }
35
main(void)36 int main (void)
37 {
38 ffi_cif cif;
39 ffi_type *args[13];
40 void *values[13];
41 float fa[13];
42 float f, ff;
43 int i;
44
45 for (i = 0; i < 13; i++)
46 {
47 args[i] = &ffi_type_float;
48 values[i] = &fa[i];
49 fa[i] = (float) i;
50 }
51
52 /* Initialize the cif */
53 CHECK(ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 13,
54 &ffi_type_float, args) == FFI_OK);
55
56 ffi_call(&cif, FFI_FN(many), &f, values);
57
58 ff = many(fa[0], fa[1],
59 fa[2], fa[3],
60 fa[4], fa[5],
61 fa[6], fa[7],
62 fa[8], fa[9],
63 fa[10],fa[11],fa[12]);
64
65 if (f - ff < FLT_EPSILON)
66 exit(0);
67 else
68 abort();
69 }
70