diff options
-rw-r--r-- | arch/m68k/Kconfig | 3 | ||||
-rw-r--r-- | arch/m68k/Kconfig.cpu | 2 | ||||
-rw-r--r-- | arch/m68k/include/asm/div64.h | 8 | ||||
-rw-r--r-- | arch/m68k/kernel/m68k_ksyms.c | 2 | ||||
-rw-r--r-- | arch/m68k/lib/Makefile | 8 |
5 files changed, 13 insertions, 10 deletions
diff --git a/arch/m68k/Kconfig b/arch/m68k/Kconfig index 2fe2d633fe08..32fd3642e71b 100644 --- a/arch/m68k/Kconfig +++ b/arch/m68k/Kconfig | |||
@@ -63,6 +63,9 @@ config ZONE_DMA | |||
63 | config CPU_HAS_NO_BITFIELDS | 63 | config CPU_HAS_NO_BITFIELDS |
64 | bool | 64 | bool |
65 | 65 | ||
66 | config CPU_HAS_NO_MULDIV64 | ||
67 | bool | ||
68 | |||
66 | config HZ | 69 | config HZ |
67 | int | 70 | int |
68 | default 1000 if CLEOPATRA | 71 | default 1000 if CLEOPATRA |
diff --git a/arch/m68k/Kconfig.cpu b/arch/m68k/Kconfig.cpu index 17d37ed57f3c..017f4fc388d2 100644 --- a/arch/m68k/Kconfig.cpu +++ b/arch/m68k/Kconfig.cpu | |||
@@ -3,6 +3,7 @@ comment "Processor Type" | |||
3 | config M68000 | 3 | config M68000 |
4 | bool | 4 | bool |
5 | select CPU_HAS_NO_BITFIELDS | 5 | select CPU_HAS_NO_BITFIELDS |
6 | select CPU_HAS_NO_MULDIV64 | ||
6 | select GENERIC_CSUM | 7 | select GENERIC_CSUM |
7 | help | 8 | help |
8 | The Freescale (was Motorola) 68000 CPU is the first generation of | 9 | The Freescale (was Motorola) 68000 CPU is the first generation of |
@@ -24,6 +25,7 @@ config COLDFIRE | |||
24 | select GENERIC_GPIO | 25 | select GENERIC_GPIO |
25 | select ARCH_REQUIRE_GPIOLIB | 26 | select ARCH_REQUIRE_GPIOLIB |
26 | select CPU_HAS_NO_BITFIELDS | 27 | select CPU_HAS_NO_BITFIELDS |
28 | select CPU_HAS_NO_MULDIV64 | ||
27 | select GENERIC_CSUM | 29 | select GENERIC_CSUM |
28 | help | 30 | help |
29 | The Freescale ColdFire family of processors is a modern derivitive | 31 | The Freescale ColdFire family of processors is a modern derivitive |
diff --git a/arch/m68k/include/asm/div64.h b/arch/m68k/include/asm/div64.h index edb66148a71d..444ea8a09e9f 100644 --- a/arch/m68k/include/asm/div64.h +++ b/arch/m68k/include/asm/div64.h | |||
@@ -1,7 +1,9 @@ | |||
1 | #ifndef _M68K_DIV64_H | 1 | #ifndef _M68K_DIV64_H |
2 | #define _M68K_DIV64_H | 2 | #define _M68K_DIV64_H |
3 | 3 | ||
4 | #ifdef CONFIG_MMU | 4 | #ifdef CONFIG_CPU_HAS_NO_MULDIV64 |
5 | #include <asm-generic/div64.h> | ||
6 | #else | ||
5 | 7 | ||
6 | #include <linux/types.h> | 8 | #include <linux/types.h> |
7 | 9 | ||
@@ -27,8 +29,6 @@ | |||
27 | __rem; \ | 29 | __rem; \ |
28 | }) | 30 | }) |
29 | 31 | ||
30 | #else | 32 | #endif /* CONFIG_CPU_HAS_NO_MULDIV64 */ |
31 | #include <asm-generic/div64.h> | ||
32 | #endif /* CONFIG_MMU */ | ||
33 | 33 | ||
34 | #endif /* _M68K_DIV64_H */ | 34 | #endif /* _M68K_DIV64_H */ |
diff --git a/arch/m68k/kernel/m68k_ksyms.c b/arch/m68k/kernel/m68k_ksyms.c index 1b7a14d1a000..774c1bd59c36 100644 --- a/arch/m68k/kernel/m68k_ksyms.c +++ b/arch/m68k/kernel/m68k_ksyms.c | |||
@@ -14,7 +14,7 @@ EXPORT_SYMBOL(__ashrdi3); | |||
14 | EXPORT_SYMBOL(__lshrdi3); | 14 | EXPORT_SYMBOL(__lshrdi3); |
15 | EXPORT_SYMBOL(__muldi3); | 15 | EXPORT_SYMBOL(__muldi3); |
16 | 16 | ||
17 | #if defined(CONFIG_M68000) || defined(CONFIG_COLDFIRE) | 17 | #if defined(CONFIG_CPU_HAS_NO_MULDIV64) |
18 | /* | 18 | /* |
19 | * Simpler 68k and ColdFire parts also need a few other gcc functions. | 19 | * Simpler 68k and ColdFire parts also need a few other gcc functions. |
20 | */ | 20 | */ |
diff --git a/arch/m68k/lib/Makefile b/arch/m68k/lib/Makefile index b3b40e4ed339..a9d782d34276 100644 --- a/arch/m68k/lib/Makefile +++ b/arch/m68k/lib/Makefile | |||
@@ -6,11 +6,9 @@ | |||
6 | lib-y := ashldi3.o ashrdi3.o lshrdi3.o muldi3.o \ | 6 | lib-y := ashldi3.o ashrdi3.o lshrdi3.o muldi3.o \ |
7 | memcpy.o memset.o memmove.o | 7 | memcpy.o memset.o memmove.o |
8 | 8 | ||
9 | ifdef CONFIG_MMU | 9 | lib-$(CONFIG_MMU) += string.o uaccess.o |
10 | lib-y += string.o uaccess.o | 10 | lib-$(CONFIG_CPU_HAS_NO_MULDIV64) += mulsi3.o divsi3.o udivsi3.o |
11 | else | 11 | lib-$(CONFIG_CPU_HAS_NO_MULDIV64) += modsi3.o umodsi3.o |
12 | lib-y += mulsi3.o divsi3.o udivsi3.o modsi3.o umodsi3.o | ||
13 | endif | ||
14 | 12 | ||
15 | ifndef CONFIG_GENERIC_CSUM | 13 | ifndef CONFIG_GENERIC_CSUM |
16 | lib-y += checksum.o | 14 | lib-y += checksum.o |