diff options
Diffstat (limited to 'arch/arm/mach-ixp23xx')
-rw-r--r-- | arch/arm/mach-ixp23xx/core.c | 55 | ||||
-rw-r--r-- | arch/arm/mach-ixp23xx/ixdp2351.c | 36 |
2 files changed, 49 insertions, 42 deletions
diff --git a/arch/arm/mach-ixp23xx/core.c b/arch/arm/mach-ixp23xx/core.c index aa4c4420ff3d..9c8a33903216 100644 --- a/arch/arm/mach-ixp23xx/core.c +++ b/arch/arm/mach-ixp23xx/core.c | |||
@@ -111,9 +111,9 @@ enum ixp23xx_irq_type { | |||
111 | 111 | ||
112 | static void ixp23xx_config_irq(unsigned int, enum ixp23xx_irq_type); | 112 | static void ixp23xx_config_irq(unsigned int, enum ixp23xx_irq_type); |
113 | 113 | ||
114 | static int ixp23xx_irq_set_type(unsigned int irq, unsigned int type) | 114 | static int ixp23xx_irq_set_type(struct irq_data *d, unsigned int type) |
115 | { | 115 | { |
116 | int line = irq - IRQ_IXP23XX_GPIO6 + 6; | 116 | int line = d->irq - IRQ_IXP23XX_GPIO6 + 6; |
117 | u32 int_style; | 117 | u32 int_style; |
118 | enum ixp23xx_irq_type irq_type; | 118 | enum ixp23xx_irq_type irq_type; |
119 | volatile u32 *int_reg; | 119 | volatile u32 *int_reg; |
@@ -149,7 +149,7 @@ static int ixp23xx_irq_set_type(unsigned int irq, unsigned int type) | |||
149 | return -EINVAL; | 149 | return -EINVAL; |
150 | } | 150 | } |
151 | 151 | ||
152 | ixp23xx_config_irq(irq, irq_type); | 152 | ixp23xx_config_irq(d->irq, irq_type); |
153 | 153 | ||
154 | if (line >= 8) { /* pins 8-15 */ | 154 | if (line >= 8) { /* pins 8-15 */ |
155 | line -= 8; | 155 | line -= 8; |
@@ -173,9 +173,10 @@ static int ixp23xx_irq_set_type(unsigned int irq, unsigned int type) | |||
173 | return 0; | 173 | return 0; |
174 | } | 174 | } |
175 | 175 | ||
176 | static void ixp23xx_irq_mask(unsigned int irq) | 176 | static void ixp23xx_irq_mask(struct irq_data *d) |
177 | { | 177 | { |
178 | volatile unsigned long *intr_reg; | 178 | volatile unsigned long *intr_reg; |
179 | unsigned int irq = d->irq; | ||
179 | 180 | ||
180 | if (irq >= 56) | 181 | if (irq >= 56) |
181 | irq += 8; | 182 | irq += 8; |
@@ -184,9 +185,9 @@ static void ixp23xx_irq_mask(unsigned int irq) | |||
184 | *intr_reg &= ~(1 << (irq % 32)); | 185 | *intr_reg &= ~(1 << (irq % 32)); |
185 | } | 186 | } |
186 | 187 | ||
187 | static void ixp23xx_irq_ack(unsigned int irq) | 188 | static void ixp23xx_irq_ack(struct irq_data *d) |
188 | { | 189 | { |
189 | int line = irq - IRQ_IXP23XX_GPIO6 + 6; | 190 | int line = d->irq - IRQ_IXP23XX_GPIO6 + 6; |
190 | 191 | ||
191 | if ((line < 6) || (line > 15)) | 192 | if ((line < 6) || (line > 15)) |
192 | return; | 193 | return; |
@@ -198,11 +199,12 @@ static void ixp23xx_irq_ack(unsigned int irq) | |||
198 | * Level triggered interrupts on GPIO lines can only be cleared when the | 199 | * Level triggered interrupts on GPIO lines can only be cleared when the |
199 | * interrupt condition disappears. | 200 | * interrupt condition disappears. |
200 | */ | 201 | */ |
201 | static void ixp23xx_irq_level_unmask(unsigned int irq) | 202 | static void ixp23xx_irq_level_unmask(struct irq_data *d) |
202 | { | 203 | { |
203 | volatile unsigned long *intr_reg; | 204 | volatile unsigned long *intr_reg; |
205 | unsigned int irq = d->irq; | ||
204 | 206 | ||
205 | ixp23xx_irq_ack(irq); | 207 | ixp23xx_irq_ack(d); |
206 | 208 | ||
207 | if (irq >= 56) | 209 | if (irq >= 56) |
208 | irq += 8; | 210 | irq += 8; |
@@ -211,9 +213,10 @@ static void ixp23xx_irq_level_unmask(unsigned int irq) | |||
211 | *intr_reg |= (1 << (irq % 32)); | 213 | *intr_reg |= (1 << (irq % 32)); |
212 | } | 214 | } |
213 | 215 | ||
214 | static void ixp23xx_irq_edge_unmask(unsigned int irq) | 216 | static void ixp23xx_irq_edge_unmask(struct irq_data *d) |
215 | { | 217 | { |
216 | volatile unsigned long *intr_reg; | 218 | volatile unsigned long *intr_reg; |
219 | unsigned int irq = d->irq; | ||
217 | 220 | ||
218 | if (irq >= 56) | 221 | if (irq >= 56) |
219 | irq += 8; | 222 | irq += 8; |
@@ -223,26 +226,30 @@ static void ixp23xx_irq_edge_unmask(unsigned int irq) | |||
223 | } | 226 | } |
224 | 227 | ||
225 | static struct irq_chip ixp23xx_irq_level_chip = { | 228 | static struct irq_chip ixp23xx_irq_level_chip = { |
226 | .ack = ixp23xx_irq_mask, | 229 | .irq_ack = ixp23xx_irq_mask, |
227 | .mask = ixp23xx_irq_mask, | 230 | .irq_mask = ixp23xx_irq_mask, |
228 | .unmask = ixp23xx_irq_level_unmask, | 231 | .irq_unmask = ixp23xx_irq_level_unmask, |
229 | .set_type = ixp23xx_irq_set_type | 232 | .irq_set_type = ixp23xx_irq_set_type |
230 | }; | 233 | }; |
231 | 234 | ||
232 | static struct irq_chip ixp23xx_irq_edge_chip = { | 235 | static struct irq_chip ixp23xx_irq_edge_chip = { |
233 | .ack = ixp23xx_irq_ack, | 236 | .irq_ack = ixp23xx_irq_ack, |
234 | .mask = ixp23xx_irq_mask, | 237 | .irq_mask = ixp23xx_irq_mask, |
235 | .unmask = ixp23xx_irq_edge_unmask, | 238 | .irq_unmask = ixp23xx_irq_edge_unmask, |
236 | .set_type = ixp23xx_irq_set_type | 239 | .irq_set_type = ixp23xx_irq_set_type |
237 | }; | 240 | }; |
238 | 241 | ||
239 | static void ixp23xx_pci_irq_mask(unsigned int irq) | 242 | static void ixp23xx_pci_irq_mask(struct irq_data *d) |
240 | { | 243 | { |
244 | unsigned int irq = d->irq; | ||
245 | |||
241 | *IXP23XX_PCI_XSCALE_INT_ENABLE &= ~(1 << (IRQ_IXP23XX_INTA + 27 - irq)); | 246 | *IXP23XX_PCI_XSCALE_INT_ENABLE &= ~(1 << (IRQ_IXP23XX_INTA + 27 - irq)); |
242 | } | 247 | } |
243 | 248 | ||
244 | static void ixp23xx_pci_irq_unmask(unsigned int irq) | 249 | static void ixp23xx_pci_irq_unmask(struct irq_data *d) |
245 | { | 250 | { |
251 | unsigned int irq = d->irq; | ||
252 | |||
246 | *IXP23XX_PCI_XSCALE_INT_ENABLE |= (1 << (IRQ_IXP23XX_INTA + 27 - irq)); | 253 | *IXP23XX_PCI_XSCALE_INT_ENABLE |= (1 << (IRQ_IXP23XX_INTA + 27 - irq)); |
247 | } | 254 | } |
248 | 255 | ||
@@ -256,7 +263,7 @@ static void pci_handler(unsigned int irq, struct irq_desc *desc) | |||
256 | 263 | ||
257 | pci_interrupt = *IXP23XX_PCI_XSCALE_INT_STATUS; | 264 | pci_interrupt = *IXP23XX_PCI_XSCALE_INT_STATUS; |
258 | 265 | ||
259 | desc->chip->ack(irq); | 266 | desc->irq_data.chip->irq_ack(&desc->irq_data); |
260 | 267 | ||
261 | /* See which PCI_INTA, or PCI_INTB interrupted */ | 268 | /* See which PCI_INTA, or PCI_INTB interrupted */ |
262 | if (pci_interrupt & (1 << 26)) { | 269 | if (pci_interrupt & (1 << 26)) { |
@@ -269,13 +276,13 @@ static void pci_handler(unsigned int irq, struct irq_desc *desc) | |||
269 | 276 | ||
270 | generic_handle_irq(irqno); | 277 | generic_handle_irq(irqno); |
271 | 278 | ||
272 | desc->chip->unmask(irq); | 279 | desc->irq_data.chip->irq_unmask(&desc->irq_data); |
273 | } | 280 | } |
274 | 281 | ||
275 | static struct irq_chip ixp23xx_pci_irq_chip = { | 282 | static struct irq_chip ixp23xx_pci_irq_chip = { |
276 | .ack = ixp23xx_pci_irq_mask, | 283 | .irq_ack = ixp23xx_pci_irq_mask, |
277 | .mask = ixp23xx_pci_irq_mask, | 284 | .irq_mask = ixp23xx_pci_irq_mask, |
278 | .unmask = ixp23xx_pci_irq_unmask | 285 | .irq_unmask = ixp23xx_pci_irq_unmask |
279 | }; | 286 | }; |
280 | 287 | ||
281 | static void ixp23xx_config_irq(unsigned int irq, enum ixp23xx_irq_type type) | 288 | static void ixp23xx_config_irq(unsigned int irq, enum ixp23xx_irq_type type) |
diff --git a/arch/arm/mach-ixp23xx/ixdp2351.c b/arch/arm/mach-ixp23xx/ixdp2351.c index 664e39c2a903..181116aa6591 100644 --- a/arch/arm/mach-ixp23xx/ixdp2351.c +++ b/arch/arm/mach-ixp23xx/ixdp2351.c | |||
@@ -48,14 +48,14 @@ | |||
48 | /* | 48 | /* |
49 | * IXDP2351 Interrupt Handling | 49 | * IXDP2351 Interrupt Handling |
50 | */ | 50 | */ |
51 | static void ixdp2351_inta_mask(unsigned int irq) | 51 | static void ixdp2351_inta_mask(struct irq_data *d) |
52 | { | 52 | { |
53 | *IXDP2351_CPLD_INTA_MASK_SET_REG = IXDP2351_INTA_IRQ_MASK(irq); | 53 | *IXDP2351_CPLD_INTA_MASK_SET_REG = IXDP2351_INTA_IRQ_MASK(d->irq); |
54 | } | 54 | } |
55 | 55 | ||
56 | static void ixdp2351_inta_unmask(unsigned int irq) | 56 | static void ixdp2351_inta_unmask(struct irq_data *d) |
57 | { | 57 | { |
58 | *IXDP2351_CPLD_INTA_MASK_CLR_REG = IXDP2351_INTA_IRQ_MASK(irq); | 58 | *IXDP2351_CPLD_INTA_MASK_CLR_REG = IXDP2351_INTA_IRQ_MASK(d->irq); |
59 | } | 59 | } |
60 | 60 | ||
61 | static void ixdp2351_inta_handler(unsigned int irq, struct irq_desc *desc) | 61 | static void ixdp2351_inta_handler(unsigned int irq, struct irq_desc *desc) |
@@ -64,7 +64,7 @@ static void ixdp2351_inta_handler(unsigned int irq, struct irq_desc *desc) | |||
64 | *IXDP2351_CPLD_INTA_STAT_REG & IXDP2351_INTA_IRQ_VALID; | 64 | *IXDP2351_CPLD_INTA_STAT_REG & IXDP2351_INTA_IRQ_VALID; |
65 | int i; | 65 | int i; |
66 | 66 | ||
67 | desc->chip->mask(irq); | 67 | desc->irq_data.chip->irq_mask(&desc->irq_data); |
68 | 68 | ||
69 | for (i = 0; i < IXDP2351_INTA_IRQ_NUM; i++) { | 69 | for (i = 0; i < IXDP2351_INTA_IRQ_NUM; i++) { |
70 | if (ex_interrupt & (1 << i)) { | 70 | if (ex_interrupt & (1 << i)) { |
@@ -74,23 +74,23 @@ static void ixdp2351_inta_handler(unsigned int irq, struct irq_desc *desc) | |||
74 | } | 74 | } |
75 | } | 75 | } |
76 | 76 | ||
77 | desc->chip->unmask(irq); | 77 | desc->irq_data.chip->irq_unmask(&desc->irq_data); |
78 | } | 78 | } |
79 | 79 | ||
80 | static struct irq_chip ixdp2351_inta_chip = { | 80 | static struct irq_chip ixdp2351_inta_chip = { |
81 | .ack = ixdp2351_inta_mask, | 81 | .irq_ack = ixdp2351_inta_mask, |
82 | .mask = ixdp2351_inta_mask, | 82 | .irq_mask = ixdp2351_inta_mask, |
83 | .unmask = ixdp2351_inta_unmask | 83 | .irq_unmask = ixdp2351_inta_unmask |
84 | }; | 84 | }; |
85 | 85 | ||
86 | static void ixdp2351_intb_mask(unsigned int irq) | 86 | static void ixdp2351_intb_mask(struct irq_data *d) |
87 | { | 87 | { |
88 | *IXDP2351_CPLD_INTB_MASK_SET_REG = IXDP2351_INTB_IRQ_MASK(irq); | 88 | *IXDP2351_CPLD_INTB_MASK_SET_REG = IXDP2351_INTB_IRQ_MASK(d->irq); |
89 | } | 89 | } |
90 | 90 | ||
91 | static void ixdp2351_intb_unmask(unsigned int irq) | 91 | static void ixdp2351_intb_unmask(struct irq_data *d) |
92 | { | 92 | { |
93 | *IXDP2351_CPLD_INTB_MASK_CLR_REG = IXDP2351_INTB_IRQ_MASK(irq); | 93 | *IXDP2351_CPLD_INTB_MASK_CLR_REG = IXDP2351_INTB_IRQ_MASK(d->irq); |
94 | } | 94 | } |
95 | 95 | ||
96 | static void ixdp2351_intb_handler(unsigned int irq, struct irq_desc *desc) | 96 | static void ixdp2351_intb_handler(unsigned int irq, struct irq_desc *desc) |
@@ -99,7 +99,7 @@ static void ixdp2351_intb_handler(unsigned int irq, struct irq_desc *desc) | |||
99 | *IXDP2351_CPLD_INTB_STAT_REG & IXDP2351_INTB_IRQ_VALID; | 99 | *IXDP2351_CPLD_INTB_STAT_REG & IXDP2351_INTB_IRQ_VALID; |
100 | int i; | 100 | int i; |
101 | 101 | ||
102 | desc->chip->ack(irq); | 102 | desc->irq_data.chip->irq_ack(&desc->irq_data); |
103 | 103 | ||
104 | for (i = 0; i < IXDP2351_INTB_IRQ_NUM; i++) { | 104 | for (i = 0; i < IXDP2351_INTB_IRQ_NUM; i++) { |
105 | if (ex_interrupt & (1 << i)) { | 105 | if (ex_interrupt & (1 << i)) { |
@@ -109,13 +109,13 @@ static void ixdp2351_intb_handler(unsigned int irq, struct irq_desc *desc) | |||
109 | } | 109 | } |
110 | } | 110 | } |
111 | 111 | ||
112 | desc->chip->unmask(irq); | 112 | desc->irq_data.chip->irq_unmask(&desc->irq_data); |
113 | } | 113 | } |
114 | 114 | ||
115 | static struct irq_chip ixdp2351_intb_chip = { | 115 | static struct irq_chip ixdp2351_intb_chip = { |
116 | .ack = ixdp2351_intb_mask, | 116 | .irq_ack = ixdp2351_intb_mask, |
117 | .mask = ixdp2351_intb_mask, | 117 | .irq_mask = ixdp2351_intb_mask, |
118 | .unmask = ixdp2351_intb_unmask | 118 | .irq_unmask = ixdp2351_intb_unmask |
119 | }; | 119 | }; |
120 | 120 | ||
121 | void __init ixdp2351_init_irq(void) | 121 | void __init ixdp2351_init_irq(void) |