about summary refs log tree commit diff
path: root/sysdeps/i386/i586/memcopy.h
diff options
context:
space:
mode:
Diffstat (limited to 'sysdeps/i386/i586/memcopy.h')
-rw-r--r--sysdeps/i386/i586/memcopy.h26
1 files changed, 15 insertions, 11 deletions
diff --git a/sysdeps/i386/i586/memcopy.h b/sysdeps/i386/i586/memcopy.h
index 0a8768788e..d8928988f3 100644
--- a/sysdeps/i386/i586/memcopy.h
+++ b/sysdeps/i386/i586/memcopy.h
@@ -1,5 +1,5 @@
 /* memcopy.h -- definitions for memory copy functions.  Pentium version.
-   Copyright (C) 1994, 1995 Free Software Foundation, Inc.
+   Copyright (C) 1994, 1995, 1996 Free Software Foundation, Inc.
    Contributed by Torbjorn Granlund (tege@sics.se).
 
 This file is part of the GNU C Library.
@@ -33,11 +33,14 @@ Cambridge, MA 02139, USA.  */
     {									\
       asm volatile ("subl	$32,%2\n"				\
 		    "js		2f\n"					\
+		    "movl	0(%0),%%edx\n"	/* alloc dest line */	\
 		    "1:\n"						\
-		    "movl	0(%1),%%eax\n"				\
-		    "movl	4(%1),%%edx\n"				\
-		    "movl	%%eax,0(%0)\n"				\
-		    "movl	%%edx,4(%0)\n"				\
+		    "movl	28(%0),%%eax\n"	/* alloc dest line */	\
+		    "subl	$32,%2\n"	/* decr loop count */	\
+		    "movl	0(%1),%%eax\n"	/* U pipe */		\
+		    "movl	4(%1),%%edx\n"	/* V pipe */		\
+		    "movl	%%eax,0(%0)\n"	/* U pipe */		\
+		    "movl	%%edx,4(%0)\n"	/* V pipe */		\
 		    "movl	8(%1),%%eax\n"				\
 		    "movl	12(%1),%%edx\n"				\
 		    "movl	%%eax,8(%0)\n"				\
@@ -50,9 +53,8 @@ Cambridge, MA 02139, USA.  */
 		    "movl	28(%1),%%edx\n"				\
 		    "movl	%%eax,24(%0)\n"				\
 		    "movl	%%edx,28(%0)\n"				\
-		    "addl	$32,%1\n"				\
-		    "addl	$32,%0\n"				\
-		    "subl	$32,%2\n"				\
+		    "leal	32(%1),%1\n"	/* update src ptr */	\
+		    "leal	32(%0),%0\n"	/* update dst ptr */	\
 		    "jns	1b\n"					\
 		    "2: addl	$32,%2" :				\
 		    "=r" (dst_bp), "=r" (src_bp), "=r" (nbytes_left) :	\
@@ -66,7 +68,10 @@ Cambridge, MA 02139, USA.  */
     {									\
       asm volatile ("subl	$32,%2\n"				\
 		    "js		2f\n"					\
+		    "movl	-4(%0),%%edx\n"				\
 		    "1:\n"						\
+		    "movl	-32(%0),%%eax\n"			\
+		    "subl	$32,%2\n"				\
 		    "movl	-4(%1),%%eax\n"				\
 		    "movl	-8(%1),%%edx\n"				\
 		    "movl	%%eax,-4(%0)\n"				\
@@ -83,9 +88,8 @@ Cambridge, MA 02139, USA.  */
 		    "movl	-32(%1),%%edx\n"			\
 		    "movl	%%eax,-28(%0)\n"			\
 		    "movl	%%edx,-32(%0)\n"			\
-		    "subl	$32,%1\n"				\
-		    "subl	$32,%0\n"				\
-		    "subl	$32,%2\n"				\
+		    "leal	-32(%1),%1\n"				\
+		    "leal	-32(%0),%0\n"				\
 		    "jns	1b\n"					\
 		    "2: addl	$32,%2" :				\
 		    "=r" (dst_ep), "=r" (src_ep), "=r" (nbytes_left) :	\