diff options
author | burnus <burnus@138bc75d-0d04-0410-961f-82ee72b054a4> | 2013-05-31 10:18:40 +0000 |
---|---|---|
committer | burnus <burnus@138bc75d-0d04-0410-961f-82ee72b054a4> | 2013-05-31 10:18:40 +0000 |
commit | 6dfe7d53c4f1976053252321bdfb4bc9d054941a (patch) | |
tree | 2f36f1f69e0b1048eb78977bea80dcfac7d886e5 /gcc/tree-ssa-math-opts.c | |
parent | ab90be9c20ff268418f712bbd403b4fce4a93ddd (diff) | |
download | gcc-6dfe7d53c4f1976053252321bdfb4bc9d054941a.tar.gz |
2013-05-31 Tobias Burnus <burnus@net-b.de>
PR middle-end/57073
* tree-ssa-math-opts.c (execute_cse_sincos): Move check
further up.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@199529 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/tree-ssa-math-opts.c')
-rw-r--r-- | gcc/tree-ssa-math-opts.c | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/gcc/tree-ssa-math-opts.c b/gcc/tree-ssa-math-opts.c index a15c4042867..b4de411b39d 100644 --- a/gcc/tree-ssa-math-opts.c +++ b/gcc/tree-ssa-math-opts.c @@ -1447,9 +1447,10 @@ execute_cse_sincos (void) arg1 = gimple_call_arg (stmt, 1); loc = gimple_location (stmt); - if (real_minus_onep (arg0) - && TREE_CODE (TREE_TYPE (arg1)) == INTEGER_TYPE - && !host_integerp (arg1,0)) + if (!host_integerp (arg1, 0)) + break; + + if (real_minus_onep (arg0)) { tree t0, t1, cond, one, minus_one; gimple stmt; @@ -1476,9 +1477,6 @@ execute_cse_sincos (void) } else { - if (!host_integerp (arg1, 0)) - break; - n = TREE_INT_CST_LOW (arg1); result = gimple_expand_builtin_powi (&gsi, loc, arg0, n); } |