ยปCore Development>Code coverage>Modules/_ctypes/libffi/testsuite/libffi.call/testclosure.c

Python code coverage for Modules/_ctypes/libffi/testsuite/libffi.call/testclosure.c

#countcontent
1n/a/* Area: closure_call
2n/a Purpose: Check return value float.
3n/a Limitations: none.
4n/a PR: 41908.
5n/a Originator: <rfm@gnu.org> 20091102 */
6n/a
7n/a/* { dg-do run } */
8n/a#include "ffitest.h"
9n/a
10n/atypedef struct cls_struct_combined {
11n/a float a;
12n/a float b;
13n/a float c;
14n/a float d;
15n/a} cls_struct_combined;
16n/a
17n/avoid cls_struct_combined_fn(struct cls_struct_combined arg)
18n/a{
19n/a printf("%g %g %g %g\n",
20n/a arg.a, arg.b,
21n/a arg.c, arg.d);
22n/a fflush(stdout);
23n/a}
24n/a
25n/astatic void
26n/acls_struct_combined_gn(ffi_cif* cif __UNUSED__, void* resp __UNUSED__,
27n/a void** args, void* userdata __UNUSED__)
28n/a{
29n/a struct cls_struct_combined a0;
30n/a
31n/a a0 = *(struct cls_struct_combined*)(args[0]);
32n/a
33n/a cls_struct_combined_fn(a0);
34n/a}
35n/a
36n/a
37n/aint main (void)
38n/a{
39n/a ffi_cif cif;
40n/a void *code;
41n/a ffi_closure *pcl = ffi_closure_alloc(sizeof(ffi_closure), &code);
42n/a ffi_type* cls_struct_fields0[5];
43n/a ffi_type cls_struct_type0;
44n/a ffi_type* dbl_arg_types[5];
45n/a
46n/a struct cls_struct_combined g_dbl = {4.0, 5.0, 1.0, 8.0};
47n/a
48n/a cls_struct_type0.size = 0;
49n/a cls_struct_type0.alignment = 0;
50n/a cls_struct_type0.type = FFI_TYPE_STRUCT;
51n/a cls_struct_type0.elements = cls_struct_fields0;
52n/a
53n/a cls_struct_fields0[0] = &ffi_type_float;
54n/a cls_struct_fields0[1] = &ffi_type_float;
55n/a cls_struct_fields0[2] = &ffi_type_float;
56n/a cls_struct_fields0[3] = &ffi_type_float;
57n/a cls_struct_fields0[4] = NULL;
58n/a
59n/a dbl_arg_types[0] = &cls_struct_type0;
60n/a dbl_arg_types[1] = NULL;
61n/a
62n/a CHECK(ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 1, &ffi_type_void,
63n/a dbl_arg_types) == FFI_OK);
64n/a
65n/a CHECK(ffi_prep_closure_loc(pcl, &cif, cls_struct_combined_gn, NULL, code) == FFI_OK);
66n/a
67n/a ((void(*)(cls_struct_combined)) (code))(g_dbl);
68n/a /* { dg-output "4 5 1 8" } */
69n/a exit(0);
70n/a}