1 /* Area:	ffi_call
2    Purpose:	Check return value float.
3    Limitations:	none.
4    PR:		none.
5    Originator:	<andreast@gcc.gnu.org> 20050212  */
6 
7 /* { dg-do run } */
8 #include "ffitest.h"
9 
10 /* Use volatile float to avoid false negative on ix86.  See PR target/323.  */
return_fl(float fl1,float fl2,float fl3,float fl4)11 static float return_fl(float fl1, float fl2, float fl3, float fl4)
12 {
13   volatile float sum;
14 
15   sum = fl1 + fl2 + fl3 + fl4;
16   return sum;
17 }
main(void)18 int main (void)
19 {
20   ffi_cif cif;
21   ffi_type *args[MAX_ARGS];
22   void *values[MAX_ARGS];
23   float fl1, fl2, fl3, fl4, rfl;
24   volatile float sum;
25 
26   args[0] = &ffi_type_float;
27   args[1] = &ffi_type_float;
28   args[2] = &ffi_type_float;
29   args[3] = &ffi_type_float;
30   values[0] = &fl1;
31   values[1] = &fl2;
32   values[2] = &fl3;
33   values[3] = &fl4;
34 
35   /* Initialize the cif */
36   CHECK(ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 4,
37 		     &ffi_type_float, args) == FFI_OK);
38   fl1 = 127.0;
39   fl2 = 128.0;
40   fl3 = 255.1;
41   fl4 = 512.7;
42 
43   ffi_call(&cif, FFI_FN(return_fl), &rfl, values);
44   printf ("%f vs %f\n", rfl, return_fl(fl1, fl2, fl3, fl4));
45 
46   sum = fl1 + fl2 + fl3 + fl4;
47   CHECK(rfl == sum);
48   exit(0);
49 }
50