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

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

#countcontent
1n/a/* Area: ffi_call
2n/a Purpose: Check return value double.
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/a#include "float.h"
10n/a
11n/atypedef union
12n/a{
13n/a double d;
14n/a unsigned char c[sizeof (double)];
15n/a} value_type;
16n/a
17n/a#define CANARY 0xba
18n/a
19n/astatic double dblit(float f)
20n/a{
21n/a return f/3.0;
22n/a}
23n/a
24n/aint main (void)
25n/a{
26n/a ffi_cif cif;
27n/a ffi_type *args[MAX_ARGS];
28n/a void *values[MAX_ARGS];
29n/a float f;
30n/a value_type result[2];
31n/a unsigned int i;
32n/a
33n/a args[0] = &ffi_type_float;
34n/a values[0] = &f;
35n/a
36n/a /* Initialize the cif */
37n/a CHECK(ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 1,
38n/a &ffi_type_double, args) == FFI_OK);
39n/a
40n/a f = 3.14159;
41n/a
42n/a /* Put a canary in the return array. This is a regression test for
43n/a a buffer overrun. */
44n/a memset(result[1].c, CANARY, sizeof (double));
45n/a
46n/a ffi_call(&cif, FFI_FN(dblit), &result[0].d, values);
47n/a
48n/a /* These are not always the same!! Check for a reasonable delta */
49n/a
50n/a CHECK(result[0].d - dblit(f) < DBL_EPSILON);
51n/a
52n/a /* Check the canary. */
53n/a for (i = 0; i < sizeof (double); ++i)
54n/a CHECK(result[1].c[i] == CANARY);
55n/a
56n/a exit(0);
57n/a
58n/a}