summaryrefslogtreecommitdiff
path: root/arch/mips/lib/ashldi3.c
diff options
context:
space:
mode:
authorTom Rini <trini@ti.com>2012-09-14 07:15:48 -0700
committerTom Rini <trini@ti.com>2012-09-14 07:15:48 -0700
commit8f082d78fafd94db3f21b503794e0875d3331e53 (patch)
tree1eef05dcd0fca58283eac2c5fff55ba53f5abc81 /arch/mips/lib/ashldi3.c
parentf71d5cd56bee6e730fe46f5f2024f1b5106ab944 (diff)
parent748fd4a621a870d378e4e4f54df76a38fd5d3cba (diff)
Merge branch 'master' of git://git.denx.de/u-boot-mips
Diffstat (limited to 'arch/mips/lib/ashldi3.c')
-rw-r--r--arch/mips/lib/ashldi3.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/arch/mips/lib/ashldi3.c b/arch/mips/lib/ashldi3.c
new file mode 100644
index 00000000000..9b50d866a01
--- /dev/null
+++ b/arch/mips/lib/ashldi3.c
@@ -0,0 +1,25 @@
+#include "libgcc.h"
+
+long long __ashldi3(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.low = 0;
+ w.s.high = (unsigned int) uu.s.low << -bm;
+ } else {
+ const unsigned int carries = (unsigned int) uu.s.low >> bm;
+
+ w.s.low = (unsigned int) uu.s.low << b;
+ w.s.high = ((unsigned int) uu.s.high << b) | carries;
+ }
+
+ return w.ll;
+}