Commit 70ef5578 authored by Helge Deller's avatar Helge Deller

MPILIB: disable usage of floating point registers on parisc

The umul_ppmm() macro for parisc uses the xmpyu assembler statement
which does calculation via a floating point register.

But usage of floating point registers inside the Linux kernel are not
allowed and gcc will stop compilation due to the -mdisable-fpregs
compiler option.

Fix this by disabling the umul_ppmm() and udiv_qrnnd() macros. The
mpilib will then use the generic built-in implementations instead.
Signed-off-by: default avatarHelge Deller <deller@gmx.de>
parent 17fdfd08
...@@ -318,7 +318,8 @@ extern UDItype __udiv_qrnnd(); ...@@ -318,7 +318,8 @@ extern UDItype __udiv_qrnnd();
"rM" ((USItype)(bh)), \ "rM" ((USItype)(bh)), \
"rM" ((USItype)(al)), \ "rM" ((USItype)(al)), \
"rM" ((USItype)(bl))) "rM" ((USItype)(bl)))
#if defined(_PA_RISC1_1) #if 0 && defined(_PA_RISC1_1)
/* xmpyu uses floating point register which is not allowed in Linux kernel. */
#define umul_ppmm(wh, wl, u, v) \ #define umul_ppmm(wh, wl, u, v) \
do { \ do { \
union {UDItype __ll; \ union {UDItype __ll; \
...@@ -337,7 +338,7 @@ do { \ ...@@ -337,7 +338,7 @@ do { \
#define UMUL_TIME 40 #define UMUL_TIME 40
#define UDIV_TIME 80 #define UDIV_TIME 80
#endif #endif
#ifndef LONGLONG_STANDALONE #if 0 /* #ifndef LONGLONG_STANDALONE */
#define udiv_qrnnd(q, r, n1, n0, d) \ #define udiv_qrnnd(q, r, n1, n0, d) \
do { USItype __r; \ do { USItype __r; \
(q) = __udiv_qrnnd(&__r, (n1), (n0), (d)); \ (q) = __udiv_qrnnd(&__r, (n1), (n0), (d)); \
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment