re PR middle-end/46515 (Many libjava failures)
authorRichard Henderson <rth@redhat.com>
Thu, 18 Nov 2010 21:08:38 +0000 (13:08 -0800)
committerRichard Henderson <rth@gcc.gnu.org>
Thu, 18 Nov 2010 21:08:38 +0000 (13:08 -0800)
PR middle-end/46515
        * function.c (maybe_copy_prologue_epilogue_insn): Rename from
        maybe_copy_epilogue_insn; handle prologue insns as well.
        * rtl.h, cfglayout.c: Update for rename.
        * recog.c (peep2_attempt): Copy prologue/epilogue data for
        RTX_FRAME_RELATED_P insns.

From-SVN: r166920

gcc/ChangeLog
gcc/cfglayout.c
gcc/function.c
gcc/recog.c
gcc/rtl.h

index 12eaf9c626c31c78e7cd67cbd7ac7f3869a94251..62adb269db068be134ea173d2ddbc138ecc71556 100644 (file)
@@ -1,3 +1,12 @@
+2010-11-18  Richard Henderson  <rth@redhat.com>
+
+       PR middle-end/46515
+       * function.c (maybe_copy_prologue_epilogue_insn): Rename from
+       maybe_copy_epilogue_insn; handle prologue insns as well.
+       * rtl.h, cfglayout.c: Update for rename.
+       * recog.c (peep2_attempt): Copy prologue/epilogue data for
+       RTX_FRAME_RELATED_P insns.
+
 2010-11-18  Jakub Jelinek  <jakub@redhat.com>
 
        PR middle-end/46534
index be99991e8db1d29bf41768192a8abc0b17f0a17a..e883af4afabd337ab28d80caa85de91fe2c0565c 100644 (file)
@@ -1179,7 +1179,7 @@ duplicate_insn_chain (rtx from, rtx to)
              || GET_CODE (PATTERN (insn)) == ADDR_DIFF_VEC)
            break;
          copy = emit_copy_of_insn_after (insn, get_last_insn ());
-          maybe_copy_epilogue_insn (insn, copy);
+          maybe_copy_prologue_epilogue_insn (insn, copy);
          break;
 
        case CODE_LABEL:
index b9805dcd0910ec54627b7fa364e9337ac6449876..0ed674d4b3c7bf9d7c66ac55d30d6288346879fb 100644 (file)
@@ -5140,19 +5140,25 @@ record_insns (rtx insns, rtx end, htab_t *hashp)
     }
 }
 
-/* INSN has been duplicated as COPY, as part of duping a basic block.
-   If INSN is an epilogue insn, then record COPY as epilogue as well.  */
+/* INSN has been duplicated or replaced by as COPY, perhaps by duplicating a
+   basic block, splitting or peepholes.  If INSN is a prologue or epilogue
+   insn, then record COPY as well.  */
 
 void
-maybe_copy_epilogue_insn (rtx insn, rtx copy)
+maybe_copy_prologue_epilogue_insn (rtx insn, rtx copy)
 {
+  htab_t hash;
   void **slot;
 
-  if (epilogue_insn_hash == NULL
-      || htab_find (epilogue_insn_hash, insn) == NULL)
-    return;
+  hash = epilogue_insn_hash;
+  if (!hash || !htab_find (hash, insn))
+    {
+      hash = prologue_insn_hash;
+      if (!hash || !htab_find (hash, insn))
+       return;
+    }
 
-  slot = htab_find_slot (epilogue_insn_hash, copy, INSERT);
+  slot = htab_find_slot (hash, copy, INSERT);
   gcc_assert (*slot == NULL);
   *slot = copy;
 }
index b140c0e17ddb98c83a23fb0d67512a84e8292bf1..edbf82b004da3f70dc600b5b5603bcfb6a40a1e6 100644 (file)
@@ -3219,6 +3219,10 @@ peep2_attempt (basic_block bb, rtx insn, int match_len, rtx attempt)
          if (!new_set || !rtx_equal_p (new_set, old_set))
            add_reg_note (new_insn, REG_FRAME_RELATED_EXPR, old_set);
        }
+
+      /* Copy prologue/epilogue status.  This is required in order to keep
+        proper placement of EPILOGUE_BEG and the DW_CFA_remember_state.  */
+      maybe_copy_prologue_epilogue_insn (old_insn, new_insn);
     }
 
   /* If we are splitting a CALL_INSN, look for the CALL_INSN
index 745d6f437ec51472c653ef294b37a42355e403f5..ab215d6ea480de0411771907e4245cf26469f685 100644 (file)
--- a/gcc/rtl.h
+++ b/gcc/rtl.h
@@ -2411,7 +2411,7 @@ extern int prologue_epilogue_contains (const_rtx);
 extern int sibcall_epilogue_contains (const_rtx);
 extern void mark_temp_addr_taken (rtx);
 extern void update_temp_slot_address (rtx, rtx);
-extern void maybe_copy_epilogue_insn (rtx, rtx);
+extern void maybe_copy_prologue_epilogue_insn (rtx, rtx);
 
 /* In stmt.c */
 extern void expand_null_return (void);