71 lines
1.4 KiB
C
71 lines
1.4 KiB
C
|
/* 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();
|
||
|
}
|