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

TOMOYO Linux Cross Reference
Linux/arch/s390/kernel/text_amode31.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/s390/kernel/text_amode31.S (Architecture sparc) and /arch/i386/kernel/text_amode31.S (Architecture i386)


  1 /* SPDX-License-Identifier: GPL-2.0 */            
  2 /*                                                
  3  * Code that needs to run below 2 GB.             
  4  *                                                
  5  * Copyright IBM Corp. 2019                       
  6  */                                               
  7                                                   
  8 #include <linux/linkage.h>                        
  9 #include <asm/asm-extable.h>                      
 10 #include <asm/errno.h>                            
 11 #include <asm/sigp.h>                             
 12                                                   
 13         .section .amode31.text,"ax"               
 14 /*                                                
 15  * Simplified version of expoline thunk. The n    
 16  * because they might be more than 2 GB away,     
 17  * branch. No comdat, exrl, etc. optimizations    
 18  * affects a few functions that are not perfor    
 19  */                                               
 20         .macro BR_EX_AMODE31_r14                  
 21         larl    %r1,0f                            
 22         ex      0,0(%r1)                          
 23         j       .                                 
 24 0:      br      %r14                              
 25         .endm                                     
 26                                                   
 27 /*                                                
 28  * int _diag14_amode31(unsigned long rx, unsig    
 29  */                                               
 30 SYM_FUNC_START(_diag14_amode31)                   
 31         lgr     %r1,%r2                           
 32         lgr     %r2,%r3                           
 33         lgr     %r3,%r4                           
 34         lhi     %r5,-EIO                          
 35         sam31                                     
 36         diag    %r1,%r2,0x14                      
 37 .Ldiag14_ex:                                      
 38         ipm     %r5                               
 39         srl     %r5,28                            
 40 .Ldiag14_fault:                                   
 41         sam64                                     
 42         lgfr    %r2,%r5                           
 43         BR_EX_AMODE31_r14                         
 44         EX_TABLE_AMODE31(.Ldiag14_ex, .Ldiag14    
 45 SYM_FUNC_END(_diag14_amode31)                     
 46                                                   
 47 /*                                                
 48  * int _diag210_amode31(struct diag210 *addr)     
 49  */                                               
 50 SYM_FUNC_START(_diag210_amode31)                  
 51         lgr     %r1,%r2                           
 52         lhi     %r2,-1                            
 53         sam31                                     
 54         diag    %r1,%r0,0x210                     
 55 .Ldiag210_ex:                                     
 56         ipm     %r2                               
 57         srl     %r2,28                            
 58 .Ldiag210_fault:                                  
 59         sam64                                     
 60         lgfr    %r2,%r2                           
 61         BR_EX_AMODE31_r14                         
 62         EX_TABLE_AMODE31(.Ldiag210_ex, .Ldiag2    
 63 SYM_FUNC_END(_diag210_amode31)                    
 64                                                   
 65 /*                                                
 66  * int diag8c(struct diag8c *addr, struct ccw_    
 67 */                                                
 68 SYM_FUNC_START(_diag8c_amode31)                   
 69         llgf    %r3,0(%r3)                        
 70         sam31                                     
 71         diag    %r2,%r4,0x8c                      
 72 .Ldiag8c_ex:                                      
 73         sam64                                     
 74         lgfr    %r2,%r3                           
 75         BR_EX_AMODE31_r14                         
 76         EX_TABLE_AMODE31(.Ldiag8c_ex, .Ldiag8c    
 77 SYM_FUNC_END(_diag8c_amode31)                     
 78 /*                                                
 79  * int _diag26c_amode31(void *req, void *resp,    
 80  */                                               
 81 SYM_FUNC_START(_diag26c_amode31)                  
 82         lghi    %r5,-EOPNOTSUPP                   
 83         sam31                                     
 84         diag    %r2,%r4,0x26c                     
 85 .Ldiag26c_ex:                                     
 86         sam64                                     
 87         lgfr    %r2,%r5                           
 88         BR_EX_AMODE31_r14                         
 89         EX_TABLE_AMODE31(.Ldiag26c_ex, .Ldiag2    
 90 SYM_FUNC_END(_diag26c_amode31)                    
 91                                                   
 92 /*                                                
 93  * void _diag0c_amode31(unsigned long rx)         
 94  */                                               
 95 SYM_FUNC_START(_diag0c_amode31)                   
 96         sam31                                     
 97         diag    %r2,%r2,0x0c                      
 98         sam64                                     
 99         BR_EX_AMODE31_r14                         
100 SYM_FUNC_END(_diag0c_amode31)                     
101                                                   
102 /*                                                
103  * void _diag308_reset_amode31(void)              
104  *                                                
105  * Calls diag 308 subcode 1 and continues exec    
106  */                                               
107 SYM_FUNC_START(_diag308_reset_amode31)            
108         larl    %r4,ctlregs             # Save    
109         stctg   %c0,%c15,0(%r4)                   
110         lg      %r2,0(%r4)              # Disa    
111         nilh    %r2,0xefff                        
112         larl    %r4,ctlreg0                       
113         stg     %r2,0(%r4)                        
114         lctlg   %c0,%c0,0(%r4)                    
115         larl    %r4,fpctl               # Floa    
116         stfpc   0(%r4)                            
117         larl    %r4,prefix              # Save    
118         stpx    0(%r4)                            
119         larl    %r4,prefix_zero # Set prefix r    
120         spx     0(%r4)                            
121         larl    %r4,continue_psw        # Save    
122         epsw    %r2,%r3                           
123         stm     %r2,%r3,0(%r4)                    
124         larl    %r4,.Lrestart_part2     # Setu    
125         larl    %r3,restart_diag308_psw           
126         og      %r4,0(%r3)              # Save    
127         lghi    %r3,0                             
128         sturg   %r4,%r3                 # Use     
129         lghi    %r1,1                             
130         lghi    %r0,0                             
131         diag    %r0,%r1,0x308                     
132 .Lrestart_part2:                                  
133         lhi     %r0,0                   # Load    
134         lhi     %r1,2                   # Use     
135         sigp    %r1,%r0,SIGP_SET_ARCHITECTURE     
136         sam64                           # Swit    
137         larl    %r4,ctlregs             # Rest    
138         lctlg   %c0,%c15,0(%r4)                   
139         larl    %r4,fpctl               # Rest    
140         lfpc    0(%r4)                            
141         larl    %r4,prefix              # Rest    
142         spx     0(%r4)                            
143         larl    %r4,continue_psw        # Rest    
144         larl    %r2,.Lcontinue                    
145         stg     %r2,8(%r4)                        
146         lpswe   0(%r4)                            
147 .Lcontinue:                                       
148         BR_EX_AMODE31_r14                         
149 SYM_FUNC_END(_diag308_reset_amode31)              
150                                                   
151         .section .amode31.data,"aw",@progbits     
152         .balign 8                                 
153 SYM_DATA_LOCAL(restart_diag308_psw,     .long     
154 SYM_DATA_LOCAL(continue_psw,            .quad     
155 SYM_DATA_LOCAL(ctlreg0,                 .quad     
156 SYM_DATA_LOCAL(ctlregs,                 .fill     
157 SYM_DATA_LOCAL(fpctl,                   .long     
158 SYM_DATA_LOCAL(prefix,                  .long     
159 SYM_DATA_LOCAL(prefix_zero,             .long     
                                                      

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