Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 59261
b: refs/heads/master
c: 348f2e3
h: refs/heads/master
i:
  59259: 440c19b
v: v3
  • Loading branch information
Eric Miao authored and Russell King committed Jul 12, 2007
1 parent 52ad8aa commit 7509afa
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 25 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 53665a50fdac6fe11e0dde4e2b95700ed5184dc4
refs/heads/master: 348f2e3b2956e30f07d2507d7234c3f12a8a612d
41 changes: 17 additions & 24 deletions trunk/arch/arm/mach-pxa/irq.c
Original file line number Diff line number Diff line change
Expand Up @@ -347,43 +347,27 @@ static struct irq_chip pxa_muxed_gpio_chip = {
.set_wake = pxa_set_gpio_wake,
};

void __init pxa_init_irq(void)
void __init pxa_init_irq_gpio(int gpio_nr)
{
int irq;
int irq, i;

/* clear all GPIO edge detects */
GFER0 = 0;
GFER1 = 0;
GFER2 = 0;
GRER0 = 0;
GRER1 = 0;
GRER2 = 0;
GEDR0 = GEDR0;
GEDR1 = GEDR1;
GEDR2 = GEDR2;

#ifdef CONFIG_PXA27x
/* And similarly for the extra regs on the PXA27x */
GFER3 = 0;
GRER3 = 0;
GEDR3 = GEDR3;
#endif
for (i = 0; i < gpio_nr; i += 32) {
GFER(i) = 0;
GRER(i) = 0;
GEDR(i) = GEDR(i);
}

/* GPIO 0 and 1 must have their mask bit always set */
GPIO_IRQ_mask[0] = 3;

pxa_init_irq_low();
#ifdef CONFIG_PXA27x
pxa_init_irq_high();
#endif

for (irq = IRQ_GPIO0; irq <= IRQ_GPIO1; irq++) {
set_irq_chip(irq, &pxa_low_gpio_chip);
set_irq_handler(irq, handle_edge_irq);
set_irq_flags(irq, IRQF_VALID | IRQF_PROBE);
}

for (irq = IRQ_GPIO(2); irq <= IRQ_GPIO(PXA_LAST_GPIO); irq++) {
for (irq = IRQ_GPIO(2); irq <= IRQ_GPIO(gpio_nr); irq++) {
set_irq_chip(irq, &pxa_muxed_gpio_chip);
set_irq_handler(irq, handle_edge_irq);
set_irq_flags(irq, IRQF_VALID | IRQF_PROBE);
Expand All @@ -393,3 +377,12 @@ void __init pxa_init_irq(void)
set_irq_chip(IRQ_GPIO_2_x, &pxa_internal_chip_low);
set_irq_chained_handler(IRQ_GPIO_2_x, pxa_gpio_demux_handler);
}

void __init pxa_init_irq(void)
{
pxa_init_irq_low();
#ifdef CONFIG_PXA27x
pxa_init_irq_high();
#endif
pxa_init_irq_gpio(PXA_LAST_GPIO + 1);
}

0 comments on commit 7509afa

Please sign in to comment.