1/* Optimized version of the standard strncmp() function.
2 This file is part of the GNU C Library.
3 Copyright (C) 2000-2022 Free Software Foundation, Inc.
4
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
9
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
14
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, see
17 <https://www.gnu.org/licenses/>. */
18
19/* Return: the result of the comparison
20
21 Inputs:
22 in0: s1
23 in1: s2
24 in2: n
25
26 Unlike memcmp(), this function is optimized for mismatches within the
27 first few characters. */
28
29#include <sysdep.h>
30#undef ret
31
32#define s1 in0
33#define s2 in1
34#define n in2
35
36#define val1 r15
37#define val2 r16
38
39
40ENTRY(strncmp)
41 alloc r2 = ar.pfs, 3, 0, 0, 0
42 mov ret0 = r0
43 cmp.eq p6, p0 = r0, r0 // set p6
44 cmp.eq p7, p0 = n, r0 // return immediately if n == 0
45(p7) br.cond.spnt .restore_and_exit ;;
46.loop:
47 ld1 val1 = [s1], 1
48 ld1 val2 = [s2], 1
49 adds n = -1, n // n--
50 ;;
51 cmp.ne.and p6, p0 = val1, r0
52 cmp.ne.and p6, p0 = val2, r0
53 cmp.ne.and p6, p0 = n, r0
54 cmp.eq.and p6, p0 = val1, val2
55(p6) br.cond.sptk .loop
56 sub ret0 = val1, val2
57.restore_and_exit:
58 br.ret.sptk.many b0
59END(strncmp)
60libc_hidden_builtin_def (strncmp)
61

source code of glibc/sysdeps/ia64/strncmp.S