aboutsummaryrefslogtreecommitdiff
path: root/ports/sysdeps/powerpc/powerpc32/405/strlen.S
blob: e267f4dfcad5c54c9f4917e7238f38c9aad47011 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
/* Optimized strlen implementation for PowerPC476.
   Copyright (C) 2010-2013 Free Software Foundation, Inc.
   This file is part of the GNU C Library.

   The GNU C Library is free software; you can redistribute it and/or
   modify it under the terms of the GNU Lesser General Public
   License as published by the Free Software Foundation; either
   version 2.1 of the License, or (at your option) any later version.

   The GNU C Library is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   Lesser General Public License for more details.

   You should have received a copy of the GNU Lesser General Public
   License along with the GNU C Library.  If not, see
   <http://www.gnu.org/licenses/>.  */

#include <sysdep.h>
#include <bp-sym.h>
#include <bp-asm.h>

/* strlen

       Register Use
       r3:source address and return length of string
       r4:byte counter

       Implementation description
       Load 2 words at a time and count bytes, if we find null we subtract one from
       the count and return the count value. We need to subtract one because
       we don't count the null character as a byte. */

EALIGN (BP_SYM (strlen),5,0)
       neg     r7,r3
       clrlwi. r8,r7,29
       addi    r4,0,0
       beq     L(byte_count_loop)
       mtctr   r8

L(loop):
       lbz     r5,0(r3)
       cmpi    cr5,r5,0x0
       addi    r3,r3,0x1
       addi    r4,r4,0x1
       beq     cr5,L(end_strlen)
       bdnz    L(loop)

L(byte_count_loop):
       lwz     r5,0(r3)
       lwz     r6,4(r3)
       dlmzb.  r12,r5,r6
       add     r4,r4,r12
       bne     L(end_strlen)
       lwz     r5,8(r3)
       lwz     r6,12(r3)
       dlmzb.  r12,r5,r6
       add     r4,r4,r12
       bne     L(end_strlen)
       lwz     r5,16(r3)
       lwz     r6,20(r3)
       dlmzb.  r12,r5,r6
       add     r4,r4,r12
       bne     L(end_strlen)
       lwz     r5,24(r3)
       lwz     r6,28(r3)
       addi    r3,r3,0x20
       dlmzb.  r12,r5,r6
       add     r4,r4,r12
       bne     L(end_strlen)
       b       L(byte_count_loop)

L(end_strlen):
       addi    r3,r4,-1
       blr
END (BP_SYM (strlen))
libc_hidden_builtin_def (strlen)