annotate gcc/testsuite/jit.dg/test-accessing-struct.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 struct foo
kono
parents:
diff changeset
9 {
kono
parents:
diff changeset
10 int x;
kono
parents:
diff changeset
11 int y;
kono
parents:
diff changeset
12 int z;
kono
parents:
diff changeset
13 };
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 void
kono
parents:
diff changeset
16 create_code (gcc_jit_context *ctxt, void *user_data)
kono
parents:
diff changeset
17 {
kono
parents:
diff changeset
18 /* Let's try to inject the equivalent of:
kono
parents:
diff changeset
19 void
kono
parents:
diff changeset
20 test_access (struct foo *f)
kono
parents:
diff changeset
21 {
kono
parents:
diff changeset
22 f->z = f->x * f->y;
kono
parents:
diff changeset
23 }
kono
parents:
diff changeset
24 */
kono
parents:
diff changeset
25 gcc_jit_type *void_type =
kono
parents:
diff changeset
26 gcc_jit_context_get_type (ctxt, GCC_JIT_TYPE_VOID);
kono
parents:
diff changeset
27 gcc_jit_type *int_type =
kono
parents:
diff changeset
28 gcc_jit_context_get_type (ctxt, GCC_JIT_TYPE_INT);
kono
parents:
diff changeset
29 gcc_jit_field *x =
kono
parents:
diff changeset
30 gcc_jit_context_new_field (ctxt,
kono
parents:
diff changeset
31 NULL,
kono
parents:
diff changeset
32 int_type,
kono
parents:
diff changeset
33 "x");
kono
parents:
diff changeset
34 gcc_jit_field *y =
kono
parents:
diff changeset
35 gcc_jit_context_new_field (ctxt,
kono
parents:
diff changeset
36 NULL,
kono
parents:
diff changeset
37 int_type,
kono
parents:
diff changeset
38 "y");
kono
parents:
diff changeset
39 gcc_jit_field *z =
kono
parents:
diff changeset
40 gcc_jit_context_new_field (ctxt,
kono
parents:
diff changeset
41 NULL,
kono
parents:
diff changeset
42 int_type,
kono
parents:
diff changeset
43 "z");
kono
parents:
diff changeset
44 gcc_jit_field *fields[] = {x, y, z};
kono
parents:
diff changeset
45 gcc_jit_struct *struct_type =
kono
parents:
diff changeset
46 gcc_jit_context_new_struct_type (ctxt, NULL, "foo", 3, fields);
kono
parents:
diff changeset
47 gcc_jit_type *ptr_type =
kono
parents:
diff changeset
48 gcc_jit_type_get_pointer (gcc_jit_struct_as_type (struct_type));
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 /* Build the test function. */
kono
parents:
diff changeset
51 gcc_jit_param *param_f =
kono
parents:
diff changeset
52 gcc_jit_context_new_param (ctxt, NULL, ptr_type, "f");
kono
parents:
diff changeset
53 gcc_jit_function *test_fn =
kono
parents:
diff changeset
54 gcc_jit_context_new_function (ctxt, NULL,
kono
parents:
diff changeset
55 GCC_JIT_FUNCTION_EXPORTED,
kono
parents:
diff changeset
56 void_type,
kono
parents:
diff changeset
57 "test_access",
kono
parents:
diff changeset
58 1, &param_f,
kono
parents:
diff changeset
59 0);
kono
parents:
diff changeset
60
kono
parents:
diff changeset
61 /* f->x * f->y */
kono
parents:
diff changeset
62 gcc_jit_rvalue *sum =
kono
parents:
diff changeset
63 gcc_jit_context_new_binary_op (
kono
parents:
diff changeset
64 ctxt, NULL,
kono
parents:
diff changeset
65 GCC_JIT_BINARY_OP_MULT,
kono
parents:
diff changeset
66 int_type,
kono
parents:
diff changeset
67 gcc_jit_lvalue_as_rvalue (
kono
parents:
diff changeset
68 gcc_jit_rvalue_dereference_field (
kono
parents:
diff changeset
69 gcc_jit_param_as_rvalue (param_f),
kono
parents:
diff changeset
70 NULL,
kono
parents:
diff changeset
71 x)),
kono
parents:
diff changeset
72 gcc_jit_lvalue_as_rvalue (
kono
parents:
diff changeset
73 gcc_jit_rvalue_dereference_field (
kono
parents:
diff changeset
74 gcc_jit_param_as_rvalue (param_f),
kono
parents:
diff changeset
75 NULL,
kono
parents:
diff changeset
76 y)));
kono
parents:
diff changeset
77
kono
parents:
diff changeset
78 /* f->z = ... */
kono
parents:
diff changeset
79 gcc_jit_block *block = gcc_jit_function_new_block (test_fn, NULL);
kono
parents:
diff changeset
80 gcc_jit_block_add_assignment (
kono
parents:
diff changeset
81 block,
kono
parents:
diff changeset
82 NULL,
kono
parents:
diff changeset
83 gcc_jit_rvalue_dereference_field (
kono
parents:
diff changeset
84 gcc_jit_param_as_rvalue (param_f),
kono
parents:
diff changeset
85 NULL,
kono
parents:
diff changeset
86 z),
kono
parents:
diff changeset
87 sum);
kono
parents:
diff changeset
88 gcc_jit_block_end_with_void_return (block, NULL);
kono
parents:
diff changeset
89 }
kono
parents:
diff changeset
90
kono
parents:
diff changeset
91 void
kono
parents:
diff changeset
92 verify_code (gcc_jit_context *ctxt, gcc_jit_result *result)
kono
parents:
diff changeset
93 {
kono
parents:
diff changeset
94 typedef void (*fn_type) (struct foo *);
kono
parents:
diff changeset
95 CHECK_NON_NULL (result);
kono
parents:
diff changeset
96
kono
parents:
diff changeset
97 fn_type test_access =
kono
parents:
diff changeset
98 (fn_type)gcc_jit_result_get_code (result, "test_access");
kono
parents:
diff changeset
99 CHECK_NON_NULL (test_access);
kono
parents:
diff changeset
100
kono
parents:
diff changeset
101 struct foo tmp;
kono
parents:
diff changeset
102 tmp.x = 5;
kono
parents:
diff changeset
103 tmp.y = 7;
kono
parents:
diff changeset
104 tmp.z = 0;
kono
parents:
diff changeset
105
kono
parents:
diff changeset
106 /* Call the JIT-generated function. */
kono
parents:
diff changeset
107 test_access (&tmp);
kono
parents:
diff changeset
108
kono
parents:
diff changeset
109 /* Verify that the code correctly modified the field "z". */
kono
parents:
diff changeset
110 CHECK_VALUE (tmp.z, 35);
kono
parents:
diff changeset
111 }
kono
parents:
diff changeset
112