提交 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; size_t temp, temp1;
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++;
...@@ -18,8 +22,7 @@ void * memcpy(void * to, const void * from, size_t n) ...@@ -18,8 +22,7 @@ void * memcpy(void * to, const void * from, size_t n)
from = cfrom; from = cfrom;
n--; n--;
} }
if (n > 2 && (long) to & 2) if (n > 2 && (long)to & 2) {
{
short *sto = to; short *sto = to;
const short *sfrom = from; const short *sfrom = from;
*sto++ = *sfrom++; *sto++ = *sfrom++;
...@@ -28,35 +31,50 @@ void * memcpy(void * to, const void * from, size_t n) ...@@ -28,35 +31,50 @@ void * memcpy(void * to, const void * from, size_t n)
n -= 2; n -= 2;
} }
temp = n >> 2; temp = n >> 2;
if (temp) if (temp) {
{
long *lto = to; long *lto = to;
const long *lfrom = from; const long *lfrom = from;
#if defined(__mc68020__) || defined(__mc68030__) || \
defined(__mc68040__) || defined(__mc68060__) || defined(__mcpu32__)
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));
#else
for (; temp; temp--) for (; temp; temp--)
*lto++ = *lfrom++; *lto++ = *lfrom++;
#endif
to = lto; to = lto;
from = lfrom; from = lfrom;
} }
if (n & 2) if (n & 2) {
{
short *sto = to; short *sto = to;
const short *sfrom = from; const short *sfrom = from;
*sto++ = *sfrom++; *sto++ = *sfrom++;
to = sto; to = sto;
from = sfrom; from = sfrom;
} }
if (n & 1) if (n & 1) {
{
char *cto = to; char *cto = to;
const char *cfrom = from; const char *cfrom = from;
*cto = *cfrom; *cto = *cfrom;
} }
return xto; return xto;
#else
const char *c_from = from;
char *c_to = to;
while (n-- > 0)
*c_to++ = *c_from++;
return((void *) to);
#endif
} }
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.
先完成此消息的编辑!
想要评论请 注册