xref: /aosp_15_r20/external/libffi/testsuite/libffi.call/float_va.c (revision 1fd5a2e1d639cd1ddf29dd0c484c123bbd850c21)
1*1fd5a2e1SPrashanth Swaminathan /* Area:        fp and variadics
2*1fd5a2e1SPrashanth Swaminathan    Purpose:     check fp inputs and returns work on variadics, even the fixed params
3*1fd5a2e1SPrashanth Swaminathan    Limitations: None
4*1fd5a2e1SPrashanth Swaminathan    PR:          none
5*1fd5a2e1SPrashanth Swaminathan    Originator:  <[email protected]> 2011-01-25
6*1fd5a2e1SPrashanth Swaminathan 
7*1fd5a2e1SPrashanth Swaminathan    Intended to stress the difference in ABI on ARM vfp
8*1fd5a2e1SPrashanth Swaminathan */
9*1fd5a2e1SPrashanth Swaminathan 
10*1fd5a2e1SPrashanth Swaminathan /* { dg-do run } */
11*1fd5a2e1SPrashanth Swaminathan 
12*1fd5a2e1SPrashanth Swaminathan #include <stdarg.h>
13*1fd5a2e1SPrashanth Swaminathan 
14*1fd5a2e1SPrashanth Swaminathan #include "ffitest.h"
15*1fd5a2e1SPrashanth Swaminathan 
16*1fd5a2e1SPrashanth Swaminathan /* prints out all the parameters, and returns the sum of them all.
17*1fd5a2e1SPrashanth Swaminathan  * 'x' is the number of variadic parameters all of which are double in this test
18*1fd5a2e1SPrashanth Swaminathan  */
float_va_fn(unsigned int x,double y,...)19*1fd5a2e1SPrashanth Swaminathan double float_va_fn(unsigned int x, double y,...)
20*1fd5a2e1SPrashanth Swaminathan {
21*1fd5a2e1SPrashanth Swaminathan   double total=0.0;
22*1fd5a2e1SPrashanth Swaminathan   va_list ap;
23*1fd5a2e1SPrashanth Swaminathan   unsigned int i;
24*1fd5a2e1SPrashanth Swaminathan 
25*1fd5a2e1SPrashanth Swaminathan   total+=(double)x;
26*1fd5a2e1SPrashanth Swaminathan   total+=y;
27*1fd5a2e1SPrashanth Swaminathan 
28*1fd5a2e1SPrashanth Swaminathan   printf("%u: %.1f :", x, y);
29*1fd5a2e1SPrashanth Swaminathan 
30*1fd5a2e1SPrashanth Swaminathan   va_start(ap, y);
31*1fd5a2e1SPrashanth Swaminathan   for(i=0;i<x;i++)
32*1fd5a2e1SPrashanth Swaminathan   {
33*1fd5a2e1SPrashanth Swaminathan     double arg=va_arg(ap, double);
34*1fd5a2e1SPrashanth Swaminathan     total+=arg;
35*1fd5a2e1SPrashanth Swaminathan     printf(" %d:%.1f ", i, arg);
36*1fd5a2e1SPrashanth Swaminathan   }
37*1fd5a2e1SPrashanth Swaminathan   va_end(ap);
38*1fd5a2e1SPrashanth Swaminathan 
39*1fd5a2e1SPrashanth Swaminathan   printf(" total: %.1f\n", total);
40*1fd5a2e1SPrashanth Swaminathan 
41*1fd5a2e1SPrashanth Swaminathan   return total;
42*1fd5a2e1SPrashanth Swaminathan }
43*1fd5a2e1SPrashanth Swaminathan 
main(void)44*1fd5a2e1SPrashanth Swaminathan int main (void)
45*1fd5a2e1SPrashanth Swaminathan {
46*1fd5a2e1SPrashanth Swaminathan   ffi_cif    cif;
47*1fd5a2e1SPrashanth Swaminathan 
48*1fd5a2e1SPrashanth Swaminathan   ffi_type    *arg_types[5];
49*1fd5a2e1SPrashanth Swaminathan   void        *values[5];
50*1fd5a2e1SPrashanth Swaminathan   double        doubles[5];
51*1fd5a2e1SPrashanth Swaminathan   unsigned int firstarg;
52*1fd5a2e1SPrashanth Swaminathan   double        resfp;
53*1fd5a2e1SPrashanth Swaminathan 
54*1fd5a2e1SPrashanth Swaminathan   /* First test, pass float_va_fn(0,2.0) - note there are no actual
55*1fd5a2e1SPrashanth Swaminathan    * variadic parameters, but it's declared variadic so the ABI may be
56*1fd5a2e1SPrashanth Swaminathan    * different. */
57*1fd5a2e1SPrashanth Swaminathan   /* Call it statically and then via ffi */
58*1fd5a2e1SPrashanth Swaminathan   resfp=float_va_fn(0,2.0);
59*1fd5a2e1SPrashanth Swaminathan   /* { dg-output "0: 2.0 : total: 2.0" } */
60*1fd5a2e1SPrashanth Swaminathan   printf("compiled: %.1f\n", resfp);
61*1fd5a2e1SPrashanth Swaminathan   /* { dg-output "\ncompiled: 2.0" } */
62*1fd5a2e1SPrashanth Swaminathan 
63*1fd5a2e1SPrashanth Swaminathan   arg_types[0] = &ffi_type_uint;
64*1fd5a2e1SPrashanth Swaminathan   arg_types[1] = &ffi_type_double;
65*1fd5a2e1SPrashanth Swaminathan   arg_types[2] = NULL;
66*1fd5a2e1SPrashanth Swaminathan   CHECK(ffi_prep_cif_var(&cif, FFI_DEFAULT_ABI, 2, 2,
67*1fd5a2e1SPrashanth Swaminathan         &ffi_type_double, arg_types) == FFI_OK);
68*1fd5a2e1SPrashanth Swaminathan 
69*1fd5a2e1SPrashanth Swaminathan   firstarg = 0;
70*1fd5a2e1SPrashanth Swaminathan   doubles[0] = 2.0;
71*1fd5a2e1SPrashanth Swaminathan   values[0] = &firstarg;
72*1fd5a2e1SPrashanth Swaminathan   values[1] = &doubles[0];
73*1fd5a2e1SPrashanth Swaminathan   ffi_call(&cif, FFI_FN(float_va_fn), &resfp, values);
74*1fd5a2e1SPrashanth Swaminathan   /* { dg-output "\n0: 2.0 : total: 2.0" } */
75*1fd5a2e1SPrashanth Swaminathan   printf("ffi: %.1f\n", resfp);
76*1fd5a2e1SPrashanth Swaminathan   /* { dg-output "\nffi: 2.0" } */
77*1fd5a2e1SPrashanth Swaminathan 
78*1fd5a2e1SPrashanth Swaminathan   /* Second test, float_va_fn(2,2.0,3.0,4.0), now with variadic params */
79*1fd5a2e1SPrashanth Swaminathan   /* Call it statically and then via ffi */
80*1fd5a2e1SPrashanth Swaminathan   resfp=float_va_fn(2,2.0,3.0,4.0);
81*1fd5a2e1SPrashanth Swaminathan   /* { dg-output "\n2: 2.0 : 0:3.0  1:4.0  total: 11.0" } */
82*1fd5a2e1SPrashanth Swaminathan   printf("compiled: %.1f\n", resfp);
83*1fd5a2e1SPrashanth Swaminathan   /* { dg-output "\ncompiled: 11.0" } */
84*1fd5a2e1SPrashanth Swaminathan 
85*1fd5a2e1SPrashanth Swaminathan   arg_types[0] = &ffi_type_uint;
86*1fd5a2e1SPrashanth Swaminathan   arg_types[1] = &ffi_type_double;
87*1fd5a2e1SPrashanth Swaminathan   arg_types[2] = &ffi_type_double;
88*1fd5a2e1SPrashanth Swaminathan   arg_types[3] = &ffi_type_double;
89*1fd5a2e1SPrashanth Swaminathan   arg_types[4] = NULL;
90*1fd5a2e1SPrashanth Swaminathan   CHECK(ffi_prep_cif_var(&cif, FFI_DEFAULT_ABI, 2, 4,
91*1fd5a2e1SPrashanth Swaminathan         &ffi_type_double, arg_types) == FFI_OK);
92*1fd5a2e1SPrashanth Swaminathan 
93*1fd5a2e1SPrashanth Swaminathan   firstarg = 2;
94*1fd5a2e1SPrashanth Swaminathan   doubles[0] = 2.0;
95*1fd5a2e1SPrashanth Swaminathan   doubles[1] = 3.0;
96*1fd5a2e1SPrashanth Swaminathan   doubles[2] = 4.0;
97*1fd5a2e1SPrashanth Swaminathan   values[0] = &firstarg;
98*1fd5a2e1SPrashanth Swaminathan   values[1] = &doubles[0];
99*1fd5a2e1SPrashanth Swaminathan   values[2] = &doubles[1];
100*1fd5a2e1SPrashanth Swaminathan   values[3] = &doubles[2];
101*1fd5a2e1SPrashanth Swaminathan   ffi_call(&cif, FFI_FN(float_va_fn), &resfp, values);
102*1fd5a2e1SPrashanth Swaminathan   /* { dg-output "\n2: 2.0 : 0:3.0  1:4.0  total: 11.0" } */
103*1fd5a2e1SPrashanth Swaminathan   printf("ffi: %.1f\n", resfp);
104*1fd5a2e1SPrashanth Swaminathan   /* { dg-output "\nffi: 11.0" } */
105*1fd5a2e1SPrashanth Swaminathan 
106*1fd5a2e1SPrashanth Swaminathan   exit(0);
107*1fd5a2e1SPrashanth Swaminathan }
108