1 /* Area:	ffi_call
2    Purpose:	Promotion test.
3    Limitations:	none.
4    PR:		none.
5    Originator:	From the original ffitest.c  */
6 
7 /* { dg-do run } */
8 #include "ffitest.h"
promotion(signed char sc,signed short ss,unsigned char uc,unsigned short us)9 static int promotion(signed char sc, signed short ss,
10 		     unsigned char uc, unsigned short us)
11 {
12   int r = (int) sc + (int) ss + (int) uc + (int) us;
13 
14   return r;
15 }
16 
main(void)17 int main (void)
18 {
19   ffi_cif cif;
20   ffi_type *args[MAX_ARGS];
21   void *values[MAX_ARGS];
22   ffi_arg rint;
23   signed char sc;
24   unsigned char uc;
25   signed short ss;
26   unsigned short us;
27   unsigned long ul;
28 
29   args[0] = &ffi_type_schar;
30   args[1] = &ffi_type_sshort;
31   args[2] = &ffi_type_uchar;
32   args[3] = &ffi_type_ushort;
33   values[0] = ≻
34   values[1] = &ss;
35   values[2] = &uc;
36   values[3] = &us;
37 
38   /* Initialize the cif */
39   CHECK(ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 4,
40 		     &ffi_type_sint, args) == FFI_OK);
41 
42   us = 0;
43   ul = 0;
44 
45   for (sc = (signed char) -127;
46        sc <= (signed char) 120; sc += 1)
47     for (ss = -30000; ss <= 30000; ss += 10000)
48       for (uc = (unsigned char) 0;
49 	   uc <= (unsigned char) 200; uc += 20)
50 	for (us = 0; us <= 60000; us += 10000)
51 	  {
52 	    ul++;
53 	    ffi_call(&cif, FFI_FN(promotion), &rint, values);
54 	    CHECK((int)rint == (signed char) sc + (signed short) ss +
55 		  (unsigned char) uc + (unsigned short) us);
56 	  }
57   printf("%lu promotion tests run\n", ul);
58   exit(0);
59 }
60