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

TOMOYO Linux Cross Reference
Linux/arch/arm64/crypto/aes-ce-ccm-core.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/arm64/crypto/aes-ce-ccm-core.S (Architecture i386) and /arch/m68k/crypto/aes-ce-ccm-core.S (Architecture m68k)


  1 /* SPDX-License-Identifier: GPL-2.0-only */       
  2 /*                                                
  3  * aes-ce-ccm-core.S - AES-CCM transform for A    
  4  *                                                
  5  * Copyright (C) 2013 - 2017 Linaro Ltd.          
  6  * Copyright (C) 2024 Google LLC                  
  7  *                                                
  8  * Author: Ard Biesheuvel <ardb@kernel.org>        
  9  */                                               
 10                                                   
 11 #include <linux/linkage.h>                        
 12 #include <asm/assembler.h>                        
 13                                                   
 14         .text                                     
 15         .arch   armv8-a+crypto                    
 16                                                   
 17         .macro  load_round_keys, rk, nr, tmp      
 18         sub     w\tmp, \nr, #10                   
 19         add     \tmp, \rk, w\tmp, sxtw #4         
 20         ld1     {v10.4s-v13.4s}, [\rk]            
 21         ld1     {v14.4s-v17.4s}, [\tmp], #64      
 22         ld1     {v18.4s-v21.4s}, [\tmp], #64      
 23         ld1     {v3.4s-v5.4s}, [\tmp]             
 24         .endm                                     
 25                                                   
 26         .macro  dround, va, vb, vk                
 27         aese    \va\().16b, \vk\().16b            
 28         aesmc   \va\().16b, \va\().16b            
 29         aese    \vb\().16b, \vk\().16b            
 30         aesmc   \vb\().16b, \vb\().16b            
 31         .endm                                     
 32                                                   
 33         .macro  aes_encrypt, va, vb, nr           
 34         tbz     \nr, #2, .L\@                     
 35         dround  \va, \vb, v10                     
 36         dround  \va, \vb, v11                     
 37         tbz     \nr, #1, .L\@                     
 38         dround  \va, \vb, v12                     
 39         dround  \va, \vb, v13                     
 40 .L\@:   .irp    v, v14, v15, v16, v17, v18, v1    
 41         dround  \va, \vb, \v                      
 42         .endr                                     
 43         aese    \va\().16b, v4.16b                
 44         aese    \vb\().16b, v4.16b                
 45         .endm                                     
 46                                                   
 47         .macro  aes_ccm_do_crypt,enc              
 48         load_round_keys x3, w4, x10               
 49                                                   
 50         ld1     {v0.16b}, [x5]                    
 51         cbz     x2, ce_aes_ccm_final              
 52         ldr     x8, [x6, #8]                      
 53 CPU_LE( rev     x8, x8                  )         
 54 0:      /* outer loop */                          
 55         ld1     {v1.8b}, [x6]                     
 56         prfm    pldl1strm, [x1]                   
 57         add     x8, x8, #1                        
 58         rev     x9, x8                            
 59         ins     v1.d[1], x9                       
 60                                                   
 61         aes_encrypt     v0, v1, w4                
 62                                                   
 63         subs    w2, w2, #16                       
 64         bmi     ce_aes_ccm_crypt_tail             
 65         ld1     {v2.16b}, [x1], #16               
 66         .if     \enc == 1                         
 67         eor     v2.16b, v2.16b, v5.16b            
 68         eor     v6.16b, v1.16b, v2.16b            
 69         .else                                     
 70         eor     v2.16b, v2.16b, v1.16b            
 71         eor     v6.16b, v2.16b, v5.16b            
 72         .endif                                    
 73         eor     v0.16b, v0.16b, v2.16b            
 74         st1     {v6.16b}, [x0], #16               
 75         bne     0b                                
 76 CPU_LE( rev     x8, x8                  )         
 77         str     x8, [x6, #8]                      
 78         cbnz    x7, ce_aes_ccm_final              
 79         st1     {v0.16b}, [x5]                    
 80         ret                                       
 81         .endm                                     
 82                                                   
 83 SYM_FUNC_START_LOCAL(ce_aes_ccm_crypt_tail)       
 84         eor     v0.16b, v0.16b, v5.16b            
 85         eor     v1.16b, v1.16b, v5.16b            
 86                                                   
 87         add     x1, x1, w2, sxtw                  
 88         add     x0, x0, w2, sxtw                  
 89                                                   
 90         adr_l   x8, .Lpermute                     
 91         add     x9, x8, w2, sxtw                  
 92         sub     x8, x8, w2, sxtw                  
 93         ld1     {v7.16b-v8.16b}, [x9]             
 94         ld1     {v9.16b}, [x8]                    
 95                                                   
 96         ld1     {v2.16b}, [x1]                    
 97         tbl     v1.16b, {v1.16b}, v7.16b          
 98         eor     v7.16b, v2.16b, v1.16b            
 99         bif     v2.16b, v7.16b, v22.16b           
100         tbx     v7.16b, {v6.16b}, v8.16b          
101         tbl     v2.16b, {v2.16b}, v9.16b          
102         eor     v0.16b, v0.16b, v2.16b            
103                                                   
104         st1     {v7.16b}, [x0]                    
105         cbz     x7, 0f                            
106                                                   
107 SYM_INNER_LABEL(ce_aes_ccm_final, SYM_L_LOCAL)    
108         ld1     {v1.16b}, [x7]                    
109                                                   
110         aes_encrypt     v0, v1, w4                
111                                                   
112         /* final round key cancels out */         
113         eor     v0.16b, v0.16b, v1.16b            
114 0:      st1     {v0.16b}, [x5]                    
115         ret                                       
116 SYM_FUNC_END(ce_aes_ccm_crypt_tail)               
117                                                   
118         /*                                        
119          * void ce_aes_ccm_encrypt(u8 out[], u    
120          *                         u8 const rk    
121          *                         u8 ctr[], u    
122          * void ce_aes_ccm_decrypt(u8 out[], u    
123          *                         u8 const rk    
124          *                         u8 ctr[], u    
125          */                                       
126 SYM_FUNC_START(ce_aes_ccm_encrypt)                
127         movi    v22.16b, #255                     
128         aes_ccm_do_crypt        1                 
129 SYM_FUNC_END(ce_aes_ccm_encrypt)                  
130                                                   
131 SYM_FUNC_START(ce_aes_ccm_decrypt)                
132         movi    v22.16b, #0                       
133         aes_ccm_do_crypt        0                 
134 SYM_FUNC_END(ce_aes_ccm_decrypt)                  
135                                                   
136         .section ".rodata", "a"                   
137         .align  6                                 
138         .fill   15, 1, 0xff                       
139 .Lpermute:                                        
140         .byte   0x0, 0x1, 0x2, 0x3, 0x4, 0x5,     
141         .byte   0x8, 0x9, 0xa, 0xb, 0xc, 0xd,     
142         .fill   15, 1, 0xff                       
                                                      

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