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

ARM: GIC: provide a single initialization function for boot CPU

Provide gic_init() which initializes the GIC distributor and current
CPU's GIC interface for the boot (or single) CPU.
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>
上级 e745a667
...@@ -213,8 +213,8 @@ void __init gic_cascade_irq(unsigned int gic_nr, unsigned int irq) ...@@ -213,8 +213,8 @@ void __init gic_cascade_irq(unsigned int gic_nr, unsigned int irq)
set_irq_chained_handler(irq, gic_handle_cascade_irq); set_irq_chained_handler(irq, gic_handle_cascade_irq);
} }
void __init gic_dist_init(unsigned int gic_nr, void __iomem *base, static void __init gic_dist_init(unsigned int gic_nr, void __iomem *base,
unsigned int irq_start) unsigned int irq_start)
{ {
unsigned int gic_irqs, irq_limit, i; unsigned int gic_irqs, irq_limit, i;
u32 cpumask = 1 << smp_processor_id(); u32 cpumask = 1 << smp_processor_id();
...@@ -314,6 +314,13 @@ void __cpuinit gic_cpu_init(unsigned int gic_nr, void __iomem *base) ...@@ -314,6 +314,13 @@ void __cpuinit gic_cpu_init(unsigned int gic_nr, void __iomem *base)
writel(1, base + GIC_CPU_CTRL); writel(1, base + GIC_CPU_CTRL);
} }
void __init gic_init(unsigned int gic_nr, unsigned int irq_start,
void __iomem *dist_base, void __iomem *cpu_base)
{
gic_dist_init(gic_nr, dist_base, irq_start);
gic_cpu_init(gic_nr, cpu_base);
}
#ifdef CONFIG_SMP #ifdef CONFIG_SMP
void gic_raise_softirq(const struct cpumask *mask, unsigned int irq) void gic_raise_softirq(const struct cpumask *mask, unsigned int irq)
{ {
......
...@@ -33,8 +33,8 @@ ...@@ -33,8 +33,8 @@
#define GIC_DIST_SOFTINT 0xf00 #define GIC_DIST_SOFTINT 0xf00
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
void gic_dist_init(unsigned int gic_nr, void __iomem *base, unsigned int irq_start);
void gic_cpu_init(unsigned int gic_nr, void __iomem *base); void gic_cpu_init(unsigned int gic_nr, void __iomem *base);
void gic_init(unsigned int, unsigned int, void __iomem *, void __iomem *);
void gic_cascade_irq(unsigned int gic_nr, unsigned int irq); void gic_cascade_irq(unsigned int gic_nr, unsigned int irq);
void gic_raise_softirq(const struct cpumask *mask, unsigned int irq); void gic_raise_softirq(const struct cpumask *mask, unsigned int irq);
#endif #endif
......
...@@ -74,8 +74,8 @@ void __iomem *gic_cpu_base_addr; ...@@ -74,8 +74,8 @@ 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_cpu_base_addr = __io(CNS3XXX_TC11MP_GIC_CPU_BASE_VIRT);
gic_dist_init(0, __io(CNS3XXX_TC11MP_GIC_DIST_BASE_VIRT), 29); gic_init(0, 29, __io(CNS3XXX_TC11MP_GIC_DIST_BASE_VIRT),
gic_cpu_init(0, gic_cpu_base_addr); gic_cpu_base_addr);
} }
void cns3xxx_power_off(void) void cns3xxx_power_off(void)
......
...@@ -44,9 +44,8 @@ static void __init msm8x60_init_irq(void) ...@@ -44,9 +44,8 @@ static void __init msm8x60_init_irq(void)
{ {
unsigned int i; unsigned int i;
gic_dist_init(0, MSM_QGIC_DIST_BASE, GIC_PPI_START);
gic_cpu_base_addr = (void *)MSM_QGIC_CPU_BASE; gic_cpu_base_addr = (void *)MSM_QGIC_CPU_BASE;
gic_cpu_init(0, MSM_QGIC_CPU_BASE); gic_init(0, GIC_PPI_START, MSM_QGIC_DIST_BASE, gic_cpu_base_addr);
/* 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);
......
...@@ -35,12 +35,12 @@ void __init gic_init_irq(void) ...@@ -35,12 +35,12 @@ void __init gic_init_irq(void)
/* 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);
gic_dist_init(0, gic_dist_base_addr, 29);
/* Static mapping, never released */ /* Static mapping, never released */
gic_cpu_base_addr = ioremap(OMAP44XX_GIC_CPU_BASE, SZ_512); gic_cpu_base_addr = ioremap(OMAP44XX_GIC_CPU_BASE, SZ_512);
BUG_ON(!gic_cpu_base_addr); BUG_ON(!gic_cpu_base_addr);
gic_cpu_init(0, gic_cpu_base_addr);
gic_init(0, 29, gic_dist_base_addr, gic_cpu_base_addr);
} }
#ifdef CONFIG_CACHE_L2X0 #ifdef CONFIG_CACHE_L2X0
......
...@@ -365,20 +365,20 @@ static void __init gic_init_irq(void) ...@@ -365,20 +365,20 @@ static void __init gic_init_irq(void)
/* core tile GIC, primary */ /* core tile GIC, primary */
gic_cpu_base_addr = __io_address(REALVIEW_EB11MP_GIC_CPU_BASE); gic_cpu_base_addr = __io_address(REALVIEW_EB11MP_GIC_CPU_BASE);
gic_dist_init(0, __io_address(REALVIEW_EB11MP_GIC_DIST_BASE), 29); gic_init(0, 29, __io_address(REALVIEW_EB11MP_GIC_DIST_BASE),
gic_cpu_init(0, gic_cpu_base_addr); gic_cpu_base_addr);
#ifndef CONFIG_REALVIEW_EB_ARM11MP_REVB #ifndef CONFIG_REALVIEW_EB_ARM11MP_REVB
/* board GIC, secondary */ /* board GIC, secondary */
gic_dist_init(1, __io_address(REALVIEW_EB_GIC_DIST_BASE), 64); gic_init(1, 64, __io_address(REALVIEW_EB_GIC_DIST_BASE),
gic_cpu_init(1, __io_address(REALVIEW_EB_GIC_CPU_BASE)); __io_address(REALVIEW_EB_GIC_CPU_BASE));
gic_cascade_irq(1, IRQ_EB11MP_EB_IRQ1); gic_cascade_irq(1, IRQ_EB11MP_EB_IRQ1);
#endif #endif
} else { } else {
/* board GIC, primary */ /* board GIC, primary */
gic_cpu_base_addr = __io_address(REALVIEW_EB_GIC_CPU_BASE); gic_cpu_base_addr = __io_address(REALVIEW_EB_GIC_CPU_BASE);
gic_dist_init(0, __io_address(REALVIEW_EB_GIC_DIST_BASE), 29); gic_init(0, 29, __io_address(REALVIEW_EB_GIC_DIST_BASE),
gic_cpu_init(0, gic_cpu_base_addr); gic_cpu_base_addr);
} }
} }
......
...@@ -305,12 +305,14 @@ static void __init gic_init_irq(void) ...@@ -305,12 +305,14 @@ 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_cpu_base_addr = __io_address(REALVIEW_DC1176_GIC_CPU_BASE);
gic_dist_init(0, __io_address(REALVIEW_DC1176_GIC_DIST_BASE), IRQ_DC1176_GIC_START); gic_init(0, IRQ_DC1176_GIC_START,
gic_cpu_init(0, gic_cpu_base_addr); __io_address(REALVIEW_DC1176_GIC_DIST_BASE),
gic_cpu_base_addr);
/* board GIC, secondary */ /* board GIC, secondary */
gic_dist_init(1, __io_address(REALVIEW_PB1176_GIC_DIST_BASE), IRQ_PB1176_GIC_START); gic_init(1, IRQ_PB1176_GIC_START,
gic_cpu_init(1, __io_address(REALVIEW_PB1176_GIC_CPU_BASE)); __io_address(REALVIEW_PB1176_GIC_DIST_BASE),
__io_address(REALVIEW_PB1176_GIC_CPU_BASE));
gic_cascade_irq(1, IRQ_DC1176_PB_IRQ1); gic_cascade_irq(1, IRQ_DC1176_PB_IRQ1);
} }
......
...@@ -310,12 +310,13 @@ static void __init gic_init_irq(void) ...@@ -310,12 +310,13 @@ static void __init gic_init_irq(void)
/* ARM11MPCore test chip GIC, primary */ /* ARM11MPCore test chip GIC, primary */
gic_cpu_base_addr = __io_address(REALVIEW_TC11MP_GIC_CPU_BASE); gic_cpu_base_addr = __io_address(REALVIEW_TC11MP_GIC_CPU_BASE);
gic_dist_init(0, __io_address(REALVIEW_TC11MP_GIC_DIST_BASE), 29); gic_init(0, 29, __io_address(REALVIEW_TC11MP_GIC_DIST_BASE),
gic_cpu_init(0, gic_cpu_base_addr); gic_cpu_base_addr);
/* board GIC, secondary */ /* board GIC, secondary */
gic_dist_init(1, __io_address(REALVIEW_PB11MP_GIC_DIST_BASE), IRQ_PB11MP_GIC_START); gic_init(1, IRQ_PB11MP_GIC_START,
gic_cpu_init(1, __io_address(REALVIEW_PB11MP_GIC_CPU_BASE)); __io_address(REALVIEW_PB11MP_GIC_DIST_BASE),
__io_address(REALVIEW_PB11MP_GIC_CPU_BASE));
gic_cascade_irq(1, IRQ_TC11MP_PB_IRQ1); gic_cascade_irq(1, IRQ_TC11MP_PB_IRQ1);
} }
......
...@@ -274,8 +274,9 @@ static void __init gic_init_irq(void) ...@@ -274,8 +274,9 @@ 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_cpu_base_addr = __io_address(REALVIEW_PBA8_GIC_CPU_BASE);
gic_dist_init(0, __io_address(REALVIEW_PBA8_GIC_DIST_BASE), IRQ_PBA8_GIC_START); gic_init(0, IRQ_PBA8_GIC_START,
gic_cpu_init(0, __io_address(REALVIEW_PBA8_GIC_CPU_BASE)); __io_address(REALVIEW_PBA8_GIC_DIST_BASE),
__io_address(REALVIEW_PBA8_GIC_CPU_BASE));
} }
static void __init realview_pba8_timer_init(void) static void __init realview_pba8_timer_init(void)
......
...@@ -314,14 +314,13 @@ static void __init gic_init_irq(void) ...@@ -314,14 +314,13 @@ 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_cpu_base_addr = __io_address(REALVIEW_PBX_TILE_GIC_CPU_BASE);
gic_dist_init(0, __io_address(REALVIEW_PBX_TILE_GIC_DIST_BASE), gic_init(0, 29, __io_address(REALVIEW_PBX_TILE_GIC_DIST_BASE),
29); __io_address(REALVIEW_PBX_TILE_GIC_CPU_BASE));
gic_cpu_init(0, __io_address(REALVIEW_PBX_TILE_GIC_CPU_BASE));
} else { } else {
gic_cpu_base_addr = __io_address(REALVIEW_PBX_GIC_CPU_BASE); gic_cpu_base_addr = __io_address(REALVIEW_PBX_GIC_CPU_BASE);
gic_dist_init(0, __io_address(REALVIEW_PBX_GIC_DIST_BASE), gic_init(0, IRQ_PBX_GIC_START,
IRQ_PBX_GIC_START); __io_address(REALVIEW_PBX_GIC_DIST_BASE),
gic_cpu_init(0, __io_address(REALVIEW_PBX_GIC_CPU_BASE)); __io_address(REALVIEW_PBX_GIC_CPU_BASE));
} }
} }
......
...@@ -123,8 +123,7 @@ void __init s5pv310_init_irq(void) ...@@ -123,8 +123,7 @@ void __init s5pv310_init_irq(void)
int irq; int irq;
gic_cpu_base_addr = S5P_VA_GIC_CPU; gic_cpu_base_addr = S5P_VA_GIC_CPU;
gic_dist_init(0, S5P_VA_GIC_DIST, IRQ_LOCALTIMER); gic_init(0, IRQ_LOCALTIMER, S5P_VA_GIC_DIST, S5P_VA_GIC_CPU);
gic_cpu_init(0, S5P_VA_GIC_CPU);
for (irq = 0; irq < MAX_COMBINER_NR; irq++) { for (irq = 0; irq < MAX_COMBINER_NR; irq++) {
combiner_init(irq, (void __iomem *)S5P_VA_COMBINER(irq), combiner_init(irq, (void __iomem *)S5P_VA_COMBINER(irq),
......
...@@ -94,8 +94,8 @@ void __init tegra_init_irq(void) ...@@ -94,8 +94,8 @@ void __init tegra_init_irq(void)
writel(0, ictlr_to_virt(i) + ICTLR_CPU_IEP_CLASS); writel(0, ictlr_to_virt(i) + ICTLR_CPU_IEP_CLASS);
} }
gic_dist_init(0, IO_ADDRESS(TEGRA_ARM_INT_DIST_BASE), 29); gic_init(0, 29, IO_ADDRESS(TEGRA_ARM_INT_DIST_BASE),
gic_cpu_init(0, IO_ADDRESS(TEGRA_ARM_PERIF_BASE + 0x100)); IO_ADDRESS(TEGRA_ARM_PERIF_BASE + 0x100));
gic = get_irq_chip(29); gic = get_irq_chip(29);
gic_unmask_irq = gic->unmask; gic_unmask_irq = gic->unmask;
......
...@@ -61,8 +61,8 @@ void __init ux500_init_devices(void) ...@@ -61,8 +61,8 @@ void __init ux500_init_devices(void)
void __init ux500_init_irq(void) void __init ux500_init_irq(void)
{ {
gic_dist_init(0, __io_address(UX500_GIC_DIST_BASE), 29); gic_init(0, 29, __io_address(UX500_GIC_DIST_BASE),
gic_cpu_init(0, __io_address(UX500_GIC_CPU_BASE)); __io_address(UX500_GIC_CPU_BASE));
/* /*
* Init clocks here so that they are available for system timer * Init clocks here so that they are available for system timer
......
...@@ -65,8 +65,7 @@ void __iomem *gic_cpu_base_addr; ...@@ -65,8 +65,7 @@ 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_cpu_base_addr = MMIO_P2V(A9_MPCORE_GIC_CPU);
gic_dist_init(0, MMIO_P2V(A9_MPCORE_GIC_DIST), 29); gic_init(0, 29, MMIO_P2V(A9_MPCORE_GIC_DIST), gic_cpu_base_addr);
gic_cpu_init(0, gic_cpu_base_addr);
} }
#if 0 #if 0
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册