~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/sh/lib/strlen.S

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /arch/sh/lib/strlen.S (Version linux-6.12-rc7) and /arch/sparc/lib/strlen.S (Version linux-4.9.337)


  1 /* SPDX-License-Identifier: GPL-2.0 */         !!   1 /* strlen.S: Sparc optimized strlen code
  2 /* $Id: strlen.S,v 1.2 2001/06/29 14:07:15 gni !!   2  * Hand optimized from GNU libc's strlen
  3  *                                             !!   3  * Copyright (C) 1991,1996 Free Software Foundation
  4  * "strlen" implementation of SuperH           !!   4  * Copyright (C) 1996,2008 David S. Miller (davem@davemloft.net)
  5  *                                             !!   5  * Copyright (C) 1996, 1997 Jakub Jelinek (jj@sunsite.mff.cuni.cz)
  6  * Copyright (C) 1999  Kaz Kojima              << 
  7  *                                             << 
  8  */                                                 6  */
  9                                                     7 
 10 /* size_t strlen (const char *s)  */           << 
 11                                                << 
 12 #include <linux/linkage.h>                          8 #include <linux/linkage.h>
 13 ENTRY(strlen)                                  !!   9 #include <asm/asm.h>
 14         mov     r4,r0                          !!  10 #include <asm/export.h>
 15         and     #3,r0                          << 
 16         tst     r0,r0                          << 
 17         bt/s    1f                             << 
 18          mov    #0,r2                          << 
 19                                                << 
 20         add     #-1,r0                         << 
 21         shll2   r0                             << 
 22         shll    r0                             << 
 23         braf    r0                             << 
 24          nop                                   << 
 25                                                    11 
 26         mov.b   @r4+,r1                        !!  12 #define LO_MAGIC 0x01010101
 27         tst     r1,r1                          !!  13 #define HI_MAGIC 0x80808080
 28         bt      8f                             << 
 29         add     #1,r2                          << 
 30                                                    14 
 31         mov.b   @r4+,r1                        !!  15         .text
 32         tst     r1,r1                          !!  16 ENTRY(strlen)
 33         bt      8f                             !!  17         mov     %o0, %o1
 34         add     #1,r2                          !!  18         andcc   %o0, 3, %g0
 35                                                !!  19         BRANCH32(be, pt, 9f)
 36         mov.b   @r4+,r1                        !!  20          sethi  %hi(HI_MAGIC), %o4
 37         tst     r1,r1                          !!  21         ldub    [%o0], %o5
 38         bt      8f                             !!  22         BRANCH_REG_ZERO(pn, %o5, 11f)
 39         add     #1,r2                          !!  23          add    %o0, 1, %o0
 40                                                !!  24         andcc   %o0, 3, %g0
 41 1:                                             !!  25         BRANCH32(be, pn, 4f)
 42         mov     #0,r3                          !!  26          or     %o4, %lo(HI_MAGIC), %o3
 43 2:                                             !!  27         ldub    [%o0], %o5
 44         mov.l   @r4+,r1                        !!  28         BRANCH_REG_ZERO(pn, %o5, 12f)
 45         cmp/str r3,r1                          !!  29          add    %o0, 1, %o0
 46         bf/s    2b                             !!  30         andcc   %o0, 3, %g0
 47          add    #4,r2                          !!  31         BRANCH32(be, pt, 5f)
 48                                                !!  32          sethi  %hi(LO_MAGIC), %o4
 49         add     #-4,r2                         !!  33         ldub    [%o0], %o5
 50 #ifndef __LITTLE_ENDIAN__                      !!  34         BRANCH_REG_ZERO(pn, %o5, 13f)
 51         swap.b  r1,r1                          !!  35          add    %o0, 1, %o0
 52         swap.w  r1,r1                          !!  36         BRANCH32(ba, pt, 8f)
 53         swap.b  r1,r1                          !!  37          or     %o4, %lo(LO_MAGIC), %o2
 54 #endif                                         !!  38 9:
 55         extu.b  r1,r0                          !!  39         or      %o4, %lo(HI_MAGIC), %o3
 56         tst     r0,r0                          !!  40 4:
 57         bt/s    8f                             !!  41         sethi   %hi(LO_MAGIC), %o4
 58          shlr8  r1                             !!  42 5:
 59         add     #1,r2                          !!  43         or      %o4, %lo(LO_MAGIC), %o2
 60         extu.b  r1,r0                          << 
 61         tst     r0,r0                          << 
 62         bt/s    8f                             << 
 63          shlr8  r1                             << 
 64         add     #1,r2                          << 
 65         extu.b  r1,r0                          << 
 66         tst     r0,r0                          << 
 67         bt      8f                             << 
 68         add     #1,r2                          << 
 69 8:                                                 44 8:
 70         rts                                    !!  45         ld      [%o0], %o5
 71          mov    r2,r0                          !!  46 2:
                                                   >>  47         sub     %o5, %o2, %o4
                                                   >>  48         andcc   %o4, %o3, %g0
                                                   >>  49         BRANCH32(be, pt, 8b)
                                                   >>  50          add    %o0, 4, %o0
                                                   >>  51 
                                                   >>  52         /* Check every byte. */
                                                   >>  53         srl     %o5, 24, %g7
                                                   >>  54         andcc   %g7, 0xff, %g0
                                                   >>  55         BRANCH32(be, pn, 1f)
                                                   >>  56          add    %o0, -4, %o4
                                                   >>  57         srl     %o5, 16, %g7
                                                   >>  58         andcc   %g7, 0xff, %g0
                                                   >>  59         BRANCH32(be, pn, 1f)
                                                   >>  60          add    %o4, 1, %o4
                                                   >>  61         srl     %o5, 8, %g7
                                                   >>  62         andcc   %g7, 0xff, %g0
                                                   >>  63         BRANCH32(be, pn, 1f)
                                                   >>  64          add    %o4, 1, %o4
                                                   >>  65         andcc   %o5, 0xff, %g0
                                                   >>  66         BRANCH32_ANNUL(bne, pt, 2b)
                                                   >>  67          ld     [%o0], %o5
                                                   >>  68         add     %o4, 1, %o4
                                                   >>  69 1:
                                                   >>  70         retl
                                                   >>  71          sub    %o4, %o1, %o0
                                                   >>  72 11:
                                                   >>  73         retl
                                                   >>  74          mov    0, %o0
                                                   >>  75 12:
                                                   >>  76         retl
                                                   >>  77          mov    1, %o0
                                                   >>  78 13:
                                                   >>  79         retl
                                                   >>  80          mov    2, %o0
                                                   >>  81 ENDPROC(strlen)
                                                   >>  82 EXPORT_SYMBOL(strlen)
                                                      

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php