OSDN Git Service

PR middle-end/59827
authormpolacek <mpolacek@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 16 Jan 2014 14:59:46 +0000 (14:59 +0000)
committermpolacek <mpolacek@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 16 Jan 2014 14:59:46 +0000 (14:59 +0000)
* gimple-low.c (gimple_check_call_args): Don't use DECL_ARG_TYPE if
it is error_mark_node.
testsuite/
* gcc.dg/pr59827.c: New test.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-4_7-branch@206665 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/gimple-low.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/pr59827.c [new file with mode: 0644]

index edcbb91..1fd13ea 100644 (file)
@@ -1,3 +1,12 @@
+2014-01-16  Marek Polacek  <polacek@redhat.com>
+
+       Backport from mainline
+       2014-01-16  Marek Polacek  <polacek@redhat.com>
+
+       PR middle-end/59827
+       * gimple-low.c (gimple_check_call_args): Don't use DECL_ARG_TYPE if
+       it is error_mark_node.
+
 2014-01-14  Uros Bizjak  <ubizjak@gmail.com>
 
        Revert:
index 293d4d7..1f74512 100644 (file)
@@ -249,6 +249,7 @@ gimple_check_call_args (gimple stmt, tree fndecl)
            break;
          arg = gimple_call_arg (stmt, i);
          if (p == error_mark_node
+             || DECL_ARG_TYPE (p) == error_mark_node
              || arg == error_mark_node
              || (!types_compatible_p (DECL_ARG_TYPE (p), TREE_TYPE (arg))
                  && !fold_convertible_p (DECL_ARG_TYPE (p), arg)))
index 520a15a..23c358b 100644 (file)
@@ -1,3 +1,11 @@
+2014-01-16  Marek Polacek  <polacek@redhat.com>
+
+       Backport from mainline
+       2014-01-16  Marek Polacek  <polacek@redhat.com>
+
+       PR middle-end/59827
+       * gcc.dg/pr59827.c: New test.
+
 2014-01-10  Richard Earnshaw  <rearnsha@arm.com>
 
        PR rtl-optimization/54300
diff --git a/gcc/testsuite/gcc.dg/pr59827.c b/gcc/testsuite/gcc.dg/pr59827.c
new file mode 100644 (file)
index 0000000..77e1e9c
--- /dev/null
@@ -0,0 +1,15 @@
+/* PR middle-end/59827 */
+/* { dg-do compile } */
+
+int
+foo (int p[2][]) /* { dg-error "array type has incomplete element type" } */
+{
+  return p[0][0];
+}
+
+void
+bar (void)
+{
+  int p[2][1];
+  foo (p); /* { dg-error "type of formal parameter 1 is incomplete" } */
+}