Kevin Cernekee | d666cd0 | 2014-10-20 21:28:05 -0700 | [diff] [blame] | 1 | /* |
| 2 | * This program is free software; you can redistribute it and/or modify it |
| 3 | * under the terms of the GNU General Public License version 2 as published |
| 4 | * by the Free Software Foundation. |
| 5 | * |
Kevin Cernekee | e5a6fcc | 2014-12-25 09:49:15 -0800 | [diff] [blame] | 6 | * Copyright (C) 2014 Broadcom Corporation |
| 7 | * Author: Kevin Cernekee <cernekee@gmail.com> |
Kevin Cernekee | d666cd0 | 2014-10-20 21:28:05 -0700 | [diff] [blame] | 8 | */ |
| 9 | |
Kevin Cernekee | e5a6fcc | 2014-12-25 09:49:15 -0800 | [diff] [blame] | 10 | #include <linux/of.h> |
| 11 | #include <linux/irqchip.h> |
Kevin Cernekee | d666cd0 | 2014-10-20 21:28:05 -0700 | [diff] [blame] | 12 | |
| 13 | #include <asm/bmips.h> |
Kevin Cernekee | e5a6fcc | 2014-12-25 09:49:15 -0800 | [diff] [blame] | 14 | #include <asm/irq.h> |
Kevin Cernekee | d666cd0 | 2014-10-20 21:28:05 -0700 | [diff] [blame] | 15 | #include <asm/irq_cpu.h> |
Kevin Cernekee | e5a6fcc | 2014-12-25 09:49:15 -0800 | [diff] [blame] | 16 | #include <asm/time.h> |
Kevin Cernekee | d666cd0 | 2014-10-20 21:28:05 -0700 | [diff] [blame] | 17 | |
| 18 | unsigned int get_c0_compare_int(void) |
| 19 | { |
| 20 | return CP0_LEGACY_COMPARE_IRQ; |
| 21 | } |
| 22 | |
Kevin Cernekee | d666cd0 | 2014-10-20 21:28:05 -0700 | [diff] [blame] | 23 | void __init arch_init_irq(void) |
| 24 | { |
Kevin Cernekee | e5a6fcc | 2014-12-25 09:49:15 -0800 | [diff] [blame] | 25 | struct device_node *dn; |
| 26 | |
| 27 | /* Only the STB (bcm7038) controller supports SMP IRQ affinity */ |
| 28 | dn = of_find_compatible_node(NULL, NULL, "brcm,bcm7038-l1-intc"); |
| 29 | if (dn) |
| 30 | of_node_put(dn); |
| 31 | else |
| 32 | bmips_tp1_irqs = 0; |
| 33 | |
| 34 | irqchip_init(); |
Kevin Cernekee | d666cd0 | 2014-10-20 21:28:05 -0700 | [diff] [blame] | 35 | } |
Kevin Cernekee | e5a6fcc | 2014-12-25 09:49:15 -0800 | [diff] [blame] | 36 | |
Joel Porquet | 0a271c2 | 2015-07-07 17:17:33 -0400 | [diff] [blame] | 37 | IRQCHIP_DECLARE(mips_cpu_intc, "mti,cpu-interrupt-controller", |
Kevin Cernekee | e5a6fcc | 2014-12-25 09:49:15 -0800 | [diff] [blame] | 38 | mips_cpu_irq_of_init); |