Subject: Re: pkg/34571: TME sun3 emulator doesn't consider floating point infinities t...
To: None <skrll@NetBSD.org, gnats-admin@netbsd.org, pkgsrc-bugs@netbsd.org,>
From: None <SigmFSK@aol.com>
List: pkgsrc-bugs
Date: 10/02/2006 00:30:02
The following reply was made to PR pkg/34571; it has been noted by GNATS.
From: SigmFSK@aol.com
To: gnats-bugs@NetBSD.org
Cc:
Subject: Re: pkg/34571: TME sun3 emulator doesn't consider floating point infinities t...
Date: Sun, 1 Oct 2006 20:12:13 EDT
I follow with the patches in "diff -u" format and a description of where to
apply them. This includes the one-line fix for the 34616 fneg problem.
go to ieee754 directory, make following patch:
--- ieee754-ops-auto.sh.orig 2006-10-01 08:30:52.000000000 -0400
+++ ieee754-ops-auto.sh 2006-10-01 08:31:01.000000000 -0400
@@ -126,7 +126,7 @@
# generate the operations:
#
- for name in add sub mul div \
+ for name in add cmp sub mul div \
rem sqrt abs neg move \
rint \
cos acos cosh \
@@ -144,7 +144,7 @@
#
monadic=true
case "${name}" in
- add | sub | mul | div | rem | pow | scale)
+ add | cmp | sub | mul | div | rem | pow | scale)
monadic=false
;;
esac
@@ -243,13 +243,14 @@
func_softfloat="${name}"
;;
*-add) op_builtin='+' ;;
+ *-cmp) op_builtin='-' ;;
*-sub) op_builtin='-' ;;
*-mul) op_builtin='*' ;;
*-div) op_builtin='/' ;;
*-sqrt) func_libm=sqrt ;;
partial-abs | unknown-abs) func_libm=fabs ;;
strict-neg) op0=0 ; func_softfloat=sub ; op1=src0 ;;
- partial-neg | unknown-neg) op0=0 ; op_builtin='-'; op1=src0 ;;
+ partial-neg | unknown-neg) op0=-1.0 ; op_builtin='*'; op1=src0 ;;
strict-move) func_softfloat=add ; op1=0 ;;
*-move) type="${level_stricter}-move" ; src0_buffer=false ;;
strict-rint) func_softfloat=round_to_int ;;
notice that above difference includes the one line fix for 34616 / fneg
running make produces the following difference
--- ieee754-ops-auto.h.orig 2006-10-01 08:30:45.000000000 -0400
+++ ieee754-ops-auto.h 2006-10-01 08:31:20.000000000 -0400
@@ -11,6 +11,9 @@
/* this does a single-precision add: */
void (*tme_ieee754_ops_single_add) _TME_P((struct tme_ieee754_ctl *,
_tme_const struct tme_float *, _tme_const struct tme_float *, struct tme_float *));
+ /* this does a single-precision cmp: */
+ void (*tme_ieee754_ops_single_cmp) _TME_P((struct tme_ieee754_ctl *,
_tme_const struct tme_float *, _tme_const struct tme_float *, struct tme_float
*));
+
/* this does a single-precision sub: */
void (*tme_ieee754_ops_single_sub) _TME_P((struct tme_ieee754_ctl *,
_tme_const struct tme_float *, _tme_const struct tme_float *, struct tme_float *));
@@ -113,6 +116,9 @@
/* this does a double-precision add: */
void (*tme_ieee754_ops_double_add) _TME_P((struct tme_ieee754_ctl *,
_tme_const struct tme_float *, _tme_const struct tme_float *, struct tme_float *));
+ /* this does a double-precision cmp: */
+ void (*tme_ieee754_ops_double_cmp) _TME_P((struct tme_ieee754_ctl *,
_tme_const struct tme_float *, _tme_const struct tme_float *, struct tme_float
*));
+
/* this does a double-precision sub: */
void (*tme_ieee754_ops_double_sub) _TME_P((struct tme_ieee754_ctl *,
_tme_const struct tme_float *, _tme_const struct tme_float *, struct tme_float *));
@@ -215,6 +221,9 @@
/* this does a extended80-precision add: */
void (*tme_ieee754_ops_extended80_add) _TME_P((struct tme_ieee754_ctl *,
_tme_const struct tme_float *, _tme_const struct tme_float *, struct tme_float
*));
+ /* this does a extended80-precision cmp: */
+ void (*tme_ieee754_ops_extended80_cmp) _TME_P((struct tme_ieee754_ctl *,
_tme_const struct tme_float *, _tme_const struct tme_float *, struct
tme_float *));
+
/* this does a extended80-precision sub: */
void (*tme_ieee754_ops_extended80_sub) _TME_P((struct tme_ieee754_ctl *,
_tme_const struct tme_float *, _tme_const struct tme_float *, struct tme_float
*));
@@ -317,6 +326,9 @@
/* this does a quad-precision add: */
void (*tme_ieee754_ops_quad_add) _TME_P((struct tme_ieee754_ctl *,
_tme_const struct tme_float *, _tme_const struct tme_float *, struct tme_float *));
+ /* this does a quad-precision cmp: */
+ void (*tme_ieee754_ops_quad_cmp) _TME_P((struct tme_ieee754_ctl *,
_tme_const struct tme_float *, _tme_const struct tme_float *, struct tme_float *));
+
/* this does a quad-precision sub: */
void (*tme_ieee754_ops_quad_sub) _TME_P((struct tme_ieee754_ctl *,
_tme_const struct tme_float *, _tme_const struct tme_float *, struct tme_float *));
and make produces the following difference
--- ieee754-ops-auto.c.orig 2006-10-01 08:30:39.000000000 -0400
+++ ieee754-ops-auto.c.orig2 2006-10-01 08:32:20.000000000 -0400
@@ -39,6 +39,25 @@
}
}
+/* this does a strict compliance single-precision cmp: */
+static void
+_tme_ieee754_strict_single_cmp(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
+{
+ int exceptions;
+
+ /* assume that this operation raises no exceptions: */
+ exceptions = 0;
+
+ /* the operation: */
+ tme_ieee754_single_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN, tme_ieee754_single_value_builtin_get(src0) -
tme_ieee754_single_value_builtin_get(src1));
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
+
+ /* signal any exceptions: */
+ if (exceptions != 0) {
+ (*ieee754_ctl->tme_ieee754_ctl_exception)(ieee754_ctl, exceptions);
+ }
+}
+
/* this does a strict compliance single-precision sub: */
static void
_tme_ieee754_strict_single_sub(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
@@ -553,6 +572,25 @@
}
}
+/* this does a strict compliance double-precision cmp: */
+static void
+_tme_ieee754_strict_double_cmp(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
+{
+ int exceptions;
+
+ /* assume that this operation raises no exceptions: */
+ exceptions = 0;
+
+ /* the operation: */
+ tme_ieee754_double_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN, tme_ieee754_double_value_builtin_get(src0) -
tme_ieee754_double_value_builtin_get(src1));
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
+
+ /* signal any exceptions: */
+ if (exceptions != 0) {
+ (*ieee754_ctl->tme_ieee754_ctl_exception)(ieee754_ctl, exceptions);
+ }
+}
+
/* this does a strict compliance double-precision sub: */
static void
_tme_ieee754_strict_double_sub(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
@@ -1071,6 +1109,25 @@
#endif /* defined(TME_HAVE_INT64_T) */
+/* this does a strict compliance extended80-precision cmp: */
+static void
+_tme_ieee754_strict_extended80_cmp(struct tme_ieee754_ctl *ieee754_ctl,
const struct tme_float *src0, const struct tme_float *src1, struct tme_float
*dst)
+{
+ int exceptions;
+
+ /* assume that this operation raises no exceptions: */
+ exceptions = 0;
+
+ /* the operation: */
+ tme_ieee754_extended80_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN, tme_ieee754_extended80_value_builtin_get(src0) -
tme_ieee754_extended80_value_builtin_get(src1));
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
+
+ /* signal any exceptions: */
+ if (exceptions != 0) {
+ (*ieee754_ctl->tme_ieee754_ctl_exception)(ieee754_ctl, exceptions);
+ }
+}
+
#if defined(TME_HAVE_INT64_T)
/* this does a strict compliance extended80-precision sub: */
@@ -1633,6 +1690,25 @@
#endif /* defined(TME_HAVE_INT64_T) */
+/* this does a strict compliance quad-precision cmp: */
+static void
+_tme_ieee754_strict_quad_cmp(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
+{
+ int exceptions;
+
+ /* assume that this operation raises no exceptions: */
+ exceptions = 0;
+
+ /* the operation: */
+ tme_ieee754_quad_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN, tme_ieee754_quad_value_builtin_get(src0) -
tme_ieee754_quad_value_builtin_get(src1));
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
+
+ /* signal any exceptions: */
+ if (exceptions != 0) {
+ (*ieee754_ctl->tme_ieee754_ctl_exception)(ieee754_ctl, exceptions);
+ }
+}
+
#if defined(TME_HAVE_INT64_T)
/* this does a strict compliance quad-precision sub: */
@@ -2166,6 +2242,9 @@
/* this does a strict compliance single-precision add: */
_tme_ieee754_strict_single_add,
+ /* this does a strict compliance single-precision cmp: */
+ _tme_ieee754_strict_single_cmp,
+
/* this does a strict compliance single-precision sub: */
_tme_ieee754_strict_single_sub,
@@ -2268,6 +2347,9 @@
/* this does a strict compliance double-precision add: */
_tme_ieee754_strict_double_add,
+ /* this does a strict compliance double-precision cmp: */
+ _tme_ieee754_strict_double_cmp,
+
/* this does a strict compliance double-precision sub: */
_tme_ieee754_strict_double_sub,
@@ -2374,6 +2456,9 @@
NULL,
#endif /* !(defined(TME_HAVE_INT64_T)) */
+ /* this does a strict compliance extended80-precision cmp: */
+ _tme_ieee754_strict_extended80_cmp,
+
/* this does a strict compliance extended80-precision sub: */
#if (defined(TME_HAVE_INT64_T))
_tme_ieee754_strict_extended80_sub,
@@ -2524,6 +2609,9 @@
NULL,
#endif /* !(defined(TME_HAVE_INT64_T)) */
+ /* this does a strict compliance quad-precision cmp: */
+ _tme_ieee754_strict_quad_cmp,
+
/* this does a strict compliance quad-precision sub: */
#if (defined(TME_HAVE_INT64_T))
_tme_ieee754_strict_quad_sub,
@@ -2705,6 +2793,41 @@
#if (TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_SINGLE)
+/* this does a partial compliance single-precision cmp: */
+static void
+_tme_ieee754_partial_single_cmp(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
+{
+ int exceptions;
+
+ /* check for a NaN operand: */
+ if (__tme_predict_false(tme_ieee754_single_check_nan_dyadic(ieee754_ctl,
src0, src1, dst))) {
+ return;
+ }
+
+ /* enter native floating-point operation: */
+ tme_float_enter(ieee754_ctl->tme_ieee754_ctl_rounding_mode,
tme_ieee754_exception_float, ieee754_ctl);
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = tme_float_leave;
+
+ /* assume that this operation raises no exceptions: */
+ exceptions = 0;
+
+ /* the operation: */
+ tme_ieee754_single_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN, tme_ieee754_single_value_builtin_get(src0) -
tme_ieee754_single_value_builtin_get(src1));
+
+ /* leave native floating-point operation: */
+ exceptions |= tme_float_leave();
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
+
+ /* signal any exceptions: */
+ if (exceptions != 0) {
+ (*ieee754_ctl->tme_ieee754_ctl_exception)(ieee754_ctl, exceptions);
+ }
+}
+
+#endif /* (TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_SINGLE) */
+
+#if (TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_SINGLE)
+
/* this does a partial compliance single-precision sub: */
static void
_tme_ieee754_partial_single_sub(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
@@ -2907,7 +3030,7 @@
exceptions = 0;
/* the operation: */
- tme_ieee754_single_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN, 0 - tme_ieee754_single_value_builtin_get(src0));
+ tme_ieee754_single_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN, -1.0 * tme_ieee754_single_value_builtin_get(src0));
/* leave native floating-point operation: */
exceptions |= tme_float_leave();
@@ -3188,6 +3311,41 @@
#if (TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_DOUBLE)
+/* this does a partial compliance double-precision cmp: */
+static void
+_tme_ieee754_partial_double_cmp(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
+{
+ int exceptions;
+
+ /* check for a NaN operand: */
+ if (__tme_predict_false(tme_ieee754_double_check_nan_dyadic(ieee754_ctl,
src0, src1, dst))) {
+ return;
+ }
+
+ /* enter native floating-point operation: */
+ tme_float_enter(ieee754_ctl->tme_ieee754_ctl_rounding_mode,
tme_ieee754_exception_float, ieee754_ctl);
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = tme_float_leave;
+
+ /* assume that this operation raises no exceptions: */
+ exceptions = 0;
+
+ /* the operation: */
+ tme_ieee754_double_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN, tme_ieee754_double_value_builtin_get(src0) -
tme_ieee754_double_value_builtin_get(src1));
+
+ /* leave native floating-point operation: */
+ exceptions |= tme_float_leave();
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
+
+ /* signal any exceptions: */
+ if (exceptions != 0) {
+ (*ieee754_ctl->tme_ieee754_ctl_exception)(ieee754_ctl, exceptions);
+ }
+}
+
+#endif /* (TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_DOUBLE) */
+
+#if (TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_DOUBLE)
+
/* this does a partial compliance double-precision sub: */
static void
_tme_ieee754_partial_double_sub(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
@@ -3390,7 +3548,7 @@
exceptions = 0;
/* the operation: */
- tme_ieee754_double_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN, 0 - tme_ieee754_double_value_builtin_get(src0));
+ tme_ieee754_double_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN, -1.0 * tme_ieee754_double_value_builtin_get(src0));
/* leave native floating-point operation: */
exceptions |= tme_float_leave();
@@ -3671,6 +3829,41 @@
#if (TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_EXTENDED80)
+/* this does a partial compliance extended80-precision cmp: */
+static void
+_tme_ieee754_partial_extended80_cmp(struct tme_ieee754_ctl *ieee754_ctl,
const struct tme_float *src0, const struct tme_float *src1, struct tme_float
*dst)
+{
+ int exceptions;
+
+ /* check for a NaN operand: */
+ if
(__tme_predict_false(tme_ieee754_extended80_check_nan_dyadic(ieee754_ctl, src0, src1, dst))) {
+ return;
+ }
+
+ /* enter native floating-point operation: */
+ tme_float_enter(ieee754_ctl->tme_ieee754_ctl_rounding_mode,
tme_ieee754_exception_float, ieee754_ctl);
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = tme_float_leave;
+
+ /* assume that this operation raises no exceptions: */
+ exceptions = 0;
+
+ /* the operation: */
+ tme_ieee754_extended80_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN, tme_ieee754_extended80_value_builtin_get(src0) -
tme_ieee754_extended80_value_builtin_get(src1));
+
+ /* leave native floating-point operation: */
+ exceptions |= tme_float_leave();
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
+
+ /* signal any exceptions: */
+ if (exceptions != 0) {
+ (*ieee754_ctl->tme_ieee754_ctl_exception)(ieee754_ctl, exceptions);
+ }
+}
+
+#endif /* (TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_EXTENDED80) */
+
+#if (TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_EXTENDED80)
+
/* this does a partial compliance extended80-precision sub: */
static void
_tme_ieee754_partial_extended80_sub(struct tme_ieee754_ctl *ieee754_ctl,
const struct tme_float *src0, const struct tme_float *src1, struct tme_float
*dst)
@@ -3873,7 +4066,7 @@
exceptions = 0;
/* the operation: */
- tme_ieee754_extended80_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN, 0 - tme_ieee754_extended80_value_builtin_get(src0));
+ tme_ieee754_extended80_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN, -1.0 * tme_ieee754_extended80_value_builtin_get(src0));
/* leave native floating-point operation: */
exceptions |= tme_float_leave();
@@ -4154,6 +4347,41 @@
#if (TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN == TME_FLOAT_FORMAT_IEEE754_QUAD)
+/* this does a partial compliance quad-precision cmp: */
+static void
+_tme_ieee754_partial_quad_cmp(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
+{
+ int exceptions;
+
+ /* check for a NaN operand: */
+ if (__tme_predict_false(tme_ieee754_quad_check_nan_dyadic(ieee754_ctl,
src0, src1, dst))) {
+ return;
+ }
+
+ /* enter native floating-point operation: */
+ tme_float_enter(ieee754_ctl->tme_ieee754_ctl_rounding_mode,
tme_ieee754_exception_float, ieee754_ctl);
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = tme_float_leave;
+
+ /* assume that this operation raises no exceptions: */
+ exceptions = 0;
+
+ /* the operation: */
+ tme_ieee754_quad_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN, tme_ieee754_quad_value_builtin_get(src0) -
tme_ieee754_quad_value_builtin_get(src1));
+
+ /* leave native floating-point operation: */
+ exceptions |= tme_float_leave();
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
+
+ /* signal any exceptions: */
+ if (exceptions != 0) {
+ (*ieee754_ctl->tme_ieee754_ctl_exception)(ieee754_ctl, exceptions);
+ }
+}
+
+#endif /* (TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_QUAD) */
+
+#if (TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN == TME_FLOAT_FORMAT_IEEE754_QUAD)
+
/* this does a partial compliance quad-precision sub: */
static void
_tme_ieee754_partial_quad_sub(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
@@ -4356,7 +4584,7 @@
exceptions = 0;
/* the operation: */
- tme_ieee754_quad_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN, 0 - tme_ieee754_quad_value_builtin_get(src0));
+ tme_ieee754_quad_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN, -1.0 * tme_ieee754_quad_value_builtin_get(src0));
/* leave native floating-point operation: */
exceptions |= tme_float_leave();
@@ -4613,6 +4841,13 @@
_tme_ieee754_strict_single_add,
#endif /* !((TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_SINGLE)) */
+ /* this does a partial compliance single-precision cmp: */
+#if ((TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_SINGLE))
+ _tme_ieee754_partial_single_cmp,
+#else /* !((TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_SINGLE)) */
+ _tme_ieee754_strict_single_cmp,
+#endif /* !((TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_SINGLE)) */
+
/* this does a partial compliance single-precision sub: */
#if ((TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_SINGLE))
_tme_ieee754_partial_single_sub,
@@ -4767,6 +5002,13 @@
_tme_ieee754_strict_double_add,
#endif /* !((TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_DOUBLE)) */
+ /* this does a partial compliance double-precision cmp: */
+#if ((TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_DOUBLE))
+ _tme_ieee754_partial_double_cmp,
+#else /* !((TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_DOUBLE)) */
+ _tme_ieee754_strict_double_cmp,
+#endif /* !((TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_DOUBLE)) */
+
/* this does a partial compliance double-precision sub: */
#if ((TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_DOUBLE))
_tme_ieee754_partial_double_sub,
@@ -4925,6 +5167,13 @@
#endif /* !(defined(TME_HAVE_INT64_T)) */
#endif /* !((TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_EXTENDED80)) */
+ /* this does a partial compliance extended80-precision cmp: */
+#if ((TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_EXTENDED80))
+ _tme_ieee754_partial_extended80_cmp,
+#else /* !((TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_EXTENDED80)) */
+ _tme_ieee754_strict_extended80_cmp,
+#endif /* !((TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_EXTENDED80)) */
+
/* this does a partial compliance extended80-precision sub: */
#if ((TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_EXTENDED80))
_tme_ieee754_partial_extended80_sub,
@@ -5127,6 +5376,13 @@
#endif /* !(defined(TME_HAVE_INT64_T)) */
#endif /* !((TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_QUAD)) */
+ /* this does a partial compliance quad-precision cmp: */
+#if ((TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_QUAD))
+ _tme_ieee754_partial_quad_cmp,
+#else /* !((TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_QUAD)) */
+ _tme_ieee754_strict_quad_cmp,
+#endif /* !((TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_QUAD)) */
+
/* this does a partial compliance quad-precision sub: */
#if ((TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN ==
TME_FLOAT_FORMAT_IEEE754_QUAD))
_tme_ieee754_partial_quad_sub,
@@ -5338,6 +5594,25 @@
}
}
+/* this does a unknown compliance single-precision cmp: */
+static void
+_tme_ieee754_unknown_single_cmp(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
+{
+ int exceptions;
+
+ /* assume that this operation raises no exceptions: */
+ exceptions = 0;
+
+ /* the operation: */
+ tme_ieee754_single_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN, tme_ieee754_single_value_builtin_get(src0) -
tme_ieee754_single_value_builtin_get(src1));
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
+
+ /* signal any exceptions: */
+ if (exceptions != 0) {
+ (*ieee754_ctl->tme_ieee754_ctl_exception)(ieee754_ctl, exceptions);
+ }
+}
+
/* this does a unknown compliance single-precision sub: */
static void
_tme_ieee754_unknown_single_sub(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
@@ -5451,7 +5726,7 @@
exceptions = 0;
/* the operation: */
- tme_ieee754_single_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN, 0 - tme_ieee754_single_value_builtin_get(src0));
+ tme_ieee754_single_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN, -1.0 * tme_ieee754_single_value_builtin_get(src0));
ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
/* signal any exceptions: */
@@ -5613,6 +5888,25 @@
}
}
+/* this does a unknown compliance double-precision cmp: */
+static void
+_tme_ieee754_unknown_double_cmp(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
+{
+ int exceptions;
+
+ /* assume that this operation raises no exceptions: */
+ exceptions = 0;
+
+ /* the operation: */
+ tme_ieee754_double_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN, tme_ieee754_double_value_builtin_get(src0) -
tme_ieee754_double_value_builtin_get(src1));
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
+
+ /* signal any exceptions: */
+ if (exceptions != 0) {
+ (*ieee754_ctl->tme_ieee754_ctl_exception)(ieee754_ctl, exceptions);
+ }
+}
+
/* this does a unknown compliance double-precision sub: */
static void
_tme_ieee754_unknown_double_sub(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
@@ -5726,7 +6020,7 @@
exceptions = 0;
/* the operation: */
- tme_ieee754_double_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN, 0 - tme_ieee754_double_value_builtin_get(src0));
+ tme_ieee754_double_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN, -1.0 * tme_ieee754_double_value_builtin_get(src0));
ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
/* signal any exceptions: */
@@ -5888,6 +6182,25 @@
}
}
+/* this does a unknown compliance extended80-precision cmp: */
+static void
+_tme_ieee754_unknown_extended80_cmp(struct tme_ieee754_ctl *ieee754_ctl,
const struct tme_float *src0, const struct tme_float *src1, struct tme_float
*dst)
+{
+ int exceptions;
+
+ /* assume that this operation raises no exceptions: */
+ exceptions = 0;
+
+ /* the operation: */
+ tme_ieee754_extended80_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN, tme_ieee754_extended80_value_builtin_get(src0) -
tme_ieee754_extended80_value_builtin_get(src1));
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
+
+ /* signal any exceptions: */
+ if (exceptions != 0) {
+ (*ieee754_ctl->tme_ieee754_ctl_exception)(ieee754_ctl, exceptions);
+ }
+}
+
/* this does a unknown compliance extended80-precision sub: */
static void
_tme_ieee754_unknown_extended80_sub(struct tme_ieee754_ctl *ieee754_ctl,
const struct tme_float *src0, const struct tme_float *src1, struct tme_float
*dst)
@@ -6001,7 +6314,7 @@
exceptions = 0;
/* the operation: */
- tme_ieee754_extended80_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN, 0 - tme_ieee754_extended80_value_builtin_get(src0));
+ tme_ieee754_extended80_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN, -1.0 * tme_ieee754_extended80_value_builtin_get(src0));
ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
/* signal any exceptions: */
@@ -6163,6 +6476,25 @@
}
}
+/* this does a unknown compliance quad-precision cmp: */
+static void
+_tme_ieee754_unknown_quad_cmp(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
+{
+ int exceptions;
+
+ /* assume that this operation raises no exceptions: */
+ exceptions = 0;
+
+ /* the operation: */
+ tme_ieee754_quad_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN, tme_ieee754_quad_value_builtin_get(src0) -
tme_ieee754_quad_value_builtin_get(src1));
+ ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
+
+ /* signal any exceptions: */
+ if (exceptions != 0) {
+ (*ieee754_ctl->tme_ieee754_ctl_exception)(ieee754_ctl, exceptions);
+ }
+}
+
/* this does a unknown compliance quad-precision sub: */
static void
_tme_ieee754_unknown_quad_sub(struct tme_ieee754_ctl *ieee754_ctl, const
struct tme_float *src0, const struct tme_float *src1, struct tme_float *dst)
@@ -6276,7 +6608,7 @@
exceptions = 0;
/* the operation: */
- tme_ieee754_quad_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN, 0 - tme_ieee754_quad_value_builtin_get(src0));
+ tme_ieee754_quad_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN, -1.0 * tme_ieee754_quad_value_builtin_get(src0));
ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
/* signal any exceptions: */
@@ -6428,6 +6760,9 @@
/* this does a unknown compliance single-precision add: */
_tme_ieee754_unknown_single_add,
+ /* this does a unknown compliance single-precision cmp: */
+ _tme_ieee754_unknown_single_cmp,
+
/* this does a unknown compliance single-precision sub: */
_tme_ieee754_unknown_single_sub,
@@ -6530,6 +6865,9 @@
/* this does a unknown compliance double-precision add: */
_tme_ieee754_unknown_double_add,
+ /* this does a unknown compliance double-precision cmp: */
+ _tme_ieee754_unknown_double_cmp,
+
/* this does a unknown compliance double-precision sub: */
_tme_ieee754_unknown_double_sub,
@@ -6632,6 +6970,9 @@
/* this does a unknown compliance extended80-precision add: */
_tme_ieee754_unknown_extended80_add,
+ /* this does a unknown compliance extended80-precision cmp: */
+ _tme_ieee754_unknown_extended80_cmp,
+
/* this does a unknown compliance extended80-precision sub: */
_tme_ieee754_unknown_extended80_sub,
@@ -6754,6 +7095,9 @@
/* this does a unknown compliance quad-precision add: */
_tme_ieee754_unknown_quad_add,
+ /* this does a unknown compliance quad-precision cmp: */
+ _tme_ieee754_unknown_quad_cmp,
+
/* this does a unknown compliance quad-precision sub: */
_tme_ieee754_unknown_quad_sub,
then I modified the auto-generated file as follows:
--- ieee754-ops-auto.c.orig2 2006-10-01 08:32:20.000000000 -0400
+++ ieee754-ops-auto.c 2006-10-01 08:32:29.000000000 -0400
@@ -48,6 +48,13 @@
/* assume that this operation raises no exceptions: */
exceptions = 0;
+ if (tme_float_is_inf(src0, TME_FLOAT_FORMAT_IEEE754_SINGLE ) &
+ tme_float_is_inf(src1, TME_FLOAT_FORMAT_IEEE754_SINGLE) &
+ (tme_float_is_negative(src0, TME_FLOAT_FORMAT_IEEE754_SINGLE) ==
+ tme_float_is_negative(src1, TME_FLOAT_FORMAT_IEEE754_SINGLE)))
+ tme_ieee754_single_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN, 0.0);
+else
+
/* the operation: */
tme_ieee754_single_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN, tme_ieee754_single_value_builtin_get(src0) -
tme_ieee754_single_value_builtin_get(src1));
ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
@@ -581,6 +588,13 @@
/* assume that this operation raises no exceptions: */
exceptions = 0;
+ if (tme_float_is_inf(src0, TME_FLOAT_FORMAT_IEEE754_DOUBLE ) &
+ tme_float_is_inf(src1, TME_FLOAT_FORMAT_IEEE754_DOUBLE) &
+ (tme_float_is_negative(src0, TME_FLOAT_FORMAT_IEEE754_DOUBLE) ==
+ tme_float_is_negative(src1, TME_FLOAT_FORMAT_IEEE754_DOUBLE)))
+ tme_ieee754_double_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN, 0.0);
+else
+
/* the operation: */
tme_ieee754_double_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN, tme_ieee754_double_value_builtin_get(src0) -
tme_ieee754_double_value_builtin_get(src1));
ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
@@ -1118,6 +1132,13 @@
/* assume that this operation raises no exceptions: */
exceptions = 0;
+ if (tme_float_is_inf(src0, TME_FLOAT_FORMAT_IEEE754_EXTENDED80 ) &
+ tme_float_is_inf(src1, TME_FLOAT_FORMAT_IEEE754_EXTENDED80) &
+ (tme_float_is_negative(src0, TME_FLOAT_FORMAT_IEEE754_EXTENDED80) ==
+ tme_float_is_negative(src1, TME_FLOAT_FORMAT_IEEE754_EXTENDED80)))
+ tme_ieee754_extended80_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN, 0.0);
+else
+
/* the operation: */
tme_ieee754_extended80_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN, tme_ieee754_extended80_value_builtin_get(src0) -
tme_ieee754_extended80_value_builtin_get(src1));
ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
@@ -1699,6 +1720,13 @@
/* assume that this operation raises no exceptions: */
exceptions = 0;
+ if (tme_float_is_inf(src0, TME_FLOAT_FORMAT_IEEE754_QUAD ) &
+ tme_float_is_inf(src1, TME_FLOAT_FORMAT_IEEE754_QUAD) &
+ (tme_float_is_negative(src0, TME_FLOAT_FORMAT_IEEE754_QUAD) ==
+ tme_float_is_negative(src1, TME_FLOAT_FORMAT_IEEE754_QUAD)))
+ tme_ieee754_quad_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN, 0.0);
+else
+
/* the operation: */
tme_ieee754_quad_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN, tme_ieee754_quad_value_builtin_get(src0) -
tme_ieee754_quad_value_builtin_get(src1));
ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
@@ -2811,6 +2839,13 @@
/* assume that this operation raises no exceptions: */
exceptions = 0;
+ if (tme_float_is_inf(src0, TME_FLOAT_FORMAT_IEEE754_SINGLE ) &
+ tme_float_is_inf(src1, TME_FLOAT_FORMAT_IEEE754_SINGLE) &
+ (tme_float_is_negative(src0, TME_FLOAT_FORMAT_IEEE754_SINGLE) ==
+ tme_float_is_negative(src1, TME_FLOAT_FORMAT_IEEE754_SINGLE)))
+ tme_ieee754_single_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN, 0.0);
+
+else
/* the operation: */
tme_ieee754_single_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN, tme_ieee754_single_value_builtin_get(src0) -
tme_ieee754_single_value_builtin_get(src1));
@@ -3329,6 +3364,13 @@
/* assume that this operation raises no exceptions: */
exceptions = 0;
+ if (tme_float_is_inf(src0, TME_FLOAT_FORMAT_IEEE754_DOUBLE ) &
+ tme_float_is_inf(src1, TME_FLOAT_FORMAT_IEEE754_DOUBLE) &
+ (tme_float_is_negative(src0, TME_FLOAT_FORMAT_IEEE754_DOUBLE) ==
+ tme_float_is_negative(src1, TME_FLOAT_FORMAT_IEEE754_DOUBLE)))
+ tme_ieee754_double_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN, 0.0);
+else
+
/* the operation: */
tme_ieee754_double_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN, tme_ieee754_double_value_builtin_get(src0) -
tme_ieee754_double_value_builtin_get(src1));
@@ -3847,6 +3889,13 @@
/* assume that this operation raises no exceptions: */
exceptions = 0;
+ if (tme_float_is_inf(src0, TME_FLOAT_FORMAT_IEEE754_EXTENDED80 ) &
+ tme_float_is_inf(src1, TME_FLOAT_FORMAT_IEEE754_EXTENDED80) &
+ (tme_float_is_negative(src0, TME_FLOAT_FORMAT_IEEE754_EXTENDED80) ==
+ tme_float_is_negative(src1, TME_FLOAT_FORMAT_IEEE754_EXTENDED80)))
+ tme_ieee754_extended80_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN, 0.0);
+else
+
/* the operation: */
tme_ieee754_extended80_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN, tme_ieee754_extended80_value_builtin_get(src0) -
tme_ieee754_extended80_value_builtin_get(src1));
@@ -4365,6 +4414,13 @@
/* assume that this operation raises no exceptions: */
exceptions = 0;
+ if (tme_float_is_inf(src0, TME_FLOAT_FORMAT_IEEE754_QUAD ) &
+ tme_float_is_inf(src1, TME_FLOAT_FORMAT_IEEE754_QUAD) &
+ (tme_float_is_negative(src0, TME_FLOAT_FORMAT_IEEE754_QUAD) ==
+ tme_float_is_negative(src1, TME_FLOAT_FORMAT_IEEE754_QUAD)))
+ tme_ieee754_quad_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN, 0.0);
+else
+
/* the operation: */
tme_ieee754_quad_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN, tme_ieee754_quad_value_builtin_get(src0) -
tme_ieee754_quad_value_builtin_get(src1));
@@ -5603,6 +5659,13 @@
/* assume that this operation raises no exceptions: */
exceptions = 0;
+ if (tme_float_is_inf(src0, TME_FLOAT_FORMAT_IEEE754_SINGLE ) &
+ tme_float_is_inf(src1, TME_FLOAT_FORMAT_IEEE754_SINGLE) &
+ (tme_float_is_negative(src0, TME_FLOAT_FORMAT_IEEE754_SINGLE) ==
+ tme_float_is_negative(src1, TME_FLOAT_FORMAT_IEEE754_SINGLE)))
+ tme_ieee754_single_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN, 0.0);
+else
+
/* the operation: */
tme_ieee754_single_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_SINGLE_BUILTIN, tme_ieee754_single_value_builtin_get(src0) -
tme_ieee754_single_value_builtin_get(src1));
ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
@@ -5897,6 +5960,13 @@
/* assume that this operation raises no exceptions: */
exceptions = 0;
+ if (tme_float_is_inf(src0, TME_FLOAT_FORMAT_IEEE754_DOUBLE ) &
+ tme_float_is_inf(src1, TME_FLOAT_FORMAT_IEEE754_DOUBLE) &
+ (tme_float_is_negative(src0, TME_FLOAT_FORMAT_IEEE754_DOUBLE) ==
+ tme_float_is_negative(src1, TME_FLOAT_FORMAT_IEEE754_DOUBLE)))
+ tme_ieee754_double_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN, 0.0);
+else
+
/* the operation: */
tme_ieee754_double_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_DOUBLE_BUILTIN, tme_ieee754_double_value_builtin_get(src0) -
tme_ieee754_double_value_builtin_get(src1));
ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
@@ -6191,6 +6261,13 @@
/* assume that this operation raises no exceptions: */
exceptions = 0;
+ if (tme_float_is_inf(src0, TME_FLOAT_FORMAT_IEEE754_EXTENDED80 ) &
+ tme_float_is_inf(src1, TME_FLOAT_FORMAT_IEEE754_EXTENDED80) &
+ (tme_float_is_negative(src0, TME_FLOAT_FORMAT_IEEE754_EXTENDED80) ==
+ tme_float_is_negative(src1, TME_FLOAT_FORMAT_IEEE754_EXTENDED80)))
+ tme_ieee754_extended80_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN, 0.0);
+else
+
/* the operation: */
tme_ieee754_extended80_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_EXTENDED80_BUILTIN, tme_ieee754_extended80_value_builtin_get(src0) -
tme_ieee754_extended80_value_builtin_get(src1));
ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
@@ -6485,6 +6562,13 @@
/* assume that this operation raises no exceptions: */
exceptions = 0;
+ if (tme_float_is_inf(src0, TME_FLOAT_FORMAT_IEEE754_QUAD ) &
+ tme_float_is_inf(src1, TME_FLOAT_FORMAT_IEEE754_QUAD) &
+ (tme_float_is_negative(src0, TME_FLOAT_FORMAT_IEEE754_QUAD) ==
+ tme_float_is_negative(src1, TME_FLOAT_FORMAT_IEEE754_QUAD)))
+ tme_ieee754_quad_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN, 0.0);
+else
+
/* the operation: */
tme_ieee754_quad_value_builtin_set(dst,
TME_FLOAT_FORMAT_IEEE754_QUAD_BUILTIN, tme_ieee754_quad_value_builtin_get(src0) -
tme_ieee754_quad_value_builtin_get(src1));
ieee754_ctl->tme_ieee754_ctl_lock_unlock = NULL;
then to the m68k directory and change the script:
--- m6888x-auto.sh.orig 2006-10-01 08:22:49.000000000 -0400
+++ m6888x-auto.sh 2006-10-01 08:22:56.000000000 -0400
@@ -136,7 +136,7 @@
12) name=asin ; fpu_types=TME_M68K_FPU_M6888X ;; # fasin pp 315
10) name=atan ; fpu_types=TME_M68K_FPU_M6888X ;; # fatan pp 318
13) name=atanh ; fpu_types=TME_M68K_FPU_M6888X ;; # fatanh pp 321
- 56) name=cmp ; name_ieee754=sub ; optype=DST_SRC ;; # fcmp pp 326
+ 56) name=cmp ; optype=DST_SRC ;; # fcmp pp 326
29) name=cos ; fpu_types=TME_M68K_FPU_M6888X ;; # fcos pp 329
25) name=cosh ; fpu_types=TME_M68K_FPU_M6888X ;; # fcosh pp 332
did a make to produce the following diff:
--- m6888x-auto.c.orig 2006-10-01 08:23:13.000000000 -0400
+++ m6888x-auto.c 2006-10-01 08:23:17.000000000 -0400
@@ -179,7 +179,7 @@
{ _tme_m6888x_fsincos, 0, TME_M68K_FPU_M6888X, TME_M6888X_OPTYPE_MONADIC,
TME_FLOAT_ROUND_NULL, TME_M6888X_ROUNDING_PRECISION_CTL },
/* opmode 56: */
- { NULL, TME_M6888X_IEEE754_OP(tme_ieee754_ops_extended80_sub),
TME_M68K_FPU_ANY, TME_M6888X_OPTYPE_DYADIC_DST_SRC, TME_FLOAT_ROUND_NULL,
TME_M6888X_ROUNDING_PRECISION_CTL },
+ { NULL, TME_M6888X_IEEE754_OP(tme_ieee754_ops_extended80_cmp),
TME_M68K_FPU_ANY, TME_M6888X_OPTYPE_DYADIC_DST_SRC, TME_FLOAT_ROUND_NULL,
TME_M6888X_ROUNDING_PRECISION_CTL },
/* opmode 57: */
{ NULL, 0, TME_M68K_FPU_NONE, TME_M6888X_OPTYPE_MONADIC,
TME_FLOAT_ROUND_NULL, TME_M6888X_ROUNDING_PRECISION_CTL },