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

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

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

  1 /*
  2  *  Copyright (C) 2004 Florian Schirmer <jolt@tuxbox.org>
  3  *
  4  *  This program is free software; you can redistribute  it and/or modify it
  5  *  under  the terms of  the GNU General  Public License as published by the
  6  *  Free Software Foundation;  either version 2 of the  License, or (at your
  7  *  option) any later version.
  8  *
  9  *  THIS  SOFTWARE  IS PROVIDED   ``AS  IS'' AND   ANY  EXPRESS OR IMPLIED
 10  *  WARRANTIES,   INCLUDING, BUT NOT  LIMITED  TO, THE IMPLIED WARRANTIES OF
 11  *  MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN
 12  *  NO  EVENT  SHALL   THE AUTHOR  BE    LIABLE FOR ANY   DIRECT, INDIRECT,
 13  *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
 14  *  NOT LIMITED   TO, PROCUREMENT OF  SUBSTITUTE GOODS  OR SERVICES; LOSS OF
 15  *  USE, DATA,  OR PROFITS; OR  BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
 16  *  ANY THEORY OF LIABILITY, WHETHER IN  CONTRACT, STRICT LIABILITY, OR TORT
 17  *  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
 18  *  THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 19  *
 20  *  You should have received a copy of the  GNU General Public License along
 21  *  with this program; if not, write  to the Free Software Foundation, Inc.,
 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_status() & CAUSEF_IP;
 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 ## _irqdispatch(void)               \
 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 after mm_init (we can use kmalloc),
 72          * so let's finish bus initialization now.
 73          */
 74         bcm47xx_bus_setup();
 75 
 76 #ifdef CONFIG_BCM47XX_BCMA
 77         if (bcm47xx_bus_type == BCM47XX_BUS_TYPE_BCMA) {
 78                 bcma_write32(bcm47xx_bus.bcma.bus.drv_mips.core,
 79                              BCMA_MIPS_MIPS74K_INTMASK(5), 1 << 31);
 80                 /*
 81                  * the kernel reads the timer irq from some register and thinks
 82                  * it's #5, but we offset it by 2 and route to #7
 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 interrupts\n");
 91                 set_vi_handler(2, bcm47xx_hw2_irqdispatch);
 92                 set_vi_handler(3, bcm47xx_hw3_irqdispatch);
 93                 set_vi_handler(4, bcm47xx_hw4_irqdispatch);
 94                 set_vi_handler(5, bcm47xx_hw5_irqdispatch);
 95                 set_vi_handler(6, bcm47xx_hw6_irqdispatch);
 96                 set_vi_handler(7, bcm47xx_hw7_irqdispatch);
 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