Update copyright notices with scripts/update-copyrights
[glibc.git] / sysdeps / i386 / i686 / multiarch / memmove_chk.S
blob182aeb3d46294a3de2e3443ec2009c49c2879794
1 /* Multiple versions of __memmove_chk
2    All versions must be listed in ifunc-impl-list.c.
3    Copyright (C) 2010-2014 Free Software Foundation, Inc.
4    Contributed by Intel Corporation.
5    This file is part of the GNU C Library.
7    The GNU C Library is free software; you can redistribute it and/or
8    modify it under the terms of the GNU Lesser General Public
9    License as published by the Free Software Foundation; either
10    version 2.1 of the License, or (at your option) any later version.
12    The GNU C Library is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15    Lesser General Public License for more details.
17    You should have received a copy of the GNU Lesser General Public
18    License along with the GNU C Library; if not, see
19    <http://www.gnu.org/licenses/>.  */
21 #include <sysdep.h>
22 #include <init-arch.h>
24 /* Define multiple versions only for the definition in lib.  */
25 #ifndef NOT_IN_libc
26 # ifdef SHARED
27         .text
28 ENTRY(__memmove_chk)
29         .type   __memmove_chk, @gnu_indirect_function
30         pushl   %ebx
31         cfi_adjust_cfa_offset (4)
32         cfi_rel_offset (ebx, 0)
33         LOAD_PIC_REG(bx)
34         cmpl    $0, KIND_OFFSET+__cpu_features@GOTOFF(%ebx)
35         jne     1f
36         call    __init_cpu_features
37 1:      leal    __memmove_chk_ia32@GOTOFF(%ebx), %eax
38         testl   $bit_SSSE3, CPUID_OFFSET+index_SSSE3+__cpu_features@GOTOFF(%ebx)
39         jz      2f
40         leal    __memmove_chk_ssse3@GOTOFF(%ebx), %eax
41         testl   $bit_Fast_Rep_String, FEATURE_OFFSET+index_Fast_Rep_String+__cpu_features@GOTOFF(%ebx)
42         jz      2f
43         leal    __memmove_chk_ssse3_rep@GOTOFF(%ebx), %eax
44 2:      popl    %ebx
45         cfi_adjust_cfa_offset (-4)
46         cfi_restore (ebx)
47         ret
48 END(__memmove_chk)
49 # else
50         .text
51 ENTRY(__memmove_chk)
52         .type   __memmove_chk, @gnu_indirect_function
53         cmpl    $0, KIND_OFFSET+__cpu_features
54         jne     1f
55         call    __init_cpu_features
56 1:      leal    __memmove_chk_ia32, %eax
57         testl   $bit_SSSE3, CPUID_OFFSET+index_SSSE3+__cpu_features
58         jz      2f
59         leal    __memmove_chk_ssse3, %eax
60         testl   $bit_Fast_Rep_String, FEATURE_OFFSET+index_Fast_Rep_String+__cpu_features
61         jz      2f
62         leal    __memmove_chk_ssse3_rep, %eax
63 2:      ret
64 END(__memmove_chk)
66         .type __memmove_chk_ssse3, @function
67         .p2align 4;
68 __memmove_chk_ssse3:
69         cfi_startproc
70         CALL_MCOUNT
71         movl    12(%esp), %eax
72         cmpl    %eax, 16(%esp)
73         jb      __chk_fail
74         jmp     __memmove_ssse3
75         cfi_endproc
76         .size __memmove_chk_ssse3, .-__memmove_chk_ssse3
78         .type __memmove_chk_ssse3_rep, @function
79         .p2align 4;
80 __memmove_chk_ssse3_rep:
81         cfi_startproc
82         CALL_MCOUNT
83         movl    12(%esp), %eax
84         cmpl    %eax, 16(%esp)
85         jb      __chk_fail
86         jmp     __memmove_ssse3_rep
87         cfi_endproc
88         .size __memmove_chk_ssse3_rep, .-__memmove_chk_ssse3_rep
90         .type __memmove_chk_ia32, @function
91         .p2align 4;
92 __memmove_chk_ia32:
93         cfi_startproc
94         CALL_MCOUNT
95         movl    12(%esp), %eax
96         cmpl    %eax, 16(%esp)
97         jb      __chk_fail
98         jmp     __memmove_ia32
99         cfi_endproc
100         .size __memmove_chk_ia32, .-__memmove_chk_ia32
101 # endif
102 #endif