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

TOMOYO Linux Cross Reference
Linux/arch/arm/mach-imx/suspend-imx53.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-imx/suspend-imx53.S (Version linux-6.12-rc7) and /arch/ppc/mach-imx/suspend-imx53.S (Version linux-5.4.285)


  1 /* SPDX-License-Identifier: GPL-2.0-or-later *    
  2 /*                                                
  3  * Copyright (C) 2008-2011 Freescale Semicondu    
  4  */                                               
  5 /*                                                
  6  */                                               
  7                                                   
  8 #include <linux/linkage.h>                        
  9                                                   
 10 #define M4IF_MCR0_OFFSET                          
 11 #define M4IF_MCR0_FDVFS                           
 12 #define M4IF_MCR0_FDVACK                          
 13                                                   
 14         .align 3                                  
 15                                                   
 16 /*                                                
 17  * ==================== low level suspend ====    
 18  *                                                
 19  * On entry                                       
 20  * r0: pm_info structure address;                 
 21  *                                                
 22  * suspend ocram space layout:                    
 23  * ======================== high address =====    
 24  *                              .                 
 25  *                              .                 
 26  *                              .                 
 27  *                              ^                 
 28  *                              ^                 
 29  *                              ^                 
 30  *                      imx53_suspend code        
 31  *              PM_INFO structure(imx5_cpu_sus    
 32  * ======================== low address ======    
 33  */                                               
 34                                                   
 35 /* Offsets of members of struct imx5_cpu_suspe    
 36 #define SUSPEND_INFO_MX53_M4IF_V_OFFSET           
 37 #define SUSPEND_INFO_MX53_IOMUXC_V_OFFSET         
 38 #define SUSPEND_INFO_MX53_IO_COUNT_OFFSET         
 39 #define SUSPEND_INFO_MX53_IO_STATE_OFFSET         
 40                                                   
 41 ENTRY(imx53_suspend)                              
 42         stmfd   sp!, {r4,r5,r6,r7}                
 43                                                   
 44         /* Save pad config */                     
 45         ldr     r1, [r0, #SUSPEND_INFO_MX53_IO    
 46         cmp     r1, #0                            
 47         beq     skip_pad_conf_1                   
 48                                                   
 49         add     r2, r0, #SUSPEND_INFO_MX53_IO_    
 50         ldr     r3, [r0, #SUSPEND_INFO_MX53_IO    
 51                                                   
 52 1:                                                
 53         ldr     r5, [r2], #12   /* IOMUXC regi    
 54         ldr     r6, [r3, r5]    /* current val    
 55         str     r6, [r2], #4    /* save area *    
 56         subs    r1, r1, #1                        
 57         bne     1b                                
 58                                                   
 59 skip_pad_conf_1:                                  
 60         /* Set FDVFS bit of M4IF_MCR0 to reque    
 61         ldr     r1, [r0, #SUSPEND_INFO_MX53_M4    
 62         ldr     r2,[r1, #M4IF_MCR0_OFFSET]        
 63         orr     r2, r2, #M4IF_MCR0_FDVFS          
 64         str     r2,[r1, #M4IF_MCR0_OFFSET]        
 65                                                   
 66         /* Poll FDVACK bit of M4IF_MCR to wait    
 67 wait_sr_ack:                                      
 68         ldr     r2,[r1, #M4IF_MCR0_OFFSET]        
 69         ands    r2, r2, #M4IF_MCR0_FDVACK         
 70         beq     wait_sr_ack                       
 71                                                   
 72         /* Set pad config */                      
 73         ldr     r1, [r0, #SUSPEND_INFO_MX53_IO    
 74         cmp     r1, #0                            
 75         beq     skip_pad_conf_2                   
 76                                                   
 77         add     r2, r0, #SUSPEND_INFO_MX53_IO_    
 78         ldr     r3, [r0, #SUSPEND_INFO_MX53_IO    
 79                                                   
 80 2:                                                
 81         ldr     r5, [r2], #4    /* IOMUXC regi    
 82         ldr     r6, [r2], #4    /* clear */       
 83         ldr     r7, [r3, r5]                      
 84         bic     r7, r7, r6                        
 85         ldr     r6, [r2], #8    /* set */         
 86         orr     r7, r7, r6                        
 87         str     r7, [r3, r5]                      
 88         subs    r1, r1, #1                        
 89         bne     2b                                
 90                                                   
 91 skip_pad_conf_2:                                  
 92         /* Zzz, enter stop mode */                
 93         wfi                                       
 94         nop                                       
 95         nop                                       
 96         nop                                       
 97         nop                                       
 98                                                   
 99         /* Restore pad config */                  
100         ldr     r1, [r0, #SUSPEND_INFO_MX53_IO    
101         cmp     r1, #0                            
102         beq     skip_pad_conf_3                   
103                                                   
104         add     r2, r0, #SUSPEND_INFO_MX53_IO_    
105         ldr     r3, [r0, #SUSPEND_INFO_MX53_IO    
106                                                   
107 3:                                                
108         ldr     r5, [r2], #12   /* IOMUXC regi    
109         ldr     r6, [r2], #4    /* saved value    
110         str     r6, [r3, r5]                      
111         subs    r1, r1, #1                        
112         bne     3b                                
113                                                   
114 skip_pad_conf_3:                                  
115         /* Clear FDVFS bit of M4IF_MCR0 to req    
116         ldr     r1, [r0, #SUSPEND_INFO_MX53_M4    
117         ldr     r2,[r1, #M4IF_MCR0_OFFSET]        
118         bic     r2, r2, #M4IF_MCR0_FDVFS          
119         str     r2,[r1, #M4IF_MCR0_OFFSET]        
120                                                   
121         /* Poll FDVACK bit of M4IF_MCR to wait    
122 wait_ar_ack:                                      
123         ldr     r2,[r1, #M4IF_MCR0_OFFSET]        
124         ands    r2, r2, #M4IF_MCR0_FDVACK         
125         bne     wait_ar_ack                       
126                                                   
127         /* Restore registers */                   
128         ldmfd   sp!, {r4,r5,r6,r7}                
129         mov     pc, lr                            
130                                                   
131 ENDPROC(imx53_suspend)                            
132                                                   
133 ENTRY(imx53_suspend_sz)                           
134         .word   . - imx53_suspend                 
                                                      

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