Update copyright dates with scripts/update-copyrights.
[glibc.git] / sysdeps / i386 / i686 / multiarch / memmove_chk.S
blob2b576d496088e7d812744a23b19eabbbf41dd55e
1 /* Multiple versions of __memmove_chk
2    All versions must be listed in ifunc-impl-list.c.
3    Copyright (C) 2010-2015 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 #if IS_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_SSE2, CPUID_OFFSET+index_SSE2+__cpu_features@GOTOFF(%ebx)
39         jz      2f
40         leal    __memmove_chk_sse2_unaligned@GOTOFF(%ebx), %eax
41         testl   $bit_Fast_Unaligned_Load, FEATURE_OFFSET+index_Fast_Unaligned_Load+__cpu_features@GOTOFF(%ebx)
42         jnz     2f
43         testl   $bit_SSSE3, CPUID_OFFSET+index_SSSE3+__cpu_features@GOTOFF(%ebx)
44         jz      2f
45         leal    __memmove_chk_ssse3@GOTOFF(%ebx), %eax
46         testl   $bit_Fast_Rep_String, FEATURE_OFFSET+index_Fast_Rep_String+__cpu_features@GOTOFF(%ebx)
47         jz      2f
48         leal    __memmove_chk_ssse3_rep@GOTOFF(%ebx), %eax
49 2:      popl    %ebx
50         cfi_adjust_cfa_offset (-4)
51         cfi_restore (ebx)
52         ret
53 END(__memmove_chk)
54 # else
55         .text
56 ENTRY(__memmove_chk)
57         .type   __memmove_chk, @gnu_indirect_function
58         cmpl    $0, KIND_OFFSET+__cpu_features
59         jne     1f
60         call    __init_cpu_features
61 1:      leal    __memmove_chk_ia32, %eax
62         testl   $bit_SSE2, CPUID_OFFSET+index_SSE2+__cpu_features
63         jz      2f
64         leal    __memmove_chk_sse2_unaligned, %eax
65         testl   $bit_Fast_Unaligned_Load, FEATURE_OFFSET+index_Fast_Unaligned_Load+__cpu_features
66         jnz     2f
67         testl   $bit_SSSE3, CPUID_OFFSET+index_SSSE3+__cpu_features
68         jz      2f
69         leal    __memmove_chk_ssse3, %eax
70         testl   $bit_Fast_Rep_String, FEATURE_OFFSET+index_Fast_Rep_String+__cpu_features
71         jz      2f
72         leal    __memmove_chk_ssse3_rep, %eax
73 2:      ret
74 END(__memmove_chk)
76         .type __memmove_chk_sse2_unaligned, @function
77         .p2align 4;
78 __memmove_chk_sse2_unaligned:
79         cfi_startproc
80         CALL_MCOUNT
81         movl    12(%esp), %eax
82         cmpl    %eax, 16(%esp)
83         jb      __chk_fail
84         jmp     __memmove_sse2_unaligned
85         cfi_endproc
86         .size __memmove_chk_sse2_unaligned, .-__memmove_chk_sse2_unaligned
88         .type __memmove_chk_ssse3, @function
89         .p2align 4;
90 __memmove_chk_ssse3:
91         cfi_startproc
92         CALL_MCOUNT
93         movl    12(%esp), %eax
94         cmpl    %eax, 16(%esp)
95         jb      __chk_fail
96         jmp     __memmove_ssse3
97         cfi_endproc
98         .size __memmove_chk_ssse3, .-__memmove_chk_ssse3
100         .type __memmove_chk_ssse3_rep, @function
101         .p2align 4;
102 __memmove_chk_ssse3_rep:
103         cfi_startproc
104         CALL_MCOUNT
105         movl    12(%esp), %eax
106         cmpl    %eax, 16(%esp)
107         jb      __chk_fail
108         jmp     __memmove_ssse3_rep
109         cfi_endproc
110         .size __memmove_chk_ssse3_rep, .-__memmove_chk_ssse3_rep
112         .type __memmove_chk_ia32, @function
113         .p2align 4;
114 __memmove_chk_ia32:
115         cfi_startproc
116         CALL_MCOUNT
117         movl    12(%esp), %eax
118         cmpl    %eax, 16(%esp)
119         jb      __chk_fail
120         jmp     __memmove_ia32
121         cfi_endproc
122         .size __memmove_chk_ia32, .-__memmove_chk_ia32
123 # endif
124 #endif