提交 66d83ab3 编写于 作者: G Greg Ungerer

m68k: remove duplicate memcpy() implementation

Merging the mmu and non-mmu directories we ended up with duplicate
implementations of memcpy(). One is a little more optimized for the
>= 68020 case, but that can easily be inserted into a single
implementation of memcpy(). Clean up the exporting of this symbol
too, otherwise we end up exporting it twice on a no-mmu build.
Signed-off-by: NGreg Ungerer <gerg@uclinux.org>
Acked-by: NGeert Uytterhoeven <geert@linux-m68k.org>
上级 d10ed2f5
...@@ -31,12 +31,6 @@ EXPORT_SYMBOL(kernel_thread); ...@@ -31,12 +31,6 @@ EXPORT_SYMBOL(kernel_thread);
/* Networking helper routines. */ /* Networking helper routines. */
EXPORT_SYMBOL(csum_partial_copy_nocheck); EXPORT_SYMBOL(csum_partial_copy_nocheck);
/* The following are special because they're not called
explicitly (the C compiler generates them). Fortunately,
their interface isn't gonna change any time soon now, so
it's OK to leave it out of version control. */
EXPORT_SYMBOL(memcpy);
/* /*
* libgcc functions - functions that are used internally by the * libgcc functions - functions that are used internally by the
* compiler... (prototypes are not correct though, but that * compiler... (prototypes are not correct though, but that
......
...@@ -4,12 +4,11 @@ ...@@ -4,12 +4,11 @@
# #
lib-y := ashldi3.o ashrdi3.o lshrdi3.o muldi3.o \ lib-y := ashldi3.o ashrdi3.o lshrdi3.o muldi3.o \
memset.o memmove.o checksum.o memcpy.o memset.o memmove.o checksum.o
ifdef CONFIG_MMU ifdef CONFIG_MMU
lib-y += string.o uaccess.o lib-y += string.o uaccess.o
else else
lib-y += mulsi3.o divsi3.o udivsi3.o modsi3.o umodsi3.o \ lib-y += mulsi3.o divsi3.o udivsi3.o modsi3.o umodsi3.o delay.o
memcpy.o delay.o
endif endif
/*
* This file is subject to the terms and conditions of the GNU General Public
* License. See the file COPYING in the main directory of this archive
* for more details.
*/
#include <linux/types.h> #include <linux/module.h>
#include <linux/string.h>
void * memcpy(void * to, const void * from, size_t n) void *memcpy(void *to, const void *from, size_t n)
{ {
#ifdef CONFIG_COLDFIRE void *xto = to;
void *xto = to; size_t temp, temp1;
size_t temp;
if (!n) if (!n)
return xto; return xto;
if ((long) to & 1) if ((long)to & 1) {
{ char *cto = to;
char *cto = to; const char *cfrom = from;
const char *cfrom = from; *cto++ = *cfrom++;
*cto++ = *cfrom++; to = cto;
to = cto; from = cfrom;
from = cfrom; n--;
n--; }
} if (n > 2 && (long)to & 2) {
if (n > 2 && (long) to & 2) short *sto = to;
{ const short *sfrom = from;
short *sto = to; *sto++ = *sfrom++;
const short *sfrom = from; to = sto;
*sto++ = *sfrom++; from = sfrom;
to = sto; n -= 2;
from = sfrom; }
n -= 2; temp = n >> 2;
} if (temp) {
temp = n >> 2; long *lto = to;
if (temp) const long *lfrom = from;
{ #if defined(__mc68020__) || defined(__mc68030__) || \
long *lto = to; defined(__mc68040__) || defined(__mc68060__) || defined(__mcpu32__)
const long *lfrom = from; asm volatile (
for (; temp; temp--) " movel %2,%3\n"
*lto++ = *lfrom++; " andw #7,%3\n"
to = lto; " lsrl #3,%2\n"
from = lfrom; " negw %3\n"
} " jmp %%pc@(1f,%3:w:2)\n"
if (n & 2) "4: movel %0@+,%1@+\n"
{ " movel %0@+,%1@+\n"
short *sto = to; " movel %0@+,%1@+\n"
const short *sfrom = from; " movel %0@+,%1@+\n"
*sto++ = *sfrom++; " movel %0@+,%1@+\n"
to = sto; " movel %0@+,%1@+\n"
from = sfrom; " movel %0@+,%1@+\n"
} " movel %0@+,%1@+\n"
if (n & 1) "1: dbra %2,4b\n"
{ " clrw %2\n"
char *cto = to; " subql #1,%2\n"
const char *cfrom = from; " jpl 4b"
*cto = *cfrom; : "=a" (lfrom), "=a" (lto), "=d" (temp), "=&d" (temp1)
} : "0" (lfrom), "1" (lto), "2" (temp));
return xto;
#else #else
const char *c_from = from; for (; temp; temp--)
char *c_to = to; *lto++ = *lfrom++;
while (n-- > 0)
*c_to++ = *c_from++;
return((void *) to);
#endif #endif
to = lto;
from = lfrom;
}
if (n & 2) {
short *sto = to;
const short *sfrom = from;
*sto++ = *sfrom++;
to = sto;
from = sfrom;
}
if (n & 1) {
char *cto = to;
const char *cfrom = from;
*cto = *cfrom;
}
return xto;
} }
EXPORT_SYMBOL(memcpy);
...@@ -20,70 +20,3 @@ char *strcat(char *dest, const char *src) ...@@ -20,70 +20,3 @@ char *strcat(char *dest, const char *src)
return __kernel_strcpy(dest + __kernel_strlen(dest), src); return __kernel_strcpy(dest + __kernel_strlen(dest), src);
} }
EXPORT_SYMBOL(strcat); EXPORT_SYMBOL(strcat);
void *memcpy(void *to, const void *from, size_t n)
{
void *xto = to;
size_t temp, temp1;
if (!n)
return xto;
if ((long)to & 1) {
char *cto = to;
const char *cfrom = from;
*cto++ = *cfrom++;
to = cto;
from = cfrom;
n--;
}
if (n > 2 && (long)to & 2) {
short *sto = to;
const short *sfrom = from;
*sto++ = *sfrom++;
to = sto;
from = sfrom;
n -= 2;
}
temp = n >> 2;
if (temp) {
long *lto = to;
const long *lfrom = from;
asm volatile (
" movel %2,%3\n"
" andw #7,%3\n"
" lsrl #3,%2\n"
" negw %3\n"
" jmp %%pc@(1f,%3:w:2)\n"
"4: movel %0@+,%1@+\n"
" movel %0@+,%1@+\n"
" movel %0@+,%1@+\n"
" movel %0@+,%1@+\n"
" movel %0@+,%1@+\n"
" movel %0@+,%1@+\n"
" movel %0@+,%1@+\n"
" movel %0@+,%1@+\n"
"1: dbra %2,4b\n"
" clrw %2\n"
" subql #1,%2\n"
" jpl 4b"
: "=a" (lfrom), "=a" (lto), "=d" (temp), "=&d" (temp1)
: "0" (lfrom), "1" (lto), "2" (temp));
to = lto;
from = lfrom;
}
if (n & 2) {
short *sto = to;
const short *sfrom = from;
*sto++ = *sfrom++;
to = sto;
from = sfrom;
}
if (n & 1) {
char *cto = to;
const char *cfrom = from;
*cto = *cfrom;
}
return xto;
}
EXPORT_SYMBOL(memcpy);
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册