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

TOMOYO Linux Cross Reference
Linux/arch/mips/bcm47xx/irq.c

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/mips/bcm47xx/irq.c (Version linux-6.12-rc7) and /arch/ppc/bcm47xx/irq.c (Version linux-4.19.322)


** Warning: Cannot open xref database.

  1 /*                                                  1 
  2  *  Copyright (C) 2004 Florian Schirmer <jolt@    
  3  *                                                
  4  *  This program is free software; you can red    
  5  *  under  the terms of  the GNU General  Publ    
  6  *  Free Software Foundation;  either version     
  7  *  option) any later version.                    
  8  *                                                
  9  *  THIS  SOFTWARE  IS PROVIDED   ``AS  IS'' A    
 10  *  WARRANTIES,   INCLUDING, BUT NOT  LIMITED     
 11  *  MERCHANTABILITY AND FITNESS FOR A PARTICUL    
 12  *  NO  EVENT  SHALL   THE AUTHOR  BE    LIABL    
 13  *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQU    
 14  *  NOT LIMITED   TO, PROCUREMENT OF  SUBSTITU    
 15  *  USE, DATA,  OR PROFITS; OR  BUSINESS INTER    
 16  *  ANY THEORY OF LIABILITY, WHETHER IN  CONTR    
 17  *  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISIN    
 18  *  THIS SOFTWARE, EVEN IF ADVISED OF THE POSS    
 19  *                                                
 20  *  You should have received a copy of the  GN    
 21  *  with this program; if not, write  to the F    
 22  *  675 Mass Ave, Cambridge, MA 02139, USA.       
 23  */                                               
 24                                                   
 25 #include "bcm47xx_private.h"                      
 26                                                   
 27 #include <linux/types.h>                          
 28 #include <linux/interrupt.h>                      
 29 #include <linux/irq.h>                            
 30 #include <asm/setup.h>                            
 31 #include <asm/irq_cpu.h>                          
 32 #include <bcm47xx.h>                              
 33                                                   
 34 asmlinkage void plat_irq_dispatch(void)           
 35 {                                                 
 36         u32 cause;                                
 37                                                   
 38         cause = read_c0_cause() & read_c0_stat    
 39                                                   
 40         clear_c0_status(cause);                   
 41                                                   
 42         if (cause & CAUSEF_IP7)                   
 43                 do_IRQ(7);                        
 44         if (cause & CAUSEF_IP2)                   
 45                 do_IRQ(2);                        
 46         if (cause & CAUSEF_IP3)                   
 47                 do_IRQ(3);                        
 48         if (cause & CAUSEF_IP4)                   
 49                 do_IRQ(4);                        
 50         if (cause & CAUSEF_IP5)                   
 51                 do_IRQ(5);                        
 52         if (cause & CAUSEF_IP6)                   
 53                 do_IRQ(6);                        
 54 }                                                 
 55                                                   
 56 #define DEFINE_HWx_IRQDISPATCH(x)                 
 57         static void bcm47xx_hw ## x ## _irqdis    
 58         {                                         
 59                 do_IRQ(x);                        
 60         }                                         
 61 DEFINE_HWx_IRQDISPATCH(2)                         
 62 DEFINE_HWx_IRQDISPATCH(3)                         
 63 DEFINE_HWx_IRQDISPATCH(4)                         
 64 DEFINE_HWx_IRQDISPATCH(5)                         
 65 DEFINE_HWx_IRQDISPATCH(6)                         
 66 DEFINE_HWx_IRQDISPATCH(7)                         
 67                                                   
 68 void __init arch_init_irq(void)                   
 69 {                                                 
 70         /*                                        
 71          * This is the first arch callback aft    
 72          * so let's finish bus initialization     
 73          */                                       
 74         bcm47xx_bus_setup();                      
 75                                                   
 76 #ifdef CONFIG_BCM47XX_BCMA                        
 77         if (bcm47xx_bus_type == BCM47XX_BUS_TY    
 78                 bcma_write32(bcm47xx_bus.bcma.    
 79                              BCMA_MIPS_MIPS74K    
 80                 /*                                
 81                  * the kernel reads the timer     
 82                  * it's #5, but we offset it b    
 83                  */                               
 84                 cp0_compare_irq = 7;              
 85         }                                         
 86 #endif                                            
 87         mips_cpu_irq_init();                      
 88                                                   
 89         if (cpu_has_vint) {                       
 90                 pr_info("Setting up vectored i    
 91                 set_vi_handler(2, bcm47xx_hw2_    
 92                 set_vi_handler(3, bcm47xx_hw3_    
 93                 set_vi_handler(4, bcm47xx_hw4_    
 94                 set_vi_handler(5, bcm47xx_hw5_    
 95                 set_vi_handler(6, bcm47xx_hw6_    
 96                 set_vi_handler(7, bcm47xx_hw7_    
 97         }                                         
 98 }                                                 
 99                                                   

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