From 65f141179f4af86da654e1a0787c58f7ecf60c72 Mon Sep 17 00:00:00 2001
From: John Tytgat <John@bass-software.com>
Date: Thu, 13 Dec 2012 12:05:30 +0000
Subject: [PATCH] fp16.c (__gnu_f2h_internal): Fix inaccuracy when aexp is 25.

	* config/arm/fp16.c (__gnu_f2h_internal): Fix inaccuracy when aexp
	is 25.

From-SVN: r194474
---
 libgcc/ChangeLog         | 5 +++++
 libgcc/config/arm/fp16.c | 8 +++-----
 2 files changed, 8 insertions(+), 5 deletions(-)

diff --git a/libgcc/ChangeLog b/libgcc/ChangeLog
index 95b95b1d1939..df3dfeef71fa 100644
--- a/libgcc/ChangeLog
+++ b/libgcc/ChangeLog
@@ -1,3 +1,8 @@
+2012-12-13  John Tytgat  <John@bass-software.com>
+
+	* config/arm/fp16.c (__gnu_f2h_internal): Fix inaccuracy when aexp
+	is 25.
+
 2012-12-12  Jakub Jelinek  <jakub@redhat.com>
 
 	PR libgcc/55451
diff --git a/libgcc/config/arm/fp16.c b/libgcc/config/arm/fp16.c
index 936caeb78d05..786830f2ec60 100644
--- a/libgcc/config/arm/fp16.c
+++ b/libgcc/config/arm/fp16.c
@@ -47,11 +47,9 @@ __gnu_f2h_internal(unsigned int a, int ieee)
   mantissa |= 0x00800000;
   if (aexp < -14)
     {
-      mask = 0x007fffff;
-      if (aexp < -25)
-	aexp = -26;
-      else if (aexp != -25)
-	mask >>= 24 + aexp;
+      mask = 0x00ffffff;
+      if (aexp >= -25)
+        mask >>= 25 + aexp;
     }
   else
     mask = 0x00001fff;
-- 
GitLab