aboutsummaryrefslogtreecommitdiffstats
path: root/toolchain-layer/recipes-devtools/gcc/gcc-4.5/more-epilogues.patch
diff options
context:
space:
mode:
Diffstat (limited to 'toolchain-layer/recipes-devtools/gcc/gcc-4.5/more-epilogues.patch')
-rw-r--r--toolchain-layer/recipes-devtools/gcc/gcc-4.5/more-epilogues.patch83
1 files changed, 0 insertions, 83 deletions
diff --git a/toolchain-layer/recipes-devtools/gcc/gcc-4.5/more-epilogues.patch b/toolchain-layer/recipes-devtools/gcc/gcc-4.5/more-epilogues.patch
deleted file mode 100644
index 64f1cf3751..0000000000
--- a/toolchain-layer/recipes-devtools/gcc/gcc-4.5/more-epilogues.patch
+++ /dev/null
@@ -1,83 +0,0 @@
-Index: a/gcc/cfgcleanup.c
-===================================================================
---- a/gcc/cfgcleanup.c (revision 315947)
-+++ b/gcc/cfgcleanup.c (working copy)
-@@ -1179,13 +1179,19 @@ flow_find_head_matching_sequence (basic_
-
- while (true)
- {
--
-- /* Ignore notes. */
-+ /* Ignore notes, except NOTE_INSN_EPILOGUE_BEG. */
- while (!NONDEBUG_INSN_P (i1) && i1 != BB_END (bb1))
-- i1 = NEXT_INSN (i1);
--
-+ {
-+ if (NOTE_P (i1) && NOTE_KIND (i1) == NOTE_INSN_EPILOGUE_BEG)
-+ break;
-+ i1 = NEXT_INSN (i1);
-+ }
- while (!NONDEBUG_INSN_P (i2) && i2 != BB_END (bb2))
-- i2 = NEXT_INSN (i2);
-+ {
-+ if (NOTE_P (i2) && NOTE_KIND (i2) == NOTE_INSN_EPILOGUE_BEG)
-+ break;
-+ i2 = NEXT_INSN (i2);
-+ }
-
- if (NOTE_P (i1) || NOTE_P (i2)
- || JUMP_P (i1) || JUMP_P (i2))
-Index: a/gcc/cfglayout.c
-===================================================================
---- a/gcc/cfglayout.c (revision 315947)
-+++ b/gcc/cfglayout.c (working copy)
-@@ -1295,6 +1295,16 @@ cfg_layout_initialize (unsigned int flag
- bb->flags |= BB_NON_LOCAL_GOTO_TARGET;
- }
-
-+ FOR_EACH_BB (bb)
-+ {
-+ rtx insn;
-+ FOR_BB_INSNS (bb, insn)
-+ if (NOTE_P (insn) && NOTE_KIND (insn) == NOTE_INSN_EPILOGUE_BEG)
-+ {
-+ bb->flags |= BB_EPILOGUE_BEGIN;
-+ break;
-+ }
-+ }
- cleanup_cfg (CLEANUP_CFGLAYOUT | flags);
- }
-
-Index: a/gcc/basic-block.h
-===================================================================
---- a/gcc/basic-block.h (revision 315947)
-+++ b/gcc/basic-block.h (working copy)
-@@ -332,7 +332,11 @@ enum bb_flags
-
- /* Set on blocks that cannot be threaded through.
- Only used in cfgcleanup.c. */
-- BB_NONTHREADABLE_BLOCK = 1 << 11
-+ BB_NONTHREADABLE_BLOCK = 1 << 11,
-+
-+ /* Set on blocks that have a NOTE_INSN_EPILOGUE_BEGIN.
-+ Only used in cfglayout mode. */
-+ BB_EPILOGUE_BEGIN = 1 << 12
- };
-
- /* Dummy flag for convenience in the hot/cold partitioning code. */
-Index: a/gcc/cfgrtl.c
-===================================================================
---- a/gcc/cfgrtl.c (revision 315947)
-+++ b/gcc/cfgrtl.c (working copy)
-@@ -2707,7 +2707,10 @@ cfg_layout_can_merge_blocks_p (basic_blo
- not allow us to redirect an edge by replacing a table jump. */
- && (!JUMP_P (BB_END (a))
- || ((!optimize || reload_completed)
-- ? simplejump_p (BB_END (a)) : onlyjump_p (BB_END (a)))));
-+ ? simplejump_p (BB_END (a)) : onlyjump_p (BB_END (a))))
-+ /* Don't separate a NOTE_INSN_EPILOGUE_BEG from its returnjump. */
-+ && (!(b->flags & BB_EPILOGUE_BEGIN)
-+ || returnjump_p (BB_END (b))));
- }
-
- /* Merge block A and B. The blocks must be mergeable. */