~ [ 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-5.0.21)


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