diff options
author | Steven J. Hill <sjhill@mips.com> | 2012-08-31 17:05:37 -0400 |
---|---|---|
committer | Steven J. Hill <sjhill@mips.com> | 2012-09-13 16:43:47 -0400 |
commit | 0b271f5600b5ae56d331a18da830e33f9fb0acdc (patch) | |
tree | d49f4e86e0563aa212545587adacb15170978082 /arch/mips/include | |
parent | ec47b27434eff8ad41e7389efca1e5a6ca8b519a (diff) |
MIPS: Make GIC code platform independent.
The GIC interrupt code is used by multiple platforms and the
current code was half Malta dependent code. These changes
abstract away the platform specific differences.
Signed-off-by: Steven J. Hill <sjhill@mips.com>
Diffstat (limited to 'arch/mips/include')
-rw-r--r-- | arch/mips/include/asm/gic.h | 29 | ||||
-rw-r--r-- | arch/mips/include/asm/mips-boards/maltaint.h | 55 |
2 files changed, 36 insertions, 48 deletions
diff --git a/arch/mips/include/asm/gic.h b/arch/mips/include/asm/gic.h index 991b659e2548..77207fa459a5 100644 --- a/arch/mips/include/asm/gic.h +++ b/arch/mips/include/asm/gic.h | |||
@@ -341,15 +341,44 @@ struct gic_shared_intr_map { | |||
341 | unsigned int local_intr_mask; | 341 | unsigned int local_intr_mask; |
342 | }; | 342 | }; |
343 | 343 | ||
344 | /* GIC nomenclature for Core Interrupt Pins. */ | ||
345 | #define GIC_CPU_INT0 0 /* Core Interrupt 2 */ | ||
346 | #define GIC_CPU_INT1 1 /* . */ | ||
347 | #define GIC_CPU_INT2 2 /* . */ | ||
348 | #define GIC_CPU_INT3 3 /* . */ | ||
349 | #define GIC_CPU_INT4 4 /* . */ | ||
350 | #define GIC_CPU_INT5 5 /* Core Interrupt 5 */ | ||
351 | |||
352 | /* Local GIC interrupts. */ | ||
353 | #define GIC_INT_TMR (GIC_CPU_INT5) | ||
354 | #define GIC_INT_PERFCTR (GIC_CPU_INT5) | ||
355 | |||
356 | /* Add 2 to convert non-EIC hardware interrupt to EIC vector number. */ | ||
357 | #define GIC_CPU_TO_VEC_OFFSET (2) | ||
358 | |||
359 | /* Mapped interrupt to pin X, then GIC will generate the vector (X+1). */ | ||
360 | #define GIC_PIN_TO_VEC_OFFSET (1) | ||
361 | |||
362 | extern unsigned long _gic_base; | ||
363 | extern unsigned int gic_irq_base; | ||
364 | extern unsigned int gic_irq_flags[]; | ||
365 | extern struct gic_shared_intr_map gic_shared_intr_map[]; | ||
366 | |||
344 | extern void gic_init(unsigned long gic_base_addr, | 367 | extern void gic_init(unsigned long gic_base_addr, |
345 | unsigned long gic_addrspace_size, struct gic_intr_map *intrmap, | 368 | unsigned long gic_addrspace_size, struct gic_intr_map *intrmap, |
346 | unsigned int intrmap_size, unsigned int irqbase); | 369 | unsigned int intrmap_size, unsigned int irqbase); |
347 | 370 | ||
371 | extern void gic_clocksource_init(unsigned int); | ||
348 | extern unsigned int gic_get_int(void); | 372 | extern unsigned int gic_get_int(void); |
349 | extern void gic_send_ipi(unsigned int intr); | 373 | extern void gic_send_ipi(unsigned int intr); |
350 | extern unsigned int plat_ipi_call_int_xlate(unsigned int); | 374 | extern unsigned int plat_ipi_call_int_xlate(unsigned int); |
351 | extern unsigned int plat_ipi_resched_int_xlate(unsigned int); | 375 | extern unsigned int plat_ipi_resched_int_xlate(unsigned int); |
352 | extern void gic_bind_eic_interrupt(int irq, int set); | 376 | extern void gic_bind_eic_interrupt(int irq, int set); |
353 | extern unsigned int gic_get_timer_pending(void); | 377 | extern unsigned int gic_get_timer_pending(void); |
378 | extern void gic_enable_interrupt(int irq_vec); | ||
379 | extern void gic_disable_interrupt(int irq_vec); | ||
380 | extern void gic_irq_ack(struct irq_data *d); | ||
381 | extern void gic_finish_irq(struct irq_data *d); | ||
382 | extern void gic_platform_init(int irqs, struct irq_chip *irq_controller); | ||
354 | 383 | ||
355 | #endif /* _ASM_GICREGS_H */ | 384 | #endif /* _ASM_GICREGS_H */ |
diff --git a/arch/mips/include/asm/mips-boards/maltaint.h b/arch/mips/include/asm/mips-boards/maltaint.h index 5447d9fc4219..669244815753 100644 --- a/arch/mips/include/asm/mips-boards/maltaint.h +++ b/arch/mips/include/asm/mips-boards/maltaint.h | |||
@@ -1,31 +1,16 @@ | |||
1 | /* | 1 | /* |
2 | * Carsten Langgaard, carstenl@mips.com | 2 | * This file is subject to the terms and conditions of the GNU General Public |
3 | * Copyright (C) 2000 MIPS Technologies, Inc. All rights reserved. | 3 | * License. See the file "COPYING" in the main directory of this archive |
4 | * | 4 | * for more details. |
5 | * ######################################################################## | ||
6 | * | ||
7 | * This program is free software; you can distribute it and/or modify it | ||
8 | * under the terms of the GNU General Public License (Version 2) as | ||
9 | * published by the Free Software Foundation. | ||
10 | * | ||
11 | * This program is distributed in the hope it will be useful, but WITHOUT | ||
12 | * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||
13 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | ||
14 | * for more details. | ||
15 | * | ||
16 | * You should have received a copy of the GNU General Public License along | ||
17 | * with this program; if not, write to the Free Software Foundation, Inc., | ||
18 | * 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. | ||
19 | * | ||
20 | * ######################################################################## | ||
21 | * | ||
22 | * Defines for the Malta interrupt controller. | ||
23 | * | 5 | * |
6 | * Copyright (C) 2000,2012 MIPS Technologies, Inc. All rights reserved. | ||
7 | * Carsten Langgaard <carstenl@mips.com> | ||
8 | * Steven J. Hill <sjhill@mips.com> | ||
24 | */ | 9 | */ |
25 | #ifndef _MIPS_MALTAINT_H | 10 | #ifndef _MIPS_MALTAINT_H |
26 | #define _MIPS_MALTAINT_H | 11 | #define _MIPS_MALTAINT_H |
27 | 12 | ||
28 | #include <irq.h> | 13 | #define MIPS_GIC_IRQ_BASE (MIPS_CPU_IRQ_BASE + 8) |
29 | 14 | ||
30 | /* | 15 | /* |
31 | * Interrupts 0..15 are used for Malta ISA compatible interrupts | 16 | * Interrupts 0..15 are used for Malta ISA compatible interrupts |
@@ -78,26 +63,6 @@ | |||
78 | #define MSC01E_INT_PERFCTR 10 | 63 | #define MSC01E_INT_PERFCTR 10 |
79 | #define MSC01E_INT_CPUCTR 11 | 64 | #define MSC01E_INT_CPUCTR 11 |
80 | 65 | ||
81 | /* GIC's Nomenclature for Core Interrupt Pins on the Malta */ | ||
82 | #define GIC_CPU_INT0 0 /* Core Interrupt 2 */ | ||
83 | #define GIC_CPU_INT1 1 /* . */ | ||
84 | #define GIC_CPU_INT2 2 /* . */ | ||
85 | #define GIC_CPU_INT3 3 /* . */ | ||
86 | #define GIC_CPU_INT4 4 /* . */ | ||
87 | #define GIC_CPU_INT5 5 /* Core Interrupt 5 */ | ||
88 | |||
89 | /* MALTA GIC local interrupts */ | ||
90 | #define GIC_INT_TMR (GIC_CPU_INT5) | ||
91 | #define GIC_INT_PERFCTR (GIC_CPU_INT5) | ||
92 | |||
93 | /* GIC constants */ | ||
94 | /* Add 2 to convert non-eic hw int # to eic vector # */ | ||
95 | #define GIC_CPU_TO_VEC_OFFSET (2) | ||
96 | /* If we map an intr to pin X, GIC will actually generate vector X+1 */ | ||
97 | #define GIC_PIN_TO_VEC_OFFSET (1) | ||
98 | |||
99 | #define GIC_EXT_INTR(x) x | ||
100 | |||
101 | /* External Interrupts used for IPI */ | 66 | /* External Interrupts used for IPI */ |
102 | #define GIC_IPI_EXT_INTR_RESCHED_VPE0 16 | 67 | #define GIC_IPI_EXT_INTR_RESCHED_VPE0 16 |
103 | #define GIC_IPI_EXT_INTR_CALLFNC_VPE0 17 | 68 | #define GIC_IPI_EXT_INTR_CALLFNC_VPE0 17 |
@@ -108,10 +73,4 @@ | |||
108 | #define GIC_IPI_EXT_INTR_RESCHED_VPE3 22 | 73 | #define GIC_IPI_EXT_INTR_RESCHED_VPE3 22 |
109 | #define GIC_IPI_EXT_INTR_CALLFNC_VPE3 23 | 74 | #define GIC_IPI_EXT_INTR_CALLFNC_VPE3 23 |
110 | 75 | ||
111 | #define MIPS_GIC_IRQ_BASE (MIPS_CPU_IRQ_BASE + 8) | ||
112 | |||
113 | #ifndef __ASSEMBLY__ | ||
114 | extern void maltaint_init(void); | ||
115 | #endif | ||
116 | |||
117 | #endif /* !(_MIPS_MALTAINT_H) */ | 76 | #endif /* !(_MIPS_MALTAINT_H) */ |