From 7f22b9fca4fea70b3d837e7c6abcb14bd1509b18 Mon Sep 17 00:00:00 2001 From: Roger Sayle Date: Mon, 28 Aug 2006 00:58:47 +0000 Subject: ifcvt.c (cheap_bb_rtx_cost_p): Don't speculatively execute x87 instructions. * ifcvt.c (cheap_bb_rtx_cost_p): Don't speculatively execute x87 instructions. From-SVN: r116501 --- gcc/ifcvt.c | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) (limited to 'gcc/ifcvt.c') diff --git a/gcc/ifcvt.c b/gcc/ifcvt.c index 4787a24..987a2fb 100644 --- a/gcc/ifcvt.c +++ b/gcc/ifcvt.c @@ -1,5 +1,5 @@ /* If-conversion support. - Copyright (C) 2000, 2001, 2002, 2003, 2004, 2005 + Copyright (C) 2000, 2001, 2002, 2003, 2004, 2005, 2006 Free Software Foundation, Inc. This file is part of GCC. @@ -153,14 +153,16 @@ cheap_bb_rtx_cost_p (basic_block bb, int max_cost) /* If this instruction is the load or set of a "stack" register, such as a floating point register on x87, then the cost of - speculatively executing this instruction needs to include - the additional cost of popping this register off of the - register stack. */ + speculatively executing this insn may need to include + the additional cost of popping its result off of the + register stack. Unfortunately, correctly recognizing and + accounting for this additional overhead is tricky, so for + now we simply prohibit such speculative execution. */ #ifdef STACK_REGS { rtx set = single_set (insn); if (set && STACK_REG_P (SET_DEST (set))) - cost += COSTS_N_INSNS (1); + return false; } #endif -- cgit v1.1