mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2024-11-30 21:15:19 +02:00
ramips: merge 2.6.39 patches
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@27399 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
parent
e98854a51f
commit
f2053cb231
@ -44,23 +44,25 @@ static inline u32 ramips_intc_rr(unsigned reg)
|
|||||||
return __raw_readl(ramips_intc_base + reg);
|
return __raw_readl(ramips_intc_base + reg);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ramips_intc_irq_unmask(unsigned int irq)
|
static void ramips_intc_irq_unmask(struct irq_data *d)
|
||||||
{
|
{
|
||||||
irq -= ramips_intc_irq_base;
|
unsigned int irq = d->irq - ramips_intc_irq_base;
|
||||||
|
|
||||||
ramips_intc_wr((1 << irq), INTC_REG_ENABLE);
|
ramips_intc_wr((1 << irq), INTC_REG_ENABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ramips_intc_irq_mask(unsigned int irq)
|
static void ramips_intc_irq_mask(struct irq_data *d)
|
||||||
{
|
{
|
||||||
irq -= ramips_intc_irq_base;
|
unsigned int irq = d->irq - ramips_intc_irq_base;
|
||||||
|
|
||||||
ramips_intc_wr((1 << irq), INTC_REG_DISABLE);
|
ramips_intc_wr((1 << irq), INTC_REG_DISABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct irq_chip ramips_intc_irq_chip = {
|
static struct irq_chip ramips_intc_irq_chip = {
|
||||||
.name = "INTC",
|
.name = "INTC",
|
||||||
.unmask = ramips_intc_irq_unmask,
|
.irq_unmask = ramips_intc_irq_unmask,
|
||||||
.mask = ramips_intc_irq_mask,
|
.irq_mask = ramips_intc_irq_mask,
|
||||||
.mask_ack = ramips_intc_irq_mask,
|
.irq_mask_ack = ramips_intc_irq_mask,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct irqaction ramips_intc_irqaction = {
|
static struct irqaction ramips_intc_irqaction = {
|
||||||
@ -83,10 +85,9 @@ void __init ramips_intc_irq_init(unsigned intc_base, unsigned irq,
|
|||||||
ramips_intc_wr(0, INTC_REG_TYPE);
|
ramips_intc_wr(0, INTC_REG_TYPE);
|
||||||
|
|
||||||
for (i = ramips_intc_irq_base;
|
for (i = ramips_intc_irq_base;
|
||||||
i < ramips_intc_irq_base + INTC_IRQ_COUNT; i++) {
|
i < ramips_intc_irq_base + INTC_IRQ_COUNT; i++)
|
||||||
set_irq_chip_and_handler(i, &ramips_intc_irq_chip,
|
irq_set_chip_and_handler(i, &ramips_intc_irq_chip,
|
||||||
handle_level_irq);
|
handle_level_irq);
|
||||||
}
|
|
||||||
|
|
||||||
setup_irq(irq, &ramips_intc_irqaction);
|
setup_irq(irq, &ramips_intc_irqaction);
|
||||||
ramips_intc_wr(INTC_INT_GLOBAL, INTC_REG_ENABLE);
|
ramips_intc_wr(INTC_INT_GLOBAL, INTC_REG_ENABLE);
|
||||||
|
@ -1,48 +0,0 @@
|
|||||||
--- a/arch/mips/ralink/common/intc.c
|
|
||||||
+++ b/arch/mips/ralink/common/intc.c
|
|
||||||
@@ -44,23 +44,25 @@ static inline u32 ramips_intc_rr(unsigne
|
|
||||||
return __raw_readl(ramips_intc_base + reg);
|
|
||||||
}
|
|
||||||
|
|
||||||
-static void ramips_intc_irq_unmask(unsigned int irq)
|
|
||||||
+static void ramips_intc_irq_unmask(struct irq_data *d)
|
|
||||||
{
|
|
||||||
- irq -= ramips_intc_irq_base;
|
|
||||||
+ unsigned int irq = d->irq - ramips_intc_irq_base;
|
|
||||||
+
|
|
||||||
ramips_intc_wr((1 << irq), INTC_REG_ENABLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
-static void ramips_intc_irq_mask(unsigned int irq)
|
|
||||||
+static void ramips_intc_irq_mask(struct irq_data *d)
|
|
||||||
{
|
|
||||||
- irq -= ramips_intc_irq_base;
|
|
||||||
+ unsigned int irq = d->irq - ramips_intc_irq_base;
|
|
||||||
+
|
|
||||||
ramips_intc_wr((1 << irq), INTC_REG_DISABLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct irq_chip ramips_intc_irq_chip = {
|
|
||||||
.name = "INTC",
|
|
||||||
- .unmask = ramips_intc_irq_unmask,
|
|
||||||
- .mask = ramips_intc_irq_mask,
|
|
||||||
- .mask_ack = ramips_intc_irq_mask,
|
|
||||||
+ .irq_unmask = ramips_intc_irq_unmask,
|
|
||||||
+ .irq_mask = ramips_intc_irq_mask,
|
|
||||||
+ .irq_mask_ack = ramips_intc_irq_mask,
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct irqaction ramips_intc_irqaction = {
|
|
||||||
@@ -83,10 +85,9 @@ void __init ramips_intc_irq_init(unsigne
|
|
||||||
ramips_intc_wr(0, INTC_REG_TYPE);
|
|
||||||
|
|
||||||
for (i = ramips_intc_irq_base;
|
|
||||||
- i < ramips_intc_irq_base + INTC_IRQ_COUNT; i++) {
|
|
||||||
- set_irq_chip_and_handler(i, &ramips_intc_irq_chip,
|
|
||||||
+ i < ramips_intc_irq_base + INTC_IRQ_COUNT; i++)
|
|
||||||
+ irq_set_chip_and_handler(i, &ramips_intc_irq_chip,
|
|
||||||
handle_level_irq);
|
|
||||||
- }
|
|
||||||
|
|
||||||
setup_irq(irq, &ramips_intc_irqaction);
|
|
||||||
ramips_intc_wr(INTC_INT_GLOBAL, INTC_REG_ENABLE);
|
|
Loading…
Reference in New Issue
Block a user