Merge branch 'for-3.2-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/tj...
[zen-stable.git] / arch / blackfin / lib / ashrdi3.c
blobb5b351e82e10758da00dc714f800f17a729ab009
1 /*
2 * Copyright 2004-2009 Analog Devices Inc.
4 * Licensed under the GPL-2 or later.
5 */
7 #include "gcclib.h"
9 #ifdef CONFIG_ARITHMETIC_OPS_L1
10 DItype __ashrdi3(DItype u, word_type b)__attribute__((l1_text));
11 #endif
13 DItype __ashrdi3(DItype u, word_type b)
15 DIunion w;
16 word_type bm;
17 DIunion uu;
19 if (b == 0)
20 return u;
22 uu.ll = u;
24 bm = (sizeof(SItype) * BITS_PER_UNIT) - b;
25 if (bm <= 0) {
26 /* w.s.high = 1..1 or 0..0 */
27 w.s.high = uu.s.high >> (sizeof(SItype) * BITS_PER_UNIT - 1);
28 w.s.low = uu.s.high >> -bm;
29 } else {
30 USItype carries = (USItype) uu.s.high << bm;
31 w.s.high = uu.s.high >> b;
32 w.s.low = ((USItype) uu.s.low >> b) | carries;
35 return w.ll;