aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/restricted/libffi/testsuite/libffi.call/many.c
blob: e3b34f45ab05cb89fb0670658603c5d38e050036 (plain) (blame)
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
/* Area:	ffi_call 
   Purpose:	Check return value float, 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 float ABI_ATTR 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) 
{ 
#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]; 
  float fa[13]; 
  float f, ff; 
  int i; 
 
  for (i = 0; i < 13; i++) 
    { 
      args[i] = &ffi_type_float; 
      values[i] = &fa[i]; 
      fa[i] = (float) i; 
    } 
 
    /* Initialize the cif */ 
    CHECK(ffi_prep_cif(&cif, ABI_NUM, 13, 
		       &ffi_type_float, 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(); 
}