2.9
[glibc/nacl-glibc.git] / sysdeps / alpha / alphaev67 / strlen.S
blobb83eacceafd168d0122b4b7b3f3e623064f59c33
1 /* Copyright (C) 2000, 2003 Free Software Foundation, Inc.
2    Contributed by David Mosberger (davidm@cs.arizona.edu).
3    EV67 optimized by Rick Gorton <rick.gorton@alpha-processor.com>.
4    This file is part of the GNU C Library.
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.
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.
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.  */
21 /* Finds length of a 0-terminated string.  */
23 #include <sysdep.h>
25         .arch ev6
26         .set noreorder
27         .set noat
29 ENTRY(strlen)
30 #ifdef PROF
31         ldgp    gp, 0(pv)
32         lda     AT, _mcount
33         jsr     AT, (AT), _mcount
34         .prologue 1
35 #else
36         .prologue 0
37 #endif
39         ldq_u   $1, 0($16)      # L : load first quadword ($16 may be misaligned)
40         lda     $2, -1($31)     # E :
41         insqh   $2, $16, $2     # U :
42         andnot  $16, 7, $0      # E :
44         or      $2, $1, $1      # E :
45         cmpbge  $31, $1, $2     # E : $2  <- bitmask: bit i == 1 <==> i-th byte == 0
46         nop                     # E :
47         bne     $2, $found      # U :
49 $loop:  ldq     $1, 8($0)       # L :
50         addq    $0, 8, $0       # E : addr += 8
51         cmpbge  $31, $1, $2     # E :
52         beq     $2, $loop       # U :
54 $found:
55         cttz    $2, $3          # U0 :
56         addq    $0, $3, $0      # E :
57         subq    $0, $16, $0     # E :
58         ret     $31, ($26)      # L0 :
60         END(strlen)
61 libc_hidden_builtin_def (strlen)