public inbox for gcc-cvs@sourceware.org
help / color / mirror / Atom feed
* [gcc r14-9555] analyzer: fix ICE due to corrupt MEM_REFs [PR113505]
@ 2024-03-19 20:08 David Malcolm
0 siblings, 0 replies; only message in thread
From: David Malcolm @ 2024-03-19 20:08 UTC (permalink / raw)
To: gcc-cvs
https://gcc.gnu.org/g:c87f1f3d660f4103c91c72a4d3e1d19ff2858671
commit r14-9555-gc87f1f3d660f4103c91c72a4d3e1d19ff2858671
Author: Jakub Jelinek <jakub@redhat.com>
Date: Tue Mar 19 16:06:13 2024 -0400
analyzer: fix ICE due to corrupt MEM_REFs [PR113505]
gcc/analyzer/ChangeLog
PR analyzer/113505
* region-model.cc (get_tree_for_byte_offset,
region_model::get_representative_path_var_1,
test_mem_ref, test_POINTER_PLUS_EXPR_then_MEM_REF): Use
char __attribute__((may_alias)) * as type of MEM_REF second argument.
gcc/testsuite/ChangeLog
PR analyzer/113505
* gcc.dg/analyzer/pr113505.c: New test.
Signed-off-by: David Malcolm <dmalcolm@redhat.com>
Diff:
---
gcc/analyzer/region-model.cc | 16 ++++++++++------
gcc/testsuite/gcc.dg/analyzer/pr113505.c | 24 ++++++++++++++++++++++++
2 files changed, 34 insertions(+), 6 deletions(-)
diff --git a/gcc/analyzer/region-model.cc b/gcc/analyzer/region-model.cc
index f079d1fb37e..8fff5324173 100644
--- a/gcc/analyzer/region-model.cc
+++ b/gcc/analyzer/region-model.cc
@@ -3967,9 +3967,10 @@ static tree
get_tree_for_byte_offset (tree ptr_expr, byte_offset_t byte_offset)
{
gcc_assert (ptr_expr);
+ tree ptype = build_pointer_type_for_mode (char_type_node, ptr_mode, true);
return fold_build2 (MEM_REF,
char_type_node,
- ptr_expr, wide_int_to_tree (size_type_node, byte_offset));
+ ptr_expr, wide_int_to_tree (ptype, byte_offset));
}
/* Simulate a series of reads of REG until we find a 0 byte
@@ -5360,9 +5361,10 @@ region_model::get_representative_path_var_1 (const region *reg,
tree addr_parent = build1 (ADDR_EXPR,
build_pointer_type (reg->get_type ()),
parent_pv.m_tree);
- return path_var (build2 (MEM_REF,
- reg->get_type (),
- addr_parent, offset_pv.m_tree),
+ tree ptype = build_pointer_type_for_mode (char_type_node, ptr_mode,
+ true);
+ return path_var (build2 (MEM_REF, reg->get_type (), addr_parent,
+ fold_convert (ptype, offset_pv.m_tree)),
parent_pv.m_stack_depth);
}
@@ -9024,7 +9026,8 @@ test_mem_ref ()
tree int_17 = build_int_cst (integer_type_node, 17);
tree addr_of_x = build1 (ADDR_EXPR, int_star, x);
- tree offset_0 = build_int_cst (integer_type_node, 0);
+ tree ptype = build_pointer_type_for_mode (char_type_node, ptr_mode, true);
+ tree offset_0 = build_int_cst (ptype, 0);
tree star_p = build2 (MEM_REF, integer_type_node, p, offset_0);
region_model_manager mgr;
@@ -9074,7 +9077,8 @@ test_POINTER_PLUS_EXPR_then_MEM_REF ()
tree a = build_global_decl ("a", int_star);
tree offset_12 = build_int_cst (size_type_node, 12);
tree pointer_plus_expr = build2 (POINTER_PLUS_EXPR, int_star, a, offset_12);
- tree offset_0 = build_int_cst (integer_type_node, 0);
+ tree ptype = build_pointer_type_for_mode (char_type_node, ptr_mode, true);
+ tree offset_0 = build_int_cst (ptype, 0);
tree mem_ref = build2 (MEM_REF, integer_type_node,
pointer_plus_expr, offset_0);
region_model_manager mgr;
diff --git a/gcc/testsuite/gcc.dg/analyzer/pr113505.c b/gcc/testsuite/gcc.dg/analyzer/pr113505.c
new file mode 100644
index 00000000000..58a2b6cd6f4
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/analyzer/pr113505.c
@@ -0,0 +1,24 @@
+/* PR analyzer/113505 */
+/* { dg-additional-options "-O -fdump-analyzer" } */
+
+enum E **foo () __attribute__((__const__));
+char a[2];
+void bar (char *);
+
+void
+baz (void)
+{
+ char *s, *l;
+ for (;;)
+ {
+ bar (a);
+ s = a;
+ while (foo ()[*s])
+ s++;
+ l = s;
+ *l++ = '\0';
+ while (foo ()[*l])
+ l++;
+ bar (s);
+ }
+}
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2024-03-19 20:08 UTC | newest]
Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-03-19 20:08 [gcc r14-9555] analyzer: fix ICE due to corrupt MEM_REFs [PR113505] David Malcolm
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).