diff options
author | Tom Rini <trini@ti.com> | 2012-09-14 07:15:48 -0700 |
---|---|---|
committer | Tom Rini <trini@ti.com> | 2012-09-14 07:15:48 -0700 |
commit | 8f082d78fafd94db3f21b503794e0875d3331e53 (patch) | |
tree | 1eef05dcd0fca58283eac2c5fff55ba53f5abc81 /arch/mips/lib/ashldi3.c | |
parent | f71d5cd56bee6e730fe46f5f2024f1b5106ab944 (diff) | |
parent | 748fd4a621a870d378e4e4f54df76a38fd5d3cba (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.c | 25 |
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; +} |