diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 2683757d1b2c02d0f1da5cbae4612554e073b948..19cb0ce48f3212b693f89ff34df403298453c0fd 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2016-12-01  Richard Biener  <rguenther@suse.de>
+
+	* tree-ssa-alias.c (indirect_refs_may_alias_p): Do not
+	treat arrays with same type as objects that cannot overlap.
+
 2016-12-01  Georg-Johann Lay  <avr@gjlay.de>
 
 	* config/avr/avr.c (avr_print_operand): Use SYMBOL_REF_P if possible.
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index ab55b438fcc4c70fe899ce702d82cc10d6529146..447d9fb4b4d4ef1a8d84e199f8b692d362473fd4 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2016-12-01  Richard Biener  <rguenther@suse.de>
+
+	* gcc.dg/torture/alias-2.c: New testcase.
+
 2016-12-01  Georg-Johann Lay  <avr@gjlay.de>
 
 	* gcc.target/avr/tiny-memx.c: Only perform if target avr_tiny.
diff --git a/gcc/testsuite/gcc.dg/torture/alias-2.c b/gcc/testsuite/gcc.dg/torture/alias-2.c
new file mode 100644
index 0000000000000000000000000000000000000000..329d46a5eb9d53357836385e66f15a3dd3fc1b30
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/torture/alias-2.c
@@ -0,0 +1,17 @@
+/* { dg-do run } */
+
+/* We do not want to treat int[3] as an object that cannot overlap
+   itself but treat it as arbitrary sub-array of a larger array object.  */
+int ar1(int (*p)[3], int (*q)[3])
+{
+  (*p)[0] = 1;
+  (*q)[1] = 2;
+  return (*p)[0];
+}
+int main()
+{
+  int a[4];
+  if (ar1 ((int (*)[3])&a[1], (int (*)[3])&a[0]) != 2)
+    __builtin_abort ();
+  return 0;
+}