rewrite floatx80 bias unmasked overflow handling
This commit is contained in:
parent
89bfe81834
commit
2059854e04
@ -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;
|
|
||||||
}
|
|
||||||
|
Loading…
Reference in New Issue
Block a user