about summary refs log tree commit diff
path: root/sysdeps/s390/s390-64
diff options
context:
space:
mode:
Diffstat (limited to 'sysdeps/s390/s390-64')
-rw-r--r--sysdeps/s390/s390-64/bcopy.S18
-rw-r--r--sysdeps/s390/s390-64/memcpy.S15
2 files changed, 28 insertions, 5 deletions
diff --git a/sysdeps/s390/s390-64/bcopy.S b/sysdeps/s390/s390-64/bcopy.S
index bb3acdb708..ff7966723b 100644
--- a/sysdeps/s390/s390-64/bcopy.S
+++ b/sysdeps/s390/s390-64/bcopy.S
@@ -34,11 +34,13 @@ ENTRY(__bcopy)
 	jnl	.L0
 	algr	%r1,%r2
 	clgr	%r1,%r3
-	jh	.L5
+	jh	.L7
 .L0:	aghi	%r4,-1		    # length - 1
 	srlg	%r1,%r4,8
-	ltgr	%r1,%r1
+	ltgr	%r1,%r1             # < 256 bytes to move ?
 	jz	.L2
+	cghi    %r1,255             # > 1MB to move ?
+	jh      .L5
 .L1:	mvc	0(256,%r3),0(%r2)   # move in 256 byte chunks
 	la	%r2,256(%r2)
 	la	%r3,256(%r3)
@@ -47,8 +49,16 @@ ENTRY(__bcopy)
 	mvc	0(1,%r3),0(%r2)	    # instruction for execute
 .L3:	ex	%r4,0(%r1)	    # execute mvc with length ((%r4)&255)+1
 .L4:	br	%r14
-
-.L5:				    # destructive overlay, can not use mvcle
+	# data copies > 1MB are faster with mvcle.
+.L5:	aghi    %r4,1               # length + 1
+	lgr	%r5,%r4	            # source length
+	lgr	%r4,%r2             # source address
+	lgr	%r2,%r3             # set destination
+	lgr	%r3,%r5             # destination length = source length
+.L6:	mvcle	%r2,%r4,0           # thats it, MVCLE is your friend
+	jo	.L6
+	br	%r14
+.L7:				    # destructive overlay, can not use mvcle
 	lgr    %r1,%r2		    # bcopy is called with source,dest
 	lgr    %r2,%r3		    # memmove with dest,source! Oh, well...
 	lgr    %r3,%r1
diff --git a/sysdeps/s390/s390-64/memcpy.S b/sysdeps/s390/s390-64/memcpy.S
index 8212bd39d6..d13c0ad14e 100644
--- a/sysdeps/s390/s390-64/memcpy.S
+++ b/sysdeps/s390/s390-64/memcpy.S
@@ -32,8 +32,11 @@ ENTRY(memcpy)
 	jz	.L3
 	aghi	%r4,-1		    # length - 1
 	lgr	%r1,%r2		    # copy destination address
-	srag	%r5,%r4,8
+	srlg	%r5,%r4,8
+	ltgr    %r5,%r5             # < 256 bytes to mvoe ?
 	jz	.L1
+	chi     %r6,255             # > 1 MB to move ?
+	jh	.L4
 .L0:	mvc	0(256,%r1),0(%r3)   # move in 256 byte chunks
 	la	%r1,256(%r1)
 	la	%r3,256(%r3)
@@ -42,5 +45,15 @@ ENTRY(memcpy)
 	mvc	0(1,%r1),0(%r3)	    # instruction for execute
 .L2:	ex	%r4,0(%r5)	    # execute mvc with length ((%r4)&255)+1
 .L3:	br	%r14
+	# data copies > 1MB are faster with mvcle.
+.L4:	aghi    %r4,1               # length + 1
+	lgr	%r5,%r4	            # source length
+	lgr	%r4,%r2             # source address
+	lgr	%r2,%r3             # set destination
+	lgr	%r3,%r5             # destination length = source length
+.L5:	mvcle	%r2,%r4,0           # thats it, MVCLE is your friend
+	jo	.L5
+	lgr     %r2,%r1             # return destination address
+	br	%r14
 END(memcpy)