1 /* Control flow optimization code for GNU compiler.
2 Copyright (C) 1987, 1988, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3 1999, 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
5 This file is part of GCC.
7 GCC is free software; you can redistribute it and/or modify it under
8 the terms of the GNU General Public License as published by the Free
9 Software Foundation; either version 2, or (at your option) any later
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING. If not, write to the Free
19 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
22 /* This file contains optimizer of the control flow. The main entry point is
23 cleanup_cfg. Following optimizations are performed:
25 - Unreachable blocks removal
26 - Edge forwarding (edge to the forwarder block is forwarded to its
27 successor. Simplification of the branch instruction is performed by
28 underlying infrastructure so branch can be converted to simplejump or
30 - Cross jumping (tail merging)
31 - Conditional jump-around-simplejump simplification
32 - Basic block merging. */
36 #include "coretypes.h"
39 #include "hard-reg-set.h"
43 #include "insn-config.h"
51 #include "cfglayout.h"
54 /* cleanup_cfg maintains following flags for each basic block. */
58 /* Set if BB is the forwarder block to avoid too many
59 forwarder_block_p calls. */
60 BB_FORWARDER_BLOCK
= 1,
61 BB_NONTHREADABLE_BLOCK
= 2
64 #define BB_FLAGS(BB) (enum bb_flags) (BB)->aux
65 #define BB_SET_FLAG(BB, FLAG) \
66 (BB)->aux = (void *) (long) ((enum bb_flags) (BB)->aux | (FLAG))
67 #define BB_CLEAR_FLAG(BB, FLAG) \
68 (BB)->aux = (void *) (long) ((enum bb_flags) (BB)->aux & ~(FLAG))
70 #define FORWARDER_BLOCK_P(BB) (BB_FLAGS (BB) & BB_FORWARDER_BLOCK)
72 /* Set to true when we are running first pass of try_optimize_cfg loop. */
73 static bool first_pass
;
74 static bool try_crossjump_to_edge (int, edge
, edge
);
75 static bool try_crossjump_bb (int, basic_block
);
76 static bool outgoing_edges_match (int, basic_block
, basic_block
);
77 static int flow_find_cross_jump (int, basic_block
, basic_block
, rtx
*, rtx
*);
78 static bool insns_match_p (int, rtx
, rtx
);
80 static void merge_blocks_move_predecessor_nojumps (basic_block
, basic_block
);
81 static void merge_blocks_move_successor_nojumps (basic_block
, basic_block
);
82 static bool try_optimize_cfg (int);
83 static bool try_simplify_condjump (basic_block
);
84 static bool try_forward_edges (int, basic_block
);
85 static edge
thread_jump (int, edge
, basic_block
);
86 static bool mark_effect (rtx
, bitmap
);
87 static void notice_new_block (basic_block
);
88 static void update_forwarder_flag (basic_block
);
89 static int mentions_nonequal_regs (rtx
*, void *);
90 static void merge_memattrs (rtx
, rtx
);
92 /* Set flags for newly created block. */
95 notice_new_block (basic_block bb
)
100 if (forwarder_block_p (bb
))
101 BB_SET_FLAG (bb
, BB_FORWARDER_BLOCK
);
104 /* Recompute forwarder flag after block has been modified. */
107 update_forwarder_flag (basic_block bb
)
109 if (forwarder_block_p (bb
))
110 BB_SET_FLAG (bb
, BB_FORWARDER_BLOCK
);
112 BB_CLEAR_FLAG (bb
, BB_FORWARDER_BLOCK
);
115 /* Simplify a conditional jump around an unconditional jump.
116 Return true if something changed. */
119 try_simplify_condjump (basic_block cbranch_block
)
121 basic_block jump_block
, jump_dest_block
, cbranch_dest_block
;
122 edge cbranch_jump_edge
, cbranch_fallthru_edge
;
125 /* Verify that there are exactly two successors. */
126 if (EDGE_COUNT (cbranch_block
->succs
) != 2)
129 /* Verify that we've got a normal conditional branch at the end
131 cbranch_insn
= BB_END (cbranch_block
);
132 if (!any_condjump_p (cbranch_insn
))
135 cbranch_fallthru_edge
= FALLTHRU_EDGE (cbranch_block
);
136 cbranch_jump_edge
= BRANCH_EDGE (cbranch_block
);
138 /* The next block must not have multiple predecessors, must not
139 be the last block in the function, and must contain just the
140 unconditional jump. */
141 jump_block
= cbranch_fallthru_edge
->dest
;
142 if (!single_pred_p (jump_block
)
143 || jump_block
->next_bb
== EXIT_BLOCK_PTR
144 || !FORWARDER_BLOCK_P (jump_block
))
146 jump_dest_block
= single_succ (jump_block
);
148 /* If we are partitioning hot/cold basic blocks, we don't want to
149 mess up unconditional or indirect jumps that cross between hot
152 Basic block partitioning may result in some jumps that appear to
153 be optimizable (or blocks that appear to be mergeable), but which really
154 must be left untouched (they are required to make it safely across
155 partition boundaries). See the comments at the top of
156 bb-reorder.c:partition_hot_cold_basic_blocks for complete details. */
158 if (BB_PARTITION (jump_block
) != BB_PARTITION (jump_dest_block
)
159 || (cbranch_jump_edge
->flags
& EDGE_CROSSING
))
162 /* The conditional branch must target the block after the
163 unconditional branch. */
164 cbranch_dest_block
= cbranch_jump_edge
->dest
;
166 if (cbranch_dest_block
== EXIT_BLOCK_PTR
167 || !can_fallthru (jump_block
, cbranch_dest_block
))
170 /* Invert the conditional branch. */
171 if (!invert_jump (cbranch_insn
, block_label (jump_dest_block
), 0))
175 fprintf (dump_file
, "Simplifying condjump %i around jump %i\n",
176 INSN_UID (cbranch_insn
), INSN_UID (BB_END (jump_block
)));
178 /* Success. Update the CFG to match. Note that after this point
179 the edge variable names appear backwards; the redirection is done
180 this way to preserve edge profile data. */
181 cbranch_jump_edge
= redirect_edge_succ_nodup (cbranch_jump_edge
,
183 cbranch_fallthru_edge
= redirect_edge_succ_nodup (cbranch_fallthru_edge
,
185 cbranch_jump_edge
->flags
|= EDGE_FALLTHRU
;
186 cbranch_fallthru_edge
->flags
&= ~EDGE_FALLTHRU
;
187 update_br_prob_note (cbranch_block
);
189 /* Delete the block with the unconditional jump, and clean up the mess. */
190 delete_basic_block (jump_block
);
191 tidy_fallthru_edge (cbranch_jump_edge
);
192 update_forwarder_flag (cbranch_block
);
197 /* Attempt to prove that operation is NOOP using CSElib or mark the effect
198 on register. Used by jump threading. */
201 mark_effect (rtx exp
, regset nonequal
)
205 switch (GET_CODE (exp
))
207 /* In case we do clobber the register, mark it as equal, as we know the
208 value is dead so it don't have to match. */
210 if (REG_P (XEXP (exp
, 0)))
212 dest
= XEXP (exp
, 0);
213 regno
= REGNO (dest
);
214 CLEAR_REGNO_REG_SET (nonequal
, regno
);
215 if (regno
< FIRST_PSEUDO_REGISTER
)
217 int n
= hard_regno_nregs
[regno
][GET_MODE (dest
)];
219 CLEAR_REGNO_REG_SET (nonequal
, regno
+ n
);
225 if (rtx_equal_for_cselib_p (SET_DEST (exp
), SET_SRC (exp
)))
227 dest
= SET_DEST (exp
);
232 regno
= REGNO (dest
);
233 SET_REGNO_REG_SET (nonequal
, regno
);
234 if (regno
< FIRST_PSEUDO_REGISTER
)
236 int n
= hard_regno_nregs
[regno
][GET_MODE (dest
)];
238 SET_REGNO_REG_SET (nonequal
, regno
+ n
);
247 /* Return nonzero if X is a register set in regset DATA.
248 Called via for_each_rtx. */
250 mentions_nonequal_regs (rtx
*x
, void *data
)
252 regset nonequal
= (regset
) data
;
258 if (REGNO_REG_SET_P (nonequal
, regno
))
260 if (regno
< FIRST_PSEUDO_REGISTER
)
262 int n
= hard_regno_nregs
[regno
][GET_MODE (*x
)];
264 if (REGNO_REG_SET_P (nonequal
, regno
+ n
))
270 /* Attempt to prove that the basic block B will have no side effects and
271 always continues in the same edge if reached via E. Return the edge
272 if exist, NULL otherwise. */
275 thread_jump (int mode
, edge e
, basic_block b
)
277 rtx set1
, set2
, cond1
, cond2
, insn
;
278 enum rtx_code code1
, code2
, reversed_code2
;
279 bool reverse1
= false;
283 reg_set_iterator rsi
;
285 if (BB_FLAGS (b
) & BB_NONTHREADABLE_BLOCK
)
288 /* At the moment, we do handle only conditional jumps, but later we may
289 want to extend this code to tablejumps and others. */
290 if (EDGE_COUNT (e
->src
->succs
) != 2)
292 if (EDGE_COUNT (b
->succs
) != 2)
294 BB_SET_FLAG (b
, BB_NONTHREADABLE_BLOCK
);
298 /* Second branch must end with onlyjump, as we will eliminate the jump. */
299 if (!any_condjump_p (BB_END (e
->src
)))
302 if (!any_condjump_p (BB_END (b
)) || !onlyjump_p (BB_END (b
)))
304 BB_SET_FLAG (b
, BB_NONTHREADABLE_BLOCK
);
308 set1
= pc_set (BB_END (e
->src
));
309 set2
= pc_set (BB_END (b
));
310 if (((e
->flags
& EDGE_FALLTHRU
) != 0)
311 != (XEXP (SET_SRC (set1
), 1) == pc_rtx
))
314 cond1
= XEXP (SET_SRC (set1
), 0);
315 cond2
= XEXP (SET_SRC (set2
), 0);
317 code1
= reversed_comparison_code (cond1
, BB_END (e
->src
));
319 code1
= GET_CODE (cond1
);
321 code2
= GET_CODE (cond2
);
322 reversed_code2
= reversed_comparison_code (cond2
, BB_END (b
));
324 if (!comparison_dominates_p (code1
, code2
)
325 && !comparison_dominates_p (code1
, reversed_code2
))
328 /* Ensure that the comparison operators are equivalent.
329 ??? This is far too pessimistic. We should allow swapped operands,
330 different CCmodes, or for example comparisons for interval, that
331 dominate even when operands are not equivalent. */
332 if (!rtx_equal_p (XEXP (cond1
, 0), XEXP (cond2
, 0))
333 || !rtx_equal_p (XEXP (cond1
, 1), XEXP (cond2
, 1)))
336 /* Short circuit cases where block B contains some side effects, as we can't
338 for (insn
= NEXT_INSN (BB_HEAD (b
)); insn
!= NEXT_INSN (BB_END (b
));
339 insn
= NEXT_INSN (insn
))
340 if (INSN_P (insn
) && side_effects_p (PATTERN (insn
)))
342 BB_SET_FLAG (b
, BB_NONTHREADABLE_BLOCK
);
348 /* First process all values computed in the source basic block. */
349 for (insn
= NEXT_INSN (BB_HEAD (e
->src
));
350 insn
!= NEXT_INSN (BB_END (e
->src
));
351 insn
= NEXT_INSN (insn
))
353 cselib_process_insn (insn
);
355 nonequal
= BITMAP_ALLOC (NULL
);
356 CLEAR_REG_SET (nonequal
);
358 /* Now assume that we've continued by the edge E to B and continue
359 processing as if it were same basic block.
360 Our goal is to prove that whole block is an NOOP. */
362 for (insn
= NEXT_INSN (BB_HEAD (b
));
363 insn
!= NEXT_INSN (BB_END (b
)) && !failed
;
364 insn
= NEXT_INSN (insn
))
368 rtx pat
= PATTERN (insn
);
370 if (GET_CODE (pat
) == PARALLEL
)
372 for (i
= 0; i
< (unsigned)XVECLEN (pat
, 0); i
++)
373 failed
|= mark_effect (XVECEXP (pat
, 0, i
), nonequal
);
376 failed
|= mark_effect (pat
, nonequal
);
379 cselib_process_insn (insn
);
382 /* Later we should clear nonequal of dead registers. So far we don't
383 have life information in cfg_cleanup. */
386 BB_SET_FLAG (b
, BB_NONTHREADABLE_BLOCK
);
390 /* cond2 must not mention any register that is not equal to the
392 if (for_each_rtx (&cond2
, mentions_nonequal_regs
, nonequal
))
395 /* In case liveness information is available, we need to prove equivalence
396 only of the live values. */
397 if (mode
& CLEANUP_UPDATE_LIFE
)
398 AND_REG_SET (nonequal
, b
->il
.rtl
->global_live_at_end
);
400 EXECUTE_IF_SET_IN_REG_SET (nonequal
, 0, i
, rsi
)
403 BITMAP_FREE (nonequal
);
405 if ((comparison_dominates_p (code1
, code2
) != 0)
406 != (XEXP (SET_SRC (set2
), 1) == pc_rtx
))
407 return BRANCH_EDGE (b
);
409 return FALLTHRU_EDGE (b
);
412 BITMAP_FREE (nonequal
);
417 /* Attempt to forward edges leaving basic block B.
418 Return true if successful. */
421 try_forward_edges (int mode
, basic_block b
)
423 bool changed
= false;
425 edge e
, *threaded_edges
= NULL
;
427 /* If we are partitioning hot/cold basic blocks, we don't want to
428 mess up unconditional or indirect jumps that cross between hot
431 Basic block partitioning may result in some jumps that appear to
432 be optimizable (or blocks that appear to be mergeable), but which really m
433 ust be left untouched (they are required to make it safely across
434 partition boundaries). See the comments at the top of
435 bb-reorder.c:partition_hot_cold_basic_blocks for complete details. */
437 if (find_reg_note (BB_END (b
), REG_CROSSING_JUMP
, NULL_RTX
))
440 for (ei
= ei_start (b
->succs
); (e
= ei_safe_edge (ei
)); )
442 basic_block target
, first
;
444 bool threaded
= false;
445 int nthreaded_edges
= 0;
446 bool may_thread
= first_pass
| (b
->flags
& BB_DIRTY
);
448 /* Skip complex edges because we don't know how to update them.
450 Still handle fallthru edges, as we can succeed to forward fallthru
451 edge to the same place as the branch edge of conditional branch
452 and turn conditional branch to an unconditional branch. */
453 if (e
->flags
& EDGE_COMPLEX
)
459 target
= first
= e
->dest
;
462 /* If we are partitioning hot/cold basic_blocks, we don't want to mess
463 up jumps that cross between hot/cold sections.
465 Basic block partitioning may result in some jumps that appear
466 to be optimizable (or blocks that appear to be mergeable), but which
467 really must be left untouched (they are required to make it safely
468 across partition boundaries). See the comments at the top of
469 bb-reorder.c:partition_hot_cold_basic_blocks for complete
472 if (first
!= EXIT_BLOCK_PTR
473 && find_reg_note (BB_END (first
), REG_CROSSING_JUMP
, NULL_RTX
))
476 while (counter
< n_basic_blocks
)
478 basic_block new_target
= NULL
;
479 bool new_target_threaded
= false;
480 may_thread
|= target
->flags
& BB_DIRTY
;
482 if (FORWARDER_BLOCK_P (target
)
483 && !(single_succ_edge (target
)->flags
& EDGE_CROSSING
)
484 && single_succ (target
) != EXIT_BLOCK_PTR
)
486 /* Bypass trivial infinite loops. */
487 new_target
= single_succ (target
);
488 if (target
== new_target
)
489 counter
= n_basic_blocks
;
492 /* Allow to thread only over one edge at time to simplify updating
494 else if ((mode
& CLEANUP_THREADING
) && may_thread
)
496 edge t
= thread_jump (mode
, e
, target
);
500 threaded_edges
= xmalloc (sizeof (*threaded_edges
)
506 /* Detect an infinite loop across blocks not
507 including the start block. */
508 for (i
= 0; i
< nthreaded_edges
; ++i
)
509 if (threaded_edges
[i
] == t
)
511 if (i
< nthreaded_edges
)
513 counter
= n_basic_blocks
;
518 /* Detect an infinite loop across the start block. */
522 gcc_assert (nthreaded_edges
< n_basic_blocks
);
523 threaded_edges
[nthreaded_edges
++] = t
;
525 new_target
= t
->dest
;
526 new_target_threaded
= true;
533 /* Avoid killing of loop pre-headers, as it is the place loop
534 optimizer wants to hoist code to.
536 For fallthru forwarders, the LOOP_BEG note must appear between
537 the header of block and CODE_LABEL of the loop, for non forwarders
538 it must appear before the JUMP_INSN. */
539 if ((mode
& CLEANUP_PRE_LOOP
) && optimize
&& flag_loop_optimize
)
541 rtx insn
= (EDGE_SUCC (target
, 0)->flags
& EDGE_FALLTHRU
542 ? BB_HEAD (target
) : prev_nonnote_insn (BB_END (target
)));
545 insn
= NEXT_INSN (insn
);
547 for (; insn
&& !LABEL_P (insn
) && !INSN_P (insn
);
548 insn
= NEXT_INSN (insn
))
550 && NOTE_LINE_NUMBER (insn
) == NOTE_INSN_LOOP_BEG
)
556 /* Do not clean up branches to just past the end of a loop
557 at this time; it can mess up the loop optimizer's
558 recognition of some patterns. */
560 insn
= PREV_INSN (BB_HEAD (target
));
561 if (insn
&& NOTE_P (insn
)
562 && NOTE_LINE_NUMBER (insn
) == NOTE_INSN_LOOP_END
)
568 threaded
|= new_target_threaded
;
571 if (counter
>= n_basic_blocks
)
574 fprintf (dump_file
, "Infinite loop in BB %i.\n",
577 else if (target
== first
)
578 ; /* We didn't do anything. */
581 /* Save the values now, as the edge may get removed. */
582 gcov_type edge_count
= e
->count
;
583 int edge_probability
= e
->probability
;
587 /* Don't force if target is exit block. */
588 if (threaded
&& target
!= EXIT_BLOCK_PTR
)
590 notice_new_block (redirect_edge_and_branch_force (e
, target
));
592 fprintf (dump_file
, "Conditionals threaded.\n");
594 else if (!redirect_edge_and_branch (e
, target
))
598 "Forwarding edge %i->%i to %i failed.\n",
599 b
->index
, e
->dest
->index
, target
->index
);
604 /* We successfully forwarded the edge. Now update profile
605 data: for each edge we traversed in the chain, remove
606 the original edge's execution count. */
607 edge_frequency
= ((edge_probability
* b
->frequency
608 + REG_BR_PROB_BASE
/ 2)
611 if (!FORWARDER_BLOCK_P (b
) && forwarder_block_p (b
))
612 BB_SET_FLAG (b
, BB_FORWARDER_BLOCK
);
618 if (!single_succ_p (first
))
620 gcc_assert (n
< nthreaded_edges
);
621 t
= threaded_edges
[n
++];
622 gcc_assert (t
->src
== first
);
623 update_bb_profile_for_threading (first
, edge_frequency
,
625 update_br_prob_note (first
);
629 first
->count
-= edge_count
;
630 if (first
->count
< 0)
632 first
->frequency
-= edge_frequency
;
633 if (first
->frequency
< 0)
634 first
->frequency
= 0;
635 /* It is possible that as the result of
636 threading we've removed edge as it is
637 threaded to the fallthru edge. Avoid
638 getting out of sync. */
639 if (n
< nthreaded_edges
640 && first
== threaded_edges
[n
]->src
)
642 t
= single_succ_edge (first
);
645 t
->count
-= edge_count
;
650 while (first
!= target
);
659 free (threaded_edges
);
664 /* Blocks A and B are to be merged into a single block. A has no incoming
665 fallthru edge, so it can be moved before B without adding or modifying
666 any jumps (aside from the jump from A to B). */
669 merge_blocks_move_predecessor_nojumps (basic_block a
, basic_block b
)
674 /* If we are partitioning hot/cold basic blocks, we don't want to
675 mess up unconditional or indirect jumps that cross between hot
678 Basic block partitioning may result in some jumps that appear to
679 be optimizable (or blocks that appear to be mergeable), but which really
680 must be left untouched (they are required to make it safely across
681 partition boundaries). See the comments at the top of
682 bb-reorder.c:partition_hot_cold_basic_blocks for complete details. */
684 if (BB_PARTITION (a
) != BB_PARTITION (b
))
687 barrier
= next_nonnote_insn (BB_END (a
));
688 gcc_assert (BARRIER_P (barrier
));
689 delete_insn (barrier
);
691 /* Move block and loop notes out of the chain so that we do not
694 ??? A better solution would be to squeeze out all the non-nested notes
695 and adjust the block trees appropriately. Even better would be to have
696 a tighter connection between block trees and rtl so that this is not
698 only_notes
= squeeze_notes (&BB_HEAD (a
), &BB_END (a
));
699 gcc_assert (!only_notes
);
701 /* Scramble the insn chain. */
702 if (BB_END (a
) != PREV_INSN (BB_HEAD (b
)))
703 reorder_insns_nobb (BB_HEAD (a
), BB_END (a
), PREV_INSN (BB_HEAD (b
)));
704 a
->flags
|= BB_DIRTY
;
707 fprintf (dump_file
, "Moved block %d before %d and merged.\n",
710 /* Swap the records for the two blocks around. */
713 link_block (a
, b
->prev_bb
);
715 /* Now blocks A and B are contiguous. Merge them. */
719 /* Blocks A and B are to be merged into a single block. B has no outgoing
720 fallthru edge, so it can be moved after A without adding or modifying
721 any jumps (aside from the jump from A to B). */
724 merge_blocks_move_successor_nojumps (basic_block a
, basic_block b
)
726 rtx barrier
, real_b_end
;
730 /* If we are partitioning hot/cold basic blocks, we don't want to
731 mess up unconditional or indirect jumps that cross between hot
734 Basic block partitioning may result in some jumps that appear to
735 be optimizable (or blocks that appear to be mergeable), but which really
736 must be left untouched (they are required to make it safely across
737 partition boundaries). See the comments at the top of
738 bb-reorder.c:partition_hot_cold_basic_blocks for complete details. */
740 if (BB_PARTITION (a
) != BB_PARTITION (b
))
743 real_b_end
= BB_END (b
);
745 /* If there is a jump table following block B temporarily add the jump table
746 to block B so that it will also be moved to the correct location. */
747 if (tablejump_p (BB_END (b
), &label
, &table
)
748 && prev_active_insn (label
) == BB_END (b
))
753 /* There had better have been a barrier there. Delete it. */
754 barrier
= NEXT_INSN (BB_END (b
));
755 if (barrier
&& BARRIER_P (barrier
))
756 delete_insn (barrier
);
758 /* Move block and loop notes out of the chain so that we do not
761 ??? A better solution would be to squeeze out all the non-nested notes
762 and adjust the block trees appropriately. Even better would be to have
763 a tighter connection between block trees and rtl so that this is not
765 only_notes
= squeeze_notes (&BB_HEAD (b
), &BB_END (b
));
766 gcc_assert (!only_notes
);
769 /* Scramble the insn chain. */
770 reorder_insns_nobb (BB_HEAD (b
), BB_END (b
), BB_END (a
));
772 /* Restore the real end of b. */
773 BB_END (b
) = real_b_end
;
776 fprintf (dump_file
, "Moved block %d after %d and merged.\n",
779 /* Now blocks A and B are contiguous. Merge them. */
783 /* Attempt to merge basic blocks that are potentially non-adjacent.
784 Return NULL iff the attempt failed, otherwise return basic block
785 where cleanup_cfg should continue. Because the merging commonly
786 moves basic block away or introduces another optimization
787 possibility, return basic block just before B so cleanup_cfg don't
790 It may be good idea to return basic block before C in the case
791 C has been moved after B and originally appeared earlier in the
792 insn sequence, but we have no information available about the
793 relative ordering of these two. Hopefully it is not too common. */
796 merge_blocks_move (edge e
, basic_block b
, basic_block c
, int mode
)
800 /* If we are partitioning hot/cold basic blocks, we don't want to
801 mess up unconditional or indirect jumps that cross between hot
804 Basic block partitioning may result in some jumps that appear to
805 be optimizable (or blocks that appear to be mergeable), but which really
806 must be left untouched (they are required to make it safely across
807 partition boundaries). See the comments at the top of
808 bb-reorder.c:partition_hot_cold_basic_blocks for complete details. */
810 if (BB_PARTITION (b
) != BB_PARTITION (c
))
815 /* If B has a fallthru edge to C, no need to move anything. */
816 if (e
->flags
& EDGE_FALLTHRU
)
818 int b_index
= b
->index
, c_index
= c
->index
;
820 update_forwarder_flag (b
);
823 fprintf (dump_file
, "Merged %d and %d without moving.\n",
826 return b
->prev_bb
== ENTRY_BLOCK_PTR
? b
: b
->prev_bb
;
829 /* Otherwise we will need to move code around. Do that only if expensive
830 transformations are allowed. */
831 else if (mode
& CLEANUP_EXPENSIVE
)
833 edge tmp_edge
, b_fallthru_edge
;
834 bool c_has_outgoing_fallthru
;
835 bool b_has_incoming_fallthru
;
838 /* Avoid overactive code motion, as the forwarder blocks should be
839 eliminated by edge redirection instead. One exception might have
840 been if B is a forwarder block and C has no fallthru edge, but
841 that should be cleaned up by bb-reorder instead. */
842 if (FORWARDER_BLOCK_P (b
) || FORWARDER_BLOCK_P (c
))
845 /* We must make sure to not munge nesting of lexical blocks,
846 and loop notes. This is done by squeezing out all the notes
847 and leaving them there to lie. Not ideal, but functional. */
849 FOR_EACH_EDGE (tmp_edge
, ei
, c
->succs
)
850 if (tmp_edge
->flags
& EDGE_FALLTHRU
)
853 c_has_outgoing_fallthru
= (tmp_edge
!= NULL
);
855 FOR_EACH_EDGE (tmp_edge
, ei
, b
->preds
)
856 if (tmp_edge
->flags
& EDGE_FALLTHRU
)
859 b_has_incoming_fallthru
= (tmp_edge
!= NULL
);
860 b_fallthru_edge
= tmp_edge
;
863 next
= next
->prev_bb
;
865 /* Otherwise, we're going to try to move C after B. If C does
866 not have an outgoing fallthru, then it can be moved
867 immediately after B without introducing or modifying jumps. */
868 if (! c_has_outgoing_fallthru
)
870 merge_blocks_move_successor_nojumps (b
, c
);
871 return next
== ENTRY_BLOCK_PTR
? next
->next_bb
: next
;
874 /* If B does not have an incoming fallthru, then it can be moved
875 immediately before C without introducing or modifying jumps.
876 C cannot be the first block, so we do not have to worry about
877 accessing a non-existent block. */
879 if (b_has_incoming_fallthru
)
883 if (b_fallthru_edge
->src
== ENTRY_BLOCK_PTR
)
885 bb
= force_nonfallthru (b_fallthru_edge
);
887 notice_new_block (bb
);
890 merge_blocks_move_predecessor_nojumps (b
, c
);
891 return next
== ENTRY_BLOCK_PTR
? next
->next_bb
: next
;
898 /* Removes the memory attributes of MEM expression
899 if they are not equal. */
902 merge_memattrs (rtx x
, rtx y
)
911 if (x
== 0 || y
== 0)
916 if (code
!= GET_CODE (y
))
919 if (GET_MODE (x
) != GET_MODE (y
))
922 if (code
== MEM
&& MEM_ATTRS (x
) != MEM_ATTRS (y
))
926 else if (! MEM_ATTRS (y
))
932 if (MEM_ALIAS_SET (x
) != MEM_ALIAS_SET (y
))
934 set_mem_alias_set (x
, 0);
935 set_mem_alias_set (y
, 0);
938 if (! mem_expr_equal_p (MEM_EXPR (x
), MEM_EXPR (y
)))
942 set_mem_offset (x
, 0);
943 set_mem_offset (y
, 0);
945 else if (MEM_OFFSET (x
) != MEM_OFFSET (y
))
947 set_mem_offset (x
, 0);
948 set_mem_offset (y
, 0);
953 else if (!MEM_SIZE (y
))
956 mem_size
= GEN_INT (MAX (INTVAL (MEM_SIZE (x
)),
957 INTVAL (MEM_SIZE (y
))));
958 set_mem_size (x
, mem_size
);
959 set_mem_size (y
, mem_size
);
961 set_mem_align (x
, MIN (MEM_ALIGN (x
), MEM_ALIGN (y
)));
962 set_mem_align (y
, MEM_ALIGN (x
));
966 fmt
= GET_RTX_FORMAT (code
);
967 for (i
= GET_RTX_LENGTH (code
) - 1; i
>= 0; i
--)
972 /* Two vectors must have the same length. */
973 if (XVECLEN (x
, i
) != XVECLEN (y
, i
))
976 for (j
= 0; j
< XVECLEN (x
, i
); j
++)
977 merge_memattrs (XVECEXP (x
, i
, j
), XVECEXP (y
, i
, j
));
982 merge_memattrs (XEXP (x
, i
), XEXP (y
, i
));
989 /* Return true if I1 and I2 are equivalent and thus can be crossjumped. */
992 insns_match_p (int mode ATTRIBUTE_UNUSED
, rtx i1
, rtx i2
)
996 /* Verify that I1 and I2 are equivalent. */
997 if (GET_CODE (i1
) != GET_CODE (i2
))
1003 if (GET_CODE (p1
) != GET_CODE (p2
))
1006 /* If this is a CALL_INSN, compare register usage information.
1007 If we don't check this on stack register machines, the two
1008 CALL_INSNs might be merged leaving reg-stack.c with mismatching
1009 numbers of stack registers in the same basic block.
1010 If we don't check this on machines with delay slots, a delay slot may
1011 be filled that clobbers a parameter expected by the subroutine.
1013 ??? We take the simple route for now and assume that if they're
1014 equal, they were constructed identically. */
1017 && (!rtx_equal_p (CALL_INSN_FUNCTION_USAGE (i1
),
1018 CALL_INSN_FUNCTION_USAGE (i2
))
1019 || SIBLING_CALL_P (i1
) != SIBLING_CALL_P (i2
)))
1023 /* If cross_jump_death_matters is not 0, the insn's mode
1024 indicates whether or not the insn contains any stack-like
1027 if ((mode
& CLEANUP_POST_REGSTACK
) && stack_regs_mentioned (i1
))
1029 /* If register stack conversion has already been done, then
1030 death notes must also be compared before it is certain that
1031 the two instruction streams match. */
1034 HARD_REG_SET i1_regset
, i2_regset
;
1036 CLEAR_HARD_REG_SET (i1_regset
);
1037 CLEAR_HARD_REG_SET (i2_regset
);
1039 for (note
= REG_NOTES (i1
); note
; note
= XEXP (note
, 1))
1040 if (REG_NOTE_KIND (note
) == REG_DEAD
&& STACK_REG_P (XEXP (note
, 0)))
1041 SET_HARD_REG_BIT (i1_regset
, REGNO (XEXP (note
, 0)));
1043 for (note
= REG_NOTES (i2
); note
; note
= XEXP (note
, 1))
1044 if (REG_NOTE_KIND (note
) == REG_DEAD
&& STACK_REG_P (XEXP (note
, 0)))
1045 SET_HARD_REG_BIT (i2_regset
, REGNO (XEXP (note
, 0)));
1047 GO_IF_HARD_REG_EQUAL (i1_regset
, i2_regset
, done
);
1056 if (reload_completed
1057 ? rtx_renumbered_equal_p (p1
, p2
) : rtx_equal_p (p1
, p2
))
1060 /* Do not do EQUIV substitution after reload. First, we're undoing the
1061 work of reload_cse. Second, we may be undoing the work of the post-
1062 reload splitting pass. */
1063 /* ??? Possibly add a new phase switch variable that can be used by
1064 targets to disallow the troublesome insns after splitting. */
1065 if (!reload_completed
)
1067 /* The following code helps take care of G++ cleanups. */
1068 rtx equiv1
= find_reg_equal_equiv_note (i1
);
1069 rtx equiv2
= find_reg_equal_equiv_note (i2
);
1071 if (equiv1
&& equiv2
1072 /* If the equivalences are not to a constant, they may
1073 reference pseudos that no longer exist, so we can't
1075 && (! reload_completed
1076 || (CONSTANT_P (XEXP (equiv1
, 0))
1077 && rtx_equal_p (XEXP (equiv1
, 0), XEXP (equiv2
, 0)))))
1079 rtx s1
= single_set (i1
);
1080 rtx s2
= single_set (i2
);
1081 if (s1
!= 0 && s2
!= 0
1082 && rtx_renumbered_equal_p (SET_DEST (s1
), SET_DEST (s2
)))
1084 validate_change (i1
, &SET_SRC (s1
), XEXP (equiv1
, 0), 1);
1085 validate_change (i2
, &SET_SRC (s2
), XEXP (equiv2
, 0), 1);
1086 if (! rtx_renumbered_equal_p (p1
, p2
))
1088 else if (apply_change_group ())
1097 /* Look through the insns at the end of BB1 and BB2 and find the longest
1098 sequence that are equivalent. Store the first insns for that sequence
1099 in *F1 and *F2 and return the sequence length.
1101 To simplify callers of this function, if the blocks match exactly,
1102 store the head of the blocks in *F1 and *F2. */
1105 flow_find_cross_jump (int mode ATTRIBUTE_UNUSED
, basic_block bb1
,
1106 basic_block bb2
, rtx
*f1
, rtx
*f2
)
1108 rtx i1
, i2
, last1
, last2
, afterlast1
, afterlast2
;
1111 /* Skip simple jumps at the end of the blocks. Complex jumps still
1112 need to be compared for equivalence, which we'll do below. */
1115 last1
= afterlast1
= last2
= afterlast2
= NULL_RTX
;
1117 || (returnjump_p (i1
) && !side_effects_p (PATTERN (i1
))))
1120 i1
= PREV_INSN (i1
);
1125 || (returnjump_p (i2
) && !side_effects_p (PATTERN (i2
))))
1128 /* Count everything except for unconditional jump as insn. */
1129 if (!simplejump_p (i2
) && !returnjump_p (i2
) && last1
)
1131 i2
= PREV_INSN (i2
);
1137 while (!INSN_P (i1
) && i1
!= BB_HEAD (bb1
))
1138 i1
= PREV_INSN (i1
);
1140 while (!INSN_P (i2
) && i2
!= BB_HEAD (bb2
))
1141 i2
= PREV_INSN (i2
);
1143 if (i1
== BB_HEAD (bb1
) || i2
== BB_HEAD (bb2
))
1146 if (!insns_match_p (mode
, i1
, i2
))
1149 merge_memattrs (i1
, i2
);
1151 /* Don't begin a cross-jump with a NOTE insn. */
1154 /* If the merged insns have different REG_EQUAL notes, then
1156 rtx equiv1
= find_reg_equal_equiv_note (i1
);
1157 rtx equiv2
= find_reg_equal_equiv_note (i2
);
1159 if (equiv1
&& !equiv2
)
1160 remove_note (i1
, equiv1
);
1161 else if (!equiv1
&& equiv2
)
1162 remove_note (i2
, equiv2
);
1163 else if (equiv1
&& equiv2
1164 && !rtx_equal_p (XEXP (equiv1
, 0), XEXP (equiv2
, 0)))
1166 remove_note (i1
, equiv1
);
1167 remove_note (i2
, equiv2
);
1170 afterlast1
= last1
, afterlast2
= last2
;
1171 last1
= i1
, last2
= i2
;
1175 i1
= PREV_INSN (i1
);
1176 i2
= PREV_INSN (i2
);
1180 /* Don't allow the insn after a compare to be shared by
1181 cross-jumping unless the compare is also shared. */
1182 if (ninsns
&& reg_mentioned_p (cc0_rtx
, last1
) && ! sets_cc0_p (last1
))
1183 last1
= afterlast1
, last2
= afterlast2
, ninsns
--;
1186 /* Include preceding notes and labels in the cross-jump. One,
1187 this may bring us to the head of the blocks as requested above.
1188 Two, it keeps line number notes as matched as may be. */
1191 while (last1
!= BB_HEAD (bb1
) && !INSN_P (PREV_INSN (last1
)))
1192 last1
= PREV_INSN (last1
);
1194 if (last1
!= BB_HEAD (bb1
) && LABEL_P (PREV_INSN (last1
)))
1195 last1
= PREV_INSN (last1
);
1197 while (last2
!= BB_HEAD (bb2
) && !INSN_P (PREV_INSN (last2
)))
1198 last2
= PREV_INSN (last2
);
1200 if (last2
!= BB_HEAD (bb2
) && LABEL_P (PREV_INSN (last2
)))
1201 last2
= PREV_INSN (last2
);
1210 /* Return true iff outgoing edges of BB1 and BB2 match, together with
1211 the branch instruction. This means that if we commonize the control
1212 flow before end of the basic block, the semantic remains unchanged.
1214 We may assume that there exists one edge with a common destination. */
1217 outgoing_edges_match (int mode
, basic_block bb1
, basic_block bb2
)
1219 int nehedges1
= 0, nehedges2
= 0;
1220 edge fallthru1
= 0, fallthru2
= 0;
1224 /* If BB1 has only one successor, we may be looking at either an
1225 unconditional jump, or a fake edge to exit. */
1226 if (single_succ_p (bb1
)
1227 && (single_succ_edge (bb1
)->flags
& (EDGE_COMPLEX
| EDGE_FAKE
)) == 0
1228 && (!JUMP_P (BB_END (bb1
)) || simplejump_p (BB_END (bb1
))))
1229 return (single_succ_p (bb2
)
1230 && (single_succ_edge (bb2
)->flags
1231 & (EDGE_COMPLEX
| EDGE_FAKE
)) == 0
1232 && (!JUMP_P (BB_END (bb2
)) || simplejump_p (BB_END (bb2
))));
1234 /* Match conditional jumps - this may get tricky when fallthru and branch
1235 edges are crossed. */
1236 if (EDGE_COUNT (bb1
->succs
) == 2
1237 && any_condjump_p (BB_END (bb1
))
1238 && onlyjump_p (BB_END (bb1
)))
1240 edge b1
, f1
, b2
, f2
;
1241 bool reverse
, match
;
1242 rtx set1
, set2
, cond1
, cond2
;
1243 enum rtx_code code1
, code2
;
1245 if (EDGE_COUNT (bb2
->succs
) != 2
1246 || !any_condjump_p (BB_END (bb2
))
1247 || !onlyjump_p (BB_END (bb2
)))
1250 b1
= BRANCH_EDGE (bb1
);
1251 b2
= BRANCH_EDGE (bb2
);
1252 f1
= FALLTHRU_EDGE (bb1
);
1253 f2
= FALLTHRU_EDGE (bb2
);
1255 /* Get around possible forwarders on fallthru edges. Other cases
1256 should be optimized out already. */
1257 if (FORWARDER_BLOCK_P (f1
->dest
))
1258 f1
= single_succ_edge (f1
->dest
);
1260 if (FORWARDER_BLOCK_P (f2
->dest
))
1261 f2
= single_succ_edge (f2
->dest
);
1263 /* To simplify use of this function, return false if there are
1264 unneeded forwarder blocks. These will get eliminated later
1265 during cleanup_cfg. */
1266 if (FORWARDER_BLOCK_P (f1
->dest
)
1267 || FORWARDER_BLOCK_P (f2
->dest
)
1268 || FORWARDER_BLOCK_P (b1
->dest
)
1269 || FORWARDER_BLOCK_P (b2
->dest
))
1272 if (f1
->dest
== f2
->dest
&& b1
->dest
== b2
->dest
)
1274 else if (f1
->dest
== b2
->dest
&& b1
->dest
== f2
->dest
)
1279 set1
= pc_set (BB_END (bb1
));
1280 set2
= pc_set (BB_END (bb2
));
1281 if ((XEXP (SET_SRC (set1
), 1) == pc_rtx
)
1282 != (XEXP (SET_SRC (set2
), 1) == pc_rtx
))
1285 cond1
= XEXP (SET_SRC (set1
), 0);
1286 cond2
= XEXP (SET_SRC (set2
), 0);
1287 code1
= GET_CODE (cond1
);
1289 code2
= reversed_comparison_code (cond2
, BB_END (bb2
));
1291 code2
= GET_CODE (cond2
);
1293 if (code2
== UNKNOWN
)
1296 /* Verify codes and operands match. */
1297 match
= ((code1
== code2
1298 && rtx_renumbered_equal_p (XEXP (cond1
, 0), XEXP (cond2
, 0))
1299 && rtx_renumbered_equal_p (XEXP (cond1
, 1), XEXP (cond2
, 1)))
1300 || (code1
== swap_condition (code2
)
1301 && rtx_renumbered_equal_p (XEXP (cond1
, 1),
1303 && rtx_renumbered_equal_p (XEXP (cond1
, 0),
1306 /* If we return true, we will join the blocks. Which means that
1307 we will only have one branch prediction bit to work with. Thus
1308 we require the existing branches to have probabilities that are
1312 && maybe_hot_bb_p (bb1
)
1313 && maybe_hot_bb_p (bb2
))
1317 if (b1
->dest
== b2
->dest
)
1318 prob2
= b2
->probability
;
1320 /* Do not use f2 probability as f2 may be forwarded. */
1321 prob2
= REG_BR_PROB_BASE
- b2
->probability
;
1323 /* Fail if the difference in probabilities is greater than 50%.
1324 This rules out two well-predicted branches with opposite
1326 if (abs (b1
->probability
- prob2
) > REG_BR_PROB_BASE
/ 2)
1330 "Outcomes of branch in bb %i and %i differ too much (%i %i)\n",
1331 bb1
->index
, bb2
->index
, b1
->probability
, prob2
);
1337 if (dump_file
&& match
)
1338 fprintf (dump_file
, "Conditionals in bb %i and %i match.\n",
1339 bb1
->index
, bb2
->index
);
1344 /* Generic case - we are seeing a computed jump, table jump or trapping
1347 /* Check whether there are tablejumps in the end of BB1 and BB2.
1348 Return true if they are identical. */
1353 if (tablejump_p (BB_END (bb1
), &label1
, &table1
)
1354 && tablejump_p (BB_END (bb2
), &label2
, &table2
)
1355 && GET_CODE (PATTERN (table1
)) == GET_CODE (PATTERN (table2
)))
1357 /* The labels should never be the same rtx. If they really are same
1358 the jump tables are same too. So disable crossjumping of blocks BB1
1359 and BB2 because when deleting the common insns in the end of BB1
1360 by delete_basic_block () the jump table would be deleted too. */
1361 /* If LABEL2 is referenced in BB1->END do not do anything
1362 because we would loose information when replacing
1363 LABEL1 by LABEL2 and then LABEL2 by LABEL1 in BB1->END. */
1364 if (label1
!= label2
&& !rtx_referenced_p (label2
, BB_END (bb1
)))
1366 /* Set IDENTICAL to true when the tables are identical. */
1367 bool identical
= false;
1370 p1
= PATTERN (table1
);
1371 p2
= PATTERN (table2
);
1372 if (GET_CODE (p1
) == ADDR_VEC
&& rtx_equal_p (p1
, p2
))
1376 else if (GET_CODE (p1
) == ADDR_DIFF_VEC
1377 && (XVECLEN (p1
, 1) == XVECLEN (p2
, 1))
1378 && rtx_equal_p (XEXP (p1
, 2), XEXP (p2
, 2))
1379 && rtx_equal_p (XEXP (p1
, 3), XEXP (p2
, 3)))
1384 for (i
= XVECLEN (p1
, 1) - 1; i
>= 0 && identical
; i
--)
1385 if (!rtx_equal_p (XVECEXP (p1
, 1, i
), XVECEXP (p2
, 1, i
)))
1391 replace_label_data rr
;
1394 /* Temporarily replace references to LABEL1 with LABEL2
1395 in BB1->END so that we could compare the instructions. */
1398 rr
.update_label_nuses
= false;
1399 for_each_rtx (&BB_END (bb1
), replace_label
, &rr
);
1401 match
= insns_match_p (mode
, BB_END (bb1
), BB_END (bb2
));
1402 if (dump_file
&& match
)
1404 "Tablejumps in bb %i and %i match.\n",
1405 bb1
->index
, bb2
->index
);
1407 /* Set the original label in BB1->END because when deleting
1408 a block whose end is a tablejump, the tablejump referenced
1409 from the instruction is deleted too. */
1412 for_each_rtx (&BB_END (bb1
), replace_label
, &rr
);
1421 /* First ensure that the instructions match. There may be many outgoing
1422 edges so this test is generally cheaper. */
1423 if (!insns_match_p (mode
, BB_END (bb1
), BB_END (bb2
)))
1426 /* Search the outgoing edges, ensure that the counts do match, find possible
1427 fallthru and exception handling edges since these needs more
1429 if (EDGE_COUNT (bb1
->succs
) != EDGE_COUNT (bb2
->succs
))
1432 FOR_EACH_EDGE (e1
, ei
, bb1
->succs
)
1434 e2
= EDGE_SUCC (bb2
, ei
.index
);
1436 if (e1
->flags
& EDGE_EH
)
1439 if (e2
->flags
& EDGE_EH
)
1442 if (e1
->flags
& EDGE_FALLTHRU
)
1444 if (e2
->flags
& EDGE_FALLTHRU
)
1448 /* If number of edges of various types does not match, fail. */
1449 if (nehedges1
!= nehedges2
1450 || (fallthru1
!= 0) != (fallthru2
!= 0))
1453 /* fallthru edges must be forwarded to the same destination. */
1456 basic_block d1
= (forwarder_block_p (fallthru1
->dest
)
1457 ? single_succ (fallthru1
->dest
): fallthru1
->dest
);
1458 basic_block d2
= (forwarder_block_p (fallthru2
->dest
)
1459 ? single_succ (fallthru2
->dest
): fallthru2
->dest
);
1465 /* Ensure the same EH region. */
1467 rtx n1
= find_reg_note (BB_END (bb1
), REG_EH_REGION
, 0);
1468 rtx n2
= find_reg_note (BB_END (bb2
), REG_EH_REGION
, 0);
1473 if (n1
&& (!n2
|| XEXP (n1
, 0) != XEXP (n2
, 0)))
1477 /* We don't need to match the rest of edges as above checks should be enough
1478 to ensure that they are equivalent. */
1482 /* E1 and E2 are edges with the same destination block. Search their
1483 predecessors for common code. If found, redirect control flow from
1484 (maybe the middle of) E1->SRC to (maybe the middle of) E2->SRC. */
1487 try_crossjump_to_edge (int mode
, edge e1
, edge e2
)
1490 basic_block src1
= e1
->src
, src2
= e2
->src
;
1491 basic_block redirect_to
, redirect_from
, to_remove
;
1492 rtx newpos1
, newpos2
;
1496 newpos1
= newpos2
= NULL_RTX
;
1498 /* If we have partitioned hot/cold basic blocks, it is a bad idea
1499 to try this optimization.
1501 Basic block partitioning may result in some jumps that appear to
1502 be optimizable (or blocks that appear to be mergeable), but which really
1503 must be left untouched (they are required to make it safely across
1504 partition boundaries). See the comments at the top of
1505 bb-reorder.c:partition_hot_cold_basic_blocks for complete details. */
1507 if (flag_reorder_blocks_and_partition
&& no_new_pseudos
)
1510 /* Search backward through forwarder blocks. We don't need to worry
1511 about multiple entry or chained forwarders, as they will be optimized
1512 away. We do this to look past the unconditional jump following a
1513 conditional jump that is required due to the current CFG shape. */
1514 if (single_pred_p (src1
)
1515 && FORWARDER_BLOCK_P (src1
))
1516 e1
= single_pred_edge (src1
), src1
= e1
->src
;
1518 if (single_pred_p (src2
)
1519 && FORWARDER_BLOCK_P (src2
))
1520 e2
= single_pred_edge (src2
), src2
= e2
->src
;
1522 /* Nothing to do if we reach ENTRY, or a common source block. */
1523 if (src1
== ENTRY_BLOCK_PTR
|| src2
== ENTRY_BLOCK_PTR
)
1528 /* Seeing more than 1 forwarder blocks would confuse us later... */
1529 if (FORWARDER_BLOCK_P (e1
->dest
)
1530 && FORWARDER_BLOCK_P (single_succ (e1
->dest
)))
1533 if (FORWARDER_BLOCK_P (e2
->dest
)
1534 && FORWARDER_BLOCK_P (single_succ (e2
->dest
)))
1537 /* Likewise with dead code (possibly newly created by the other optimizations
1539 if (EDGE_COUNT (src1
->preds
) == 0 || EDGE_COUNT (src2
->preds
) == 0)
1542 /* Look for the common insn sequence, part the first ... */
1543 if (!outgoing_edges_match (mode
, src1
, src2
))
1546 /* ... and part the second. */
1547 nmatch
= flow_find_cross_jump (mode
, src1
, src2
, &newpos1
, &newpos2
);
1549 /* Don't proceed with the crossjump unless we found a sufficient number
1550 of matching instructions or the 'from' block was totally matched
1551 (such that its predecessors will hopefully be redirected and the
1553 if ((nmatch
< PARAM_VALUE (PARAM_MIN_CROSSJUMP_INSNS
))
1554 && (newpos1
!= BB_HEAD (src1
)))
1557 /* Here we know that the insns in the end of SRC1 which are common with SRC2
1559 If we have tablejumps in the end of SRC1 and SRC2
1560 they have been already compared for equivalence in outgoing_edges_match ()
1561 so replace the references to TABLE1 by references to TABLE2. */
1566 if (tablejump_p (BB_END (src1
), &label1
, &table1
)
1567 && tablejump_p (BB_END (src2
), &label2
, &table2
)
1568 && label1
!= label2
)
1570 replace_label_data rr
;
1573 /* Replace references to LABEL1 with LABEL2. */
1576 rr
.update_label_nuses
= true;
1577 for (insn
= get_insns (); insn
; insn
= NEXT_INSN (insn
))
1579 /* Do not replace the label in SRC1->END because when deleting
1580 a block whose end is a tablejump, the tablejump referenced
1581 from the instruction is deleted too. */
1582 if (insn
!= BB_END (src1
))
1583 for_each_rtx (&insn
, replace_label
, &rr
);
1588 /* Avoid splitting if possible. */
1589 if (newpos2
== BB_HEAD (src2
))
1594 fprintf (dump_file
, "Splitting bb %i before %i insns\n",
1595 src2
->index
, nmatch
);
1596 redirect_to
= split_block (src2
, PREV_INSN (newpos2
))->dest
;
1601 "Cross jumping from bb %i to bb %i; %i common insns\n",
1602 src1
->index
, src2
->index
, nmatch
);
1604 redirect_to
->count
+= src1
->count
;
1605 redirect_to
->frequency
+= src1
->frequency
;
1606 /* We may have some registers visible trought the block. */
1607 redirect_to
->flags
|= BB_DIRTY
;
1609 /* Recompute the frequencies and counts of outgoing edges. */
1610 FOR_EACH_EDGE (s
, ei
, redirect_to
->succs
)
1614 basic_block d
= s
->dest
;
1616 if (FORWARDER_BLOCK_P (d
))
1617 d
= single_succ (d
);
1619 FOR_EACH_EDGE (s2
, ei
, src1
->succs
)
1621 basic_block d2
= s2
->dest
;
1622 if (FORWARDER_BLOCK_P (d2
))
1623 d2
= single_succ (d2
);
1628 s
->count
+= s2
->count
;
1630 /* Take care to update possible forwarder blocks. We verified
1631 that there is no more than one in the chain, so we can't run
1632 into infinite loop. */
1633 if (FORWARDER_BLOCK_P (s
->dest
))
1635 single_succ_edge (s
->dest
)->count
+= s2
->count
;
1636 s
->dest
->count
+= s2
->count
;
1637 s
->dest
->frequency
+= EDGE_FREQUENCY (s
);
1640 if (FORWARDER_BLOCK_P (s2
->dest
))
1642 single_succ_edge (s2
->dest
)->count
-= s2
->count
;
1643 if (single_succ_edge (s2
->dest
)->count
< 0)
1644 single_succ_edge (s2
->dest
)->count
= 0;
1645 s2
->dest
->count
-= s2
->count
;
1646 s2
->dest
->frequency
-= EDGE_FREQUENCY (s
);
1647 if (s2
->dest
->frequency
< 0)
1648 s2
->dest
->frequency
= 0;
1649 if (s2
->dest
->count
< 0)
1650 s2
->dest
->count
= 0;
1653 if (!redirect_to
->frequency
&& !src1
->frequency
)
1654 s
->probability
= (s
->probability
+ s2
->probability
) / 2;
1657 = ((s
->probability
* redirect_to
->frequency
+
1658 s2
->probability
* src1
->frequency
)
1659 / (redirect_to
->frequency
+ src1
->frequency
));
1662 update_br_prob_note (redirect_to
);
1664 /* Edit SRC1 to go to REDIRECT_TO at NEWPOS1. */
1666 /* Skip possible basic block header. */
1667 if (LABEL_P (newpos1
))
1668 newpos1
= NEXT_INSN (newpos1
);
1670 if (NOTE_P (newpos1
))
1671 newpos1
= NEXT_INSN (newpos1
);
1673 redirect_from
= split_block (src1
, PREV_INSN (newpos1
))->src
;
1674 to_remove
= single_succ (redirect_from
);
1676 redirect_edge_and_branch_force (single_succ_edge (redirect_from
), redirect_to
);
1677 delete_basic_block (to_remove
);
1679 update_forwarder_flag (redirect_from
);
1680 if (redirect_to
!= src2
)
1681 update_forwarder_flag (src2
);
1686 /* Search the predecessors of BB for common insn sequences. When found,
1687 share code between them by redirecting control flow. Return true if
1688 any changes made. */
1691 try_crossjump_bb (int mode
, basic_block bb
)
1693 edge e
, e2
, fallthru
;
1695 unsigned max
, ix
, ix2
;
1696 basic_block ev
, ev2
;
1699 /* Nothing to do if there is not at least two incoming edges. */
1700 if (EDGE_COUNT (bb
->preds
) < 2)
1703 /* Don't crossjump if this block ends in a computed jump,
1704 unless we are optimizing for size. */
1706 && bb
!= EXIT_BLOCK_PTR
1707 && computed_jump_p (BB_END (bb
)))
1710 /* If we are partitioning hot/cold basic blocks, we don't want to
1711 mess up unconditional or indirect jumps that cross between hot
1714 Basic block partitioning may result in some jumps that appear to
1715 be optimizable (or blocks that appear to be mergeable), but which really
1716 must be left untouched (they are required to make it safely across
1717 partition boundaries). See the comments at the top of
1718 bb-reorder.c:partition_hot_cold_basic_blocks for complete details. */
1720 if (BB_PARTITION (EDGE_PRED (bb
, 0)->src
) !=
1721 BB_PARTITION (EDGE_PRED (bb
, 1)->src
)
1722 || (EDGE_PRED (bb
, 0)->flags
& EDGE_CROSSING
))
1725 /* It is always cheapest to redirect a block that ends in a branch to
1726 a block that falls through into BB, as that adds no branches to the
1727 program. We'll try that combination first. */
1729 max
= PARAM_VALUE (PARAM_MAX_CROSSJUMP_EDGES
);
1731 if (EDGE_COUNT (bb
->preds
) > max
)
1734 FOR_EACH_EDGE (e
, ei
, bb
->preds
)
1736 if (e
->flags
& EDGE_FALLTHRU
)
1741 for (ix
= 0, ev
= bb
; ix
< EDGE_COUNT (ev
->preds
); )
1743 e
= EDGE_PRED (ev
, ix
);
1746 /* As noted above, first try with the fallthru predecessor. */
1749 /* Don't combine the fallthru edge into anything else.
1750 If there is a match, we'll do it the other way around. */
1753 /* If nothing changed since the last attempt, there is nothing
1756 && (!(e
->src
->flags
& BB_DIRTY
)
1757 && !(fallthru
->src
->flags
& BB_DIRTY
)))
1760 if (try_crossjump_to_edge (mode
, e
, fallthru
))
1769 /* Non-obvious work limiting check: Recognize that we're going
1770 to call try_crossjump_bb on every basic block. So if we have
1771 two blocks with lots of outgoing edges (a switch) and they
1772 share lots of common destinations, then we would do the
1773 cross-jump check once for each common destination.
1775 Now, if the blocks actually are cross-jump candidates, then
1776 all of their destinations will be shared. Which means that
1777 we only need check them for cross-jump candidacy once. We
1778 can eliminate redundant checks of crossjump(A,B) by arbitrarily
1779 choosing to do the check from the block for which the edge
1780 in question is the first successor of A. */
1781 if (EDGE_SUCC (e
->src
, 0) != e
)
1784 for (ix2
= 0, ev2
= bb
; ix2
< EDGE_COUNT (ev2
->preds
); )
1786 e2
= EDGE_PRED (ev2
, ix2
);
1792 /* We've already checked the fallthru edge above. */
1796 /* The "first successor" check above only prevents multiple
1797 checks of crossjump(A,B). In order to prevent redundant
1798 checks of crossjump(B,A), require that A be the block
1799 with the lowest index. */
1800 if (e
->src
->index
> e2
->src
->index
)
1803 /* If nothing changed since the last attempt, there is nothing
1806 && (!(e
->src
->flags
& BB_DIRTY
)
1807 && !(e2
->src
->flags
& BB_DIRTY
)))
1810 if (try_crossjump_to_edge (mode
, e
, e2
))
1823 /* Do simple CFG optimizations - basic block merging, simplifying of jump
1824 instructions etc. Return nonzero if changes were made. */
1827 try_optimize_cfg (int mode
)
1829 bool changed_overall
= false;
1832 basic_block bb
, b
, next
;
1834 if (mode
& CLEANUP_CROSSJUMP
)
1835 add_noreturn_fake_exit_edges ();
1838 update_forwarder_flag (bb
);
1840 if (mode
& (CLEANUP_UPDATE_LIFE
| CLEANUP_CROSSJUMP
| CLEANUP_THREADING
))
1843 if (! targetm
.cannot_modify_jumps_p ())
1846 /* Attempt to merge blocks as made possible by edge removal. If
1847 a block has only one successor, and the successor has only
1848 one predecessor, they may be combined. */
1856 "\n\ntry_optimize_cfg iteration %i\n\n",
1859 for (b
= ENTRY_BLOCK_PTR
->next_bb
; b
!= EXIT_BLOCK_PTR
;)
1863 bool changed_here
= false;
1865 /* Delete trivially dead basic blocks. */
1866 while (EDGE_COUNT (b
->preds
) == 0)
1870 fprintf (dump_file
, "Deleting block %i.\n",
1873 delete_basic_block (b
);
1874 if (!(mode
& CLEANUP_CFGLAYOUT
))
1879 /* Remove code labels no longer used. */
1880 if (single_pred_p (b
)
1881 && (single_pred_edge (b
)->flags
& EDGE_FALLTHRU
)
1882 && !(single_pred_edge (b
)->flags
& EDGE_COMPLEX
)
1883 && LABEL_P (BB_HEAD (b
))
1884 /* If the previous block ends with a branch to this
1885 block, we can't delete the label. Normally this
1886 is a condjump that is yet to be simplified, but
1887 if CASE_DROPS_THRU, this can be a tablejump with
1888 some element going to the same place as the
1889 default (fallthru). */
1890 && (single_pred (b
) == ENTRY_BLOCK_PTR
1891 || !JUMP_P (BB_END (single_pred (b
)))
1892 || ! label_is_jump_target_p (BB_HEAD (b
),
1893 BB_END (single_pred (b
)))))
1895 rtx label
= BB_HEAD (b
);
1897 delete_insn_chain (label
, label
);
1898 /* In the case label is undeletable, move it after the
1899 BASIC_BLOCK note. */
1900 if (NOTE_LINE_NUMBER (BB_HEAD (b
)) == NOTE_INSN_DELETED_LABEL
)
1902 rtx bb_note
= NEXT_INSN (BB_HEAD (b
));
1904 reorder_insns_nobb (label
, label
, bb_note
);
1905 BB_HEAD (b
) = bb_note
;
1908 fprintf (dump_file
, "Deleted label in block %i.\n",
1912 /* If we fall through an empty block, we can remove it. */
1913 if (!(mode
& CLEANUP_CFGLAYOUT
)
1914 && single_pred_p (b
)
1915 && (single_pred_edge (b
)->flags
& EDGE_FALLTHRU
)
1916 && !LABEL_P (BB_HEAD (b
))
1917 && FORWARDER_BLOCK_P (b
)
1918 /* Note that forwarder_block_p true ensures that
1919 there is a successor for this block. */
1920 && (single_succ_edge (b
)->flags
& EDGE_FALLTHRU
)
1921 && n_basic_blocks
> 1)
1925 "Deleting fallthru block %i.\n",
1928 c
= b
->prev_bb
== ENTRY_BLOCK_PTR
? b
->next_bb
: b
->prev_bb
;
1929 redirect_edge_succ_nodup (single_pred_edge (b
),
1931 delete_basic_block (b
);
1936 if (single_succ_p (b
)
1937 && (s
= single_succ_edge (b
))
1938 && !(s
->flags
& EDGE_COMPLEX
)
1939 && (c
= s
->dest
) != EXIT_BLOCK_PTR
1940 && single_pred_p (c
)
1943 /* When not in cfg_layout mode use code aware of reordering
1944 INSN. This code possibly creates new basic blocks so it
1945 does not fit merge_blocks interface and is kept here in
1946 hope that it will become useless once more of compiler
1947 is transformed to use cfg_layout mode. */
1949 if ((mode
& CLEANUP_CFGLAYOUT
)
1950 && can_merge_blocks_p (b
, c
))
1952 merge_blocks (b
, c
);
1953 update_forwarder_flag (b
);
1954 changed_here
= true;
1956 else if (!(mode
& CLEANUP_CFGLAYOUT
)
1957 /* If the jump insn has side effects,
1958 we can't kill the edge. */
1959 && (!JUMP_P (BB_END (b
))
1960 || (reload_completed
1961 ? simplejump_p (BB_END (b
))
1962 : (onlyjump_p (BB_END (b
))
1963 && !tablejump_p (BB_END (b
),
1965 && (next
= merge_blocks_move (s
, b
, c
, mode
)))
1968 changed_here
= true;
1972 /* Simplify branch over branch. */
1973 if ((mode
& CLEANUP_EXPENSIVE
)
1974 && !(mode
& CLEANUP_CFGLAYOUT
)
1975 && try_simplify_condjump (b
))
1976 changed_here
= true;
1978 /* If B has a single outgoing edge, but uses a
1979 non-trivial jump instruction without side-effects, we
1980 can either delete the jump entirely, or replace it
1981 with a simple unconditional jump. */
1982 if (single_succ_p (b
)
1983 && single_succ (b
) != EXIT_BLOCK_PTR
1984 && onlyjump_p (BB_END (b
))
1985 && !find_reg_note (BB_END (b
), REG_CROSSING_JUMP
, NULL_RTX
)
1986 && try_redirect_by_replacing_jump (single_succ_edge (b
),
1988 (mode
& CLEANUP_CFGLAYOUT
) != 0))
1990 update_forwarder_flag (b
);
1991 changed_here
= true;
1994 /* Simplify branch to branch. */
1995 if (try_forward_edges (mode
, b
))
1996 changed_here
= true;
1998 /* Look for shared code between blocks. */
1999 if ((mode
& CLEANUP_CROSSJUMP
)
2000 && try_crossjump_bb (mode
, b
))
2001 changed_here
= true;
2003 /* Don't get confused by the index shift caused by
2011 if ((mode
& CLEANUP_CROSSJUMP
)
2012 && try_crossjump_bb (mode
, EXIT_BLOCK_PTR
))
2015 #ifdef ENABLE_CHECKING
2017 verify_flow_info ();
2020 changed_overall
|= changed
;
2026 if (mode
& CLEANUP_CROSSJUMP
)
2027 remove_fake_exit_edges ();
2029 clear_aux_for_blocks ();
2031 return changed_overall
;
2034 /* Delete all unreachable basic blocks. */
2037 delete_unreachable_blocks (void)
2039 bool changed
= false;
2040 basic_block b
, next_bb
;
2042 find_unreachable_blocks ();
2044 /* Delete all unreachable basic blocks. */
2046 for (b
= ENTRY_BLOCK_PTR
->next_bb
; b
!= EXIT_BLOCK_PTR
; b
= next_bb
)
2048 next_bb
= b
->next_bb
;
2050 if (!(b
->flags
& BB_REACHABLE
))
2052 delete_basic_block (b
);
2058 tidy_fallthru_edges ();
2062 /* Merges sequential blocks if possible. */
2065 merge_seq_blocks (void)
2068 bool changed
= false;
2070 for (bb
= ENTRY_BLOCK_PTR
->next_bb
; bb
!= EXIT_BLOCK_PTR
; )
2072 if (single_succ_p (bb
)
2073 && can_merge_blocks_p (bb
, single_succ (bb
)))
2075 /* Merge the blocks and retry. */
2076 merge_blocks (bb
, single_succ (bb
));
2087 /* Tidy the CFG by deleting unreachable code and whatnot. */
2090 cleanup_cfg (int mode
)
2092 bool changed
= false;
2094 timevar_push (TV_CLEANUP_CFG
);
2095 if (delete_unreachable_blocks ())
2098 /* We've possibly created trivially dead code. Cleanup it right
2099 now to introduce more opportunities for try_optimize_cfg. */
2100 if (!(mode
& (CLEANUP_NO_INSN_DEL
| CLEANUP_UPDATE_LIFE
))
2101 && !reload_completed
)
2102 delete_trivially_dead_insns (get_insns(), max_reg_num ());
2107 while (try_optimize_cfg (mode
))
2109 delete_unreachable_blocks (), changed
= true;
2110 if (mode
& CLEANUP_UPDATE_LIFE
)
2112 /* Cleaning up CFG introduces more opportunities for dead code
2113 removal that in turn may introduce more opportunities for
2114 cleaning up the CFG. */
2115 if (!update_life_info_in_dirty_blocks (UPDATE_LIFE_GLOBAL_RM_NOTES
,
2117 | PROP_SCAN_DEAD_CODE
2118 | PROP_KILL_DEAD_CODE
2119 | ((mode
& CLEANUP_LOG_LINKS
)
2120 ? PROP_LOG_LINKS
: 0)))
2123 else if (!(mode
& CLEANUP_NO_INSN_DEL
)
2124 && (mode
& CLEANUP_EXPENSIVE
)
2125 && !reload_completed
)
2127 if (!delete_trivially_dead_insns (get_insns(), max_reg_num ()))
2132 delete_dead_jumptables ();
2135 timevar_pop (TV_CLEANUP_CFG
);