Commit 06a28716 authored by Bartosz Golaszewski's avatar Bartosz Golaszewski Committed by Sekhar Nori

ARM: davinci: aintc: use the new config structure

Modify the aintc driver to take all its configuration from the new
config structure. Stop referencing davinci_soc_info in any way.
Move the declaration for davinci_aintc_init() to irq-davinci-aintc.h
and make it take the new config structure as parameter. Convert all
users to the new version.
Signed-off-by: default avatarBartosz Golaszewski <bgolaszewski@baylibre.com>
Reviewed-by: default avatarDavid Lechner <david@lechnology.com>
Signed-off-by: default avatarSekhar Nori <nsekhar@ti.com>
parent fd0f4275
...@@ -805,7 +805,7 @@ static const struct davinci_aintc_config dm355_aintc_config = { ...@@ -805,7 +805,7 @@ static const struct davinci_aintc_config dm355_aintc_config = {
void __init dm355_init_irq(void) void __init dm355_init_irq(void)
{ {
davinci_aintc_init(); davinci_aintc_init(&dm355_aintc_config);
} }
static int __init dm355_init_devices(void) static int __init dm355_init_devices(void)
......
...@@ -1064,7 +1064,7 @@ static const struct davinci_aintc_config dm365_aintc_config = { ...@@ -1064,7 +1064,7 @@ static const struct davinci_aintc_config dm365_aintc_config = {
void __init dm365_init_irq(void) void __init dm365_init_irq(void)
{ {
davinci_aintc_init(); davinci_aintc_init(&dm365_aintc_config);
} }
static int __init dm365_init_devices(void) static int __init dm365_init_devices(void)
......
...@@ -741,7 +741,7 @@ static const struct davinci_aintc_config dm644x_aintc_config = { ...@@ -741,7 +741,7 @@ static const struct davinci_aintc_config dm644x_aintc_config = {
void __init dm644x_init_irq(void) void __init dm644x_init_irq(void)
{ {
davinci_aintc_init(); davinci_aintc_init(&dm644x_aintc_config);
} }
void __init dm644x_init_devices(void) void __init dm644x_init_devices(void)
......
...@@ -702,7 +702,7 @@ static const struct davinci_aintc_config dm646x_aintc_config = { ...@@ -702,7 +702,7 @@ static const struct davinci_aintc_config dm646x_aintc_config = {
void __init dm646x_init_irq(void) void __init dm646x_init_irq(void)
{ {
davinci_aintc_init(); davinci_aintc_init(&dm646x_aintc_config);
} }
static int __init dm646x_init_devices(void) static int __init dm646x_init_devices(void)
......
...@@ -24,8 +24,6 @@ ...@@ -24,8 +24,6 @@
void davinci_timer_init(struct clk *clk); void davinci_timer_init(struct clk *clk);
extern void davinci_aintc_init(void);
struct davinci_timer_instance { struct davinci_timer_instance {
u32 base; u32 base;
u32 bottom_irq; u32 bottom_irq;
......
...@@ -8,6 +8,7 @@ ...@@ -8,6 +8,7 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/irq.h> #include <linux/irq.h>
#include <linux/irqchip/irq-davinci-aintc.h>
#include <linux/io.h> #include <linux/io.h>
#include <linux/irqdomain.h> #include <linux/irqdomain.h>
...@@ -82,13 +83,14 @@ davinci_aintc_handle_irq(struct pt_regs *regs) ...@@ -82,13 +83,14 @@ davinci_aintc_handle_irq(struct pt_regs *regs)
} }
/* ARM Interrupt Controller Initialization */ /* ARM Interrupt Controller Initialization */
void __init davinci_aintc_init(void) void __init davinci_aintc_init(const struct davinci_aintc_config *config)
{ {
unsigned i, j; unsigned int irq_off, reg_off, prio, shift;
const u8 *davinci_def_priorities = davinci_soc_info.intc_irq_prios;
int ret, irq_base; int ret, irq_base;
const u8 *prios;
davinci_aintc_base = ioremap(davinci_soc_info.intc_base, SZ_4K); davinci_aintc_base = ioremap(config->reg.start,
resource_size(&config->reg));
if (WARN_ON(!davinci_aintc_base)) if (WARN_ON(!davinci_aintc_base))
return; return;
...@@ -114,23 +116,21 @@ void __init davinci_aintc_init(void) ...@@ -114,23 +116,21 @@ void __init davinci_aintc_init(void)
davinci_aintc_writel(~0x0, DAVINCI_AINTC_IRQ_REG0); davinci_aintc_writel(~0x0, DAVINCI_AINTC_IRQ_REG0);
davinci_aintc_writel(~0x0, DAVINCI_AINTC_IRQ_REG1); davinci_aintc_writel(~0x0, DAVINCI_AINTC_IRQ_REG1);
for (i = DAVINCI_AINTC_IRQ_INTPRI0_REG; prios = config->prios;
i <= DAVINCI_AINTC_IRQ_INTPRI7_REG; i += 4) { for (reg_off = DAVINCI_AINTC_IRQ_INTPRI0_REG;
u32 pri; reg_off <= DAVINCI_AINTC_IRQ_INTPRI7_REG; reg_off += 4) {
for (shift = 0, prio = 0; shift < 32; shift += 4, prios++)
for (j = 0, pri = 0; j < 32; j += 4, davinci_def_priorities++) prio |= (*prios & 0x07) << shift;
pri |= (*davinci_def_priorities & 0x07) << j; davinci_aintc_writel(prio, reg_off);
davinci_aintc_writel(pri, i);
} }
irq_base = irq_alloc_descs(-1, 0, davinci_soc_info.intc_irq_num, 0); irq_base = irq_alloc_descs(-1, 0, config->num_irqs, 0);
if (WARN_ON(irq_base < 0)) if (WARN_ON(irq_base < 0))
return; return;
davinci_aintc_irq_domain = irq_domain_add_legacy(NULL, davinci_aintc_irq_domain = irq_domain_add_legacy(NULL,
davinci_soc_info.intc_irq_num, config->num_irqs, irq_base, 0,
irq_base, 0, &irq_domain_simple_ops, &irq_domain_simple_ops, NULL);
NULL);
if (WARN_ON(!davinci_aintc_irq_domain)) if (WARN_ON(!davinci_aintc_irq_domain))
return; return;
...@@ -140,10 +140,11 @@ void __init davinci_aintc_init(void) ...@@ -140,10 +140,11 @@ void __init davinci_aintc_init(void)
if (WARN_ON(ret)) if (WARN_ON(ret))
return; return;
for (i = 0, j = 0; i < davinci_soc_info.intc_irq_num; for (irq_off = 0, reg_off = 0;
i += 32, j += 0x04) irq_off < config->num_irqs;
davinci_aintc_setup_gc(davinci_aintc_base + j, irq_off += 32, reg_off += 0x04)
irq_base + i, 32); davinci_aintc_setup_gc(davinci_aintc_base + reg_off,
irq_base + irq_off, 32);
irq_set_handler(DAVINCI_INTC_IRQ(IRQ_TINT1_TINT34), handle_level_irq); irq_set_handler(DAVINCI_INTC_IRQ(IRQ_TINT1_TINT34), handle_level_irq);
set_handle_irq(davinci_aintc_handle_irq); set_handle_irq(davinci_aintc_handle_irq);
......
...@@ -22,4 +22,6 @@ struct davinci_aintc_config { ...@@ -22,4 +22,6 @@ struct davinci_aintc_config {
u8 *prios; u8 *prios;
}; };
void davinci_aintc_init(const struct davinci_aintc_config *config);
#endif /* _LINUX_IRQ_DAVINCI_AINTC_ */ #endif /* _LINUX_IRQ_DAVINCI_AINTC_ */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment