aboutsummaryrefslogtreecommitdiffstats
path: root/xen/arch/x86/string.c
diff options
context:
space:
mode:
authorkaf24@firebug.cl.cam.ac.uk <kaf24@firebug.cl.cam.ac.uk>2005-04-20 17:46:27 +0000
committerkaf24@firebug.cl.cam.ac.uk <kaf24@firebug.cl.cam.ac.uk>2005-04-20 17:46:27 +0000
commit8ffbb0bb83a29b67cbb2f86e0d95569e8306afe2 (patch)
tree01f56536eaddbb44f6885d51af26c5a24c4fbd54 /xen/arch/x86/string.c
parentbcdd6aeee0f44b5fed9f8b95e49f088169301e4d (diff)
downloadxen-8ffbb0bb83a29b67cbb2f86e0d95569e8306afe2.tar.gz
xen-8ffbb0bb83a29b67cbb2f86e0d95569e8306afe2.tar.bz2
xen-8ffbb0bb83a29b67cbb2f86e0d95569e8306afe2.zip
bitkeeper revision 1.1343 (42669573FPZbSiupGqFkPopp_NRfpA)
Make the fallback memset/memcpy/memmove have a concrete in-place implementation, or we end up with a recursive dependency when building for x86/64. Signed-off-by: Keir Fraser <keir@xensource.com>
Diffstat (limited to 'xen/arch/x86/string.c')
-rw-r--r--xen/arch/x86/string.c48
1 files changed, 42 insertions, 6 deletions
diff --git a/xen/arch/x86/string.c b/xen/arch/x86/string.c
index 5a7788ba11..b45a9197d5 100644
--- a/xen/arch/x86/string.c
+++ b/xen/arch/x86/string.c
@@ -9,19 +9,55 @@
#include <xen/lib.h>
#undef memmove
-void *memmove(void *dest, const void *src, size_t count)
+void *memmove(void *dest, const void *src, size_t n)
{
- return __memmove(dest, src, count);
+ int d0, d1, d2;
+
+ if ( dest < src )
+ return memcpy(dest, src, n);
+
+ __asm__ __volatile__ (
+ " std ; "
+ " rep ; movsb ; "
+ " cld "
+ : "=&c" (d0), "=&S" (d1), "=&D" (d2)
+ : "0" (n), "1" (n-1+(const char *)src), "2" (n-1+(char *)dest)
+ : "memory");
+
+ return dest;
}
#undef memcpy
-void *memcpy(void *dest, const void *src, size_t count)
+void *memcpy(void *dest, const void *src, size_t n)
{
- return __memcpy(dest, src, count);
+ int d0, d1, d2;
+
+ __asm__ __volatile__ (
+ " rep ; movsl ; "
+ " testb $2,%b4 ; "
+ " je 1f ; "
+ " movsw ; "
+ "1: testb $1,%b4 ; "
+ " je 2f ; "
+ " movsb ; "
+ "2: "
+ : "=&c" (d0), "=&D" (d1), "=&S" (d2)
+ : "0" (n/4), "q" (n), "1" (dest), "2" (src)
+ : "memory");
+
+ return dest;
}
#undef memset
-void *memset(void *s, int c, size_t count)
+void *memset(void *s, int c, size_t n)
{
- return __memset(s, c, count);
+ int d0, d1;
+
+ __asm__ __volatile__ (
+ "rep ; stosb"
+ : "=&c" (d0), "=&D" (d1)
+ : "a" (c), "1" (s), "0" (n)
+ : "memory");
+
+ return s;
}