rewrite floatx80 bias unmasked overflow handling

This commit is contained in:
Stanislav Shwartsman 2024-04-28 10:16:31 +03:00
parent 89bfe81834
commit 2059854e04

View File

@ -40,7 +40,7 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#include "softfloat.h" #include "softfloat.h"
extFloat80_t extFloat80_t
SoftFloat_roundPackToExtF80(bool sign, int32_t exp, uint64_t sig, uint64_t sigExtra, uint8_t roundingPrecision, struct softfloat_status_t *status) softfloat_roundPackToExtF80(bool sign, int32_t exp, uint64_t sig, uint64_t sigExtra, uint8_t roundingPrecision, struct softfloat_status_t *status)
{ {
uint8_t roundingMode; uint8_t roundingMode;
bool roundNearEven; bool roundNearEven;
@ -101,9 +101,15 @@ extFloat80_t
} }
} }
if ((0x7FFE < exp) || ((exp == 0x7FFE) && ((uint64_t) (sig + roundIncrement) < sig))) { if ((0x7FFE < exp) || ((exp == 0x7FFE) && ((uint64_t) (sig + roundIncrement) < sig))) {
if (! softfloat_isMaskedException(status, softfloat_flag_overflow)) {
softfloat_raiseFlags(status, softfloat_flag_overflow);
exp -= 0x6000;
}
else {
goto overflow; goto overflow;
} }
} }
}
/*------------------------------------------------------------------------ /*------------------------------------------------------------------------
*------------------------------------------------------------------------*/ *------------------------------------------------------------------------*/
sigExact = sig; sigExact = sig;
@ -169,6 +175,11 @@ extFloat80_t
} }
} }
if ((0x7FFE < exp) || ((exp == 0x7FFE) && (sig == UINT64_C(0xFFFFFFFFFFFFFFFF)) && doIncrement)) { if ((0x7FFE < exp) || ((exp == 0x7FFE) && (sig == UINT64_C(0xFFFFFFFFFFFFFFFF)) && doIncrement)) {
if (! softfloat_isMaskedException(status, softfloat_flag_overflow)) {
softfloat_raiseFlags(status, softfloat_flag_overflow);
exp -= 0x6000;
}
else {
/*---------------------------------------------------------------- /*----------------------------------------------------------------
*----------------------------------------------------------------*/ *----------------------------------------------------------------*/
roundMask = 0; roundMask = 0;
@ -188,6 +199,7 @@ extFloat80_t
return packToExtF80(sign, exp, sig); return packToExtF80(sign, exp, sig);
} }
} }
}
/*------------------------------------------------------------------------ /*------------------------------------------------------------------------
*------------------------------------------------------------------------*/ *------------------------------------------------------------------------*/
if (sigExtra) { if (sigExtra) {
@ -211,19 +223,3 @@ extFloat80_t
} }
return packToExtF80(sign, exp, sig); return packToExtF80(sign, exp, sig);
} }
extFloat80_t
softfloat_roundPackToExtF80(bool sign, int32_t exp, uint64_t sig, uint64_t sigExtra, uint8_t roundingPrecision, struct softfloat_status_t *status)
{
extFloat80_t result = SoftFloat_roundPackToExtF80(sign, exp, sig, sigExtra, roundingPrecision, status);
// bias unmasked overflow
if (status->softfloat_exceptionFlags & ~status->softfloat_exceptionMasks & softfloat_flag_overflow) {
softfloat_status_t round_status = *status;
softfloat_raiseFlags(&round_status, softfloat_flag_overflow);
result = SoftFloat_roundPackToExtF80(sign, exp - 0x6000, sig, sigExtra, roundingPrecision, &round_status);
*status = round_status;
}
return result;
}