powerpc/math-emu: Adopt new version of _FP_CHOOSENAN

Move to using the same macro definition for _FP_CHOOSENAN as s390,
sh, sparc32/64.  The original author didn't understand this and
matched what sparc64 was doing and they have updated to this definition.

Signed-off-by: Liu Yu <yu.liu@freescale.com>
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
This commit is contained in:
Liu Yu 2008-10-28 11:50:19 +08:00 коммит произвёл Kumar Gala
Родитель cf03033658
Коммит 463a8c01e1
1 изменённых файлов: 17 добавлений и 9 удалений

Просмотреть файл

@ -111,16 +111,24 @@
#define FP_EX_DIVZERO (1 << (31 - 5)) #define FP_EX_DIVZERO (1 << (31 - 5))
#define FP_EX_INEXACT (1 << (31 - 6)) #define FP_EX_INEXACT (1 << (31 - 6))
/* This macro appears to be called when both X and Y are NaNs, and /*
* has to choose one and copy it to R. i386 goes for the larger of the * If one NaN is signaling and the other is not,
* two, sparc64 just picks Y. I don't understand this at all so I'll * we choose that one, otherwise we choose X.
* go with sparc64 because it's shorter :-> -- PMM
*/ */
#define _FP_CHOOSENAN(fs, wc, R, X, Y, OP) \ #define _FP_CHOOSENAN(fs, wc, R, X, Y, OP) \
do { \ do { \
R##_s = Y##_s; \ if ((_FP_FRAC_HIGH_RAW_##fs(Y) & _FP_QNANBIT_##fs) \
_FP_FRAC_COPY_##wc(R,Y); \ && !(_FP_FRAC_HIGH_RAW_##fs(X) & _FP_QNANBIT_##fs)) \
R##_c = FP_CLS_NAN; \ { \
R##_s = X##_s; \
_FP_FRAC_COPY_##wc(R,X); \
} \
else \
{ \
R##_s = Y##_s; \
_FP_FRAC_COPY_##wc(R,Y); \
} \
R##_c = FP_CLS_NAN; \
} while (0) } while (0)