aboutsummaryrefslogtreecommitdiff
path: root/gcc/builtins.c
diff options
context:
space:
mode:
authorRoger Sayle <roger@eyesopen.com>2003-01-23 02:57:26 +0000
committerRoger Sayle <sayle@gcc.gnu.org>2003-01-23 02:57:26 +0000
commit34ee7f8278d155d6d128f6af19b10ed35fa8f3d5 (patch)
treee350e7cda96af13a3c7a7347f5f121cef549541c /gcc/builtins.c
parent94edc4abdc1de8d0c77421354eabf3bfc3de0c91 (diff)
downloadgcc-34ee7f8278d155d6d128f6af19b10ed35fa8f3d5.zip
gcc-34ee7f8278d155d6d128f6af19b10ed35fa8f3d5.tar.gz
gcc-34ee7f8278d155d6d128f6af19b10ed35fa8f3d5.tar.bz2
re PR rtl-optimization/8423 (CSE1 not propagating __builtin_constant_p enough)
PR optimization/8423 * cse.c (fold_rtx): Only eliminate a CONSTANT_P_RTX to 1 when its argument is constant, or 0 if !flag_gcse. * simplify-rtx.c (simplify_rtx): Convert CONSTANT_P_RTX to 1 if it's argument is constant. * gcse.c (want_to_gcse_p): Ignore CONSTANT_P_RTX nodes. (hash_scan_set): Don't record CONSTANT_P_RTX expressions. (do_local_cprop): Don't propagate CONSTANT_P_RTX constants. * builtins.c (purge_builtin_constant_p): New function to force instantiation of any remaining CONSTANT_P_RTX nodes. * rtl.h (purge_builtin_constant_p): Prototype here. * toplev.c (rest_of_compilation): Invoke purge_builtin_constant_p pass after GCSE and before loop. (flag_gcse): No longer static. * flags.h (flag_gcse): Prototype here. From-SVN: r61642
Diffstat (limited to 'gcc/builtins.c')
-rw-r--r--gcc/builtins.c33
1 files changed, 31 insertions, 2 deletions
diff --git a/gcc/builtins.c b/gcc/builtins.c
index ffa09f9..5e72df6 100644
--- a/gcc/builtins.c
+++ b/gcc/builtins.c
@@ -1461,8 +1461,8 @@ expand_builtin_constant_p (exp)
arglist = TREE_VALUE (arglist);
/* We have taken care of the easy cases during constant folding. This
- case is not obvious, so emit (constant_p_rtx (ARGLIST)) and let CSE get a
- chance to see if it can deduce whether ARGLIST is constant. */
+ case is not obvious, so emit (constant_p_rtx (ARGLIST)) and let CSE
+ get a chance to see if it can deduce whether ARGLIST is constant. */
tmp = expand_expr (arglist, NULL_RTX, VOIDmode, 0);
tmp = gen_rtx_CONSTANT_P_RTX (value_mode, tmp);
@@ -4496,3 +4496,32 @@ default_expand_builtin (exp, target, subtarget, mode, ignore)
{
return NULL_RTX;
}
+
+/* Instantiate all remaining CONSTANT_P_RTX nodes. */
+
+void
+purge_builtin_constant_p ()
+{
+ rtx insn, done, set;
+ rtx arg, new, note;
+ basic_block bb;
+
+ FOR_EACH_BB (bb)
+ {
+ done = NEXT_INSN (bb->end);
+ for (insn = bb->head; insn != done; insn = NEXT_INSN (insn))
+ if (INSN_P (insn)
+ && (set = single_set (insn)) != NULL_RTX
+ && GET_CODE (SET_SRC (set)) == CONSTANT_P_RTX)
+ {
+ arg = XEXP (SET_SRC (set), 0);
+ new = CONSTANT_P (arg) ? const1_rtx : const0_rtx;
+ validate_change (insn, &SET_SRC (set), new, 0);
+
+ /* Remove the REG_EQUAL note from the insn. */
+ if ((note = find_reg_note (insn, REG_EQUAL, NULL_RTX)) != 0)
+ remove_note (insn, note);
+ }
+ }
+}
+