1 #include <linux/init.h>
2 #include <linux/list.h>
5 #include <asm/mach/irq.h>
6 #include <asm/hardware/iomd.h>
9 static void iomd_ack_irq_a(struct irq_data
*d
)
11 unsigned int val
, mask
;
14 val
= iomd_readb(IOMD_IRQMASKA
);
15 iomd_writeb(val
& ~mask
, IOMD_IRQMASKA
);
16 iomd_writeb(mask
, IOMD_IRQCLRA
);
19 static void iomd_mask_irq_a(struct irq_data
*d
)
21 unsigned int val
, mask
;
24 val
= iomd_readb(IOMD_IRQMASKA
);
25 iomd_writeb(val
& ~mask
, IOMD_IRQMASKA
);
28 static void iomd_unmask_irq_a(struct irq_data
*d
)
30 unsigned int val
, mask
;
33 val
= iomd_readb(IOMD_IRQMASKA
);
34 iomd_writeb(val
| mask
, IOMD_IRQMASKA
);
37 static struct irq_chip iomd_a_chip
= {
38 .irq_ack
= iomd_ack_irq_a
,
39 .irq_mask
= iomd_mask_irq_a
,
40 .irq_unmask
= iomd_unmask_irq_a
,
43 static void iomd_mask_irq_b(struct irq_data
*d
)
45 unsigned int val
, mask
;
47 mask
= 1 << (d
->irq
& 7);
48 val
= iomd_readb(IOMD_IRQMASKB
);
49 iomd_writeb(val
& ~mask
, IOMD_IRQMASKB
);
52 static void iomd_unmask_irq_b(struct irq_data
*d
)
54 unsigned int val
, mask
;
56 mask
= 1 << (d
->irq
& 7);
57 val
= iomd_readb(IOMD_IRQMASKB
);
58 iomd_writeb(val
| mask
, IOMD_IRQMASKB
);
61 static struct irq_chip iomd_b_chip
= {
62 .irq_ack
= iomd_mask_irq_b
,
63 .irq_mask
= iomd_mask_irq_b
,
64 .irq_unmask
= iomd_unmask_irq_b
,
67 static void iomd_mask_irq_dma(struct irq_data
*d
)
69 unsigned int val
, mask
;
71 mask
= 1 << (d
->irq
& 7);
72 val
= iomd_readb(IOMD_DMAMASK
);
73 iomd_writeb(val
& ~mask
, IOMD_DMAMASK
);
76 static void iomd_unmask_irq_dma(struct irq_data
*d
)
78 unsigned int val
, mask
;
80 mask
= 1 << (d
->irq
& 7);
81 val
= iomd_readb(IOMD_DMAMASK
);
82 iomd_writeb(val
| mask
, IOMD_DMAMASK
);
85 static struct irq_chip iomd_dma_chip
= {
86 .irq_ack
= iomd_mask_irq_dma
,
87 .irq_mask
= iomd_mask_irq_dma
,
88 .irq_unmask
= iomd_unmask_irq_dma
,
91 static void iomd_mask_irq_fiq(struct irq_data
*d
)
93 unsigned int val
, mask
;
95 mask
= 1 << (d
->irq
& 7);
96 val
= iomd_readb(IOMD_FIQMASK
);
97 iomd_writeb(val
& ~mask
, IOMD_FIQMASK
);
100 static void iomd_unmask_irq_fiq(struct irq_data
*d
)
102 unsigned int val
, mask
;
104 mask
= 1 << (d
->irq
& 7);
105 val
= iomd_readb(IOMD_FIQMASK
);
106 iomd_writeb(val
| mask
, IOMD_FIQMASK
);
109 static struct irq_chip iomd_fiq_chip
= {
110 .irq_ack
= iomd_mask_irq_fiq
,
111 .irq_mask
= iomd_mask_irq_fiq
,
112 .irq_unmask
= iomd_unmask_irq_fiq
,
115 void __init
rpc_init_irq(void)
117 unsigned int irq
, flags
;
119 iomd_writeb(0, IOMD_IRQMASKA
);
120 iomd_writeb(0, IOMD_IRQMASKB
);
121 iomd_writeb(0, IOMD_FIQMASK
);
122 iomd_writeb(0, IOMD_DMAMASK
);
124 for (irq
= 0; irq
< NR_IRQS
; irq
++) {
127 if (irq
<= 6 || (irq
>= 9 && irq
<= 15))
130 if (irq
== 21 || (irq
>= 16 && irq
<= 19) ||
131 irq
== IRQ_KEYBOARDTX
)
132 flags
|= IRQF_NOAUTOEN
;
136 set_irq_chip(irq
, &iomd_a_chip
);
137 set_irq_handler(irq
, handle_level_irq
);
138 set_irq_flags(irq
, flags
);
142 set_irq_chip(irq
, &iomd_b_chip
);
143 set_irq_handler(irq
, handle_level_irq
);
144 set_irq_flags(irq
, flags
);
148 set_irq_chip(irq
, &iomd_dma_chip
);
149 set_irq_handler(irq
, handle_level_irq
);
150 set_irq_flags(irq
, flags
);
154 set_irq_chip(irq
, &iomd_fiq_chip
);
155 set_irq_flags(irq
, IRQF_VALID
);