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

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

#countcontent
1n/a/* Area: ffi_call
2n/a Purpose: Check return value long long.
3n/a Limitations: none.
4n/a PR: none.
5n/a Originator: From the original ffitest.c */
6n/a
7n/a/* { dg-do run } */
8n/a#include "ffitest.h"
9n/astatic long long return_ll(long long ll)
10n/a{
11n/a return ll;
12n/a}
13n/a
14n/aint main (void)
15n/a{
16n/a ffi_cif cif;
17n/a ffi_type *args[MAX_ARGS];
18n/a void *values[MAX_ARGS];
19n/a long long rlonglong;
20n/a long long ll;
21n/a
22n/a args[0] = &ffi_type_sint64;
23n/a values[0] = ≪
24n/a
25n/a /* Initialize the cif */
26n/a CHECK(ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 1,
27n/a &ffi_type_sint64, args) == FFI_OK);
28n/a
29n/a for (ll = 0LL; ll < 100LL; ll++)
30n/a {
31n/a ffi_call(&cif, FFI_FN(return_ll), &rlonglong, values);
32n/a CHECK(rlonglong == ll);
33n/a }
34n/a
35n/a for (ll = 55555555555000LL; ll < 55555555555100LL; ll++)
36n/a {
37n/a ffi_call(&cif, FFI_FN(return_ll), &rlonglong, values);
38n/a CHECK(rlonglong == ll);
39n/a }
40n/a exit(0);
41n/a}