mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-01-24 07:57:22 +08:00
ef44da427f
* libc/machine/i386/i386mach.h: added SOTYPE_FUNCTION to set type of global entry points if _I386MACH_NEED_SOTYPE_FUNCTION is defined; Added __CLI and __STI macros (controlled via _I386MACH_ALLOW_HW_INTERRUPTS macro). * libc/machine/i386/f_atan2.S libc/machine/i386/f_atan2f.S libc/machine/i386/f_frexp.S libc/machine/i386/f_frexpf.S libc/machine/i386/f_ldexp.S libc/machine/i386/f_ldexpf.S libc/machine/i386/f_log.S libc/machine/i386/f_log10.S libc/machine/i386/f_log10f.S libc/machine/i386/f_logf.S libc/machine/i386/f_tan.S libc/machine/i386/f_tanf.S libc/machine/i386/memchr.S libc/machine/i386/memcmp.S libc/machine/i386/memcpy.S libc/machine/i386/memmove.S libc/machine/i386/memset.S libc/machine/i386/setjmp.S libc/machine/i386/strchr.S libc/machine/i386/strlen.S: (that's libc/machine/i386/*.S) added SOTYPE_FUNCTION(symbol) for all global entry points. * libc/machine/i386/setjmp.S: removed code replicated in libc/machine/i386/i386mach.h and included i386mach.h instead; Use __CLI and __STI instead of cli and sti.
147 lines
2.0 KiB
ArmAsm
147 lines
2.0 KiB
ArmAsm
/*
|
|
* ====================================================
|
|
* Copyright (C) 1998 by Cygnus Solutions. All rights reserved.
|
|
*
|
|
* Permission to use, copy, modify, and distribute this
|
|
* software is freely granted, provided that this notice
|
|
* is preserved.
|
|
* ====================================================
|
|
*/
|
|
|
|
#include "i386mach.h"
|
|
|
|
.global SYM (memmove)
|
|
SOTYPE_FUNCTION(memmove)
|
|
|
|
SYM (memmove):
|
|
|
|
pushl ebp
|
|
movl esp,ebp
|
|
pushl esi
|
|
pushl edi
|
|
pushl ebx
|
|
movl 8(ebp),edi
|
|
movl 16(ebp),ecx
|
|
movl 12(ebp),esi
|
|
|
|
/* check for destructive overlap (src < dst && dst < src + length) */
|
|
|
|
cld
|
|
cmpl edi,esi
|
|
jae .L2
|
|
leal -1(ecx,esi),ebx
|
|
cmpl ebx,edi
|
|
ja .L2
|
|
|
|
/* IF: destructive overlap, must copy backwards */
|
|
|
|
addl ecx,esi
|
|
addl ecx,edi
|
|
std
|
|
|
|
#ifndef __OPTIMIZE_SIZE__
|
|
|
|
cmpl $8,ecx
|
|
jbe .L13
|
|
.L18:
|
|
|
|
/* move trailing bytes in reverse until destination address is long word aligned */
|
|
|
|
movl edi,edx
|
|
movl ecx,ebx
|
|
andl $3,edx
|
|
jz .L21
|
|
|
|
movl edx,ecx
|
|
decl esi
|
|
decl edi
|
|
subl ecx,ebx
|
|
rep
|
|
movsb
|
|
|
|
mov ebx,ecx
|
|
incl esi
|
|
incl edi
|
|
|
|
.L21:
|
|
|
|
/* move bytes in reverse, a long word at a time */
|
|
|
|
shrl $2,ecx
|
|
subl $4,esi
|
|
subl $4,edi
|
|
rep
|
|
movsl
|
|
|
|
addl $4,esi
|
|
addl $4,edi
|
|
movl ebx,ecx
|
|
andl $3,ecx
|
|
|
|
#endif /* !__OPTIMIZE_SIZE__ */
|
|
|
|
/* handle any remaining bytes not on a long word boundary */
|
|
|
|
.L13:
|
|
decl esi
|
|
decl edi
|
|
|
|
.L15:
|
|
rep
|
|
movsb
|
|
jmp .L5
|
|
.p2align 4,,7
|
|
|
|
/* ELSE: no destructive overlap so we copy forwards */
|
|
|
|
.L2:
|
|
|
|
#ifndef __OPTIMIZE_SIZE__
|
|
|
|
cmpl $8,ecx
|
|
jbe .L3
|
|
|
|
/* move any preceding bytes until destination address is long word aligned */
|
|
|
|
movl edi,edx
|
|
movl ecx,ebx
|
|
andl $3,edx
|
|
jz .L11
|
|
movl $4,ecx
|
|
subl edx,ecx
|
|
andl $3,ecx
|
|
subl ecx,ebx
|
|
rep
|
|
movsb
|
|
|
|
mov ebx,ecx
|
|
|
|
/* move bytes a long word at a time */
|
|
|
|
.L11:
|
|
shrl $2,ecx
|
|
.p2align 2
|
|
rep
|
|
movsl
|
|
|
|
movl ebx,ecx
|
|
andl $3,ecx
|
|
|
|
#endif /* !__OPTIMIZE_SIZE__ */
|
|
|
|
/* handle any remaining bytes */
|
|
|
|
.L3:
|
|
rep
|
|
movsb
|
|
.L5:
|
|
movl 8(ebp),eax
|
|
cld
|
|
|
|
leal -12(ebp),esp
|
|
popl ebx
|
|
popl edi
|
|
popl esi
|
|
leave
|
|
ret
|