78 lines
1.5 KiB
C
78 lines
1.5 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,
|
|
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();
|
|
}
|