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

TOMOYO Linux Cross Reference
Linux/arch/powerpc/kernel/head_32.h

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ 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.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /arch/powerpc/kernel/head_32.h (Architecture m68k) and /arch/alpha/kernel/head_32.h (Architecture alpha)


  1 /* SPDX-License-Identifier: GPL-2.0 */              1 
  2 #ifndef __HEAD_32_H__                             
  3 #define __HEAD_32_H__                             
  4                                                   
  5 #include <asm/ptrace.h> /* for STACK_FRAME_REG    
  6                                                   
  7 /*                                                
  8  * Exception entry code.  This code runs with     
  9  * turned off, i.e. using physical addresses.     
 10  * We assume sprg3 has the physical address of    
 11  * task's thread_struct.                          
 12  */                                               
 13 .macro EXCEPTION_PROLOG         trapno name ha    
 14         EXCEPTION_PROLOG_0      handle_dar_dsi    
 15         EXCEPTION_PROLOG_1                        
 16         EXCEPTION_PROLOG_2      \trapno \name     
 17 .endm                                             
 18                                                   
 19 .macro EXCEPTION_PROLOG_0 handle_dar_dsisr=0      
 20         mtspr   SPRN_SPRG_SCRATCH0,r10            
 21         mtspr   SPRN_SPRG_SCRATCH1,r11            
 22         mfspr   r10, SPRN_SPRG_THREAD             
 23         .if     \handle_dar_dsisr                 
 24         mfspr   r11, SPRN_DAR                     
 25         stw     r11, DAR(r10)                     
 26         mfspr   r11, SPRN_DSISR                   
 27         stw     r11, DSISR(r10)                   
 28         .endif                                    
 29         mfspr   r11, SPRN_SRR0                    
 30         stw     r11, SRR0(r10)                    
 31         mfspr   r11, SPRN_SRR1          /* che    
 32         stw     r11, SRR1(r10)                    
 33         mfcr    r10                               
 34         andi.   r11, r11, MSR_PR                  
 35 .endm                                             
 36                                                   
 37 .macro EXCEPTION_PROLOG_1                         
 38         mtspr   SPRN_SPRG_SCRATCH2,r1             
 39         subi    r1, r1, INT_FRAME_SIZE            
 40         beq     1f                                
 41         mfspr   r1,SPRN_SPRG_THREAD               
 42         lwz     r1,TASK_STACK-THREAD(r1)          
 43         addi    r1, r1, THREAD_SIZE - INT_FRAM    
 44 1:                                                
 45 #ifdef CONFIG_VMAP_STACK                          
 46         mtcrf   0x3f, r1                          
 47         bt      32 - THREAD_ALIGN_SHIFT, vmap_    
 48 #endif                                            
 49 .endm                                             
 50                                                   
 51 .macro EXCEPTION_PROLOG_2 trapno name handle_d    
 52 #ifdef CONFIG_PPC_8xx                             
 53         .if     \handle_dar_dsisr                 
 54         li      r11, RPN_PATTERN                  
 55         mtspr   SPRN_DAR, r11   /* Tag DAR, to    
 56         .endif                                    
 57 #endif                                            
 58         LOAD_REG_IMMEDIATE(r11, MSR_KERNEL & ~    
 59         mtspr   SPRN_SRR1, r11                    
 60         lis     r11, 1f@h                         
 61         ori     r11, r11, 1f@l                    
 62         mtspr   SPRN_SRR0, r11                    
 63         mfspr   r11, SPRN_SPRG_SCRATCH2           
 64         rfi                                       
 65                                                   
 66         .text                                     
 67 \name\()_virt:                                    
 68 1:                                                
 69         stw     r11,GPR1(r1)                      
 70         stw     r11,0(r1)                         
 71         mr      r11, r1                           
 72         stw     r10,_CCR(r11)           /* sav    
 73         stw     r12,GPR12(r11)                    
 74         stw     r9,GPR9(r11)                      
 75         mfspr   r10,SPRN_SPRG_SCRATCH0            
 76         mfspr   r12,SPRN_SPRG_SCRATCH1            
 77         stw     r10,GPR10(r11)                    
 78         stw     r12,GPR11(r11)                    
 79         mflr    r10                               
 80         stw     r10,_LINK(r11)                    
 81         mfspr   r12, SPRN_SPRG_THREAD             
 82         tovirt(r12, r12)                          
 83         .if     \handle_dar_dsisr                 
 84         lwz     r10, DAR(r12)                     
 85         stw     r10, _DAR(r11)                    
 86         lwz     r10, DSISR(r12)                   
 87         stw     r10, _DSISR(r11)                  
 88         .endif                                    
 89         lwz     r9, SRR1(r12)                     
 90         lwz     r12, SRR0(r12)                    
 91 #ifdef CONFIG_PPC_8xx                             
 92         mtspr   SPRN_EID, r2            /* Set    
 93 #else                                             
 94         li      r10, MSR_KERNEL         /* can    
 95         mtmsr   r10                     /* (ex    
 96 #endif                                            
 97         COMMON_EXCEPTION_PROLOG_END \trapno       
 98 _ASM_NOKPROBE_SYMBOL(\name\()_virt)               
 99 .endm                                             
100                                                   
101 .macro COMMON_EXCEPTION_PROLOG_END trapno         
102         stw     r0,GPR0(r1)                       
103         lis     r10,STACK_FRAME_REGS_MARKER@ha    
104         addi    r10,r10,STACK_FRAME_REGS_MARKE    
105         stw     r10,STACK_INT_FRAME_MARKER(r1)    
106         li      r10, \trapno                      
107         stw     r10,_TRAP(r1)                     
108         SAVE_GPRS(3, 8, r1)                       
109         SAVE_NVGPRS(r1)                           
110         stw     r2,GPR2(r1)                       
111         stw     r12,_NIP(r1)                      
112         stw     r9,_MSR(r1)                       
113         mfctr   r10                               
114         mfspr   r2,SPRN_SPRG_THREAD               
115         stw     r10,_CTR(r1)                      
116         tovirt(r2, r2)                            
117         mfspr   r10,SPRN_XER                      
118         addi    r2, r2, -THREAD                   
119         stw     r10,_XER(r1)                      
120         addi    r3,r1,STACK_INT_FRAME_REGS        
121 .endm                                             
122                                                   
123 .macro prepare_transfer_to_handler                
124 #ifdef CONFIG_PPC_BOOK3S_32                       
125         andi.   r12,r9,MSR_PR                     
126         bne     777f                              
127         bl      prepare_transfer_to_handler       
128 #ifdef CONFIG_PPC_KUEP                            
129         b       778f                              
130 777:                                              
131         bl      __kuep_lock                       
132 778:                                              
133 #endif                                            
134 777:                                              
135 #endif                                            
136 .endm                                             
137                                                   
138 .macro SYSCALL_ENTRY trapno                       
139         mfspr   r9, SPRN_SRR1                     
140         mfspr   r12, SPRN_SRR0                    
141         LOAD_REG_IMMEDIATE(r11, MSR_KERNEL)       
142         lis     r10, 1f@h                         
143         ori     r10, r10, 1f@l                    
144         mtspr   SPRN_SRR1, r11                    
145         mtspr   SPRN_SRR0, r10                    
146         mfspr   r10,SPRN_SPRG_THREAD              
147         mr      r11, r1                           
148         lwz     r1,TASK_STACK-THREAD(r10)         
149         tovirt(r10, r10)                          
150         addi    r1, r1, THREAD_SIZE - INT_FRAM    
151         rfi                                       
152 1:                                                
153         stw     r12,_NIP(r1)                      
154         mfcr    r12                               
155         rlwinm  r12,r12,0,4,2   /* Clear SO bi    
156         stw     r12,_CCR(r1)                      
157         b       transfer_to_syscall               
158 .endm                                             
159                                                   
160 /*                                                
161  * Note: code which follows this uses cr0.eq (    
162  * r11, r12 (SRR0), and r9 (SRR1).                
163  *                                                
164  * Note2: once we have set r1 we are in a posi    
165  * again, and we could thus set MSR:RI at that    
166  */                                               
167                                                   
168 /*                                                
169  * Exception vectors.                             
170  */                                               
171 #ifdef CONFIG_PPC_BOOK3S                          
172 #define START_EXCEPTION(n, label)                 
173         __HEAD;                                   
174         . = n;                                    
175         DO_KVM n;                                 
176 label:                                            
177                                                   
178 #else                                             
179 #define START_EXCEPTION(n, label)                 
180         __HEAD;                                   
181         . = n;                                    
182 label:                                            
183                                                   
184 #endif                                            
185                                                   
186 #define EXCEPTION(n, label, hdlr)                 
187         START_EXCEPTION(n, label)                 
188         EXCEPTION_PROLOG n label;                 
189         prepare_transfer_to_handler;              
190         bl      hdlr;                             
191         b       interrupt_return                  
192                                                   
193 .macro vmap_stack_overflow_exception              
194         __HEAD                                    
195 vmap_stack_overflow:                              
196 #ifdef CONFIG_SMP                                 
197         mfspr   r1, SPRN_SPRG_THREAD              
198         lwz     r1, TASK_CPU - THREAD(r1)         
199         slwi    r1, r1, 3                         
200         addis   r1, r1, emergency_ctx-PAGE_OFF    
201 #else                                             
202         lis     r1, emergency_ctx-PAGE_OFFSET@    
203 #endif                                            
204         lwz     r1, emergency_ctx-PAGE_OFFSET@    
205         addi    r1, r1, THREAD_SIZE - INT_FRAM    
206         EXCEPTION_PROLOG_2 0 vmap_stack_overfl    
207         prepare_transfer_to_handler               
208         bl      stack_overflow_exception          
209         b       interrupt_return                  
210 .endm                                             
211                                                   
212 #endif /* __HEAD_32_H__ */                        
213                                                   

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