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

TOMOYO Linux Cross Reference
Linux/arch/arc/lib/memcmp.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/arc/lib/memcmp.S (Version linux-6.12-rc7) and /arch/mips/lib/memcmp.S (Version linux-5.19.17)


  1 /* SPDX-License-Identifier: GPL-2.0-only */       
  2 /*                                                
  3  * Copyright (C) 2004, 2007-2010, 2011-2012 Sy    
  4  */                                               
  5                                                   
  6 #include <linux/linkage.h>                        
  7                                                   
  8 #ifdef __LITTLE_ENDIAN__                          
  9 #define WORD2 r2                                  
 10 #define SHIFT r3                                  
 11 #else /* BIG ENDIAN */                            
 12 #define WORD2 r3                                  
 13 #define SHIFT r2                                  
 14 #endif                                            
 15                                                   
 16 ENTRY_CFI(memcmp)                                 
 17         or      r12,r0,r1                         
 18         asl_s   r12,r12,30                        
 19         sub     r3,r2,1                           
 20         brls    r2,r12,.Lbytewise                 
 21         ld      r4,[r0,0]                         
 22         ld      r5,[r1,0]                         
 23         lsr.f   lp_count,r3,3                     
 24 #ifdef CONFIG_ISA_ARCV2                           
 25         /* In ARCv2 a branch can't be the last    
 26          * loop.                                  
 27          * So we move the branch to the start     
 28          * after the end, and set up r12 so th    
 29          *  initially.                            
 30          */                                       
 31         mov_s   r12,WORD2                         
 32         lpne    .Loop_end                         
 33         brne    WORD2,r12,.Lodd                   
 34         ld      WORD2,[r0,4]                      
 35 #else                                             
 36         lpne    .Loop_end                         
 37         ld_s    WORD2,[r0,4]                      
 38 #endif                                            
 39         ld_s    r12,[r1,4]                        
 40         brne    r4,r5,.Leven                      
 41         ld.a    r4,[r0,8]                         
 42         ld.a    r5,[r1,8]                         
 43 #ifdef CONFIG_ISA_ARCV2                           
 44 .Loop_end:                                        
 45         brne    WORD2,r12,.Lodd                   
 46 #else                                             
 47         brne    WORD2,r12,.Lodd                   
 48 .Loop_end:                                        
 49 #endif                                            
 50         asl_s   SHIFT,SHIFT,3                     
 51         bhs_s   .Last_cmp                         
 52         brne    r4,r5,.Leven                      
 53         ld      r4,[r0,4]                         
 54         ld      r5,[r1,4]                         
 55 #ifdef __LITTLE_ENDIAN__                          
 56         nop_s                                     
 57         ; one more load latency cycle             
 58 .Last_cmp:                                        
 59         xor     r0,r4,r5                          
 60         bset    r0,r0,SHIFT                       
 61         sub_s   r1,r0,1                           
 62         bic_s   r1,r1,r0                          
 63         norm    r1,r1                             
 64         b.d     .Leven_cmp                        
 65         and     r1,r1,24                          
 66 .Leven:                                           
 67         xor     r0,r4,r5                          
 68         sub_s   r1,r0,1                           
 69         bic_s   r1,r1,r0                          
 70         norm    r1,r1                             
 71         ; slow track insn                         
 72         and     r1,r1,24                          
 73 .Leven_cmp:                                       
 74         asl     r2,r4,r1                          
 75         asl     r12,r5,r1                         
 76         lsr_s   r2,r2,1                           
 77         lsr_s   r12,r12,1                         
 78         j_s.d   [blink]                           
 79         sub     r0,r2,r12                         
 80         .balign 4                                 
 81 .Lodd:                                            
 82         xor     r0,WORD2,r12                      
 83         sub_s   r1,r0,1                           
 84         bic_s   r1,r1,r0                          
 85         norm    r1,r1                             
 86         ; slow track insn                         
 87         and     r1,r1,24                          
 88         asl_s   r2,r2,r1                          
 89         asl_s   r12,r12,r1                        
 90         lsr_s   r2,r2,1                           
 91         lsr_s   r12,r12,1                         
 92         j_s.d   [blink]                           
 93         sub     r0,r2,r12                         
 94 #else /* BIG ENDIAN */                            
 95 .Last_cmp:                                        
 96         neg_s   SHIFT,SHIFT                       
 97         lsr     r4,r4,SHIFT                       
 98         lsr     r5,r5,SHIFT                       
 99         ; slow track insn                         
100 .Leven:                                           
101         sub.f   r0,r4,r5                          
102         mov.ne  r0,1                              
103         j_s.d   [blink]                           
104         bset.cs r0,r0,31                          
105 .Lodd:                                            
106         cmp_s   WORD2,r12                         
107         mov_s   r0,1                              
108         j_s.d   [blink]                           
109         bset.cs r0,r0,31                          
110 #endif /* ENDIAN */                               
111         .balign 4                                 
112 .Lbytewise:                                       
113         breq    r2,0,.Lnil                        
114         ldb     r4,[r0,0]                         
115         ldb     r5,[r1,0]                         
116         lsr.f   lp_count,r3                       
117 #ifdef CONFIG_ISA_ARCV2                           
118         mov     r12,r3                            
119         lpne    .Lbyte_end                        
120         brne    r3,r12,.Lbyte_odd                 
121 #else                                             
122         lpne    .Lbyte_end                        
123 #endif                                            
124         ldb_s   r3,[r0,1]                         
125         ldb     r12,[r1,1]                        
126         brne    r4,r5,.Lbyte_even                 
127         ldb.a   r4,[r0,2]                         
128         ldb.a   r5,[r1,2]                         
129 #ifdef CONFIG_ISA_ARCV2                           
130 .Lbyte_end:                                       
131         brne    r3,r12,.Lbyte_odd                 
132 #else                                             
133         brne    r3,r12,.Lbyte_odd                 
134 .Lbyte_end:                                       
135 #endif                                            
136         bcc     .Lbyte_even                       
137         brne    r4,r5,.Lbyte_even                 
138         ldb_s   r3,[r0,1]                         
139         ldb_s   r12,[r1,1]                        
140 .Lbyte_odd:                                       
141         j_s.d   [blink]                           
142         sub     r0,r3,r12                         
143 .Lbyte_even:                                      
144         j_s.d   [blink]                           
145         sub     r0,r4,r5                          
146 .Lnil:                                            
147         j_s.d   [blink]                           
148         mov     r0,0                              
149 END_CFI(memcmp)                                   
                                                      

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