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
| /* Area: ffi_call
| Purpose: Check return value double, with many arguments
| Limitations: none.
| PR: none.
| Originator: From the original ffitest.c */
|
| /* { dg-do run } */
| #include "ffitest.h"
|
| #include <stdlib.h>
| #include <float.h>
| #include <math.h>
|
| static double many(double f1,
| double f2,
| double f3,
| double f4,
| double f5,
| double f6,
| double f7,
| double f8,
| double f9,
| double f10,
| double f11,
| double f12,
| double f13)
| {
| #if 0
| printf("%f %f %f %f %f %f %f %f %f %f %f %f %f\n",
| (double) f1, (double) f2, (double) f3, (double) f4, (double) f5,
| (double) f6, (double) f7, (double) f8, (double) f9, (double) f10,
| (double) f11, (double) f12, (double) f13);
| #endif
|
| return ((f1/f2+f3/f4+f5/f6+f7/f8+f9/f10+f11/f12) * f13);
| }
|
| int main (void)
| {
| ffi_cif cif;
| ffi_type *args[13];
| void *values[13];
| double fa[13];
| double f, ff;
| int i;
|
| for (i = 0; i < 13; i++)
| {
| args[i] = &ffi_type_double;
| values[i] = &fa[i];
| fa[i] = (double) i;
| }
|
| /* Initialize the cif */
| CHECK(ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 13,
| &ffi_type_double, args) == FFI_OK);
|
| ffi_call(&cif, FFI_FN(many), &f, values);
|
| ff = many(fa[0], fa[1],
| fa[2], fa[3],
| fa[4], fa[5],
| fa[6], fa[7],
| fa[8], fa[9],
| fa[10],fa[11],fa[12]);
| if (fabs(f - ff) < FLT_EPSILON)
| exit(0);
| else
| abort();
| }
|
|