Author: das
Date: Fri Jan 20 06:16:14 2012
New Revision: 230363
URL: http://svn.freebsd.org/changeset/base/230363

Log:
  Merge in the latest SoftFloat changes from NetBSD.  (NetBSD isn't the
  original vendor, but we're using their heavily modified version.)
  This brings in functions for long double emulation (both extended and
  quad formats), which may be useful for testing, and also for replacing
  libc/sparc64/fpu/.

Added:
  head/lib/libc/softfloat/eqtf2.c   (contents, props changed)
  head/lib/libc/softfloat/getf2.c   (contents, props changed)
  head/lib/libc/softfloat/gexf2.c   (contents, props changed)
  head/lib/libc/softfloat/gttf2.c   (contents, props changed)
  head/lib/libc/softfloat/gtxf2.c   (contents, props changed)
  head/lib/libc/softfloat/letf2.c   (contents, props changed)
  head/lib/libc/softfloat/lttf2.c   (contents, props changed)
  head/lib/libc/softfloat/negtf2.c   (contents, props changed)
  head/lib/libc/softfloat/negxf2.c   (contents, props changed)
  head/lib/libc/softfloat/netf2.c   (contents, props changed)
  head/lib/libc/softfloat/nexf2.c   (contents, props changed)
Modified:
  head/lib/libc/softfloat/Makefile.inc
  head/lib/libc/softfloat/bits32/softfloat-macros
  head/lib/libc/softfloat/bits64/softfloat-macros
  head/lib/libc/softfloat/bits64/softfloat.c
  head/lib/libc/softfloat/softfloat-for-gcc.h
  head/lib/libc/softfloat/softfloat-source.txt
  head/lib/libc/softfloat/softfloat-specialize
  head/lib/libc/softfloat/softfloat.txt

Modified: head/lib/libc/softfloat/Makefile.inc
==============================================================================
--- head/lib/libc/softfloat/Makefile.inc        Fri Jan 20 05:05:47 2012        
(r230362)
+++ head/lib/libc/softfloat/Makefile.inc        Fri Jan 20 06:16:14 2012        
(r230363)
@@ -1,4 +1,4 @@
-#      $NetBSD: Makefile.inc,v 1.3 2003/05/06 08:58:20 rearnsha Exp $
+#      $NetBSD: Makefile.inc,v 1.10 2011/07/04 02:53:15 mrg Exp $
 # $FreeBSD$
 
 SOFTFLOAT_BITS?=64
@@ -17,4 +17,14 @@ SRCS+=               eqsf2.c nesf2.c gtsf2.c gesf2.c 
                eqdf2.c nedf2.c gtdf2.c gedf2.c ltdf2.c ledf2.c negdf2.c \
                unordsf2.c unorddf2.c
 
+.if defined(SOFTFLOAT_128)
+CFLAGS+=       -DFLOAT128
+SRCS+=         eqtf2.c netf2.c gttf2.c getf2.c lttf2.c letf2.c negtf2.c
+.endif
+
+.if defined(SOFTFLOAT_X80)
+CFLAGS+=       -DFLOATX80
+SRCS+=         nexf2.c gtxf2.c gexf2.c negxf2.c
+.endif
+
 SYM_MAPS+=     ${.CURDIR}/softfloat/Symbol.map

Modified: head/lib/libc/softfloat/bits32/softfloat-macros
==============================================================================
--- head/lib/libc/softfloat/bits32/softfloat-macros     Fri Jan 20 05:05:47 
2012        (r230362)
+++ head/lib/libc/softfloat/bits32/softfloat-macros     Fri Jan 20 06:16:14 
2012        (r230363)
@@ -312,7 +312,7 @@ INLINE void
     carry0 = ( z1 < a1 );
     z0 = a0 + b0;
     z1 += carry1;
-    z0 += ( z1 < carry1 );
+    z0 += ( z1 < (bits32)carry1 );
     z0 += carry0;
     *z2Ptr = z2;
     *z1Ptr = z1;
@@ -369,7 +369,7 @@ INLINE void
     z1 = a1 - b1;
     borrow0 = ( a1 < b1 );
     z0 = a0 - b0;
-    z0 -= ( z1 < borrow1 );
+    z0 -= ( z1 < (bits32)borrow1 );
     z1 -= borrow1;
     z0 -= borrow0;
     *z2Ptr = z2;

Modified: head/lib/libc/softfloat/bits64/softfloat-macros
==============================================================================
--- head/lib/libc/softfloat/bits64/softfloat-macros     Fri Jan 20 05:05:47 
2012        (r230362)
+++ head/lib/libc/softfloat/bits64/softfloat-macros     Fri Jan 20 06:16:14 
2012        (r230363)
@@ -1,4 +1,4 @@
-/* $NetBSD: softfloat-macros,v 1.1 2002/05/21 23:51:08 bjh21 Exp $ */
+/* $NetBSD: softfloat-macros,v 1.2 2009/02/16 10:23:35 tron Exp $ */
 /* $FreeBSD$ */
 
 /*
@@ -387,7 +387,7 @@ INLINE void
     carry0 = ( z1 < a1 );
     z0 = a0 + b0;
     z1 += carry1;
-    z0 += ( z1 < carry1 );
+    z0 += ( z1 < (bits64)carry1 );
     z0 += carry0;
     *z2Ptr = z2;
     *z1Ptr = z1;
@@ -444,7 +444,7 @@ INLINE void
     z1 = a1 - b1;
     borrow0 = ( a1 < b1 );
     z0 = a0 - b0;
-    z0 -= ( z1 < borrow1 );
+    z0 -= ( z1 < (bits64)borrow1 );
     z1 -= borrow1;
     z0 -= borrow0;
     *z2Ptr = z2;

Modified: head/lib/libc/softfloat/bits64/softfloat.c
==============================================================================
--- head/lib/libc/softfloat/bits64/softfloat.c  Fri Jan 20 05:05:47 2012        
(r230362)
+++ head/lib/libc/softfloat/bits64/softfloat.c  Fri Jan 20 06:16:14 2012        
(r230363)
@@ -1,4 +1,4 @@
-/* $NetBSD: softfloat.c,v 1.2 2003/07/26 19:24:52 salo Exp $ */
+/* $NetBSD: softfloat.c,v 1.8 2011/07/10 04:52:23 matt Exp $ */
 
 /*
  * This version hacked for use with gcc -msoft-float by bjh21.
@@ -1126,6 +1126,15 @@ float32 int32_to_float32( int32 a )
 
 }
 
+float32 uint32_to_float32( uint32 a )
+{
+    if ( a == 0 ) return 0;
+    if ( a & (bits32) 0x80000000 )
+       return normalizeRoundAndPackFloat32( 0, 0x9D, a >> 1 );
+    return normalizeRoundAndPackFloat32( 0, 0x9C, a );
+}
+
+
 /*
 -------------------------------------------------------------------------------
 Returns the result of converting the 32-bit two's complement integer `a'
@@ -1149,6 +1158,17 @@ float64 int32_to_float64( int32 a )
 
 }
 
+float64 uint32_to_float64( uint32 a )
+{
+    int8 shiftCount;
+    bits64 zSig = a;
+
+    if ( a == 0 ) return 0;
+    shiftCount = countLeadingZeros32( a ) + 21;
+    return packFloat64( 0, 0x432 - shiftCount, zSig<<shiftCount );
+
+}
+
 #ifdef FLOATX80
 
 /*
@@ -1175,6 +1195,17 @@ floatx80 int32_to_floatx80( int32 a )
 
 }
 
+floatx80 uint32_to_floatx80( uint32 a )
+{
+    int8 shiftCount;
+    bits64 zSig = a;
+
+    if ( a == 0 ) return packFloatx80( 0, 0, 0 );
+    shiftCount = countLeadingZeros32( a ) + 32;
+    return packFloatx80( 0, 0x403E - shiftCount, zSig<<shiftCount );
+
+}
+
 #endif
 
 #ifdef FLOAT128
@@ -1202,6 +1233,17 @@ float128 int32_to_float128( int32 a )
 
 }
 
+float128 uint32_to_float128( uint32 a )
+{
+    int8 shiftCount;
+    bits64 zSig0 = a;
+
+    if ( a == 0 ) return packFloat128( 0, 0, 0, 0 );
+    shiftCount = countLeadingZeros32( a ) + 17;
+    return packFloat128( 0, 0x402E - shiftCount, zSig0<<shiftCount, 0 );
+
+}
+
 #endif
 
 #ifndef SOFTFLOAT_FOR_GCC /* __floatdi?f is in libgcc2.c */
@@ -4438,6 +4480,59 @@ int64 float128_to_int64_round_to_zero( f
 
 }
 
+#if (defined(SOFTFLOATSPARC64_FOR_GCC) || defined(SOFTFLOAT_FOR_GCC)) \
+    && defined(SOFTFLOAT_NEED_FIXUNS)
+/*
+ * just like above - but do not care for overflow of signed results
+ */
+uint64 float128_to_uint64_round_to_zero( float128 a )
+{
+    flag aSign;
+    int32 aExp, shiftCount;
+    bits64 aSig0, aSig1;
+    uint64 z;
+
+    aSig1 = extractFloat128Frac1( a );
+    aSig0 = extractFloat128Frac0( a );
+    aExp = extractFloat128Exp( a );
+    aSign = extractFloat128Sign( a );
+    if ( aExp ) aSig0 |= LIT64( 0x0001000000000000 );
+    shiftCount = aExp - 0x402F;
+    if ( 0 < shiftCount ) {
+        if ( 0x403F <= aExp ) {
+            aSig0 &= LIT64( 0x0000FFFFFFFFFFFF );
+            if (    ( a.high == LIT64( 0xC03E000000000000 ) )
+                 && ( aSig1 < LIT64( 0x0002000000000000 ) ) ) {
+                if ( aSig1 ) float_exception_flags |= float_flag_inexact;
+            }
+            else {
+                float_raise( float_flag_invalid );
+            }
+            return LIT64( 0xFFFFFFFFFFFFFFFF );
+        }
+        z = ( aSig0<<shiftCount ) | ( aSig1>>( ( - shiftCount ) & 63 ) );
+        if ( (bits64) ( aSig1<<shiftCount ) ) {
+            float_exception_flags |= float_flag_inexact;
+        }
+    }
+    else {
+        if ( aExp < 0x3FFF ) {
+            if ( aExp | aSig0 | aSig1 ) {
+                float_exception_flags |= float_flag_inexact;
+            }
+            return 0;
+        }
+        z = aSig0>>( - shiftCount );
+        if (aSig1 || ( shiftCount && (bits64) ( aSig0<<( shiftCount & 63 ) ) ) 
) {
+            float_exception_flags |= float_flag_inexact;
+        }
+    }
+    if ( aSign ) z = - z;
+    return z;
+
+}
+#endif /* (SOFTFLOATSPARC64_FOR_GCC || SOFTFLOAT_FOR_GCC) && 
SOFTFLOAT_NEED_FIXUNS */
+
 /*
 -------------------------------------------------------------------------------
 Returns the result of converting the quadruple-precision floating-point
@@ -5110,7 +5205,7 @@ float128 float128_rem( float128 a, float
         sub128( aSig0, aSig1, bSig0, bSig1, &aSig0, &aSig1 );
     } while ( 0 <= (sbits64) aSig0 );
     add128(
-        aSig0, aSig1, alternateASig0, alternateASig1, &sigMean0, &sigMean1 );
+        aSig0, aSig1, alternateASig0, alternateASig1, (bits64 *)&sigMean0, 
&sigMean1 );
     if (    ( sigMean0 < 0 )
          || ( ( ( sigMean0 | sigMean1 ) == 0 ) && ( q & 1 ) ) ) {
         aSig0 = alternateASig0;

Added: head/lib/libc/softfloat/eqtf2.c
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/lib/libc/softfloat/eqtf2.c     Fri Jan 20 06:16:14 2012        
(r230363)
@@ -0,0 +1,24 @@
+/* $NetBSD: eqtf2.c,v 1.1 2011/01/17 10:08:35 matt Exp $ */
+
+/*
+ * Written by Matt Thomas, 2011.  This file is in the Public Domain.
+ */
+
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#include "softfloat-for-gcc.h"
+#include "milieu.h"
+#include "softfloat.h"
+
+#ifdef FLOAT128
+flag __eqtf2(float128, float128);
+
+flag
+__eqtf2(float128 a, float128 b)
+{
+
+       /* libgcc1.c says !(a == b) */
+       return !float128_eq(a, b);
+}
+#endif /* FLOAT128 */

Added: head/lib/libc/softfloat/getf2.c
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/lib/libc/softfloat/getf2.c     Fri Jan 20 06:16:14 2012        
(r230363)
@@ -0,0 +1,26 @@
+/* $NetBSD: getf2.c,v 1.1 2011/01/17 10:08:35 matt Exp $ */
+
+/*
+ * Written by Matt Thomas, 2011.  This file is in the Public Domain.
+ */
+
+#include "softfloat-for-gcc.h"
+#include "milieu.h"
+#include "softfloat.h"
+
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#ifdef FLOAT128
+
+flag __getf2(float128, float128);
+
+flag
+__getf2(float128 a, float128 b)
+{
+
+       /* libgcc1.c says (a >= b) - 1 */
+       return float128_le(b, a) - 1;
+}
+
+#endif /* FLOAT128 */

Added: head/lib/libc/softfloat/gexf2.c
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/lib/libc/softfloat/gexf2.c     Fri Jan 20 06:16:14 2012        
(r230363)
@@ -0,0 +1,25 @@
+/* $NetBSD: gexf2.c,v 1.2 2004/09/27 10:16:24 he Exp $ */
+
+/*
+ * Written by Ben Harris, 2000.  This file is in the Public Domain.
+ */
+
+#include "softfloat-for-gcc.h"
+#include "milieu.h"
+#include "softfloat.h"
+
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#ifdef FLOATX80
+
+flag __gexf2(floatx80, floatx80);
+
+flag
+__gexf2(floatx80 a, floatx80 b)
+{
+
+       /* libgcc1.c says (a >= b) - 1 */
+       return floatx80_le(b, a) - 1;
+}
+#endif /* FLOATX80 */

Added: head/lib/libc/softfloat/gttf2.c
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/lib/libc/softfloat/gttf2.c     Fri Jan 20 06:16:14 2012        
(r230363)
@@ -0,0 +1,26 @@
+/* $NetBSD: gttf2.c,v 1.1 2011/01/17 10:08:35 matt Exp $ */
+
+/*
+ * Written by Matt Thomas, 2011.  This file is in the Public Domain.
+ */
+
+#include "softfloat-for-gcc.h"
+#include "milieu.h"
+#include "softfloat.h"
+
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#ifdef FLOAT128
+
+flag __gttf2(float128, float128);
+
+flag
+__gttf2(float128 a, float128 b)
+{
+
+       /* libgcc1.c says a > b */
+       return float128_lt(b, a);
+}
+
+#endif /* FLOAT128 */

Added: head/lib/libc/softfloat/gtxf2.c
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/lib/libc/softfloat/gtxf2.c     Fri Jan 20 06:16:14 2012        
(r230363)
@@ -0,0 +1,25 @@
+/* $NetBSD: gtxf2.c,v 1.2 2004/09/27 10:16:24 he Exp $ */
+
+/*
+ * Written by Ben Harris, 2000.  This file is in the Public Domain.
+ */
+
+#include "softfloat-for-gcc.h"
+#include "milieu.h"
+#include "softfloat.h"
+
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#ifdef FLOATX80
+
+flag __gtxf2(floatx80, floatx80);
+
+flag
+__gtxf2(floatx80 a, floatx80 b)
+{
+
+       /* libgcc1.c says a > b */
+       return floatx80_lt(b, a);
+}
+#endif /* FLOATX80 */

Added: head/lib/libc/softfloat/letf2.c
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/lib/libc/softfloat/letf2.c     Fri Jan 20 06:16:14 2012        
(r230363)
@@ -0,0 +1,26 @@
+/* $NetBSD: letf2.c,v 1.1 2011/01/17 10:08:35 matt Exp $ */
+
+/*
+ * Written by Matt Thomas, 2011.  This file is in the Public Domain.
+ */
+
+#include "softfloat-for-gcc.h"
+#include "milieu.h"
+#include "softfloat.h"
+
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#ifdef FLOAT128
+
+flag __letf2(float128, float128);
+
+flag
+__letf2(float128 a, float128 b)
+{
+
+       /* libgcc1.c says 1 - (a <= b) */
+       return 1 - float128_le(a, b);
+}
+
+#endif /* FLOAT128 */

Added: head/lib/libc/softfloat/lttf2.c
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/lib/libc/softfloat/lttf2.c     Fri Jan 20 06:16:14 2012        
(r230363)
@@ -0,0 +1,26 @@
+/* $NetBSD: lttf2.c,v 1.1 2011/01/17 10:08:35 matt Exp $ */
+
+/*
+ * Written by Matt Thomas, 2011.  This file is in the Public Domain.
+ */
+
+#include "softfloat-for-gcc.h"
+#include "milieu.h"
+#include "softfloat.h"
+
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#ifdef FLOAT128
+
+flag __lttf2(float128, float128);
+
+flag
+__lttf2(float128 a, float128 b)
+{
+
+       /* libgcc1.c says -(a < b) */
+       return -float128_lt(a, b);
+}
+
+#endif /* FLOAT128 */

Added: head/lib/libc/softfloat/negtf2.c
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/lib/libc/softfloat/negtf2.c    Fri Jan 20 06:16:14 2012        
(r230363)
@@ -0,0 +1,27 @@
+/* $NetBSD: negtf2.c,v 1.1 2011/01/17 10:08:35 matt Exp $ */
+
+/*
+ * Written by Matt Thomas, 2011.  This file is in the Public Domain.
+ */
+
+#include "softfloat-for-gcc.h"
+#include "milieu.h"
+#include "softfloat.h"
+
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#ifdef FLOAT128
+
+float128 __negtf2(float128);
+
+float128
+__negtf2(float128 a)
+{
+
+       /* libgcc1.c says -a */
+       a.high ^= FLOAT64_MANGLE(0x8000000000000000ULL);
+       return a;
+}
+
+#endif /* FLOAT128 */

Added: head/lib/libc/softfloat/negxf2.c
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/lib/libc/softfloat/negxf2.c    Fri Jan 20 06:16:14 2012        
(r230363)
@@ -0,0 +1,25 @@
+/* $NetBSD: negxf2.c,v 1.2 2004/09/27 10:16:24 he Exp $ */
+
+/*
+ * Written by Ben Harris, 2000.  This file is in the Public Domain.
+ */
+
+#include "softfloat-for-gcc.h"
+#include "milieu.h"
+#include "softfloat.h"
+
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#ifdef FLOATX80
+
+floatx80 __negxf2(floatx80);
+
+floatx80
+__negxf2(floatx80 a)
+{
+
+       /* libgcc1.c says -a */
+       return __mulxf3(a,__floatsixf(-1));
+}
+#endif /* FLOATX80 */

Added: head/lib/libc/softfloat/netf2.c
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/lib/libc/softfloat/netf2.c     Fri Jan 20 06:16:14 2012        
(r230363)
@@ -0,0 +1,26 @@
+/* $NetBSD: netf2.c,v 1.1 2011/01/17 10:08:35 matt Exp $ */
+
+/*
+ * Written by Matt Thomas, 2011.  This file is in the Public Domain.
+ */
+
+#include "softfloat-for-gcc.h"
+#include "milieu.h"
+#include "softfloat.h"
+
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#ifdef FLOAT128
+
+flag __netf2(float128, float128);
+
+flag
+__netf2(float128 a, float128 b)
+{
+
+       /* libgcc1.c says a != b */
+       return !float128_eq(a, b);
+}
+
+#endif /* FLOAT128 */

Added: head/lib/libc/softfloat/nexf2.c
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/lib/libc/softfloat/nexf2.c     Fri Jan 20 06:16:14 2012        
(r230363)
@@ -0,0 +1,25 @@
+/* $NetBSD: nexf2.c,v 1.2 2004/09/27 10:16:24 he Exp $ */
+
+/*
+ * Written by Ben Harris, 2000.  This file is in the Public Domain.
+ */
+
+#include "softfloat-for-gcc.h"
+#include "milieu.h"
+#include "softfloat.h"
+
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#ifdef FLOATX80
+
+flag __nexf2(floatx80, floatx80);
+
+flag
+__nexf2(floatx80 a, floatx80 b)
+{
+
+       /* libgcc1.c says a != b */
+       return !floatx80_eq(a, b);
+}
+#endif /* FLOATX80 */

Modified: head/lib/libc/softfloat/softfloat-for-gcc.h
==============================================================================
--- head/lib/libc/softfloat/softfloat-for-gcc.h Fri Jan 20 05:05:47 2012        
(r230362)
+++ head/lib/libc/softfloat/softfloat-for-gcc.h Fri Jan 20 06:16:14 2012        
(r230363)
@@ -1,4 +1,4 @@
-/* $NetBSD: softfloat-for-gcc.h,v 1.6 2003/07/26 19:24:51 salo Exp $ */
+/* $NetBSD: softfloat-for-gcc.h,v 1.8 2009/12/14 01:07:42 matt Exp $ */
 /* $FreeBSD$ */
 
 /*
@@ -16,6 +16,9 @@
 #define float64_eq             __softfloat_float64_eq
 #define float64_le             __softfloat_float64_le
 #define float64_lt             __softfloat_float64_lt
+#define float128_eq            __softfloat_float128_eq
+#define float128_le            __softfloat_float128_le
+#define float128_lt            __softfloat_float128_lt
 
 /*
  * Macros to define functions with the GCC expected names
@@ -23,21 +26,144 @@
 
 #define float32_add                    __addsf3
 #define float64_add                    __adddf3
+#define floatx80_add                   __addxf3
+#define float128_add                   __addtf3
+
 #define float32_sub                    __subsf3
 #define float64_sub                    __subdf3
+#define floatx80_sub                   __subxf3
+#define float128_sub                   __subtf3
+
 #define float32_mul                    __mulsf3
 #define float64_mul                    __muldf3
+#define floatx80_mul                   __mulxf3
+#define float128_mul                   __multf3
+
 #define float32_div                    __divsf3
 #define float64_div                    __divdf3
+#define floatx80_div                   __divxf3
+#define float128_div                   __divtf3
+
+#if 0
+#define float32_neg                    __negsf2
+#define float64_neg                    __negdf2
+#define floatx80_neg                   __negxf2
+#define float128_neg                   __negtf2
+#endif
+
 #define int32_to_float32               __floatsisf
 #define int32_to_float64               __floatsidf
+#define int32_to_floatx80              __floatsixf
+#define int32_to_float128              __floatsitf
+
 #define int64_to_float32               __floatdisf
 #define int64_to_float64               __floatdidf
+#define int64_to_floatx80              __floatdixf
+#define int64_to_float128              __floatditf
+
+#define int128_to_float32              __floattisf
+#define int128_to_float64              __floattidf
+#define int128_to_floatx80             __floattixf
+#define int128_to_float128             __floattitf
+
+#define uint32_to_float32              __floatunsisf
+#define uint32_to_float64              __floatunsidf
+#define uint32_to_floatx80             __floatunsixf
+#define uint32_to_float128             __floatunsitf
+
+#define uint64_to_float32              __floatundisf
+#define uint64_to_float64              __floatundidf
+#define uint64_to_floatx80             __floatundixf
+#define uint64_to_float128             __floatunditf
+
+#define uint128_to_float32             __floatuntisf
+#define uint128_to_float64             __floatuntidf
+#define uint128_to_floatx80            __floatuntixf
+#define uint128_to_float128            __floatuntitf
+
 #define float32_to_int32_round_to_zero __fixsfsi
 #define float64_to_int32_round_to_zero __fixdfsi
+#define floatx80_to_int32_round_to_zero __fixxfsi
+#define float128_to_int32_round_to_zero __fixtfsi
+
 #define float32_to_int64_round_to_zero __fixsfdi
 #define float64_to_int64_round_to_zero __fixdfdi
+#define floatx80_to_int64_round_to_zero        __fixxfdi
+#define float128_to_int64_round_to_zero        __fixtfdi
+
+#define float32_to_int128_round_to_zero __fixsfti
+#define float64_to_int128_round_to_zero __fixdfti
+#define floatx80_to_int128_round_to_zero __fixxfti
+#define float128_to_int128_round_to_zero __fixtfti
+
 #define float32_to_uint32_round_to_zero        __fixunssfsi
 #define float64_to_uint32_round_to_zero        __fixunsdfsi
+#define floatx80_to_uint32_round_to_zero       __fixunsxfsi
+#define float128_to_uint32_round_to_zero       __fixunstfsi
+
+#define float32_to_uint64_round_to_zero        __fixunssfdi
+#define float64_to_uint64_round_to_zero        __fixunsdfdi
+#define floatx80_to_uint64_round_to_zero       __fixunsxfdi
+#define float128_to_uint64_round_to_zero       __fixunstfdi
+
+#define float32_to_uint128_round_to_zero       __fixunssfti
+#define float64_to_uint128_round_to_zero       __fixunsdfti
+#define floatx80_to_uint128_round_to_zero      __fixunsxfti
+#define float128_to_uint128_round_to_zero      __fixunstfti
+
 #define float32_to_float64             __extendsfdf2
+#define float32_to_floatx80            __extendsfxf2
+#define float32_to_float128            __extendsftf2
+#define float64_to_floatx80            __extenddfxf2
+#define float64_to_float128            __extenddftf2
+
+#define float128_to_float64            __trunctfdf2
+#define floatx80_to_float64            __truncxfdf2
+#define float128_to_float32            __trunctfsf2
+#define floatx80_to_float32            __truncxfsf2
 #define float64_to_float32             __truncdfsf2
+
+#if 0
+#define float32_cmp                    __cmpsf2
+#define float32_unord                  __unordsf2
+#define float32_eq                     __eqsf2
+#define float32_ne                     __nesf2
+#define float32_ge                     __gesf2
+#define float32_lt                     __ltsf2
+#define float32_le                     __lesf2
+#define float32_gt                     __gtsf2
+#endif
+
+#if 0
+#define float64_cmp                    __cmpdf2
+#define float64_unord                  __unorddf2
+#define float64_eq                     __eqdf2
+#define float64_ne                     __nedf2
+#define float64_ge                     __gedf2
+#define float64_lt                     __ltdf2
+#define float64_le                     __ledf2
+#define float64_gt                     __gtdf2
+#endif
+
+/* XXX not in libgcc */
+#if 1
+#define floatx80_cmp                   __cmpxf2
+#define floatx80_unord                 __unordxf2
+#define floatx80_eq                    __eqxf2
+#define floatx80_ne                    __nexf2
+#define floatx80_ge                    __gexf2
+#define floatx80_lt                    __ltxf2
+#define floatx80_le                    __lexf2
+#define floatx80_gt                    __gtxf2
+#endif
+
+#if 0
+#define float128_cmp                   __cmptf2
+#define float128_unord                 __unordtf2
+#define float128_eq                    __eqtf2
+#define float128_ne                    __netf2
+#define float128_ge                    __getf2
+#define float128_lt                    __lttf2
+#define float128_le                    __letf2
+#define float128_gt                    __gttf2
+#endif

Modified: head/lib/libc/softfloat/softfloat-source.txt
==============================================================================
--- head/lib/libc/softfloat/softfloat-source.txt        Fri Jan 20 05:05:47 
2012        (r230362)
+++ head/lib/libc/softfloat/softfloat-source.txt        Fri Jan 20 06:16:14 
2012        (r230363)
@@ -1,4 +1,4 @@
-$NetBSD: softfloat-source.txt,v 1.1 2000/06/06 08:15:10 bjh21 Exp $
+$NetBSD: softfloat-source.txt,v 1.2 2006/11/24 19:46:58 christos Exp $
 $FreeBSD$
 
 SoftFloat Release 2a Source Documentation
@@ -33,7 +33,7 @@ C Compiler (`gcc') for several platforms
 Limitations
 
 SoftFloat as written requires an ISO/ANSI-style C compiler.  No attempt has
-been made to accomodate compilers that are not ISO-conformant.  Older ``K&R-
+been made to accommodate compilers that are not ISO-conformant.  Older ``K&R-
 style'' compilers are not adequate for compiling SoftFloat.  All testing I
 have done so far has been with the GNU C Compiler.  Compilation with other
 compilers should be possible but has not been tested.

Modified: head/lib/libc/softfloat/softfloat-specialize
==============================================================================
--- head/lib/libc/softfloat/softfloat-specialize        Fri Jan 20 05:05:47 
2012        (r230362)
+++ head/lib/libc/softfloat/softfloat-specialize        Fri Jan 20 06:16:14 
2012        (r230363)
@@ -1,4 +1,4 @@
-/*     $NetBSD: softfloat-specialize,v 1.3 2002/05/12 13:12:45 bjh21 Exp $     
*/
+/*     $NetBSD: softfloat-specialize,v 1.6 2011/03/06 10:27:37 martin Exp $    
*/
 /* $FreeBSD$ */
 
 /* This is a derivative work. */
@@ -34,6 +34,8 @@ this code that are retained.
 */
 
 #include <signal.h>
+#include <string.h>
+#include <unistd.h>
 
 /*
 -------------------------------------------------------------------------------
@@ -58,6 +60,9 @@ substitute a result value.  If traps are
 should be simply `float_exception_flags |= flags;'.
 -------------------------------------------------------------------------------
 */
+#ifdef SOFTFLOAT_FOR_GCC
+#define float_exception_mask   __softfloat_float_exception_mask
+#endif
 int float_exception_mask = 0;
 void float_raise( int flags )
 {
@@ -65,9 +70,29 @@ void float_raise( int flags )
     float_exception_flags |= flags;
 
     if ( flags & float_exception_mask ) {
+#if 0
+       siginfo_t info;
+       memset(&info, 0, sizeof info);
+       info.si_signo = SIGFPE;
+       info.si_pid = getpid();
+       info.si_uid = geteuid();
+       if (flags & float_flag_underflow)
+           info.si_code = FPE_FLTUND;
+       else if (flags & float_flag_overflow)
+           info.si_code = FPE_FLTOVF;
+       else if (flags & float_flag_divbyzero)
+           info.si_code = FPE_FLTDIV;
+       else if (flags & float_flag_invalid)
+           info.si_code = FPE_FLTINV;
+       else if (flags & float_flag_inexact)
+           info.si_code = FPE_FLTRES;
+       sigqueueinfo(getpid(), &info);
+#else
        raise( SIGFPE );
+#endif
     }
 }
+#undef float_exception_mask
 
 /*
 -------------------------------------------------------------------------------
@@ -108,7 +133,8 @@ Returns 1 if the single-precision floati
 NaN; otherwise returns 0.
 -------------------------------------------------------------------------------
 */
-#if defined(SOFTFLOAT_FOR_GCC) && !defined(SOFTFLOATSPARC64_FOR_GCC)
+#if defined(SOFTFLOAT_FOR_GCC) && !defined(SOFTFLOATSPARC64_FOR_GCC) && \
+    !defined(SOFTFLOAT_M68K_FOR_GCC)
 static
 #endif
 flag float32_is_signaling_nan( float32 a )
@@ -207,7 +233,8 @@ Returns 1 if the double-precision floati
 NaN; otherwise returns 0.
 -------------------------------------------------------------------------------
 */
-#if defined(SOFTFLOAT_FOR_GCC) && !defined(SOFTFLOATSPARC64_FOR_GCC)
+#if defined(SOFTFLOAT_FOR_GCC) && !defined(SOFTFLOATSPARC64_FOR_GCC) && \
+    !defined(SOFTFLOATM68K_FOR_GCC)
 static
 #endif
 flag float64_is_signaling_nan( float64 a )

Modified: head/lib/libc/softfloat/softfloat.txt
==============================================================================
--- head/lib/libc/softfloat/softfloat.txt       Fri Jan 20 05:05:47 2012        
(r230362)
+++ head/lib/libc/softfloat/softfloat.txt       Fri Jan 20 06:16:14 2012        
(r230363)
@@ -1,4 +1,4 @@
-$NetBSD: softfloat.txt,v 1.1 2000/06/06 08:15:10 bjh21 Exp $
+$NetBSD: softfloat.txt,v 1.2 2006/11/24 19:46:58 christos Exp $
 $FreeBSD$
 
 SoftFloat Release 2a General Documentation
@@ -27,7 +27,7 @@ Limitations
 
 SoftFloat is written in C and is designed to work with other C code.  The
 SoftFloat header files assume an ISO/ANSI-style C compiler.  No attempt
-has been made to accomodate compilers that are not ISO-conformant.  In
+has been made to accommodate compilers that are not ISO-conformant.  In
 particular, the distributed header files will not be acceptable to any
 compiler that does not recognize function prototypes.
 
_______________________________________________
svn-src-head@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to