bd267a5305
Remove a redundant call to `ieee754_setandtestcx' in `ieee754sp_cmp' and `ieee754dp_cmp'. The IEEE 754 exception requested will have already been set by a call to `ieee754_setcx' immediately above, because `sig' has to be non-zero to reach here, and the comparison result returned will be 0 regardless of the result from the call. Simplify the return expression remaining. All this reducing the size of code by 16 and 12 instructions or 64 and 48 bytes respectively. Signed-off-by: Maciej W. Rozycki <macro@linux-mips.org> Cc: linux-mips@linux-mips.org Patchwork: https://patchwork.linux-mips.org/patch/9690/ Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
60 lines
1.5 KiB
C
60 lines
1.5 KiB
C
/* IEEE754 floating point arithmetic
|
|
* single precision
|
|
*/
|
|
/*
|
|
* MIPS floating point support
|
|
* Copyright (C) 1994-2000 Algorithmics Ltd.
|
|
*
|
|
* This program is free software; you can distribute it and/or modify it
|
|
* under the terms of the GNU General Public License (Version 2) as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*/
|
|
|
|
#include "ieee754sp.h"
|
|
|
|
int ieee754sp_cmp(union ieee754sp x, union ieee754sp y, int cmp, int sig)
|
|
{
|
|
int vx;
|
|
int vy;
|
|
|
|
COMPXSP;
|
|
COMPYSP;
|
|
|
|
EXPLODEXSP;
|
|
EXPLODEYSP;
|
|
FLUSHXSP;
|
|
FLUSHYSP;
|
|
ieee754_clearcx(); /* Even clear inexact flag here */
|
|
|
|
if (ieee754_class_nan(xc) || ieee754_class_nan(yc)) {
|
|
if (sig ||
|
|
xc == IEEE754_CLASS_SNAN || yc == IEEE754_CLASS_SNAN)
|
|
ieee754_setcx(IEEE754_INVALID_OPERATION);
|
|
return (cmp & IEEE754_CUN) != 0;
|
|
} else {
|
|
vx = x.bits;
|
|
vy = y.bits;
|
|
|
|
if (vx < 0)
|
|
vx = -vx ^ SP_SIGN_BIT;
|
|
if (vy < 0)
|
|
vy = -vy ^ SP_SIGN_BIT;
|
|
|
|
if (vx < vy)
|
|
return (cmp & IEEE754_CLT) != 0;
|
|
else if (vx == vy)
|
|
return (cmp & IEEE754_CEQ) != 0;
|
|
else
|
|
return (cmp & IEEE754_CGT) != 0;
|
|
}
|
|
}
|