summaryrefslogtreecommitdiff
path: root/arch/sh/lib/ashrdi3.c
diff options
context:
space:
mode:
authorTom Rini <trini@konsulko.com>2015-03-01 21:06:33 -0500
committerTom Rini <trini@konsulko.com>2015-03-01 21:06:33 -0500
commit00956eb5f313d0a62c39f4fa642ffbaa85cc955c (patch)
tree3e30dd00af063f3f8bac6ad2c3f85d669b0d9506 /arch/sh/lib/ashrdi3.c
parent55ca6138240b8c5b986e918aca4d96d402cc2f21 (diff)
parentc3dd82386493d67cc5b0de06876360a27224b620 (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.c27
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;
+}