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

TOMOYO Linux Cross Reference
Linux/arch/arm/mach-exynos/sleep.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/arm/mach-exynos/sleep.S (Version linux-6.12-rc7) and /arch/m68k/mach-exynos/sleep.S (Version linux-5.3.18)


  1 /* SPDX-License-Identifier: GPL-2.0+ */           
  2 /*                                                
  3  * Copyright (c) 2013 Samsung Electronics Co.,    
  4  *              http://www.samsung.com            
  5  *                                                
  6  * Exynos low-level resume code                   
  7  */                                               
  8                                                   
  9 #include <linux/linkage.h>                        
 10 #include <asm/asm-offsets.h>                      
 11 #include <asm/hardware/cache-l2x0.h>              
 12 #include "smc.h"                                  
 13                                                   
 14 #define CPU_MASK        0xff0ffff0                
 15 #define CPU_CORTEX_A9   0x410fc090                
 16                                                   
 17         .text                                     
 18         .align                                    
 19                                                   
 20         /*                                        
 21          * sleep magic, to allow the bootloade    
 22          * image to resume to. Must be the fir    
 23          * exynos_cpu_resume entry.               
 24          */                                       
 25                                                   
 26         .word   0x2bedf00d                        
 27                                                   
 28         /*                                        
 29          * exynos_cpu_resume                      
 30          *                                        
 31          * resume code entry for bootloader to    
 32          */                                       
 33                                                   
 34 ENTRY(exynos_cpu_resume)                          
 35 #ifdef CONFIG_CACHE_L2X0                          
 36         mrc     p15, 0, r0, c0, c0, 0             
 37         ldr     r1, =CPU_MASK                     
 38         and     r0, r0, r1                        
 39         ldr     r1, =CPU_CORTEX_A9                
 40         cmp     r0, r1                            
 41         bleq    l2c310_early_resume               
 42 #endif                                            
 43         b       cpu_resume                        
 44 ENDPROC(exynos_cpu_resume)                        
 45                                                   
 46         .align                                    
 47         .arch armv7-a                             
 48         .arch_extension sec                       
 49 ENTRY(exynos_cpu_resume_ns)                       
 50         mrc     p15, 0, r0, c0, c0, 0             
 51         ldr     r1, =CPU_MASK                     
 52         and     r0, r0, r1                        
 53         ldr     r1, =CPU_CORTEX_A9                
 54         cmp     r0, r1                            
 55         bne     skip_cp15                         
 56                                                   
 57         adr     r0, _cp15_save_power              
 58         ldr     r1, [r0]                          
 59         ldr     r1, [r0, r1]                      
 60         adr     r0, _cp15_save_diag               
 61         ldr     r2, [r0]                          
 62         ldr     r2, [r0, r2]                      
 63         mov     r0, #SMC_CMD_C15RESUME            
 64         dsb                                       
 65         smc     #0                                
 66 #ifdef CONFIG_CACHE_L2X0                          
 67         adr     r0, 1f                            
 68         ldr     r2, [r0]                          
 69         add     r0, r2, r0                        
 70                                                   
 71         /* Check that the address has been ini    
 72         ldr     r1, [r0, #L2X0_R_PHY_BASE]        
 73         teq     r1, #0                            
 74         beq     skip_l2x0                         
 75                                                   
 76         /* Check if controller has been enable    
 77         ldr     r2, [r1, #L2X0_CTRL]              
 78         tst     r2, #0x1                          
 79         bne     skip_l2x0                         
 80                                                   
 81         ldr     r1, [r0, #L2X0_R_TAG_LATENCY]     
 82         ldr     r2, [r0, #L2X0_R_DATA_LATENCY]    
 83         ldr     r3, [r0, #L2X0_R_PREFETCH_CTRL    
 84         mov     r0, #SMC_CMD_L2X0SETUP1           
 85         smc     #0                                
 86                                                   
 87         /* Reload saved regs pointer because s    
 88         adr     r0, 1f                            
 89         ldr     r2, [r0]                          
 90         add     r0, r2, r0                        
 91                                                   
 92         ldr     r1, [r0, #L2X0_R_PWR_CTRL]        
 93         ldr     r2, [r0, #L2X0_R_AUX_CTRL]        
 94         mov     r0, #SMC_CMD_L2X0SETUP2           
 95         smc     #0                                
 96                                                   
 97         mov     r0, #SMC_CMD_L2X0INVALL           
 98         smc     #0                                
 99                                                   
100         mov     r1, #1                            
101         mov     r0, #SMC_CMD_L2X0CTRL             
102         smc     #0                                
103 skip_l2x0:                                        
104 #endif /* CONFIG_CACHE_L2X0 */                    
105 skip_cp15:                                        
106         b       cpu_resume                        
107 ENDPROC(exynos_cpu_resume_ns)                     
108                                                   
109         .align                                    
110 _cp15_save_power:                                 
111         .long   cp15_save_power - .               
112 _cp15_save_diag:                                  
113         .long   cp15_save_diag - .                
114 #ifdef CONFIG_CACHE_L2X0                          
115 1:      .long   l2x0_saved_regs - .               
116 #endif /* CONFIG_CACHE_L2X0 */                    
117                                                   
118         .data                                     
119         .align  2                                 
120         .globl cp15_save_diag                     
121 cp15_save_diag:                                   
122         .long   0       @ cp15 diagnostic         
123         .globl cp15_save_power                    
124 cp15_save_power:                                  
125         .long   0       @ cp15 power control      
                                                      

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