Commit 0de0d5c6 by David S. Miller Committed by David S. Miller

Sparc longlong.h enhancements.

libgcc/

	* longlong.h [SPARC] (umul_ppmm, udiv_qrnnd): Use hardware integer multiply
	and divide instructions on 32-bit when V9.
	(add_ssaaaa, sub_ddmmss): Convert to branchless code on 64-bit.

From-SVN: r188090
parent 7033d59e
2012-05-31 David S. Miller <davem@davemloft.net>
* longlong.h [SPARC] (umul_ppmm, udiv_qrnnd): Use hardware integer
multiply and divide instructions on 32-bit when V9.
(add_ssaaaa, sub_ddmmss): Convert to branchless code on 64-bit.
2012-05-29 Joseph Myers <joseph@codesourcery.com> 2012-05-29 Joseph Myers <joseph@codesourcery.com>
* config/arm/ieee754-df.S: Fix typos. * config/arm/ieee754-df.S: Fix typos.
......
...@@ -1127,6 +1127,29 @@ UDItype __umulsidi3 (USItype, USItype); ...@@ -1127,6 +1127,29 @@ UDItype __umulsidi3 (USItype, USItype);
"rJ" ((USItype) (al)), \ "rJ" ((USItype) (al)), \
"rI" ((USItype) (bl)) \ "rI" ((USItype) (bl)) \
__CLOBBER_CC) __CLOBBER_CC)
#if defined (__sparc_v9__)
#define umul_ppmm(w1, w0, u, v) \
do { \
register USItype __g1 asm ("g1"); \
__asm__ ("umul\t%2,%3,%1\n\t" \
"srlx\t%1, 32, %0" \
: "=r" ((USItype) (w1)), \
"=r" (__g1) \
: "r" ((USItype) (u)), \
"r" ((USItype) (v))); \
(w0) = __g1; \
} while (0)
#define udiv_qrnnd(__q, __r, __n1, __n0, __d) \
__asm__ ("mov\t%2,%%y\n\t" \
"udiv\t%3,%4,%0\n\t" \
"umul\t%0,%4,%1\n\t" \
"sub\t%3,%1,%1" \
: "=&r" ((USItype) (__q)), \
"=&r" ((USItype) (__r)) \
: "r" ((USItype) (__n1)), \
"r" ((USItype) (__n0)), \
"r" ((USItype) (__d)))
#else
#if defined (__sparc_v8__) #if defined (__sparc_v8__)
#define umul_ppmm(w1, w0, u, v) \ #define umul_ppmm(w1, w0, u, v) \
__asm__ ("umul %2,%3,%1;rd %%y,%0" \ __asm__ ("umul %2,%3,%1;rd %%y,%0" \
...@@ -1292,37 +1315,44 @@ UDItype __umulsidi3 (USItype, USItype); ...@@ -1292,37 +1315,44 @@ UDItype __umulsidi3 (USItype, USItype);
#define UDIV_TIME (3+7*32) /* 7 instructions/iteration. 32 iterations. */ #define UDIV_TIME (3+7*32) /* 7 instructions/iteration. 32 iterations. */
#endif /* __sparclite__ */ #endif /* __sparclite__ */
#endif /* __sparc_v8__ */ #endif /* __sparc_v8__ */
#endif /* __sparc_v9__ */
#endif /* sparc32 */ #endif /* sparc32 */
#if ((defined (__sparc__) && defined (__arch64__)) || defined (__sparcv9)) \ #if ((defined (__sparc__) && defined (__arch64__)) || defined (__sparcv9)) \
&& W_TYPE_SIZE == 64 && W_TYPE_SIZE == 64
#define add_ssaaaa(sh, sl, ah, al, bh, bl) \ #define add_ssaaaa(sh, sl, ah, al, bh, bl) \
__asm__ ("addcc %r4,%5,%1\n\t" \ do { \
"add %r2,%3,%0\n\t" \ UDItype __carry = 0; \
"bcs,a,pn %%xcc, 1f\n\t" \ __asm__ ("addcc\t%r5,%6,%1\n\t" \
"add %0, 1, %0\n" \ "add\t%r3,%4,%0\n\t" \
"1:" \ "movcs\t%%xcc, 1, %2\n\t" \
"add\t%0, %2, %0" \
: "=r" ((UDItype)(sh)), \ : "=r" ((UDItype)(sh)), \
"=&r" ((UDItype)(sl)) \ "=&r" ((UDItype)(sl)), \
"+r" (__carry) \
: "%rJ" ((UDItype)(ah)), \ : "%rJ" ((UDItype)(ah)), \
"rI" ((UDItype)(bh)), \ "rI" ((UDItype)(bh)), \
"%rJ" ((UDItype)(al)), \ "%rJ" ((UDItype)(al)), \
"rI" ((UDItype)(bl)) \ "rI" ((UDItype)(bl)) \
__CLOBBER_CC) __CLOBBER_CC); \
} while (0)
#define sub_ddmmss(sh, sl, ah, al, bh, bl) \ #define sub_ddmmss(sh, sl, ah, al, bh, bl) \
__asm__ ("subcc %r4,%5,%1\n\t" \ do { \
"sub %r2,%3,%0\n\t" \ UDItype __carry = 0; \
"bcs,a,pn %%xcc, 1f\n\t" \ __asm__ ("subcc\t%r5,%6,%1\n\t" \
"sub %0, 1, %0\n\t" \ "sub\t%r3,%4,%0\n\t" \
"1:" \ "movcs\t%%xcc, 1, %2\n\t" \
"add\t%0, %2, %0" \
: "=r" ((UDItype)(sh)), \ : "=r" ((UDItype)(sh)), \
"=&r" ((UDItype)(sl)) \ "=&r" ((UDItype)(sl)), \
: "rJ" ((UDItype)(ah)), \ "+r" (__carry) \
: "%rJ" ((UDItype)(ah)), \
"rI" ((UDItype)(bh)), \ "rI" ((UDItype)(bh)), \
"rJ" ((UDItype)(al)), \ "%rJ" ((UDItype)(al)), \
"rI" ((UDItype)(bl)) \ "rI" ((UDItype)(bl)) \
__CLOBBER_CC) __CLOBBER_CC); \
} while (0)
#define umul_ppmm(wh, wl, u, v) \ #define umul_ppmm(wh, wl, u, v) \
do { \ do { \
......
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