Not all the paths in the functions, such as f16ToFloatX(), initialize the member 'exp' of the structure floatX.
Signed-off-by: Andrey Shinkevich <andrey.shinkev...@virtuozzo.com> --- source/slowfloat.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/tests/fp/berkeley-testfloat-3/source/slowfloat.c b/tests/fp/berkeley-testfloat-3/source/slowfloat.c index 4e84656..6e0f0a6 100644 --- a/tests/fp/berkeley-testfloat-3/source/slowfloat.c +++ b/tests/fp/berkeley-testfloat-3/source/slowfloat.c @@ -623,6 +623,7 @@ static void f16ToFloatX( float16_t a, struct floatX *xPtr ) xPtr->isInf = false; xPtr->isZero = false; xPtr->sign = ((uiA & 0x8000) != 0); + xPtr->exp = 0; exp = uiA>>10 & 0x1F; sig64 = uiA & 0x03FF; sig64 <<= 45; @@ -759,6 +760,7 @@ static void f32ToFloatX( float32_t a, struct floatX *xPtr ) xPtr->isInf = false; xPtr->isZero = false; xPtr->sign = ((uiA & 0x80000000) != 0); + xPtr->exp = 0; exp = uiA>>23 & 0xFF; sig64 = uiA & 0x007FFFFF; sig64 <<= 32; @@ -895,6 +897,7 @@ static void f64ToFloatX( float64_t a, struct floatX *xPtr ) xPtr->isInf = false; xPtr->isZero = false; xPtr->sign = ((uiA & UINT64_C( 0x8000000000000000 )) != 0); + xPtr->exp = 0; exp = uiA>>52 & 0x7FF; sig64 = uiA & UINT64_C( 0x000FFFFFFFFFFFFF ); if ( exp == 0x7FF ) { @@ -1220,6 +1223,7 @@ static void f128MToFloatX( const float128_t *aPtr, struct floatX *xPtr ) xPtr->isZero = false; uiA64 = uiAPtr->v64; xPtr->sign = ((uiA64 & UINT64_C( 0x8000000000000000 )) != 0); + xPtr->exp = 0; exp = uiA64>>48 & 0x7FFF; sig.v64 = uiA64 & UINT64_C( 0x0000FFFFFFFFFFFF ); sig.v0 = uiAPtr->v0; -- 1.8.3.1