diff options
Diffstat (limited to 'arch/mips/lib')
| -rw-r--r-- | arch/mips/lib/Makefile | 3 | ||||
| -rw-r--r-- | arch/mips/lib/ashldi3.c | 29 | ||||
| -rw-r--r-- | arch/mips/lib/ashrdi3.c | 31 | ||||
| -rw-r--r-- | arch/mips/lib/libgcc.h | 26 | ||||
| -rw-r--r-- | arch/mips/lib/lshrdi3.c | 29 |
5 files changed, 118 insertions, 0 deletions
diff --git a/arch/mips/lib/Makefile b/arch/mips/lib/Makefile index cf12caf80774..b225543f5302 100644 --- a/arch/mips/lib/Makefile +++ b/arch/mips/lib/Makefile | |||
| @@ -7,4 +7,7 @@ lib-y += csum_partial_copy.o memcpy.o promlib.o strlen_user.o strncpy_user.o \ | |||
| 7 | 7 | ||
| 8 | obj-y += iomap.o | 8 | obj-y += iomap.o |
| 9 | 9 | ||
| 10 | # libgcc-style stuff needed in the kernel | ||
| 11 | lib-y += ashldi3.o ashrdi3.o lshrdi3.o | ||
| 12 | |||
| 10 | EXTRA_AFLAGS := $(CFLAGS) | 13 | EXTRA_AFLAGS := $(CFLAGS) |
diff --git a/arch/mips/lib/ashldi3.c b/arch/mips/lib/ashldi3.c new file mode 100644 index 000000000000..beb80f316095 --- /dev/null +++ b/arch/mips/lib/ashldi3.c | |||
| @@ -0,0 +1,29 @@ | |||
| 1 | #include <linux/module.h> | ||
| 2 | |||
| 3 | #include "libgcc.h" | ||
| 4 | |||
| 5 | long long __ashldi3(long long u, word_type b) | ||
| 6 | { | ||
| 7 | DWunion uu, w; | ||
| 8 | word_type bm; | ||
| 9 | |||
| 10 | if (b == 0) | ||
| 11 | return u; | ||
| 12 | |||
| 13 | uu.ll = u; | ||
| 14 | bm = 32 - b; | ||
| 15 | |||
| 16 | if (bm <= 0) { | ||
| 17 | w.s.low = 0; | ||
| 18 | w.s.high = (unsigned int) uu.s.low << -bm; | ||
| 19 | } else { | ||
| 20 | const unsigned int carries = (unsigned int) uu.s.low >> bm; | ||
| 21 | |||
| 22 | w.s.low = (unsigned int) uu.s.low << b; | ||
| 23 | w.s.high = ((unsigned int) uu.s.high << b) | carries; | ||
| 24 | } | ||
| 25 | |||
| 26 | return w.ll; | ||
| 27 | } | ||
| 28 | |||
| 29 | EXPORT_SYMBOL(__ashldi3); | ||
diff --git a/arch/mips/lib/ashrdi3.c b/arch/mips/lib/ashrdi3.c new file mode 100644 index 000000000000..c884a912b660 --- /dev/null +++ b/arch/mips/lib/ashrdi3.c | |||
| @@ -0,0 +1,31 @@ | |||
| 1 | #include <linux/module.h> | ||
| 2 | |||
| 3 | #include "libgcc.h" | ||
| 4 | |||
| 5 | long long __ashrdi3(long long u, word_type b) | ||
| 6 | { | ||
| 7 | DWunion uu, w; | ||
| 8 | word_type bm; | ||
| 9 | |||
| 10 | if (b == 0) | ||
| 11 | return u; | ||
| 12 | |||
| 13 | uu.ll = u; | ||
| 14 | bm = 32 - b; | ||
| 15 | |||
| 16 | if (bm <= 0) { | ||
| 17 | /* w.s.high = 1..1 or 0..0 */ | ||
| 18 | w.s.high = | ||
| 19 | uu.s.high >> 31; | ||
| 20 | w.s.low = uu.s.high >> -bm; | ||
| 21 | } else { | ||
| 22 | const unsigned int carries = (unsigned int) uu.s.high << bm; | ||
| 23 | |||
| 24 | w.s.high = uu.s.high >> b; | ||
| 25 | w.s.low = ((unsigned int) uu.s.low >> b) | carries; | ||
| 26 | } | ||
| 27 | |||
| 28 | return w.ll; | ||
| 29 | } | ||
| 30 | |||
| 31 | EXPORT_SYMBOL(__ashrdi3); | ||
diff --git a/arch/mips/lib/libgcc.h b/arch/mips/lib/libgcc.h new file mode 100644 index 000000000000..3f19d1c5d942 --- /dev/null +++ b/arch/mips/lib/libgcc.h | |||
| @@ -0,0 +1,26 @@ | |||
| 1 | #ifndef __ASM_LIBGCC_H | ||
| 2 | #define __ASM_LIBGCC_H | ||
| 3 | |||
| 4 | #include <asm/byteorder.h> | ||
| 5 | |||
| 6 | typedef int word_type __attribute__ ((mode (__word__))); | ||
| 7 | |||
| 8 | #ifdef __BIG_ENDIAN | ||
| 9 | struct DWstruct { | ||
| 10 | int high, low; | ||
| 11 | }; | ||
| 12 | #elif defined(__LITTLE_ENDIAN) | ||
| 13 | struct DWstruct { | ||
| 14 | int low, high; | ||
| 15 | }; | ||
| 16 | #else | ||
| 17 | #error I feel sick. | ||
| 18 | #endif | ||
| 19 | |||
| 20 | typedef union | ||
| 21 | { | ||
| 22 | struct DWstruct s; | ||
| 23 | long long ll; | ||
| 24 | } DWunion; | ||
| 25 | |||
| 26 | #endif /* __ASM_LIBGCC_H */ | ||
diff --git a/arch/mips/lib/lshrdi3.c b/arch/mips/lib/lshrdi3.c new file mode 100644 index 000000000000..dcf8d6810b7c --- /dev/null +++ b/arch/mips/lib/lshrdi3.c | |||
| @@ -0,0 +1,29 @@ | |||
| 1 | #include <linux/module.h> | ||
| 2 | |||
| 3 | #include "libgcc.h" | ||
| 4 | |||
| 5 | long long __lshrdi3(long long u, word_type b) | ||
| 6 | { | ||
| 7 | DWunion uu, w; | ||
| 8 | word_type bm; | ||
| 9 | |||
| 10 | if (b == 0) | ||
| 11 | return u; | ||
| 12 | |||
| 13 | uu.ll = u; | ||
| 14 | bm = 32 - b; | ||
| 15 | |||
| 16 | if (bm <= 0) { | ||
| 17 | w.s.high = 0; | ||
| 18 | w.s.low = (unsigned int) uu.s.high >> -bm; | ||
| 19 | } else { | ||
| 20 | const unsigned int carries = (unsigned int) uu.s.high << bm; | ||
| 21 | |||
| 22 | w.s.high = (unsigned int) uu.s.high >> b; | ||
| 23 | w.s.low = ((unsigned int) uu.s.low >> b) | carries; | ||
| 24 | } | ||
| 25 | |||
| 26 | return w.ll; | ||
| 27 | } | ||
| 28 | |||
| 29 | EXPORT_SYMBOL(__lshrdi3); | ||
