5fd1486ce5
2017-01-24 Pekka Jääskeläinen <pekka@parmance.com> Martin Jambor <mjambor@suse.cz> * Makefile.def (target_modules): Added libhsail-rt. (languages): Added language brig. * Makefile.in: Regenerated. * configure.ac (TOPLEVEL_CONFIGURE_ARGUMENTS): Added tgarget-libhsail-rt. Make brig unsupported on untested architectures. * configure: Regenerated. gcc/ * brig-builtins.def: New file. * builtins.def (DEF_HSAIL_BUILTIN): New macro. (DEF_HSAIL_ATOMIC_BUILTIN): Likewise. (DEF_HSAIL_SAT_BUILTIN): Likewise. (DEF_HSAIL_INTR_BUILTIN): Likewise. (DEF_HSAIL_CVT_ZEROI_SAT_BUILTIN): Likewise. * builtin-types.def (BT_INT8): New. (BT_INT16): Likewise. (BT_UINT8): Likewise. (BT_UINT16): Likewise. (BT_FN_ULONG): Likewise. (BT_FN_UINT_INT): Likewise. (BT_FN_UINT_ULONG): Likewise. (BT_FN_UINT_LONG): Likewise. (BT_FN_UINT_PTR): Likewise. (BT_FN_ULONG_PTR): Likewise. (BT_FN_INT8_FLOAT): Likewise. (BT_FN_INT16_FLOAT): Likewise. (BT_FN_UINT32_FLOAT): Likewise. (BT_FN_UINT16_FLOAT): Likewise. (BT_FN_UINT8_FLOAT): Likewise. (BT_FN_UINT64_FLOAT): Likewise. (BT_FN_UINT16_UINT32): Likewise. (BT_FN_UINT32_UINT16): Likewise. (BT_FN_UINT16_UINT16_UINT16): Likewise. (BT_FN_INT_PTR_INT): Likewise. (BT_FN_UINT_PTR_UINT): Likewise. (BT_FN_LONG_PTR_LONG): Likewise. (BT_FN_ULONG_PTR_ULONG): Likewise. (BT_FN_VOID_UINT64_UINT64): Likewise. (BT_FN_UINT8_UINT8_UINT8): Likewise. (BT_FN_INT8_INT8_INT8): Likewise. (BT_FN_INT16_INT16_INT16): Likewise. (BT_FN_INT_INT_INT): Likewise. (BT_FN_UINT_FLOAT_UINT): Likewise. (BT_FN_FLOAT_UINT_UINT): Likewise. (BT_FN_ULONG_UINT_UINT): Likewise. (BT_FN_ULONG_UINT_PTR): Likewise. (BT_FN_ULONG_ULONG_ULONG): Likewise. (BT_FN_UINT_UINT_UINT): Likewise. (BT_FN_VOID_UINT_PTR): Likewise. (BT_FN_UINT_UINT_PTR: Likewise. (BT_FN_UINT32_UINT64_PTR): Likewise. (BT_FN_INT_INT_UINT_UINT): Likewise. (BT_FN_UINT_UINT_UINT_UINT): Likewise. (BT_FN_UINT_UINT_UINT_PTR): Likewise. (BT_FN_UINT_ULONG_ULONG_UINT): Likewise. (BT_FN_ULONG_ULONG_ULONG_ULONG): Likewise. (BT_FN_LONG_LONG_UINT_UINT): Likewise. (BT_FN_ULONG_ULONG_UINT_UINT): Likewise. (BT_FN_VOID_UINT32_UINT64_PTR): Likewise. (BT_FN_VOID_UINT32_UINT32_PTR): Likewise. (BT_FN_UINT_UINT_UINT_UINT_UINT): Likewise. (BT_FN_UINT_FLOAT_FLOAT_FLOAT_FLOAT): Likewise. (BT_FN_ULONG_ULONG_ULONG_UINT_UINT): Likewise. * doc/frontends.texi: List BRIG FE. * doc/install.texi (Testing): Add BRIG tesring requirements. * doc/invoke.texi (Overall Options): Mention BRIG. * doc/standards.texi (Standards): Doucment BRIG HSA version. gcc/brig/ * Make-lang.in: New file. * brig-builtins.h: Likewise. * brig-c.h: Likewise. * brig-lang.c: Likewise. * brigspec.c: Likewise. * config-lang.in: Likewise. * lang-specs.h: Likewise. * lang.opt: Likewise. * brigfrontend/brig-arg-block-handler.cc: Likewise. * brigfrontend/brig-atomic-inst-handler.cc: Likewise. * brigfrontend/brig-basic-inst-handler.cc: Likewise. * brigfrontend/brig-branch-inst-handler.cc: Likewise. * brigfrontend/brig-cmp-inst-handler.cc: Likewise. * brigfrontend/brig-code-entry-handler.cc: Likewise. * brigfrontend/brig-code-entry-handler.h: Likewise. * brigfrontend/brig-comment-handler.cc: Likewise. * brigfrontend/brig-control-handler.cc: Likewise. * brigfrontend/brig-copy-move-inst-handler.cc: Likewise. * brigfrontend/brig-cvt-inst-handler.cc: Likewise. * brigfrontend/brig-fbarrier-handler.cc: Likewise. * brigfrontend/brig-function-handler.cc: Likewise. * brigfrontend/brig-function.cc: Likewise. * brigfrontend/brig-function.h: Likewise. * brigfrontend/brig-inst-mod-handler.cc: Likewise. * brigfrontend/brig-label-handler.cc: Likewise. * brigfrontend/brig-lane-inst-handler.cc: Likewise. * brigfrontend/brig-machine.c: Likewise. * brigfrontend/brig-machine.h: Likewise. * brigfrontend/brig-mem-inst-handler.cc: Likewise. * brigfrontend/brig-module-handler.cc: Likewise. * brigfrontend/brig-queue-inst-handler.cc: Likewise. * brigfrontend/brig-seg-inst-handler.cc: Likewise. * brigfrontend/brig-signal-inst-handler.cc: Likewise. * brigfrontend/brig-to-generic.cc: Likewise. * brigfrontend/brig-to-generic.h: Likewise. * brigfrontend/brig-util.cc: Likewise. * brigfrontend/brig-util.h: Likewise. * brigfrontend/brig-variable-handler.cc: Likewise. * brigfrontend/phsa.h: Likewise. gcc/testsuite/ * lib/brig-dg.exp: New file. * lib/brig.exp: Likewise. * brig.dg/README: Likewise. * brig.dg/dg.exp: Likewise. * brig.dg/test/gimple/alloca.hsail: Likewise. * brig.dg/test/gimple/atomics.hsail: Likewise. * brig.dg/test/gimple/branches.hsail: Likewise. * brig.dg/test/gimple/fbarrier.hsail: Likewise. * brig.dg/test/gimple/function_calls.hsail: Likewise. * brig.dg/test/gimple/kernarg.hsail: Likewise. * brig.dg/test/gimple/mem.hsail: Likewise. * brig.dg/test/gimple/mulhi.hsail: Likewise. * brig.dg/test/gimple/packed.hsail: Likewise. * brig.dg/test/gimple/smoke_test.hsail: Likewise. * brig.dg/test/gimple/variables.hsail: Likewise. * brig.dg/test/gimple/vector.hsail: Likewise. include/ * hsa.h: Moved here from libgomp/plugin/hsa.h. libgomp/ * plugin/hsa.h: Moved to top level include. * plugin/plugin-hsa.c: Chanfgd include of hsa.h accordingly. libhsail-rt/ * Makefile.am: New file. * target-config.h.in: Likewise. * configure.ac: Likewise. * configure: Likewise. * config.h.in: Likewise. * aclocal.m4: Likewise. * README: Likewise. * Makefile.in: Likewise. * include/internal/fibers.h: Likewise. * include/internal/phsa-queue-interface.h: Likewise. * include/internal/phsa-rt.h: Likewise. * include/internal/workitems.h: Likewise. * rt/arithmetic.c: Likewise. * rt/atomics.c: Likewise. * rt/bitstring.c: Likewise. * rt/fbarrier.c: Likewise. * rt/fibers.c: Likewise. * rt/fp16.c: Likewise. * rt/misc.c: Likewise. * rt/multimedia.c: Likewise. * rt/queue.c: Likewise. * rt/sat_arithmetic.c: Likewise. * rt/segment.c: Likewise. * rt/workitems.c: Likewise. Co-Authored-By: Martin Jambor <mjambor@suse.cz> From-SVN: r244867
476 lines
9.6 KiB
C
476 lines
9.6 KiB
C
/* arithmetic.c -- Builtins for HSAIL arithmetic instructions for which
|
|
there is no feasible direct gcc GENERIC expression.
|
|
|
|
Copyright (C) 2015-2016 Free Software Foundation, Inc.
|
|
Contributed by Pekka Jaaskelainen <pekka.jaaskelainen@parmance.com>
|
|
for General Processor Tech.
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a
|
|
copy of this software and associated documentation files
|
|
(the "Software"), to deal in the Software without restriction, including
|
|
without limitation the rights to use, copy, modify, merge, publish,
|
|
distribute, sublicense, and/or sell copies of the Software, and to
|
|
permit persons to whom the Software is furnished to do so, subject to
|
|
the following conditions:
|
|
|
|
The above copyright notice and this permission notice shall be included
|
|
in all copies or substantial portions of the Software.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
|
DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
|
USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <stdint.h>
|
|
#include <limits.h>
|
|
#include <math.h>
|
|
#include <float.h>
|
|
|
|
/* HSAIL defines INT_MIN % -1 to be 0 while with C it's undefined,
|
|
and causes an overflow exception at least with gcc and C on IA-32. */
|
|
|
|
int32_t
|
|
__hsail_rem_s32 (int32_t dividend, int32_t divisor)
|
|
{
|
|
if (dividend == INT_MIN && divisor == -1)
|
|
return 0;
|
|
else
|
|
return dividend % divisor;
|
|
}
|
|
|
|
int64_t
|
|
__hsail_rem_s64 (int64_t dividend, int64_t divisor)
|
|
{
|
|
if (dividend == INT64_MIN && divisor == -1)
|
|
return 0;
|
|
else
|
|
return dividend % divisor;
|
|
}
|
|
|
|
/* HSAIL has defined behavior for min and max when one of the operands is
|
|
NaN: in that case the other operand is returned. In C and with gcc's
|
|
MIN_EXPR/MAX_EXPR, the returned operand is undefined. */
|
|
|
|
float
|
|
__hsail_min_f32 (float a, float b)
|
|
{
|
|
if (isnan (a))
|
|
return b;
|
|
else if (isnan (b))
|
|
return a;
|
|
else if (a == 0.0f && b == 0.0f)
|
|
return signbit (a) ? a : b;
|
|
else if (a > b)
|
|
return b;
|
|
else
|
|
return a;
|
|
}
|
|
|
|
double
|
|
__hsail_min_f64 (double a, double b)
|
|
{
|
|
if (isnan (a))
|
|
return b;
|
|
else if (isnan (b))
|
|
return a;
|
|
else if (a > b)
|
|
return b;
|
|
else
|
|
return a;
|
|
}
|
|
|
|
float
|
|
__hsail_max_f32 (float a, float b)
|
|
{
|
|
if (isnan (a))
|
|
return b;
|
|
else if (isnan (b))
|
|
return a;
|
|
else if (a == 0.0f && b == 0.0f && signbit (a))
|
|
return b;
|
|
else if (a < b)
|
|
return b;
|
|
else
|
|
return a;
|
|
}
|
|
|
|
double
|
|
__hsail_max_f64 (double a, double b)
|
|
{
|
|
if (isnan (a))
|
|
return b;
|
|
else if (isnan (b))
|
|
return a;
|
|
else if (a == 0.0 && b == 0.0 && signbit (a))
|
|
return b;
|
|
else if (a < b)
|
|
return b;
|
|
else
|
|
return a;
|
|
}
|
|
|
|
uint8_t
|
|
__hsail_cvt_zeroi_sat_u8_f32 (float a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (float) UINT8_MAX)
|
|
return UINT8_MAX;
|
|
else if (a <= 0.0f)
|
|
return 0;
|
|
return (uint8_t) a;
|
|
}
|
|
|
|
int8_t
|
|
__hsail_cvt_zeroi_sat_s8_f32 (float a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (float) INT8_MAX)
|
|
return INT8_MAX;
|
|
if (a <= (float) INT8_MIN)
|
|
return INT8_MIN;
|
|
return (int8_t) a;
|
|
}
|
|
|
|
uint16_t
|
|
__hsail_cvt_zeroi_sat_u16_f32 (float a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (float) UINT16_MAX)
|
|
return UINT16_MAX;
|
|
else if (a <= 0.0f)
|
|
return 0;
|
|
return (uint16_t) a;
|
|
}
|
|
|
|
int16_t
|
|
__hsail_cvt_zeroi_sat_s16_f32 (float a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (float) INT16_MAX)
|
|
return INT16_MAX;
|
|
if (a <= (float) INT16_MIN)
|
|
return INT16_MIN;
|
|
return (int16_t) a;
|
|
}
|
|
|
|
uint32_t
|
|
__hsail_cvt_zeroi_sat_u32_f32 (float a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (float) UINT32_MAX)
|
|
return UINT32_MAX;
|
|
else if (a <= 0.0f)
|
|
return 0;
|
|
return (uint32_t) a;
|
|
}
|
|
|
|
int32_t
|
|
__hsail_cvt_zeroi_sat_s32_f32 (float a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (float) INT32_MAX)
|
|
return INT32_MAX;
|
|
if (a <= (float) INT32_MIN)
|
|
return INT32_MIN;
|
|
return (int32_t) a;
|
|
}
|
|
|
|
uint64_t
|
|
__hsail_cvt_zeroi_sat_u64_f32 (float a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (float) UINT64_MAX)
|
|
return UINT64_MAX;
|
|
else if (a <= 0.0f)
|
|
return 0;
|
|
return (uint64_t) a;
|
|
}
|
|
|
|
int64_t
|
|
__hsail_cvt_zeroi_sat_s64_f32 (float a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (float) INT64_MAX)
|
|
return INT64_MAX;
|
|
if (a <= (float) INT64_MIN)
|
|
return INT64_MIN;
|
|
return (int64_t) a;
|
|
}
|
|
|
|
uint8_t
|
|
__hsail_cvt_zeroi_sat_u8_f64 (double a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (double) UINT8_MAX)
|
|
return UINT8_MAX;
|
|
else if (a <= 0.0f)
|
|
return 0;
|
|
return (uint8_t) a;
|
|
}
|
|
|
|
int8_t
|
|
__hsail_cvt_zeroi_sat_s8_f64 (double a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (double) INT8_MAX)
|
|
return INT8_MAX;
|
|
if (a <= (double) INT8_MIN)
|
|
return INT8_MIN;
|
|
return (int8_t) a;
|
|
}
|
|
|
|
uint16_t
|
|
__hsail_cvt_zeroi_sat_u16_f64 (double a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (double) UINT16_MAX)
|
|
return UINT16_MAX;
|
|
else if (a <= 0.0f)
|
|
return 0;
|
|
return (uint16_t) a;
|
|
}
|
|
|
|
int16_t
|
|
__hsail_cvt_zeroi_sat_s16_f64 (double a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (double) INT16_MAX)
|
|
return INT16_MAX;
|
|
if (a <= (double) INT16_MIN)
|
|
return INT16_MIN;
|
|
return (int16_t) a;
|
|
}
|
|
|
|
uint32_t
|
|
__hsail_cvt_zeroi_sat_u32_f64 (double a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (double) UINT32_MAX)
|
|
return UINT32_MAX;
|
|
else if (a <= 0.0f)
|
|
return 0;
|
|
return (uint32_t) a;
|
|
}
|
|
|
|
int32_t
|
|
__hsail_cvt_zeroi_sat_s32_f64 (double a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (double) INT32_MAX)
|
|
return INT32_MAX;
|
|
if (a <= (double) INT32_MIN)
|
|
return INT32_MIN;
|
|
return (int32_t) a;
|
|
}
|
|
|
|
uint64_t
|
|
__hsail_cvt_zeroi_sat_u64_f64 (double a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (double) UINT64_MAX)
|
|
return UINT64_MAX;
|
|
else if (a <= 0.0f)
|
|
return 0;
|
|
return (uint64_t) a;
|
|
}
|
|
|
|
int64_t
|
|
__hsail_cvt_zeroi_sat_s64_f64 (double a)
|
|
{
|
|
if (isnan (a))
|
|
return 0;
|
|
if (a >= (double) INT64_MAX)
|
|
return INT64_MAX;
|
|
if (a <= (double) INT64_MIN)
|
|
return INT64_MIN;
|
|
return (int64_t) a;
|
|
}
|
|
|
|
|
|
/* Flush the operand to zero in case it's a denormalized number.
|
|
Do not cause any exceptions in case of NaNs. */
|
|
|
|
float
|
|
__hsail_ftz_f32 (float a)
|
|
{
|
|
if (isnan (a) || isinf (a) || a == 0.0f)
|
|
return a;
|
|
|
|
if (a < 0.0f)
|
|
{
|
|
if (-a < FLT_MIN)
|
|
return -0.0f;
|
|
}
|
|
else
|
|
{
|
|
if (a < FLT_MIN)
|
|
return 0.0f;
|
|
}
|
|
return a;
|
|
}
|
|
|
|
#define F16_MIN (6.10e-5)
|
|
|
|
/* Flush the single precision operand to zero in case it's considered
|
|
a denormalized number in case it was a f16. Do not cause any exceptions
|
|
in case of NaNs. */
|
|
|
|
float
|
|
__hsail_ftz_f32_f16 (float a)
|
|
{
|
|
if (isnan (a) || isinf (a) || a == 0.0f)
|
|
return a;
|
|
|
|
if (a < 0.0f)
|
|
{
|
|
if (-a < F16_MIN)
|
|
return -0.0f;
|
|
}
|
|
else
|
|
{
|
|
if (a < F16_MIN)
|
|
return 0.0f;
|
|
}
|
|
return a;
|
|
}
|
|
|
|
double
|
|
__hsail_ftz_f64 (double a)
|
|
{
|
|
if (isnan (a) || isinf (a) || a == 0.0d)
|
|
return a;
|
|
|
|
if (a < 0.0d)
|
|
{
|
|
if (-a < DBL_MIN)
|
|
return -0.0d;
|
|
}
|
|
else
|
|
{
|
|
if (a < DBL_MIN)
|
|
return 0.0d;
|
|
}
|
|
return a;
|
|
}
|
|
|
|
uint32_t
|
|
__hsail_borrow_u32 (uint32_t a, uint32_t b)
|
|
{
|
|
uint64_t c = (uint64_t) a - (uint64_t) b;
|
|
if (c > UINT32_MAX)
|
|
return 1;
|
|
else
|
|
return 0;
|
|
}
|
|
|
|
uint64_t
|
|
__hsail_borrow_u64 (uint64_t a, uint64_t b)
|
|
{
|
|
__uint128_t c = (__uint128_t) a - (__uint128_t) b;
|
|
if (c > UINT64_MAX)
|
|
return 1;
|
|
else
|
|
return 0;
|
|
}
|
|
|
|
uint32_t
|
|
__hsail_carry_u32 (uint32_t a, uint32_t b)
|
|
{
|
|
uint64_t c = (uint64_t) a + (uint64_t) b;
|
|
if (c > UINT32_MAX)
|
|
return 1;
|
|
else
|
|
return 0;
|
|
}
|
|
|
|
uint64_t
|
|
__hsail_carry_u64 (uint64_t a, uint64_t b)
|
|
{
|
|
__uint128_t c = (__uint128_t) a + (__uint128_t) b;
|
|
if (c > UINT64_MAX)
|
|
return 1;
|
|
else
|
|
return 0;
|
|
}
|
|
|
|
float
|
|
__hsail_fract_f32 (float a)
|
|
{
|
|
int exp;
|
|
if (isinf (a))
|
|
return signbit (a) == 0 ? 0.0f : -0.0f;
|
|
if (isnan (a) || a == 0.0f)
|
|
return a;
|
|
else
|
|
return fminf (a - floorf (a), 0x1.fffffep-1f);
|
|
}
|
|
|
|
double
|
|
__hsail_fract_f64 (double a)
|
|
{
|
|
int exp;
|
|
if (isinf (a))
|
|
return 0.0f * isinf (a);
|
|
if (isnan (a) || a == 0.0f)
|
|
return a;
|
|
else
|
|
return fmin (a - floor (a), 0x1.fffffffffffffp-1d);
|
|
}
|
|
|
|
uint32_t
|
|
__hsail_class_f32 (float a, uint32_t flags)
|
|
{
|
|
return (flags & 0x0001 && isnan (a) && !(*(uint32_t *) &a & 0x40000000))
|
|
|| (flags & 0x0002 && isnan (a) && (*(uint32_t *) &a & 0x40000000))
|
|
|| (flags & 0x0004 && isinf (a) && a < 0.0f)
|
|
|| (flags & 0x0008 && isnormal (a) && signbit (a))
|
|
|| (flags & 0x0010 && a < 0.0f && a > -FLT_MIN)
|
|
|| (flags & 0x0020 && a == 0.0f && signbit (a))
|
|
|| (flags & 0x0040 && a == 0.0f && !signbit (a))
|
|
|| (flags & 0x0080 && a > 0.0f && a < FLT_MIN)
|
|
|| (flags & 0x0100 && isnormal (a) && !signbit (a))
|
|
|| (flags & 0x0200 && isinf (a) && a >= 0.0f);
|
|
}
|
|
|
|
/* 'class' for a f32-converted f16 which should otherwise be treated like f32
|
|
except for its limits. */
|
|
|
|
uint32_t
|
|
__hsail_class_f32_f16 (float a, uint32_t flags)
|
|
{
|
|
return (flags & 0x0001 && isnan (a) && !(*(uint32_t *) &a & 0x40000000))
|
|
|| (flags & 0x0002 && isnan (a) && (*(uint32_t *) &a & 0x40000000))
|
|
|| (flags & 0x0004 && isinf (a) && a < 0.0f)
|
|
|| (flags & 0x0008 && a != 0.0f && !isinf (a) && !isnan (a)
|
|
&& a <= -F16_MIN)
|
|
|| (flags & 0x0010 && a != 0.0f && !isinf (a) && !isnan (a) && a < 0.0f
|
|
&& a > -F16_MIN)
|
|
|| (flags & 0x0020 && a == 0.0f && signbit (a))
|
|
|| (flags & 0x0040 && a == 0.0f && !signbit (a))
|
|
|| (flags & 0x0080 && a != 0.0f && !isinf (a) && !isnan (a) && a > 0.0f
|
|
&& a < F16_MIN)
|
|
|| (flags & 0x0100 && a != 0.0f && !isinf (a) && !isnan (a)
|
|
&& a >= F16_MIN)
|
|
|| (flags & 0x0200 && isinf (a) && a >= 0.0f);
|
|
}
|