blob: be424dfcf3654ab76da38d486fceb0c17dad0684 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#include <linux/string.h>
2#include <linux/module.h>
3
4#undef memcpy
5#undef memset
6
7void *memcpy(void *to, const void *from, size_t n)
8{
9#ifdef CONFIG_X86_USE_3DNOW
10 return __memcpy3d(to, from, n);
11#else
12 return __memcpy(to, from, n);
13#endif
14}
15EXPORT_SYMBOL(memcpy);
16
17void *memset(void *s, int c, size_t count)
18{
19 return __memset(s, c, count);
20}
21EXPORT_SYMBOL(memset);
22
23void *memmove(void *dest, const void *src, size_t n)
24{
25 int d0, d1, d2;
26
27 if (dest < src) {
Ma, Lingfdf42892010-08-23 14:11:12 -070028 if ((dest + n) < src)
29 return memcpy(dest, src, n);
30 else
31 __asm__ __volatile__(
32 "rep\n\t"
33 "movsb\n\t"
34 : "=&c" (d0), "=&S" (d1), "=&D" (d2)
35 :"0" (n),
36 "1" (src),
37 "2" (dest)
38 :"memory");
39
Linus Torvalds1da177e2005-04-16 15:20:36 -070040 } else {
Ma, Lingfdf42892010-08-23 14:11:12 -070041
42 if((src + count) < dest)
43 return memcpy(dest, src, count);
44 else
45 __asm__ __volatile__(
46 "std\n\t"
47 "rep\n\t"
48 "movsb\n\t"
49 "cld"
50 : "=&c" (d0), "=&S" (d1), "=&D" (d2)
51 :"0" (n),
52 "1" (n-1+src),
53 "2" (n-1+dest)
54 :"memory");
Linus Torvalds1da177e2005-04-16 15:20:36 -070055 }
Ma, Lingfdf42892010-08-23 14:11:12 -070056
Linus Torvalds1da177e2005-04-16 15:20:36 -070057 return dest;
58}
59EXPORT_SYMBOL(memmove);