OSDN Git Service

softfloat: logB(0) should raise divideByZero exception
authorSong Gao <gaosong@loongson.cn>
Fri, 30 Sep 2022 02:45:10 +0000 (10:45 +0800)
committerSong Gao <gaosong@loongson.cn>
Mon, 17 Oct 2022 02:28:35 +0000 (10:28 +0800)
logB(0) should raise divideByZero exception from IEEE 754-2008 spec 7.3

Suggested-by: Richard Henderson <richard.henderson@linaro.org>
Signed-off-by: Song Gao <gaosong@loongson.cn>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-Id: <20220930024510.800005-4-gaosong@loongson.cn>

fpu/softfloat-parts.c.inc

index a9f268f..2474000 100644 (file)
@@ -1436,6 +1436,7 @@ static void partsN(log2)(FloatPartsN *a, float_status *s, const FloatFmt *fmt)
             parts_return_nan(a, s);
             return;
         case float_class_zero:
+            float_raise(float_flag_divbyzero, s);
             /* log2(0) = -inf */
             a->cls = float_class_inf;
             a->sign = 1;