qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Qemu-devel] [6007] target-ppc: keep only the table version for mfrom


From: Aurelien Jarno
Subject: [Qemu-devel] [6007] target-ppc: keep only the table version for mfrom
Date: Sat, 13 Dec 2008 12:30:23 +0000

Revision: 6007
          http://svn.sv.gnu.org/viewvc/?view=rev&root=qemu&revision=6007
Author:   aurel32
Date:     2008-12-13 12:30:21 +0000 (Sat, 13 Dec 2008)

Log Message:
-----------
target-ppc: keep only the table version for mfrom

Signed-off-by: Aurelien Jarno <address@hidden>

Modified Paths:
--------------
    trunk/target-ppc/op_helper.c

Modified: trunk/target-ppc/op_helper.c
===================================================================
--- trunk/target-ppc/op_helper.c        2008-12-13 12:13:33 UTC (rev 6006)
+++ trunk/target-ppc/op_helper.c        2008-12-13 12:30:21 UTC (rev 6007)
@@ -1865,30 +1865,16 @@
 /* 602 specific instructions */
 /* mfrom is the most crazy instruction ever seen, imho ! */
 /* Real implementation uses a ROM table. Do the same */
+/* Extremly decomposed:
+ *                      -arg / 256
+ * return 256 * log10(10           + 1.0) + 0.5
+ */
 #if !defined (CONFIG_USER_ONLY)
-#define USE_MFROM_ROM_TABLE
 target_ulong helper_602_mfrom (target_ulong arg)
 {
     if (likely(arg < 602)) {
-#if defined(USE_MFROM_ROM_TABLE)
 #include "mfrom_table.c"
         return mfrom_ROM_table[arg];
-#else
-        double d;
-        /* Extremly decomposed:
-         *                      -arg / 256
-         * return 256 * log10(10           + 1.0) + 0.5
-         */
-        d = arg;
-        d = float64_div(d, 256, &env->fp_status);
-        d = float64_chs(d);
-        d = exp10(d); // XXX: use float emulation function
-        d = float64_add(d, 1.0, &env->fp_status);
-        d = log10(d); // XXX: use float emulation function
-        d = float64_mul(d, 256, &env->fp_status);
-        d = float64_add(d, 0.5, &env->fp_status);
-        return float64_round_to_int(d, &env->fp_status);
-#endif
     } else {
         return 0;
     }






reply via email to

[Prev in Thread] Current Thread [Next in Thread]