1 /* Highly optimized version for i586.
2 Copyright (C) 1997, 2000, 2003, 2005 Free Software Foundation, Inc.
3 This file is part of the GNU C Library.
4 Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
6 The GNU C Library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2.1 of the License, or (at your option) any later version.
11 The GNU C Library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
16 You should have received a copy of the GNU Lesser General Public
17 License along with the GNU C Library; if not, write to the Free
18 Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
22 #include "asm-syntax.h"
26 /* BEWARE: `#ifdef memcpy' means that memcpy is redefined as `mempcpy',
27 and the return value is the byte after the last one copied in
29 #define MEMPCPY_P (defined memcpy)
31 #define PARMS LINKAGE+8 /* space for 2 saved regs */
33 #define DEST RTN+RTN_SIZE
34 #define SRC DEST+PTR_SIZE
35 #define LEN SRC+PTR_SIZE
38 #if defined PIC && !defined NOT_IN_libc
42 jb HIDDEN_JUMPTARGET (__chk_fail)
45 ENTRY (BP_SYM (memcpy))
49 cfi_adjust_cfa_offset (4)
51 cfi_adjust_cfa_offset (4)
54 cfi_rel_offset (edi, 4)
56 cfi_rel_offset (esi, 0)
58 CHECK_BOUNDS_BOTH_WIDE (%edi, DEST(%esp), %ecx)
59 CHECK_BOUNDS_BOTH_WIDE (%esi, SRC(%esp), %ecx)
62 /* We need this in any case. */
65 /* Cutoff for the big loop is a size of 32 bytes since otherwise
66 the loop will never be entered. */
81 /* Read ahead to make sure we write in the cache since the stupid
82 i586 designers haven't implemented read-on-write-miss. */
84 L(3): movl 28(%edi), %edx
86 /* Now correct the loop counter. Please note that in the following
87 code the flags are not changed anymore. */
112 /* Correct extra loop counter modification. */
115 movl DEST(%esp), %eax
125 cfi_adjust_cfa_offset (-4)
128 cfi_adjust_cfa_offset (-4)
133 END (BP_SYM (memcpy))
135 libc_hidden_builtin_def (memcpy)