2006-02-24 Roland McGrath <roland@redhat.com>
[kopensolaris-gnu/glibc.git] / sysdeps / ia64 / strncmp.S
1 /* Optimized version of the standard strncmp() function.
2    This file is part of the GNU C Library.
3    Copyright (C) 2000, 2001, 2003 Free Software Foundation, Inc.
4    Contributed by Dan Pop <Dan.Pop@cern.ch>.
5
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.
10
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.
15
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
19    02111-1307 USA.  */
20
21 /* Return: the result of the comparison
22
23    Inputs:
24         in0:    s1
25         in1:    s2
26         in2:    n
27
28    Unlike memcmp(), this function is optimized for mismatches within the
29    first few characters.  */
30
31 #include <sysdep.h>
32 #undef ret
33
34 #define s1              in0
35 #define s2              in1
36 #define n               in2
37
38 #define val1            r15
39 #define val2            r16
40
41
42 ENTRY(strncmp)
43         alloc   r2 = ar.pfs, 3, 0, 0, 0
44         mov     ret0 = r0
45         cmp.eq  p6, p0 = r0, r0         // set p6
46         cmp.eq  p7, p0 = n, r0          // return immediately if n == 0
47 (p7)    br.cond.spnt .restore_and_exit ;;
48 .loop:
49         ld1     val1 = [s1], 1
50         ld1     val2 = [s2], 1
51         adds    n = -1, n               // n--
52         ;;
53         cmp.ne.and p6, p0 = val1, r0
54         cmp.ne.and p6, p0 = val2, r0
55         cmp.ne.and p6, p0 = n, r0
56         cmp.eq.and p6, p0 = val1, val2
57 (p6)    br.cond.sptk .loop
58         sub     ret0 = val1, val2
59 .restore_and_exit:
60         br.ret.sptk.many b0
61 END(strncmp)    
62 libc_hidden_builtin_def (strncmp)