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

TOMOYO Linux Cross Reference
Linux/arch/m68k/68000/entry.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/m68k/68000/entry.S (Version linux-6.12-rc7) and /arch/sparc64/68000/entry.S (Version linux-5.11.22)


  1 /* SPDX-License-Identifier: GPL-2.0-or-later      
  2  *                                                
  3  *  entry.S -- non-mmu 68000 interrupt and exc    
  4  *                                                
  5  *  Copyright (C) 1991, 1992  Linus Torvalds      
  6  *                                                
  7  * Linux/m68k support by Hamish Macdonald         
  8  */                                               
  9                                                   
 10 #include <linux/linkage.h>                        
 11 #include <asm/thread_info.h>                      
 12 #include <asm/unistd.h>                           
 13 #include <asm/errno.h>                            
 14 #include <asm/setup.h>                            
 15 #include <asm/traps.h>                            
 16 #include <asm/asm-offsets.h>                      
 17 #include <asm/entry.h>                            
 18                                                   
 19 .text                                             
 20                                                   
 21 .globl system_call                                
 22 .globl resume                                     
 23 .globl ret_from_exception                         
 24 .globl sys_call_table                             
 25 .globl bad_interrupt                              
 26 .globl inthandler1                                
 27 .globl inthandler2                                
 28 .globl inthandler3                                
 29 .globl inthandler4                                
 30 .globl inthandler5                                
 31 .globl inthandler6                                
 32 .globl inthandler7                                
 33                                                   
 34 badsys:                                           
 35         movel   #-ENOSYS,%sp@(PT_OFF_D0)          
 36         jra     ret_from_exception                
 37                                                   
 38 do_trace:                                         
 39         movel   #-ENOSYS,%sp@(PT_OFF_D0) /* ne    
 40         subql   #4,%sp                            
 41         SAVE_SWITCH_STACK                         
 42         jbsr    syscall_trace_enter               
 43         RESTORE_SWITCH_STACK                      
 44         addql   #4,%sp                            
 45         addql   #1,%d0                            
 46         jeq     ret_from_exception                
 47         movel   %sp@(PT_OFF_ORIG_D0),%d1          
 48         movel   #-ENOSYS,%d0                      
 49         cmpl    #NR_syscalls,%d1                  
 50         jcc     1f                                
 51         lsl     #2,%d1                            
 52         lea     sys_call_table, %a0               
 53         jbsr    %a0@(%d1)                         
 54                                                   
 55 1:      movel   %d0,%sp@(PT_OFF_D0)     /* sav    
 56         subql   #4,%sp                  /* dum    
 57         SAVE_SWITCH_STACK                         
 58         jbsr    syscall_trace_leave               
 59         RESTORE_SWITCH_STACK                      
 60         addql   #4,%sp                            
 61         jra     ret_from_exception                
 62                                                   
 63 ENTRY(system_call)                                
 64         SAVE_ALL_SYS                              
 65                                                   
 66         /* save top of frame*/                    
 67         pea     %sp@                              
 68         jbsr    set_esp0                          
 69         addql   #4,%sp                            
 70                                                   
 71         movel   %sp@(PT_OFF_ORIG_D0),%d0          
 72                                                   
 73         movel   %sp,%d1                 /* get    
 74         andl    #-THREAD_SIZE,%d1                 
 75         movel   %d1,%a2                           
 76         btst    #(TIF_SYSCALL_TRACE%8),%a2@(TI    
 77         jne     do_trace                          
 78         cmpl    #NR_syscalls,%d0                  
 79         jcc     badsys                            
 80         lsl     #2,%d0                            
 81         lea     sys_call_table,%a0                
 82         movel   %a0@(%d0), %a0                    
 83         jbsr    %a0@                              
 84         movel   %d0,%sp@(PT_OFF_D0)     /* sav    
 85                                                   
 86 ret_from_exception:                               
 87         btst    #5,%sp@(PT_OFF_SR)      /* che    
 88         jeq     Luser_return            /* if     
 89                                                   
 90 Lkernel_return:                                   
 91         RESTORE_ALL                               
 92                                                   
 93 Luser_return:                                     
 94         /* only allow interrupts when we are r    
 95         /* kernel stack, otherwise stack overf    
 96         /* heavy interrupt load*/                 
 97         andw    #ALLOWINT,%sr                     
 98                                                   
 99         movel   %sp,%d1                 /* get    
100         andl    #-THREAD_SIZE,%d1                 
101         movel   %d1,%a2                           
102 1:                                                
103         move    %a2@(TINFO_FLAGS),%d1   /* thr    
104         jne     Lwork_to_do                       
105         RESTORE_ALL                               
106                                                   
107 Lwork_to_do:                                      
108         movel   %a2@(TINFO_FLAGS),%d1   /* thr    
109         btst    #TIF_NEED_RESCHED,%d1             
110         jne     reschedule                        
111                                                   
112 Lsignal_return:                                   
113         subql   #4,%sp                  /* dum    
114         SAVE_SWITCH_STACK                         
115         pea     %sp@(SWITCH_STACK_SIZE)           
116         bsrw    do_notify_resume                  
117         addql   #4,%sp                            
118         RESTORE_SWITCH_STACK                      
119         addql   #4,%sp                            
120         jra     1b                                
121                                                   
122 /*                                                
123  * This is the main interrupt handler, respons    
124  */                                               
125 inthandler1:                                      
126         SAVE_ALL_INT                              
127         movew   %sp@(PT_OFF_FORMATVEC), %d0       
128         and     #0x3ff, %d0                       
129                                                   
130         movel   %sp,%sp@-                         
131         movel   #65,%sp@-               /*  pu    
132         jbsr    process_int             /*  pr    
133 3:      addql   #8,%sp                  /*  po    
134         bra     ret_from_exception                
135                                                   
136 inthandler2:                                      
137         SAVE_ALL_INT                              
138         movew   %sp@(PT_OFF_FORMATVEC), %d0       
139         and     #0x3ff, %d0                       
140                                                   
141         movel   %sp,%sp@-                         
142         movel   #66,%sp@-               /*  pu    
143         jbsr    process_int             /*  pr    
144 3:      addql   #8,%sp                  /*  po    
145         bra     ret_from_exception                
146                                                   
147 inthandler3:                                      
148         SAVE_ALL_INT                              
149         movew   %sp@(PT_OFF_FORMATVEC), %d0       
150         and     #0x3ff, %d0                       
151                                                   
152         movel   %sp,%sp@-                         
153         movel   #67,%sp@-               /*  pu    
154         jbsr    process_int             /*  pr    
155 3:      addql   #8,%sp                  /*  po    
156         bra     ret_from_exception                
157                                                   
158 inthandler4:                                      
159         SAVE_ALL_INT                              
160         movew   %sp@(PT_OFF_FORMATVEC), %d0       
161         and     #0x3ff, %d0                       
162                                                   
163         movel   %sp,%sp@-                         
164         movel   #68,%sp@-               /*  pu    
165         jbsr    process_int             /*  pr    
166 3:      addql   #8,%sp                  /*  po    
167         bra     ret_from_exception                
168                                                   
169 inthandler5:                                      
170         SAVE_ALL_INT                              
171         movew   %sp@(PT_OFF_FORMATVEC), %d0       
172         and     #0x3ff, %d0                       
173                                                   
174         movel   %sp,%sp@-                         
175         movel   #69,%sp@-               /*  pu    
176         jbsr    process_int             /*  pr    
177 3:      addql   #8,%sp                  /*  po    
178         bra     ret_from_exception                
179                                                   
180 inthandler6:                                      
181         SAVE_ALL_INT                              
182         movew   %sp@(PT_OFF_FORMATVEC), %d0       
183         and     #0x3ff, %d0                       
184                                                   
185         movel   %sp,%sp@-                         
186         movel   #70,%sp@-               /*  pu    
187         jbsr    process_int             /*  pr    
188 3:      addql   #8,%sp                  /*  po    
189         bra     ret_from_exception                
190                                                   
191 inthandler7:                                      
192         SAVE_ALL_INT                              
193         movew   %sp@(PT_OFF_FORMATVEC), %d0       
194         and     #0x3ff, %d0                       
195                                                   
196         movel   %sp,%sp@-                         
197         movel   #71,%sp@-               /*  pu    
198         jbsr    process_int             /*  pr    
199 3:      addql   #8,%sp                  /*  po    
200         bra     ret_from_exception                
201                                                   
202 inthandler:                                       
203         SAVE_ALL_INT                              
204         movew   %sp@(PT_OFF_FORMATVEC), %d0       
205         and     #0x3ff, %d0                       
206                                                   
207         movel   %sp,%sp@-                         
208         movel   %d0,%sp@-               /*  pu    
209         jbsr    process_int             /*  pr    
210 3:      addql   #8,%sp                  /*  po    
211         bra     ret_from_exception                
212                                                   
213 /*                                                
214  * Handler for uninitialized and spurious inte    
215  */                                               
216 ENTRY(bad_interrupt)                              
217         addql   #1,irq_err_count                  
218         rte                                       
219                                                   
220 /*                                                
221  * Beware - when entering resume, prev (the cu    
222  * in a0, next (the new task) is in a1, so don    
223  * registers until their contents are no longe    
224  */                                               
225 ENTRY(resume)                                     
226         movel   %a0,%d1                           
227         movew   %sr,%a0@(TASK_THREAD+THREAD_SR    
228         SAVE_SWITCH_STACK                         
229         movel   %sp,%a0@(TASK_THREAD+THREAD_KS    
230         movel   %usp,%a3                          
231         movel   %a3,%a0@(TASK_THREAD+THREAD_US    
232                                                   
233         movel   %a1@(TASK_THREAD+THREAD_USP),%    
234         movel   %a3,%usp                          
235         movel   %a1@(TASK_THREAD+THREAD_KSP),%    
236         RESTORE_SWITCH_STACK                      
237         movew   %a1@(TASK_THREAD+THREAD_SR),%s    
238         rts                                       
239                                                   
                                                      

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