m68k: handle presence of 64bit mul/div instructions cleanly
authorGreg Ungerer <gerg@uclinux.org>
Fri, 11 Nov 2011 05:13:08 +0000 (15:13 +1000)
committerGreg Ungerer <gerg@uclinux.org>
Sat, 24 Dec 2011 11:47:57 +0000 (21:47 +1000)
The traditional 68000 processors and the newer reduced instruction set
ColdFire processors do not support the 32*32->64 multiply or the 64/32->32
divide instructions. This is not a difference based on the presence of
a hardware MMU or not.

Create a new config symbol to mark that a CPU type doesn't support the
longer multiply/divide instructions. Use this then as a basis for using
the fast 64bit based divide (in div64.h) and for linking in the extra
libgcc functions that may be required (mulsi3, divsi3, etc).

Signed-off-by: Greg Ungerer <gerg@uclinux.org>
Acked-by: Geert Uytterhoeven <geert@linux-m68k.org>
arch/m68k/Kconfig
arch/m68k/Kconfig.cpu
arch/m68k/include/asm/div64.h
arch/m68k/kernel/m68k_ksyms.c
arch/m68k/lib/Makefile

index 2fe2d633fe089d2ba6b80c6b4ae09151220c387f..32fd3642e71b6d0ac091efcd19638d57e27a4d22 100644 (file)
@@ -63,6 +63,9 @@ config ZONE_DMA
 config CPU_HAS_NO_BITFIELDS
        bool
 
+config CPU_HAS_NO_MULDIV64
+       bool
+
 config HZ
        int
        default 1000 if CLEOPATRA
index 17d37ed57f3ce876f7f0ea6fb545c920bbb2edb5..017f4fc388d253b73e68521a26fad42ace9444e5 100644 (file)
@@ -3,6 +3,7 @@ comment "Processor Type"
 config M68000
        bool
        select CPU_HAS_NO_BITFIELDS
+       select CPU_HAS_NO_MULDIV64
        select GENERIC_CSUM
        help
          The Freescale (was Motorola) 68000 CPU is the first generation of
@@ -24,6 +25,7 @@ config COLDFIRE
        select GENERIC_GPIO
        select ARCH_REQUIRE_GPIOLIB
        select CPU_HAS_NO_BITFIELDS
+       select CPU_HAS_NO_MULDIV64
        select GENERIC_CSUM
        help
          The Freescale ColdFire family of processors is a modern derivitive
index edb66148a71dc85886e3112d9af2f08019d7856e..444ea8a09e9f3386434e89d502c41d1f4107302e 100644 (file)
@@ -1,7 +1,9 @@
 #ifndef _M68K_DIV64_H
 #define _M68K_DIV64_H
 
-#ifdef CONFIG_MMU
+#ifdef CONFIG_CPU_HAS_NO_MULDIV64
+#include <asm-generic/div64.h>
+#else
 
 #include <linux/types.h>
 
@@ -27,8 +29,6 @@
        __rem;                                                  \
 })
 
-#else
-#include <asm-generic/div64.h>
-#endif /* CONFIG_MMU */
+#endif /* CONFIG_CPU_HAS_NO_MULDIV64 */
 
 #endif /* _M68K_DIV64_H */
index 1b7a14d1a00070af31fe62299f6dbe3b8e03d4be..774c1bd59c3655adea34251d77cb7792effcd688 100644 (file)
@@ -14,7 +14,7 @@ EXPORT_SYMBOL(__ashrdi3);
 EXPORT_SYMBOL(__lshrdi3);
 EXPORT_SYMBOL(__muldi3);
 
-#if defined(CONFIG_M68000) || defined(CONFIG_COLDFIRE)
+#if defined(CONFIG_CPU_HAS_NO_MULDIV64)
 /*
  * Simpler 68k and ColdFire parts also need a few other gcc functions.
  */
index b3b40e4ed339d5e33d6e0191b395f9bf689cf35c..a9d782d34276c427cac22538cccefa47d8d24d11 100644 (file)
@@ -6,11 +6,9 @@
 lib-y  := ashldi3.o ashrdi3.o lshrdi3.o muldi3.o \
           memcpy.o memset.o memmove.o
 
-ifdef CONFIG_MMU
-lib-y  += string.o uaccess.o
-else
-lib-y  += mulsi3.o divsi3.o udivsi3.o modsi3.o umodsi3.o
-endif
+lib-$(CONFIG_MMU) += string.o uaccess.o
+lib-$(CONFIG_CPU_HAS_NO_MULDIV64) += mulsi3.o divsi3.o udivsi3.o
+lib-$(CONFIG_CPU_HAS_NO_MULDIV64) += modsi3.o umodsi3.o
 
 ifndef CONFIG_GENERIC_CSUM
 lib-y  += checksum.o