re PR middle-end/28713 (GNU OpenMP produces type mismatches)
authorJakub Jelinek <jakub@redhat.com>
Tue, 15 Aug 2006 14:57:52 +0000 (16:57 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Tue, 15 Aug 2006 14:57:52 +0000 (16:57 +0200)
PR middle-end/28713
* omp-low.c (lower_omp_parallel): Convert t to
receiver_decl's type.
(expand_omp_parallel): STRIP_NOPS from the MODIFY_EXPR
source before comparison.

From-SVN: r116154

gcc/ChangeLog
gcc/omp-low.c

index 1da5d559fb1acbe995ad789c103c5a87273bc766..033b64bfa243d39f9b33eaea779f9c25c253f13c 100644 (file)
@@ -1,5 +1,11 @@
 2006-08-15  Jakub Jelinek  <jakub@redhat.com>
 
+       PR middle-end/28713
+       * omp-low.c (lower_omp_parallel): Convert t to
+       receiver_decl's type.
+       (expand_omp_parallel): STRIP_NOPS from the MODIFY_EXPR
+       source before comparison.
+
        PR middle-end/28724
        * gimplify.c (gimplify_omp_atomic_pipeline): Convert oldival
        to itype in assignment to oldival2.
index e8e835190e85e5e58b31a3dfccc6283df001f014..b76e00ced115e4ffedd32f29370b22f58f604bb3 100644 (file)
@@ -2475,13 +2475,17 @@ expand_omp_parallel (struct omp_region *region)
 
          for (si = bsi_start (entry_succ_bb); ; bsi_next (&si))
            {
-             tree stmt;
+             tree stmt, arg;
 
              gcc_assert (!bsi_end_p (si));
              stmt = bsi_stmt (si);
-             if (TREE_CODE (stmt) == MODIFY_EXPR
-                 && TREE_CODE (TREE_OPERAND (stmt, 1)) == ADDR_EXPR
-                 && TREE_OPERAND (TREE_OPERAND (stmt, 1), 0)
+             if (TREE_CODE (stmt) != MODIFY_EXPR)
+               continue;
+
+             arg = TREE_OPERAND (stmt, 1);
+             STRIP_NOPS (arg);
+             if (TREE_CODE (arg) == ADDR_EXPR
+                 && TREE_OPERAND (arg, 0)
                     == OMP_PARALLEL_DATA_ARG (entry_stmt))
                {
                  if (TREE_OPERAND (stmt, 0) == DECL_ARGUMENTS (child_fn))
@@ -4084,6 +4088,8 @@ lower_omp_parallel (tree *stmt_p, omp_context *ctx)
   if (ctx->record_type)
     {
       t = build_fold_addr_expr (ctx->sender_decl);
+      /* fixup_child_record_type might have changed receiver_decl's type.  */
+      t = fold_convert (TREE_TYPE (ctx->receiver_decl), t);
       t = build2 (MODIFY_EXPR, void_type_node, ctx->receiver_decl, t);
       append_to_statement_list (t, &new_body);
     }