Home | History | Annotate | Download | only in memdisk
      1 /* ----------------------------------------------------------------------- *
      2  *
      3  *   Copyright 2008 H. Peter Anvin - All Rights Reserved
      4  *
      5  *   Permission is hereby granted, free of charge, to any person
      6  *   obtaining a copy of this software and associated documentation
      7  *   files (the "Software"), to deal in the Software without
      8  *   restriction, including without limitation the rights to use,
      9  *   copy, modify, merge, publish, distribute, sublicense, and/or
     10  *   sell copies of the Software, and to permit persons to whom
     11  *   the Software is furnished to do so, subject to the following
     12  *   conditions:
     13  *
     14  *   The above copyright notice and this permission notice shall
     15  *   be included in all copies or substantial portions of the Software.
     16  *
     17  *   THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
     18  *   EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
     19  *   OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
     20  *   NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
     21  *   HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
     22  *   WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
     23  *   FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
     24  *   OTHER DEALINGS IN THE SOFTWARE.
     25  *
     26  * ----------------------------------------------------------------------- */
     27 
     28 /*
     29  * memmove.S
     30  *
     31  * Reasonably efficient memmove, using aligned transfers at least
     32  * for the destination operand.
     33  */
     34 
     35 	.globl	memmove
     36 	.type	memmove,@function
     37 	.text
     38 memmove:
     39 	jecxz	3f
     40 
     41 	pushl	%esi
     42 	pushl	%edi
     43 	pushl	%eax		/* Return value */
     44 
     45 	movl	%eax,%edi
     46 	movl	%edx,%esi
     47 
     48 	cmpl	%edi,%esi
     49 	jb	1f
     50 
     51 	/* source >= dest, forwards move */
     52 
     53 	/* Initial alignment */
     54 	movl	%edi,%edx
     55 	shrl	$1,%edx
     56 	jnc	11f
     57 	movsb
     58 	decl	%ecx
     59 11:
     60 	movb	%cl,%al
     61 	cmpl	$2,%ecx
     62 	jb	13f
     63 
     64 	shrl	$1,%edx
     65 	jnc	12f
     66 	movsw
     67 	subl	$2,%ecx
     68 12:
     69 	/* Bulk transfer */
     70 	movb	%cl,%al
     71 	shrl	$2,%ecx
     72 	rep; movsl
     73 
     74 	/* Final alignment */
     75 	testb	$2,%al
     76 	jz	14f
     77 	movsw
     78 13:
     79 14:
     80 	testb	$1,%al
     81 	jz	15f
     82 	movsb
     83 15:
     84 	jmp	2f
     85 
     86 
     87 1:
     88 	/* source < dest, backwards move */
     89 	std
     90 	leal	-1(%ecx,%esi),%esi
     91 	leal	-1(%ecx,%edi),%edi
     92 
     93 	/* Initial alignment */
     94 	movl	%edi,%edx
     95 	shrl	$1,%edx
     96 	jc	21f
     97 	movsb
     98 	decl	%ecx
     99 21:
    100 	decl	%esi
    101 	decl	%edi
    102 	movb	%cl,%al
    103 	cmpl	$2,%ecx
    104 	jb	23f
    105 	shrl	$1,%edx
    106 	jc	22f
    107 	movsw
    108 	subl	$2,%ecx
    109 22:
    110 	/* Bulk transfer */
    111 	subl	$2,%esi
    112 	subl	$2,%edi
    113 	movb	%cl,%al
    114 	shrl	$2,%ecx
    115 	rep; movsl
    116 
    117 	/* Final alignment */
    118 	addl	$2,%esi
    119 	addl	$2,%edi
    120 	testb	$2,%al
    121 	jz	24f
    122 	movsw
    123 23:
    124 24:
    125 	incl	%esi
    126 	incl	%edi
    127 	testb	$1,%al
    128 	jz	25f
    129 	movsb
    130 25:
    131 	cld
    132 2:
    133 	popl	%eax		/* Return value */
    134 	popl	%edi
    135 	popl	%esi
    136 3:
    137 	ret
    138 
    139 	.size	memmove, .-memmove
    140