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

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

#countcontent
1n/a/* Area: ffi_call
2n/a Purpose: Check denorm double value.
3n/a Limitations: none.
4n/a PR: PR26483.
5n/a Originator: From the original ffitest.c */
6n/a
7n/a/* { dg-do run } */
8n/a/* { dg-options "-mieee" { target alpha*-*-* } } */
9n/a
10n/a#include "ffitest.h"
11n/a#include "float.h"
12n/a
13n/atypedef union
14n/a{
15n/a double d;
16n/a unsigned char c[sizeof (double)];
17n/a} value_type;
18n/a
19n/a#define CANARY 0xba
20n/a
21n/astatic double dblit(double d)
22n/a{
23n/a return d;
24n/a}
25n/a
26n/aint main (void)
27n/a{
28n/a ffi_cif cif;
29n/a ffi_type *args[MAX_ARGS];
30n/a void *values[MAX_ARGS];
31n/a double d;
32n/a value_type result[2];
33n/a unsigned int i;
34n/a
35n/a args[0] = &ffi_type_double;
36n/a values[0] = &d;
37n/a
38n/a /* Initialize the cif */
39n/a CHECK(ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 1,
40n/a &ffi_type_double, args) == FFI_OK);
41n/a
42n/a d = DBL_MIN / 2;
43n/a
44n/a /* Put a canary in the return array. This is a regression test for
45n/a a buffer overrun. */
46n/a memset(result[1].c, CANARY, sizeof (double));
47n/a
48n/a ffi_call(&cif, FFI_FN(dblit), &result[0].d, values);
49n/a
50n/a /* The standard delta check doesn't work for denorms. Since we didn't do
51n/a any arithmetic, we should get the original result back, and hence an
52n/a exact check should be OK here. */
53n/a
54n/a CHECK(result[0].d == dblit(d));
55n/a
56n/a /* Check the canary. */
57n/a for (i = 0; i < sizeof (double); ++i)
58n/a CHECK(result[1].c[i] == CANARY);
59n/a
60n/a exit(0);
61n/a
62n/a}