diff options
author | rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2008-02-07 17:45:24 +0000 |
---|---|---|
committer | rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2008-02-07 17:45:24 +0000 |
commit | e8e2764693bd76d9eb22d309c522ba06718f56e2 (patch) | |
tree | 0203ab6e3a3a5824c6068a31539b18426d43af15 /gcc/config | |
parent | 4251ed760f214b43bb43729abcd0ce1feda5c173 (diff) | |
download | gcc-e8e2764693bd76d9eb22d309c522ba06718f56e2.tar.gz |
PR rtl-opt/33410
* config/alpha/alpha.c (alpha_emit_xfloating_compare): Use an
EXPR_LIST for the REG_EQUAL instead of a comparison with a
funny mode.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@132171 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/config')
-rw-r--r-- | gcc/config/alpha/alpha.c | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/gcc/config/alpha/alpha.c b/gcc/config/alpha/alpha.c index 800b354a71d..991193f28dc 100644 --- a/gcc/config/alpha/alpha.c +++ b/gcc/config/alpha/alpha.c @@ -3047,7 +3047,7 @@ static rtx alpha_emit_xfloating_compare (enum rtx_code *pcode, rtx op0, rtx op1) { enum rtx_code cmp_code, res_code; - rtx func, out, operands[2]; + rtx func, out, operands[2], note; /* X_floating library comparison functions return -1 unordered @@ -3087,10 +3087,13 @@ alpha_emit_xfloating_compare (enum rtx_code *pcode, rtx op0, rtx op1) operands[1] = op1; out = gen_reg_rtx (DImode); - /* ??? Strange mode for equiv because what's actually returned - is -1,0,1, not a proper boolean value. */ - alpha_emit_xfloating_libcall (func, out, operands, 2, - gen_rtx_fmt_ee (cmp_code, CCmode, op0, op1)); + /* What's actually returned is -1,0,1, not a proper boolean value, + so use an EXPR_LIST as with a generic libcall instead of a + comparison type expression. */ + note = gen_rtx_EXPR_LIST (VOIDmode, op1, NULL_RTX); + note = gen_rtx_EXPR_LIST (VOIDmode, op0, note); + note = gen_rtx_EXPR_LIST (VOIDmode, func, note); + alpha_emit_xfloating_libcall (func, out, operands, 2, note); return out; } |