annotate gcc/testsuite/jit.dg/test-accessing-union.c @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 #include <stdlib.h>
kono
parents:
diff changeset
2 #include <stdio.h>
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 #include "libgccjit.h"
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 #include "harness.h"
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 /* Quote from here in docs/topics/types.rst. */
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 union int_or_float
kono
parents:
diff changeset
11 {
kono
parents:
diff changeset
12 int as_int;
kono
parents:
diff changeset
13 float as_float;
kono
parents:
diff changeset
14 };
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 void
kono
parents:
diff changeset
17 create_code (gcc_jit_context *ctxt, void *user_data)
kono
parents:
diff changeset
18 {
kono
parents:
diff changeset
19 /* Let's try to inject the equivalent of:
kono
parents:
diff changeset
20 float
kono
parents:
diff changeset
21 test_union (int i)
kono
parents:
diff changeset
22 {
kono
parents:
diff changeset
23 union int_or_float u;
kono
parents:
diff changeset
24 u.as_int = i;
kono
parents:
diff changeset
25 return u.as_float;
kono
parents:
diff changeset
26 }
kono
parents:
diff changeset
27 */
kono
parents:
diff changeset
28 gcc_jit_type *int_type =
kono
parents:
diff changeset
29 gcc_jit_context_get_type (ctxt, GCC_JIT_TYPE_INT);
kono
parents:
diff changeset
30 gcc_jit_type *float_type =
kono
parents:
diff changeset
31 gcc_jit_context_get_type (ctxt, GCC_JIT_TYPE_FLOAT);
kono
parents:
diff changeset
32 gcc_jit_field *as_int =
kono
parents:
diff changeset
33 gcc_jit_context_new_field (ctxt,
kono
parents:
diff changeset
34 NULL,
kono
parents:
diff changeset
35 int_type,
kono
parents:
diff changeset
36 "as_int");
kono
parents:
diff changeset
37 gcc_jit_field *as_float =
kono
parents:
diff changeset
38 gcc_jit_context_new_field (ctxt,
kono
parents:
diff changeset
39 NULL,
kono
parents:
diff changeset
40 float_type,
kono
parents:
diff changeset
41 "as_float");
kono
parents:
diff changeset
42 gcc_jit_field *fields[] = {as_int, as_float};
kono
parents:
diff changeset
43 gcc_jit_type *union_type =
kono
parents:
diff changeset
44 gcc_jit_context_new_union_type (ctxt, NULL,
kono
parents:
diff changeset
45 "int_or_float", 2, fields);
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 /* Build the test function. */
kono
parents:
diff changeset
48 gcc_jit_param *param_i =
kono
parents:
diff changeset
49 gcc_jit_context_new_param (ctxt, NULL, int_type, "i");
kono
parents:
diff changeset
50 gcc_jit_function *test_fn =
kono
parents:
diff changeset
51 gcc_jit_context_new_function (ctxt, NULL,
kono
parents:
diff changeset
52 GCC_JIT_FUNCTION_EXPORTED,
kono
parents:
diff changeset
53 float_type,
kono
parents:
diff changeset
54 "test_union",
kono
parents:
diff changeset
55 1, &param_i,
kono
parents:
diff changeset
56 0);
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 gcc_jit_lvalue *u =
kono
parents:
diff changeset
59 gcc_jit_function_new_local (test_fn, NULL,
kono
parents:
diff changeset
60 union_type, "u");
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 gcc_jit_block *block = gcc_jit_function_new_block (test_fn, NULL);
kono
parents:
diff changeset
63
kono
parents:
diff changeset
64 /* u.as_int = i; */
kono
parents:
diff changeset
65 gcc_jit_block_add_assignment (
kono
parents:
diff changeset
66 block,
kono
parents:
diff changeset
67 NULL,
kono
parents:
diff changeset
68 /* "u.as_int = ..." */
kono
parents:
diff changeset
69 gcc_jit_lvalue_access_field (u,
kono
parents:
diff changeset
70 NULL,
kono
parents:
diff changeset
71 as_int),
kono
parents:
diff changeset
72 gcc_jit_param_as_rvalue (param_i));
kono
parents:
diff changeset
73
kono
parents:
diff changeset
74 /* return u.as_float; */
kono
parents:
diff changeset
75 gcc_jit_block_end_with_return (
kono
parents:
diff changeset
76 block, NULL,
kono
parents:
diff changeset
77 gcc_jit_rvalue_access_field (gcc_jit_lvalue_as_rvalue (u),
kono
parents:
diff changeset
78 NULL,
kono
parents:
diff changeset
79 as_float));
kono
parents:
diff changeset
80 }
kono
parents:
diff changeset
81
kono
parents:
diff changeset
82 /* Quote up to here in docs/topics/types.rst. */
kono
parents:
diff changeset
83
kono
parents:
diff changeset
84 void
kono
parents:
diff changeset
85 verify_code (gcc_jit_context *ctxt, gcc_jit_result *result)
kono
parents:
diff changeset
86 {
kono
parents:
diff changeset
87 typedef float (*fn_type) (int i);
kono
parents:
diff changeset
88 CHECK_NON_NULL (result);
kono
parents:
diff changeset
89
kono
parents:
diff changeset
90 fn_type test_union =
kono
parents:
diff changeset
91 (fn_type)gcc_jit_result_get_code (result, "test_union");
kono
parents:
diff changeset
92 CHECK_NON_NULL (test_union);
kono
parents:
diff changeset
93
kono
parents:
diff changeset
94 /* Call the JIT-generated function. */
kono
parents:
diff changeset
95 float f_result = test_union (42);
kono
parents:
diff changeset
96
kono
parents:
diff changeset
97 union int_or_float u;
kono
parents:
diff changeset
98 u.as_float = f_result;
kono
parents:
diff changeset
99
kono
parents:
diff changeset
100 CHECK_VALUE (u.as_int, 42);
kono
parents:
diff changeset
101 }