public inbox for gcc-patches@gcc.gnu.org
 help / color / mirror / Atom feed
* [PATCH] Fix middle-end/81737
@ 2017-08-07  8:47 Marek Polacek
  2017-08-07  8:58 ` Jakub Jelinek
  0 siblings, 1 reply; 8+ messages in thread
From: Marek Polacek @ 2017-08-07  8:47 UTC (permalink / raw)
  To: GCC Patches

In my recent change I failed to check whether the type domain
of a type is non-NULL and this goof causes crashing on this
testcase.

Bootstrapped/regtested on x86_64-linux, ok for trunk?

2017-08-07  Marek Polacek  <polacek@redhat.com>

	PR middle-end/81737
	* fold-const.c (fold_indirect_ref_1): Check type_domain.

	* gcc.dg/pr81737.c: New test.

diff --git gcc/fold-const.c gcc/fold-const.c
index d563ba76766..8eaea6cce3a 100644
--- gcc/fold-const.c
+++ gcc/fold-const.c
@@ -14107,8 +14107,10 @@ fold_indirect_ref_1 (location_t loc, tree type, tree op0)
 		   && type == TREE_TYPE (op00type))
 	    {
 	      tree type_domain = TYPE_DOMAIN (op00type);
-	      tree min = TYPE_MIN_VALUE (type_domain);
-	      if (min && TREE_CODE (min) == INTEGER_CST)
+	      tree min;
+	      if (type_domain != NULL_TREE
+		  && (min = TYPE_MIN_VALUE (type_domain))
+		  && TREE_CODE (min) == INTEGER_CST)
 		{
 		  offset_int off = wi::to_offset (op01);
 		  offset_int el_sz = wi::to_offset (TYPE_SIZE_UNIT (type));
diff --git gcc/testsuite/gcc.dg/pr81737.c gcc/testsuite/gcc.dg/pr81737.c
index e69de29bb2d..493358956ef 100644
--- gcc/testsuite/gcc.dg/pr81737.c
+++ gcc/testsuite/gcc.dg/pr81737.c
@@ -0,0 +1,6 @@
+/* PR middle-end/81737 */
+/* { dg-do compile } */
+/* { dg-options "" } */
+
+extern int a[];
+void fn1() { (a + 0)[1]; }

	Marek

^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2017-08-16 10:51 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-08-07  8:47 [PATCH] Fix middle-end/81737 Marek Polacek
2017-08-07  8:58 ` Jakub Jelinek
2017-08-07  9:10   ` Marek Polacek
2017-08-07 14:07     ` Richard Biener
2017-08-08 17:23       ` Marek Polacek
2017-08-14  8:32         ` Richard Biener
2017-08-16 10:51           ` Marek Polacek
2017-08-16 13:38             ` Richard Biener

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).