annotate gcc/testsuite/jit.dg/test-error-dereference-field-of-non-pointer.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 };
kono
parents:
diff changeset
13
kono
parents:
diff changeset
14 void
kono
parents:
diff changeset
15 create_code (gcc_jit_context *ctxt, void *user_data)
kono
parents:
diff changeset
16 {
kono
parents:
diff changeset
17 /* Let's try to inject the equivalent of:
kono
parents:
diff changeset
18 void
kono
parents:
diff changeset
19 test_bogus_dereference ()
kono
parents:
diff changeset
20 {
kono
parents:
diff changeset
21 struct foo tmp;
kono
parents:
diff changeset
22 tmp->x = tmp->y;
kono
parents:
diff changeset
23 }
kono
parents:
diff changeset
24 i.e. where tmp is *not* a pointer.
kono
parents:
diff changeset
25 */
kono
parents:
diff changeset
26 gcc_jit_type *void_type =
kono
parents:
diff changeset
27 gcc_jit_context_get_type (ctxt, GCC_JIT_TYPE_VOID);
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
kono
parents:
diff changeset
31 /* Map "struct foo". */
kono
parents:
diff changeset
32 gcc_jit_field *x =
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 "x");
kono
parents:
diff changeset
37 gcc_jit_field *y =
kono
parents:
diff changeset
38 gcc_jit_context_new_field (ctxt,
kono
parents:
diff changeset
39 NULL,
kono
parents:
diff changeset
40 int_type,
kono
parents:
diff changeset
41 "y");
kono
parents:
diff changeset
42 gcc_jit_field *foo_fields[] = {x, y};
kono
parents:
diff changeset
43 gcc_jit_struct *struct_foo =
kono
parents:
diff changeset
44 gcc_jit_context_new_struct_type (ctxt, NULL, "foo", 2, foo_fields);
kono
parents:
diff changeset
45
kono
parents:
diff changeset
46 /* Build the test function. */
kono
parents:
diff changeset
47 gcc_jit_function *test_fn =
kono
parents:
diff changeset
48 gcc_jit_context_new_function (ctxt, NULL,
kono
parents:
diff changeset
49 GCC_JIT_FUNCTION_EXPORTED,
kono
parents:
diff changeset
50 void_type,
kono
parents:
diff changeset
51 "test_bogus_dereference",
kono
parents:
diff changeset
52 0, NULL,
kono
parents:
diff changeset
53 0);
kono
parents:
diff changeset
54 gcc_jit_lvalue *tmp =
kono
parents:
diff changeset
55 gcc_jit_function_new_local (test_fn, NULL,
kono
parents:
diff changeset
56 gcc_jit_struct_as_type (struct_foo),
kono
parents:
diff changeset
57 "tmp");
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 gcc_jit_block *block = gcc_jit_function_new_block (test_fn, NULL);
kono
parents:
diff changeset
60
kono
parents:
diff changeset
61 /* Erroneous: tmp->x = ... */
kono
parents:
diff changeset
62 gcc_jit_lvalue *lvalue =
kono
parents:
diff changeset
63 gcc_jit_rvalue_dereference_field (
kono
parents:
diff changeset
64 gcc_jit_lvalue_as_rvalue (tmp),
kono
parents:
diff changeset
65 NULL,
kono
parents:
diff changeset
66 x);
kono
parents:
diff changeset
67
kono
parents:
diff changeset
68 /* Erroneous: ... = tmp->y; */
kono
parents:
diff changeset
69 gcc_jit_rvalue *rvalue =
kono
parents:
diff changeset
70 gcc_jit_lvalue_as_rvalue (
kono
parents:
diff changeset
71 gcc_jit_rvalue_dereference_field (
kono
parents:
diff changeset
72 gcc_jit_lvalue_as_rvalue (tmp),
kono
parents:
diff changeset
73 NULL,
kono
parents:
diff changeset
74 y));
kono
parents:
diff changeset
75
kono
parents:
diff changeset
76 gcc_jit_block_add_assignment (
kono
parents:
diff changeset
77 block,
kono
parents:
diff changeset
78 NULL,
kono
parents:
diff changeset
79 lvalue, rvalue);
kono
parents:
diff changeset
80
kono
parents:
diff changeset
81 gcc_jit_block_end_with_void_return (block, NULL);
kono
parents:
diff changeset
82 }
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 CHECK_VALUE (result, NULL);
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 /* Verify that the correct error message was emitted. */
kono
parents:
diff changeset
90 CHECK_STRING_VALUE (gcc_jit_context_get_first_error (ctxt),
kono
parents:
diff changeset
91 ("gcc_jit_rvalue_dereference_field:"
kono
parents:
diff changeset
92 " dereference of non-pointer tmp (type: struct foo)"
kono
parents:
diff changeset
93 " when accessing ->x"));
kono
parents:
diff changeset
94 }
kono
parents:
diff changeset
95