12 #include <linux/types.h>
14 #include <linux/kernel.h>
21 static void intc2_irq_gpio_mask(
struct irq_data *
d)
24 u32 type = irqd_get_trigger_type(d);
28 imr &= ~(0x001 << irq);
30 imr &= ~(0x100 << irq);
34 static void intc2_irq_gpio_unmask(
struct irq_data *d)
37 u32 type = irqd_get_trigger_type(d);
40 if (type & IRQ_TYPE_EDGE_RISING)
41 imr |= (0x001 << irq);
43 imr |= (0x100 << irq);
47 static void intc2_irq_gpio_ack(
struct irq_data *d)
50 u32 type = irqd_get_trigger_type(d);
53 if (type & IRQ_TYPE_EDGE_RISING)
54 imr |= (0x001 << irq);
56 imr |= (0x100 << irq);
60 static int intc2_irq_gpio_set_type(
struct irq_data *d,
unsigned int f)
67 static struct irq_chip intc2_irq_gpio_chip = {
69 .irq_mask = intc2_irq_gpio_mask,
70 .irq_unmask = intc2_irq_gpio_unmask,
71 .irq_ack = intc2_irq_gpio_ack,
72 .irq_set_type = intc2_irq_gpio_set_type,
75 static int __init mcf_intc2_init(
void)