Commit 8993fde4 by Richard Henderson Committed by Richard Henderson

arm: Enable umull and ctz in longlong.h

        * longlong.h [ARM] (umul_ppmm): Use umull for arm3m and later.
        [ARM] (count_trailing_zeros): Use the builtin.

From-SVN: r184957
parent 4999c62c
2012-03-05 Richard Henderson <rth@redhat.com>
* longlong.h [ARM] (umul_ppmm): Use umull for arm3m and later.
[ARM] (count_trailing_zeros): Use the builtin.
2012-03-01 Kai Tietz <ktietz@redhat.com> 2012-03-01 Kai Tietz <ktietz@redhat.com>
* soft-fp: Imported from glibc upstream. * soft-fp: Imported from glibc upstream.
......
...@@ -220,9 +220,12 @@ UDItype __umulsidi3 (USItype, USItype); ...@@ -220,9 +220,12 @@ UDItype __umulsidi3 (USItype, USItype);
"rI" ((USItype) (bh)), \ "rI" ((USItype) (bh)), \
"r" ((USItype) (al)), \ "r" ((USItype) (al)), \
"rI" ((USItype) (bl)) __CLOBBER_CC) "rI" ((USItype) (bl)) __CLOBBER_CC)
#define umul_ppmm(xh, xl, a, b) \ # if defined(__ARM_ARCH_2__) || defined(__ARM_ARCH_2A__) \
{register USItype __t0, __t1, __t2; \ || defined(__ARM_ARCH_3__)
__asm__ ("%@ Inlined umul_ppmm\n" \ # define umul_ppmm(xh, xl, a, b) \
do { \
register USItype __t0, __t1, __t2; \
__asm__ ("%@ Inlined umul_ppmm\n" \
" mov %2, %5, lsr #16\n" \ " mov %2, %5, lsr #16\n" \
" mov %0, %6, lsr #16\n" \ " mov %0, %6, lsr #16\n" \
" bic %3, %5, %2, lsl #16\n" \ " bic %3, %5, %2, lsl #16\n" \
...@@ -239,14 +242,26 @@ UDItype __umulsidi3 (USItype, USItype); ...@@ -239,14 +242,26 @@ UDItype __umulsidi3 (USItype, USItype);
"=r" ((USItype) (xl)), \ "=r" ((USItype) (xl)), \
"=&r" (__t0), "=&r" (__t1), "=r" (__t2) \ "=&r" (__t0), "=&r" (__t1), "=r" (__t2) \
: "r" ((USItype) (a)), \ : "r" ((USItype) (a)), \
"r" ((USItype) (b)) __CLOBBER_CC );} "r" ((USItype) (b)) __CLOBBER_CC ); \
#define UMUL_TIME 20 } while (0)
#define UDIV_TIME 100 # define UMUL_TIME 20
# else
# define umul_ppmm(xh, xl, a, b) \
do { \
/* Generate umull, under compiler control. */ \
register UDItype __t0 = (UDItype)(USItype)(a) * (USItype)(b); \
(xl) = (USItype)__t0; \
(xh) = (USItype)(__t0 >> 32); \
} while (0)
# define UMUL_TIME 3
# endif
# define UDIV_TIME 100
#endif /* __arm__ */ #endif /* __arm__ */
#if defined(__arm__) #if defined(__arm__)
/* Let gcc decide how best to implement count_leading_zeros. */ /* Let gcc decide how best to implement count_leading_zeros. */
#define count_leading_zeros(COUNT,X) ((COUNT) = __builtin_clz (X)) #define count_leading_zeros(COUNT,X) ((COUNT) = __builtin_clz (X))
#define count_trailing_zeros(COUNT,X) ((COUNT) = __builtin_ctz (X))
#define COUNT_LEADING_ZEROS_0 32 #define COUNT_LEADING_ZEROS_0 32
#endif #endif
......
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