aboutsummaryrefslogtreecommitdiff
path: root/gcc/builtins.c
diff options
context:
space:
mode:
authorRichard Henderson <rth@redhat.com>2001-06-24 09:09:29 -0700
committerRichard Henderson <rth@gcc.gnu.org>2001-06-24 09:09:29 -0700
commitc1c455a71d130dcbf413f0c9451bcc8287d24b41 (patch)
tree072c952c07efd8ca1810f95ac5c40173d17818a7 /gcc/builtins.c
parent7b8b8ade895d4483a53f1bb6ca6eba893d38e9ef (diff)
downloadgcc-c1c455a71d130dcbf413f0c9451bcc8287d24b41.zip
gcc-c1c455a71d130dcbf413f0c9451bcc8287d24b41.tar.gz
gcc-c1c455a71d130dcbf413f0c9451bcc8287d24b41.tar.bz2
builtins.c (expand_builtin_expect_jump): Disable if the expression can't be re-evaluated.
* builtins.c (expand_builtin_expect_jump): Disable if the expression can't be re-evaluated. From-SVN: r43543
Diffstat (limited to 'gcc/builtins.c')
-rw-r--r--gcc/builtins.c16
1 files changed, 16 insertions, 0 deletions
diff --git a/gcc/builtins.c b/gcc/builtins.c
index 3e4ef15..4fc329f 100644
--- a/gcc/builtins.c
+++ b/gcc/builtins.c
@@ -3304,6 +3304,22 @@ expand_builtin_expect_jump (exp, if_false_label, if_true_label)
int j;
int num_jumps = 0;
+ /* If we fail to locate an appropriate conditional jump, we'll
+ fall back to normal evaluation. Ensure that the expression
+ can be re-evaluated. */
+ switch (unsafe_for_reeval (arg0))
+ {
+ case 0: /* Safe. */
+ break;
+
+ case 1: /* Mildly unsafe. */
+ arg0 = unsave_expr (arg0);
+ break;
+
+ case 2: /* Wildly unsafe. */
+ return NULL_RTX;
+ }
+
/* Expand the jump insns. */
start_sequence ();
do_jump (arg0, if_false_label, if_true_label);