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


  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                          << 
 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                                                    10 
 26         mov.b   @r4+,r1                        !!  11 #define LO_MAGIC 0x01010101
 27         tst     r1,r1                          !!  12 #define HI_MAGIC 0x80808080
 28         bt      8f                             << 
 29         add     #1,r2                          << 
 30                                                    13 
 31         mov.b   @r4+,r1                        !!  14         .text
 32         tst     r1,r1                          !!  15 ENTRY(strlen)
 33         bt      8f                             !!  16         mov     %o0, %o1
 34         add     #1,r2                          !!  17         andcc   %o0, 3, %g0
 35                                                !!  18         BRANCH32(be, pt, 9f)
 36         mov.b   @r4+,r1                        !!  19          sethi  %hi(HI_MAGIC), %o4
 37         tst     r1,r1                          !!  20         ldub    [%o0], %o5
 38         bt      8f                             !!  21         BRANCH_REG_ZERO(pn, %o5, 11f)
 39         add     #1,r2                          !!  22          add    %o0, 1, %o0
 40                                                !!  23         andcc   %o0, 3, %g0
 41 1:                                             !!  24         BRANCH32(be, pn, 4f)
 42         mov     #0,r3                          !!  25          or     %o4, %lo(HI_MAGIC), %o3
 43 2:                                             !!  26         ldub    [%o0], %o5
 44         mov.l   @r4+,r1                        !!  27         BRANCH_REG_ZERO(pn, %o5, 12f)
 45         cmp/str r3,r1                          !!  28          add    %o0, 1, %o0
 46         bf/s    2b                             !!  29         andcc   %o0, 3, %g0
 47          add    #4,r2                          !!  30         BRANCH32(be, pt, 5f)
 48                                                !!  31          sethi  %hi(LO_MAGIC), %o4
 49         add     #-4,r2                         !!  32         ldub    [%o0], %o5
 50 #ifndef __LITTLE_ENDIAN__                      !!  33         BRANCH_REG_ZERO(pn, %o5, 13f)
 51         swap.b  r1,r1                          !!  34          add    %o0, 1, %o0
 52         swap.w  r1,r1                          !!  35         BRANCH32(ba, pt, 8f)
 53         swap.b  r1,r1                          !!  36          or     %o4, %lo(LO_MAGIC), %o2
 54 #endif                                         !!  37 9:
 55         extu.b  r1,r0                          !!  38         or      %o4, %lo(HI_MAGIC), %o3
 56         tst     r0,r0                          !!  39 4:
 57         bt/s    8f                             !!  40         sethi   %hi(LO_MAGIC), %o4
 58          shlr8  r1                             !!  41 5:
 59         add     #1,r2                          !!  42         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:                                                 43 8:
 70         rts                                    !!  44         ld      [%o0], %o5
 71          mov    r2,r0                          !!  45 2:
                                                   >>  46         sub     %o5, %o2, %o4
                                                   >>  47         andcc   %o4, %o3, %g0
                                                   >>  48         BRANCH32(be, pt, 8b)
                                                   >>  49          add    %o0, 4, %o0
                                                   >>  50 
                                                   >>  51         /* Check every byte. */
                                                   >>  52         srl     %o5, 24, %g7
                                                   >>  53         andcc   %g7, 0xff, %g0
                                                   >>  54         BRANCH32(be, pn, 1f)
                                                   >>  55          add    %o0, -4, %o4
                                                   >>  56         srl     %o5, 16, %g7
                                                   >>  57         andcc   %g7, 0xff, %g0
                                                   >>  58         BRANCH32(be, pn, 1f)
                                                   >>  59          add    %o4, 1, %o4
                                                   >>  60         srl     %o5, 8, %g7
                                                   >>  61         andcc   %g7, 0xff, %g0
                                                   >>  62         BRANCH32(be, pn, 1f)
                                                   >>  63          add    %o4, 1, %o4
                                                   >>  64         andcc   %o5, 0xff, %g0
                                                   >>  65         BRANCH32_ANNUL(bne, pt, 2b)
                                                   >>  66          ld     [%o0], %o5
                                                   >>  67         add     %o4, 1, %o4
                                                   >>  68 1:
                                                   >>  69         retl
                                                   >>  70          sub    %o4, %o1, %o0
                                                   >>  71 11:
                                                   >>  72         retl
                                                   >>  73          mov    0, %o0
                                                   >>  74 12:
                                                   >>  75         retl
                                                   >>  76          mov    1, %o0
                                                   >>  77 13:
                                                   >>  78         retl
                                                   >>  79          mov    2, %o0
                                                   >>  80 ENDPROC(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