mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-01-24 15:25:00 +08:00
Simply check for datatypes with unusual number of unused bits (#4309)
Avoids potential undefined behavior in H5T_is_numeric_with_unusual_unused_bits
This commit is contained in:
parent
c22b801c9d
commit
a37a049ceb
17
src/H5T.c
17
src/H5T.c
@ -6785,24 +6785,13 @@ H5T_is_numeric_with_unusual_unused_bits(const H5T_t *dt)
|
||||
/* Is the correct type? */
|
||||
if (H5T_INTEGER == dt->shared->type || H5T_FLOAT == dt->shared->type ||
|
||||
H5T_BITFIELD == dt->shared->type) {
|
||||
#if LDBL_MANT_DIG == 106
|
||||
/* This currently won't work for the IBM long double type */
|
||||
if (H5T_FLOAT == dt->shared->type && dt->shared->size == 16 &&
|
||||
(dt->shared->u.atomic.prec == 64 || dt->shared->u.atomic.prec == 128))
|
||||
HGOTO_DONE(false);
|
||||
#endif
|
||||
|
||||
/* Has unused bits? */
|
||||
if (dt->shared->u.atomic.prec < (dt->shared->size * 8)) {
|
||||
unsigned surround_bits =
|
||||
1U << (1 + H5VM_log2_gen((dt->shared->u.atomic.prec + dt->shared->u.atomic.offset) - 1));
|
||||
|
||||
if (dt->shared->size > 1 && dt->shared->u.atomic.prec < (dt->shared->size * 8))
|
||||
/* Unused bits are unusually large? */
|
||||
if (dt->shared->size > 1 && ((dt->shared->size * 8) > surround_bits))
|
||||
HGOTO_DONE(true);
|
||||
}
|
||||
ret_value =
|
||||
(dt->shared->size * 8) > (2 * (dt->shared->u.atomic.prec + dt->shared->u.atomic.offset));
|
||||
}
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5T_is_numeric_with_unusual_unused_bits() */
|
||||
|
Loading…
Reference in New Issue
Block a user