tree-sra.c (build_access_from_expr_1): Use more precise diagnostics for storage order...
authorEric Botcazou <ebotcazou@adacore.com>
Fri, 11 Aug 2017 13:06:43 +0000 (13:06 +0000)
committerEric Botcazou <ebotcazou@gcc.gnu.org>
Fri, 11 Aug 2017 13:06:43 +0000 (13:06 +0000)
* tree-sra.c (build_access_from_expr_1): Use more precise diagnostics
for storage order barriers.

From-SVN: r251050

gcc/ChangeLog
gcc/tree-sra.c

index 9be7f17931cdbd6ecfaae15e6add508ccddaabea..94fb7f805aaf804d6e7563054593dcb72a0f214c 100644 (file)
@@ -1,3 +1,8 @@
+2017-08-11  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-sra.c (build_access_from_expr_1): Use more precise diagnostics
+       for storage order barriers.
+
 2017-08-11  Martin Liska  <mliska@suse.cz>
 
        PR tree-opt/79987
index c9865c6eb318cd00f3e9db5a2ec47527f4a1eb1f..68edbce21b327589ddc8098a5f956f7f74ca77f1 100644 (file)
@@ -1175,11 +1175,17 @@ build_access_from_expr_1 (tree expr, gimple *stmt, bool write)
   else
     partial_ref = false;
 
+  if (storage_order_barrier_p (expr))
+    {
+      disqualify_base_of_expr (expr, "storage order barrier.");
+      return NULL;
+    }
+
   /* We need to dive through V_C_Es in order to get the size of its parameter
      and not the result type.  Ada produces such statements.  We are also
      capable of handling the topmost V_C_E but not any of those buried in other
      handled components.  */
-  if (TREE_CODE (expr) == VIEW_CONVERT_EXPR && !storage_order_barrier_p (expr))
+  if (TREE_CODE (expr) == VIEW_CONVERT_EXPR)
     expr = TREE_OPERAND (expr, 0);
 
   if (contains_view_convert_expr_p (expr))