提交 ff2e27ae 编写于 作者: R Russell King

ARM: GIC: consolidate gic_cpu_base_addr to common GIC code

Every architecture using the GIC has a gic_cpu_base_addr pointer for
GIC 0 for their entry assembly code to use to decode the cause of the
current interrupt.  Move this into the common GIC code.
Reviewed-by: NCatalin Marinas <catalin.marinas@arm.com>
Tested-by: NAbhijeet Dharmapurikar <adharmap@codeaurora.org>
Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
上级 38489533
...@@ -35,6 +35,9 @@ ...@@ -35,6 +35,9 @@
static DEFINE_SPINLOCK(irq_controller_lock); static DEFINE_SPINLOCK(irq_controller_lock);
/* Address of GIC 0 CPU interface */
void __iomem *gic_cpu_base_addr;
struct gic_chip_data { struct gic_chip_data {
unsigned int irq_offset; unsigned int irq_offset;
void __iomem *dist_base; void __iomem *dist_base;
...@@ -317,6 +320,8 @@ static void __cpuinit gic_cpu_init(unsigned int gic_nr, void __iomem *base) ...@@ -317,6 +320,8 @@ static void __cpuinit gic_cpu_init(unsigned int gic_nr, void __iomem *base)
void __init gic_init(unsigned int gic_nr, unsigned int irq_start, void __init gic_init(unsigned int gic_nr, unsigned int irq_start,
void __iomem *dist_base, void __iomem *cpu_base) void __iomem *dist_base, void __iomem *cpu_base)
{ {
if (gic_nr == 0)
gic_cpu_base_addr = cpu_base;
gic_dist_init(gic_nr, dist_base, irq_start); gic_dist_init(gic_nr, dist_base, irq_start);
gic_cpu_init(gic_nr, cpu_base); gic_cpu_init(gic_nr, cpu_base);
} }
......
...@@ -33,6 +33,8 @@ ...@@ -33,6 +33,8 @@
#define GIC_DIST_SOFTINT 0xf00 #define GIC_DIST_SOFTINT 0xf00
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
extern void __iomem *gic_cpu_base_addr;
void gic_init(unsigned int, unsigned int, void __iomem *, void __iomem *); void gic_init(unsigned int, unsigned int, void __iomem *, void __iomem *);
void gic_secondary_init(unsigned int); void gic_secondary_init(unsigned int);
void gic_cascade_irq(unsigned int gic_nr, unsigned int irq); void gic_cascade_irq(unsigned int gic_nr, unsigned int irq);
......
...@@ -69,13 +69,10 @@ void __init cns3xxx_map_io(void) ...@@ -69,13 +69,10 @@ void __init cns3xxx_map_io(void)
} }
/* used by entry-macro.S */ /* used by entry-macro.S */
void __iomem *gic_cpu_base_addr;
void __init cns3xxx_init_irq(void) void __init cns3xxx_init_irq(void)
{ {
gic_cpu_base_addr = __io(CNS3XXX_TC11MP_GIC_CPU_BASE_VIRT);
gic_init(0, 29, __io(CNS3XXX_TC11MP_GIC_DIST_BASE_VIRT), gic_init(0, 29, __io(CNS3XXX_TC11MP_GIC_DIST_BASE_VIRT),
gic_cpu_base_addr); __io(CNS3XXX_TC11MP_GIC_CPU_BASE_VIRT));
} }
void cns3xxx_power_off(void) void cns3xxx_power_off(void)
......
...@@ -11,7 +11,6 @@ ...@@ -11,7 +11,6 @@
#ifndef __CNS3XXX_CORE_H #ifndef __CNS3XXX_CORE_H
#define __CNS3XXX_CORE_H #define __CNS3XXX_CORE_H
extern void __iomem *gic_cpu_base_addr;
extern struct sys_timer cns3xxx_timer; extern struct sys_timer cns3xxx_timer;
void __init cns3xxx_map_io(void); void __init cns3xxx_map_io(void);
......
...@@ -28,8 +28,6 @@ ...@@ -28,8 +28,6 @@
#include <mach/board.h> #include <mach/board.h>
#include <mach/msm_iomap.h> #include <mach/msm_iomap.h>
void __iomem *gic_cpu_base_addr;
unsigned long clk_get_max_axi_khz(void) unsigned long clk_get_max_axi_khz(void)
{ {
return 0; return 0;
...@@ -44,8 +42,8 @@ static void __init msm8x60_init_irq(void) ...@@ -44,8 +42,8 @@ static void __init msm8x60_init_irq(void)
{ {
unsigned int i; unsigned int i;
gic_cpu_base_addr = (void *)MSM_QGIC_CPU_BASE; gic_init(0, GIC_PPI_START, MSM_QGIC_DIST_BASE,
gic_init(0, GIC_PPI_START, MSM_QGIC_DIST_BASE, gic_cpu_base_addr); (void *)MSM_QGIC_CPU_BASE);
/* Edge trigger PPIs except AVS_SVICINT and AVS_SVICINTSWDONE */ /* Edge trigger PPIs except AVS_SVICINT and AVS_SVICINTSWDONE */
writel(0xFFFFD7FF, MSM_QGIC_DIST_BASE + GIC_DIST_CONFIG + 4); writel(0xFFFFD7FF, MSM_QGIC_DIST_BASE + GIC_DIST_CONFIG + 4);
......
...@@ -24,7 +24,6 @@ ...@@ -24,7 +24,6 @@
extern void __iomem *l2cache_base; extern void __iomem *l2cache_base;
#endif #endif
extern void __iomem *gic_cpu_base_addr;
extern void __iomem *gic_dist_base_addr; extern void __iomem *gic_dist_base_addr;
extern void __init gic_init_irq(void); extern void __init gic_init_irq(void);
......
...@@ -26,21 +26,22 @@ ...@@ -26,21 +26,22 @@
void __iomem *l2cache_base; void __iomem *l2cache_base;
#endif #endif
void __iomem *gic_cpu_base_addr;
void __iomem *gic_dist_base_addr; void __iomem *gic_dist_base_addr;
void __init gic_init_irq(void) void __init gic_init_irq(void)
{ {
void __iomem *gic_cpu_base;
/* Static mapping, never released */ /* Static mapping, never released */
gic_dist_base_addr = ioremap(OMAP44XX_GIC_DIST_BASE, SZ_4K); gic_dist_base_addr = ioremap(OMAP44XX_GIC_DIST_BASE, SZ_4K);
BUG_ON(!gic_dist_base_addr); BUG_ON(!gic_dist_base_addr);
/* Static mapping, never released */ /* Static mapping, never released */
gic_cpu_base_addr = ioremap(OMAP44XX_GIC_CPU_BASE, SZ_512); gic_cpu_base = ioremap(OMAP44XX_GIC_CPU_BASE, SZ_512);
BUG_ON(!gic_cpu_base_addr); BUG_ON(!gic_cpu_base);
gic_init(0, 29, gic_dist_base_addr, gic_cpu_base_addr); gic_init(0, 29, gic_dist_base_addr, gic_cpu_base);
} }
#ifdef CONFIG_CACHE_L2X0 #ifdef CONFIG_CACHE_L2X0
......
...@@ -54,9 +54,6 @@ ...@@ -54,9 +54,6 @@
#include "core.h" #include "core.h"
/* used by entry-macro.S and platsmp.c */
void __iomem *gic_cpu_base_addr;
#ifdef CONFIG_ZONE_DMA #ifdef CONFIG_ZONE_DMA
/* /*
* Adjust the zones if there are restrictions for DMA access. * Adjust the zones if there are restrictions for DMA access.
......
...@@ -53,7 +53,6 @@ extern struct platform_device realview_i2c_device; ...@@ -53,7 +53,6 @@ extern struct platform_device realview_i2c_device;
extern struct mmci_platform_data realview_mmc0_plat_data; extern struct mmci_platform_data realview_mmc0_plat_data;
extern struct mmci_platform_data realview_mmc1_plat_data; extern struct mmci_platform_data realview_mmc1_plat_data;
extern struct clcd_board clcd_plat_data; extern struct clcd_board clcd_plat_data;
extern void __iomem *gic_cpu_base_addr;
extern void __iomem *timer0_va_base; extern void __iomem *timer0_va_base;
extern void __iomem *timer1_va_base; extern void __iomem *timer1_va_base;
extern void __iomem *timer2_va_base; extern void __iomem *timer2_va_base;
......
...@@ -364,9 +364,8 @@ static void __init gic_init_irq(void) ...@@ -364,9 +364,8 @@ static void __init gic_init_irq(void)
writel(0x00000000, __io_address(REALVIEW_SYS_LOCK)); writel(0x00000000, __io_address(REALVIEW_SYS_LOCK));
/* core tile GIC, primary */ /* core tile GIC, primary */
gic_cpu_base_addr = __io_address(REALVIEW_EB11MP_GIC_CPU_BASE);
gic_init(0, 29, __io_address(REALVIEW_EB11MP_GIC_DIST_BASE), gic_init(0, 29, __io_address(REALVIEW_EB11MP_GIC_DIST_BASE),
gic_cpu_base_addr); __io_address(REALVIEW_EB11MP_GIC_CPU_BASE));
#ifndef CONFIG_REALVIEW_EB_ARM11MP_REVB #ifndef CONFIG_REALVIEW_EB_ARM11MP_REVB
/* board GIC, secondary */ /* board GIC, secondary */
...@@ -376,9 +375,8 @@ static void __init gic_init_irq(void) ...@@ -376,9 +375,8 @@ static void __init gic_init_irq(void)
#endif #endif
} else { } else {
/* board GIC, primary */ /* board GIC, primary */
gic_cpu_base_addr = __io_address(REALVIEW_EB_GIC_CPU_BASE);
gic_init(0, 29, __io_address(REALVIEW_EB_GIC_DIST_BASE), gic_init(0, 29, __io_address(REALVIEW_EB_GIC_DIST_BASE),
gic_cpu_base_addr); __io_address(REALVIEW_EB_GIC_CPU_BASE));
} }
} }
......
...@@ -304,10 +304,9 @@ static struct platform_device char_lcd_device = { ...@@ -304,10 +304,9 @@ static struct platform_device char_lcd_device = {
static void __init gic_init_irq(void) static void __init gic_init_irq(void)
{ {
/* ARM1176 DevChip GIC, primary */ /* ARM1176 DevChip GIC, primary */
gic_cpu_base_addr = __io_address(REALVIEW_DC1176_GIC_CPU_BASE);
gic_init(0, IRQ_DC1176_GIC_START, gic_init(0, IRQ_DC1176_GIC_START,
__io_address(REALVIEW_DC1176_GIC_DIST_BASE), __io_address(REALVIEW_DC1176_GIC_DIST_BASE),
gic_cpu_base_addr); __io_address(REALVIEW_DC1176_GIC_CPU_BASE));
/* board GIC, secondary */ /* board GIC, secondary */
gic_init(1, IRQ_PB1176_GIC_START, gic_init(1, IRQ_PB1176_GIC_START,
......
...@@ -309,9 +309,8 @@ static void __init gic_init_irq(void) ...@@ -309,9 +309,8 @@ static void __init gic_init_irq(void)
writel(0x00000000, __io_address(REALVIEW_SYS_LOCK)); writel(0x00000000, __io_address(REALVIEW_SYS_LOCK));
/* ARM11MPCore test chip GIC, primary */ /* ARM11MPCore test chip GIC, primary */
gic_cpu_base_addr = __io_address(REALVIEW_TC11MP_GIC_CPU_BASE);
gic_init(0, 29, __io_address(REALVIEW_TC11MP_GIC_DIST_BASE), gic_init(0, 29, __io_address(REALVIEW_TC11MP_GIC_DIST_BASE),
gic_cpu_base_addr); __io_address(REALVIEW_TC11MP_GIC_CPU_BASE));
/* board GIC, secondary */ /* board GIC, secondary */
gic_init(1, IRQ_PB11MP_GIC_START, gic_init(1, IRQ_PB11MP_GIC_START,
......
...@@ -273,7 +273,6 @@ static struct platform_device pmu_device = { ...@@ -273,7 +273,6 @@ static struct platform_device pmu_device = {
static void __init gic_init_irq(void) static void __init gic_init_irq(void)
{ {
/* ARM PB-A8 on-board GIC */ /* ARM PB-A8 on-board GIC */
gic_cpu_base_addr = __io_address(REALVIEW_PBA8_GIC_CPU_BASE);
gic_init(0, IRQ_PBA8_GIC_START, gic_init(0, IRQ_PBA8_GIC_START,
__io_address(REALVIEW_PBA8_GIC_DIST_BASE), __io_address(REALVIEW_PBA8_GIC_DIST_BASE),
__io_address(REALVIEW_PBA8_GIC_CPU_BASE)); __io_address(REALVIEW_PBA8_GIC_CPU_BASE));
......
...@@ -313,11 +313,9 @@ static void __init gic_init_irq(void) ...@@ -313,11 +313,9 @@ static void __init gic_init_irq(void)
{ {
/* ARM PBX on-board GIC */ /* ARM PBX on-board GIC */
if (core_tile_pbx11mp() || core_tile_pbxa9mp()) { if (core_tile_pbx11mp() || core_tile_pbxa9mp()) {
gic_cpu_base_addr = __io_address(REALVIEW_PBX_TILE_GIC_CPU_BASE);
gic_init(0, 29, __io_address(REALVIEW_PBX_TILE_GIC_DIST_BASE), gic_init(0, 29, __io_address(REALVIEW_PBX_TILE_GIC_DIST_BASE),
__io_address(REALVIEW_PBX_TILE_GIC_CPU_BASE)); __io_address(REALVIEW_PBX_TILE_GIC_CPU_BASE));
} else { } else {
gic_cpu_base_addr = __io_address(REALVIEW_PBX_GIC_CPU_BASE);
gic_init(0, IRQ_PBX_GIC_START, gic_init(0, IRQ_PBX_GIC_START,
__io_address(REALVIEW_PBX_GIC_DIST_BASE), __io_address(REALVIEW_PBX_GIC_DIST_BASE),
__io_address(REALVIEW_PBX_GIC_CPU_BASE)); __io_address(REALVIEW_PBX_GIC_CPU_BASE));
......
...@@ -24,8 +24,6 @@ ...@@ -24,8 +24,6 @@
#include <mach/regs-irq.h> #include <mach/regs-irq.h>
void __iomem *gic_cpu_base_addr;
extern int combiner_init(unsigned int combiner_nr, void __iomem *base, extern int combiner_init(unsigned int combiner_nr, void __iomem *base,
unsigned int irq_start); unsigned int irq_start);
extern void combiner_cascade_irq(unsigned int combiner_nr, unsigned int irq); extern void combiner_cascade_irq(unsigned int combiner_nr, unsigned int irq);
...@@ -122,7 +120,6 @@ void __init s5pv310_init_irq(void) ...@@ -122,7 +120,6 @@ void __init s5pv310_init_irq(void)
{ {
int irq; int irq;
gic_cpu_base_addr = S5P_VA_GIC_CPU;
gic_init(0, IRQ_LOCALTIMER, S5P_VA_GIC_DIST, S5P_VA_GIC_CPU); gic_init(0, IRQ_LOCALTIMER, S5P_VA_GIC_DIST, S5P_VA_GIC_CPU);
for (irq = 0; irq < MAX_COMBINER_NR; irq++) { for (irq = 0; irq < MAX_COMBINER_NR; irq++) {
......
...@@ -9,8 +9,6 @@ ...@@ -9,8 +9,6 @@
#include <asm/hardware/gic.h> #include <asm/hardware/gic.h>
#include <asm/smp_mpidr.h> #include <asm/smp_mpidr.h>
extern void __iomem *gic_cpu_base_addr;
/* /*
* We use IRQ1 as the IPI * We use IRQ1 as the IPI
*/ */
......
...@@ -22,5 +22,3 @@ struct map_desc; ...@@ -22,5 +22,3 @@ struct map_desc;
void v2m_map_io(struct map_desc *tile, size_t num); void v2m_map_io(struct map_desc *tile, size_t num);
extern struct sys_timer v2m_timer; extern struct sys_timer v2m_timer;
extern void __iomem *gic_cpu_base_addr;
...@@ -60,12 +60,10 @@ static void __init ct_ca9x4_map_io(void) ...@@ -60,12 +60,10 @@ static void __init ct_ca9x4_map_io(void)
v2m_map_io(ct_ca9x4_io_desc, ARRAY_SIZE(ct_ca9x4_io_desc)); v2m_map_io(ct_ca9x4_io_desc, ARRAY_SIZE(ct_ca9x4_io_desc));
} }
void __iomem *gic_cpu_base_addr;
static void __init ct_ca9x4_init_irq(void) static void __init ct_ca9x4_init_irq(void)
{ {
gic_cpu_base_addr = MMIO_P2V(A9_MPCORE_GIC_CPU); gic_init(0, 29, MMIO_P2V(A9_MPCORE_GIC_DIST),
gic_init(0, 29, MMIO_P2V(A9_MPCORE_GIC_DIST), gic_cpu_base_addr); MMIO_P2V(A9_MPCORE_GIC_CPU));
} }
#if 0 #if 0
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册