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
| /* 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,
| long int i1,
| double f3,
| double f4,
| long int i2,
| double f5,
| double f6,
| long int i3,
| double f7,
| double f8,
| long int i4,
| double f9,
| double f10,
| long int i5,
| double f11,
| double f12,
| long int i6,
| double f13)
| {
| return ((double) (i1 + i2 + i3 + i4 + i5 + i6) + (f1/f2+f3/f4+f5/f6+f7/f8+f9/f10+f11/f12) * f13);
| }
|
| int main (void)
| {
| ffi_cif cif;
| ffi_type *args[19];
| void *values[19];
| double fa[19];
| long int la[19];
| double f, ff;
| int i;
|
| for (i = 0; i < 19; i++)
| {
| if( (i - 2) % 3 == 0) {
| args[i] = &ffi_type_slong;
| la[i] = (long int) i;
| values[i] = &la[i];
| }
| else {
| args[i] = &ffi_type_double;
| fa[i] = (double) i;
| values[i] = &fa[i];
| }
| }
|
| /* Initialize the cif */
| CHECK(ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 19,
| &ffi_type_double, args) == FFI_OK);
|
| ffi_call(&cif, FFI_FN(many), &f, values);
|
| ff = many(fa[0], fa[1], la[2],
| fa[3], fa[4], la[5],
| fa[6], fa[7], la[8],
| fa[9], fa[10], la[11],
| fa[12], fa[13], la[14],
| fa[15], fa[16], la[17],
| fa[18]);
| if (fabs(f - ff) < FLT_EPSILON)
| exit(0);
| else
| abort();
| }
|
|