diff options
author | Tom Rini <trini@konsulko.com> | 2015-03-01 21:06:33 -0500 |
---|---|---|
committer | Tom Rini <trini@konsulko.com> | 2015-03-01 21:06:33 -0500 |
commit | 00956eb5f313d0a62c39f4fa642ffbaa85cc955c (patch) | |
tree | 3e30dd00af063f3f8bac6ad2c3f85d669b0d9506 /arch/sh/lib/ashrdi3.c | |
parent | 55ca6138240b8c5b986e918aca4d96d402cc2f21 (diff) | |
parent | c3dd82386493d67cc5b0de06876360a27224b620 (diff) |
Merge branch 'master' of git://git.denx.de/u-boot-sh
Diffstat (limited to 'arch/sh/lib/ashrdi3.c')
-rw-r--r-- | arch/sh/lib/ashrdi3.c | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/arch/sh/lib/ashrdi3.c b/arch/sh/lib/ashrdi3.c new file mode 100644 index 0000000000..f30359b73f --- /dev/null +++ b/arch/sh/lib/ashrdi3.c @@ -0,0 +1,27 @@ +#include "libgcc.h" + +long long __ashrdi3(long long u, word_type b) +{ + DWunion uu, w; + word_type bm; + + if (b == 0) + return u; + + uu.ll = u; + bm = 32 - b; + + if (bm <= 0) { + /* w.s.high = 1..1 or 0..0 */ + w.s.high = + uu.s.high >> 31; + w.s.low = uu.s.high >> -bm; + } else { + const unsigned int carries = (unsigned int) uu.s.high << bm; + + w.s.high = uu.s.high >> b; + w.s.low = ((unsigned int) uu.s.low >> b) | carries; + } + + return w.ll; +} |