From: Joseph Myers Date: Mon, 8 Jun 2020 16:56:47 +0000 (+0000) Subject: softfloat: do not set denominator high bit for floatx80 remainder X-Git-Tag: v5.1.0-rc0~46^2~13 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=566601f1f9d972e44214696d3cb320e6c18880aa;p=thirdparty%2Fqemu.git softfloat: do not set denominator high bit for floatx80 remainder The floatx80 remainder implementation unnecessarily sets the high bit of bSig explicitly. By that point in the function, arguments that are invalid, zero, infinity or NaN have already been handled and subnormals have been through normalizeFloatx80Subnormal, so the high bit will already be set. Remove the unnecessary code. Signed-off-by: Joseph Myers Reviewed-by: Richard Henderson Message-Id: Signed-off-by: Paolo Bonzini --- diff --git a/fpu/softfloat.c b/fpu/softfloat.c index ab50088c35c..1ee33427153 100644 --- a/fpu/softfloat.c +++ b/fpu/softfloat.c @@ -5751,7 +5751,6 @@ floatx80 floatx80_modrem(floatx80 a, floatx80 b, bool mod, if ( aSig0 == 0 ) return a; normalizeFloatx80Subnormal( aSig0, &aExp, &aSig0 ); } - bSig |= UINT64_C(0x8000000000000000); zSign = aSign; expDiff = aExp - bExp; aSig1 = 0;