aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
Diffstat (limited to 'arch')
-rw-r--r--arch/m68k/amiga/amiints.c9
-rw-r--r--arch/m68k/amiga/cia.c18
-rw-r--r--arch/m68k/apollo/dn_ints.c11
-rw-r--r--arch/m68k/atari/ataints.c15
-rw-r--r--arch/m68k/include/asm/irq.h15
-rw-r--r--arch/m68k/kernel/ints.c86
-rw-r--r--arch/m68k/mac/macints.c9
-rw-r--r--arch/m68k/q40/q40ints.c17
-rw-r--r--arch/m68k/sun3/sun3ints.c13
9 files changed, 91 insertions, 102 deletions
diff --git a/arch/m68k/amiga/amiints.c b/arch/m68k/amiga/amiints.c
index c5b5212cc3f9..320c5d048dc7 100644
--- a/arch/m68k/amiga/amiints.c
+++ b/arch/m68k/amiga/amiints.c
@@ -52,11 +52,10 @@ static irqreturn_t ami_int3(int irq, void *dev_id);
52static irqreturn_t ami_int4(int irq, void *dev_id); 52static irqreturn_t ami_int4(int irq, void *dev_id);
53static irqreturn_t ami_int5(int irq, void *dev_id); 53static irqreturn_t ami_int5(int irq, void *dev_id);
54 54
55static struct irq_controller amiga_irq_controller = { 55static struct irq_chip amiga_irq_chip = {
56 .name = "amiga", 56 .name = "amiga",
57 .lock = __SPIN_LOCK_UNLOCKED(amiga_irq_controller.lock), 57 .irq_enable = amiga_enable_irq,
58 .enable = amiga_enable_irq, 58 .irq_disable = amiga_disable_irq,
59 .disable = amiga_disable_irq,
60}; 59};
61 60
62/* 61/*
@@ -81,7 +80,7 @@ void __init amiga_init_IRQ(void)
81 if (request_irq(IRQ_AUTO_5, ami_int5, 0, "int5", NULL)) 80 if (request_irq(IRQ_AUTO_5, ami_int5, 0, "int5", NULL))
82 pr_err("Couldn't register int%d\n", 5); 81 pr_err("Couldn't register int%d\n", 5);
83 82
84 m68k_setup_irq_controller(&amiga_irq_controller, IRQ_USER, AMI_STD_IRQS); 83 m68k_setup_irq_chip(&amiga_irq_chip, IRQ_USER, AMI_STD_IRQS);
85 84
86 /* turn off PCMCIA interrupts */ 85 /* turn off PCMCIA interrupts */
87 if (AMIGAHW_PRESENT(PCMCIA)) 86 if (AMIGAHW_PRESENT(PCMCIA))
diff --git a/arch/m68k/amiga/cia.c b/arch/m68k/amiga/cia.c
index ecd0f7ca6f0e..637ef53112b6 100644
--- a/arch/m68k/amiga/cia.c
+++ b/arch/m68k/amiga/cia.c
@@ -121,11 +121,10 @@ static void cia_disable_irq(unsigned int irq)
121 cia_able_irq(&ciaa_base, 1 << (irq - IRQ_AMIGA_CIAA)); 121 cia_able_irq(&ciaa_base, 1 << (irq - IRQ_AMIGA_CIAA));
122} 122}
123 123
124static struct irq_controller cia_irq_controller = { 124static struct irq_chip cia_irq_chip = {
125 .name = "cia", 125 .name = "cia",
126 .lock = __SPIN_LOCK_UNLOCKED(cia_irq_controller.lock), 126 .irq_enable = cia_enable_irq,
127 .enable = cia_enable_irq, 127 .irq_disable = cia_disable_irq,
128 .disable = cia_disable_irq,
129}; 128};
130 129
131/* 130/*
@@ -158,23 +157,22 @@ static void auto_disable_irq(unsigned int irq)
158 } 157 }
159} 158}
160 159
161static struct irq_controller auto_irq_controller = { 160static struct irq_chip auto_irq_chip = {
162 .name = "auto", 161 .name = "auto",
163 .lock = __SPIN_LOCK_UNLOCKED(auto_irq_controller.lock), 162 .irq_enable = auto_enable_irq,
164 .enable = auto_enable_irq, 163 .irq_disable = auto_disable_irq,
165 .disable = auto_disable_irq,
166}; 164};
167 165
168void __init cia_init_IRQ(struct ciabase *base) 166void __init cia_init_IRQ(struct ciabase *base)
169{ 167{
170 m68k_setup_irq_controller(&cia_irq_controller, base->cia_irq, CIA_IRQS); 168 m68k_setup_irq_chip(&cia_irq_chip, base->cia_irq, CIA_IRQS);
171 169
172 /* clear any pending interrupt and turn off all interrupts */ 170 /* clear any pending interrupt and turn off all interrupts */
173 cia_set_irq(base, CIA_ICR_ALL); 171 cia_set_irq(base, CIA_ICR_ALL);
174 cia_able_irq(base, CIA_ICR_ALL); 172 cia_able_irq(base, CIA_ICR_ALL);
175 173
176 /* override auto int and install CIA handler */ 174 /* override auto int and install CIA handler */
177 m68k_setup_irq_controller(&auto_irq_controller, base->handler_irq, 1); 175 m68k_setup_irq_chip(&auto_irq_chip, base->handler_irq, 1);
178 m68k_irq_startup(base->handler_irq); 176 m68k_irq_startup(base->handler_irq);
179 if (request_irq(base->handler_irq, cia_handler, IRQF_SHARED, 177 if (request_irq(base->handler_irq, cia_handler, IRQF_SHARED,
180 base->name, base)) 178 base->name, base))
diff --git a/arch/m68k/apollo/dn_ints.c b/arch/m68k/apollo/dn_ints.c
index 5d47f3aa3810..d6e8f33466be 100644
--- a/arch/m68k/apollo/dn_ints.c
+++ b/arch/m68k/apollo/dn_ints.c
@@ -12,7 +12,7 @@ void dn_process_int(unsigned int irq, struct pt_regs *fp)
12 *(volatile unsigned char *)(picb)=0x20; 12 *(volatile unsigned char *)(picb)=0x20;
13} 13}
14 14
15int apollo_irq_startup(unsigned int irq) 15unsigned int apollo_irq_startup(unsigned int irq)
16{ 16{
17 if (irq < 8) 17 if (irq < 8)
18 *(volatile unsigned char *)(pica+1) &= ~(1 << irq); 18 *(volatile unsigned char *)(pica+1) &= ~(1 << irq);
@@ -29,16 +29,15 @@ void apollo_irq_shutdown(unsigned int irq)
29 *(volatile unsigned char *)(picb+1) |= (1 << (irq - 8)); 29 *(volatile unsigned char *)(picb+1) |= (1 << (irq - 8));
30} 30}
31 31
32static struct irq_controller apollo_irq_controller = { 32static struct irq_chip apollo_irq_chip = {
33 .name = "apollo", 33 .name = "apollo",
34 .lock = __SPIN_LOCK_UNLOCKED(apollo_irq_controller.lock), 34 .irq_startup = apollo_irq_startup,
35 .startup = apollo_irq_startup, 35 .irq_shutdown = apollo_irq_shutdown,
36 .shutdown = apollo_irq_shutdown,
37}; 36};
38 37
39 38
40void __init dn_init_IRQ(void) 39void __init dn_init_IRQ(void)
41{ 40{
42 m68k_setup_user_interrupt(VEC_USER + 96, 16, dn_process_int); 41 m68k_setup_user_interrupt(VEC_USER + 96, 16, dn_process_int);
43 m68k_setup_irq_controller(&apollo_irq_controller, IRQ_APOLLO, 16); 42 m68k_setup_irq_chip(&apollo_irq_chip, IRQ_APOLLO, 16);
44} 43}
diff --git a/arch/m68k/atari/ataints.c b/arch/m68k/atari/ataints.c
index 26a804e67bce..ac0ebdf6ca72 100644
--- a/arch/m68k/atari/ataints.c
+++ b/arch/m68k/atari/ataints.c
@@ -320,7 +320,7 @@ extern void atari_microwire_cmd(int cmd);
320 320
321extern int atari_SCC_reset_done; 321extern int atari_SCC_reset_done;
322 322
323static int atari_startup_irq(unsigned int irq) 323static unsigned int atari_startup_irq(unsigned int irq)
324{ 324{
325 m68k_irq_startup(irq); 325 m68k_irq_startup(irq);
326 atari_turnon_irq(irq); 326 atari_turnon_irq(irq);
@@ -338,13 +338,12 @@ static void atari_shutdown_irq(unsigned int irq)
338 vectors[VEC_INT4] = falcon_hblhandler; 338 vectors[VEC_INT4] = falcon_hblhandler;
339} 339}
340 340
341static struct irq_controller atari_irq_controller = { 341static struct irq_chip atari_irq_chip = {
342 .name = "atari", 342 .name = "atari",
343 .lock = __SPIN_LOCK_UNLOCKED(atari_irq_controller.lock), 343 .irq_startup = atari_startup_irq,
344 .startup = atari_startup_irq, 344 .irq_shutdown = atari_shutdown_irq,
345 .shutdown = atari_shutdown_irq, 345 .irq_enable = atari_enable_irq,
346 .enable = atari_enable_irq, 346 .irq_disable = atari_disable_irq,
347 .disable = atari_disable_irq,
348}; 347};
349 348
350/* 349/*
@@ -361,7 +360,7 @@ static struct irq_controller atari_irq_controller = {
361void __init atari_init_IRQ(void) 360void __init atari_init_IRQ(void)
362{ 361{
363 m68k_setup_user_interrupt(VEC_USER, NUM_ATARI_SOURCES - IRQ_USER, NULL); 362 m68k_setup_user_interrupt(VEC_USER, NUM_ATARI_SOURCES - IRQ_USER, NULL);
364 m68k_setup_irq_controller(&atari_irq_controller, 1, NUM_ATARI_SOURCES - 1); 363 m68k_setup_irq_chip(&atari_irq_chip, 1, NUM_ATARI_SOURCES - 1);
365 364
366 /* Initialize the MFP(s) */ 365 /* Initialize the MFP(s) */
367 366
diff --git a/arch/m68k/include/asm/irq.h b/arch/m68k/include/asm/irq.h
index 69ed0d74d532..d8c6f68b7a78 100644
--- a/arch/m68k/include/asm/irq.h
+++ b/arch/m68k/include/asm/irq.h
@@ -93,16 +93,15 @@ struct irq_handler {
93 const char *devname; 93 const char *devname;
94}; 94};
95 95
96struct irq_controller { 96struct irq_chip {
97 const char *name; 97 const char *name;
98 spinlock_t lock; 98 unsigned int (*irq_startup)(unsigned int irq);
99 int (*startup)(unsigned int irq); 99 void (*irq_shutdown)(unsigned int irq);
100 void (*shutdown)(unsigned int irq); 100 void (*irq_enable)(unsigned int irq);
101 void (*enable)(unsigned int irq); 101 void (*irq_disable)(unsigned int irq);
102 void (*disable)(unsigned int irq);
103}; 102};
104 103
105extern int m68k_irq_startup(unsigned int); 104extern unsigned int m68k_irq_startup(unsigned int);
106extern void m68k_irq_shutdown(unsigned int); 105extern void m68k_irq_shutdown(unsigned int);
107 106
108/* 107/*
@@ -113,7 +112,7 @@ extern irq_node_t *new_irq_node(void);
113extern void m68k_setup_auto_interrupt(void (*handler)(unsigned int, struct pt_regs *)); 112extern void m68k_setup_auto_interrupt(void (*handler)(unsigned int, struct pt_regs *));
114extern void m68k_setup_user_interrupt(unsigned int vec, unsigned int cnt, 113extern void m68k_setup_user_interrupt(unsigned int vec, unsigned int cnt,
115 void (*handler)(unsigned int, struct pt_regs *)); 114 void (*handler)(unsigned int, struct pt_regs *));
116extern void m68k_setup_irq_controller(struct irq_controller *, unsigned int, unsigned int); 115extern void m68k_setup_irq_chip(struct irq_chip *, unsigned int, unsigned int);
117 116
118asmlinkage void m68k_handle_int(unsigned int); 117asmlinkage void m68k_handle_int(unsigned int);
119asmlinkage void __m68k_handle_int(unsigned int, struct pt_regs *); 118asmlinkage void __m68k_handle_int(unsigned int, struct pt_regs *);
diff --git a/arch/m68k/kernel/ints.c b/arch/m68k/kernel/ints.c
index 761ee0440c99..f43ad7b93ab6 100644
--- a/arch/m68k/kernel/ints.c
+++ b/arch/m68k/kernel/ints.c
@@ -52,23 +52,21 @@ extern u16 user_irqvec_fixup[];
52 52
53/* table for system interrupt handlers */ 53/* table for system interrupt handlers */
54static struct irq_node *irq_list[NR_IRQS]; 54static struct irq_node *irq_list[NR_IRQS];
55static struct irq_controller *irq_controller[NR_IRQS]; 55static struct irq_chip *irq_chip[NR_IRQS];
56static int irq_depth[NR_IRQS]; 56static int irq_depth[NR_IRQS];
57 57
58static int m68k_first_user_vec; 58static int m68k_first_user_vec;
59 59
60static struct irq_controller auto_irq_controller = { 60static struct irq_chip auto_irq_chip = {
61 .name = "auto", 61 .name = "auto",
62 .lock = __SPIN_LOCK_UNLOCKED(auto_irq_controller.lock), 62 .irq_startup = m68k_irq_startup,
63 .startup = m68k_irq_startup, 63 .irq_shutdown = m68k_irq_shutdown,
64 .shutdown = m68k_irq_shutdown,
65}; 64};
66 65
67static struct irq_controller user_irq_controller = { 66static struct irq_chip user_irq_chip = {
68 .name = "user", 67 .name = "user",
69 .lock = __SPIN_LOCK_UNLOCKED(user_irq_controller.lock), 68 .irq_startup = m68k_irq_startup,
70 .startup = m68k_irq_startup, 69 .irq_shutdown = m68k_irq_shutdown,
71 .shutdown = m68k_irq_shutdown,
72}; 70};
73 71
74#define NUM_IRQ_NODES 100 72#define NUM_IRQ_NODES 100
@@ -96,7 +94,7 @@ void __init init_IRQ(void)
96 } 94 }
97 95
98 for (i = IRQ_AUTO_1; i <= IRQ_AUTO_7; i++) 96 for (i = IRQ_AUTO_1; i <= IRQ_AUTO_7; i++)
99 irq_controller[i] = &auto_irq_controller; 97 irq_chip[i] = &auto_irq_chip;
100 98
101 mach_init_IRQ(); 99 mach_init_IRQ();
102} 100}
@@ -136,7 +134,7 @@ void __init m68k_setup_user_interrupt(unsigned int vec, unsigned int cnt,
136 BUG_ON(IRQ_USER + cnt > NR_IRQS); 134 BUG_ON(IRQ_USER + cnt > NR_IRQS);
137 m68k_first_user_vec = vec; 135 m68k_first_user_vec = vec;
138 for (i = 0; i < cnt; i++) 136 for (i = 0; i < cnt; i++)
139 irq_controller[IRQ_USER + i] = &user_irq_controller; 137 irq_chip[IRQ_USER + i] = &user_irq_chip;
140 *user_irqvec_fixup = vec - IRQ_USER; 138 *user_irqvec_fixup = vec - IRQ_USER;
141 if (handler) 139 if (handler)
142 *user_irqhandler_fixup = (u32)handler; 140 *user_irqhandler_fixup = (u32)handler;
@@ -144,7 +142,7 @@ void __init m68k_setup_user_interrupt(unsigned int vec, unsigned int cnt,
144} 142}
145 143
146/** 144/**
147 * m68k_setup_irq_controller 145 * m68k_setup_irq_chip
148 * @contr: irq controller which controls specified irq 146 * @contr: irq controller which controls specified irq
149 * @irq: first irq to be managed by the controller 147 * @irq: first irq to be managed by the controller
150 * 148 *
@@ -153,13 +151,13 @@ void __init m68k_setup_user_interrupt(unsigned int vec, unsigned int cnt,
153 * be changed as well, but the controller probably should use m68k_irq_startup/ 151 * be changed as well, but the controller probably should use m68k_irq_startup/
154 * m68k_irq_shutdown. 152 * m68k_irq_shutdown.
155 */ 153 */
156void m68k_setup_irq_controller(struct irq_controller *contr, unsigned int irq, 154void m68k_setup_irq_chip(struct irq_chip *contr, unsigned int irq,
157 unsigned int cnt) 155 unsigned int cnt)
158{ 156{
159 int i; 157 int i;
160 158
161 for (i = 0; i < cnt; i++) 159 for (i = 0; i < cnt; i++)
162 irq_controller[irq + i] = contr; 160 irq_chip[irq + i] = contr;
163} 161}
164 162
165irq_node_t *new_irq_node(void) 163irq_node_t *new_irq_node(void)
@@ -180,23 +178,23 @@ irq_node_t *new_irq_node(void)
180 178
181int setup_irq(unsigned int irq, struct irq_node *node) 179int setup_irq(unsigned int irq, struct irq_node *node)
182{ 180{
183 struct irq_controller *contr; 181 struct irq_chip *contr;
184 struct irq_node **prev; 182 struct irq_node **prev;
185 unsigned long flags; 183 unsigned long flags;
186 184
187 if (irq >= NR_IRQS || !(contr = irq_controller[irq])) { 185 if (irq >= NR_IRQS || !(contr = irq_chip[irq])) {
188 printk("%s: Incorrect IRQ %d from %s\n", 186 printk("%s: Incorrect IRQ %d from %s\n",
189 __func__, irq, node->devname); 187 __func__, irq, node->devname);
190 return -ENXIO; 188 return -ENXIO;
191 } 189 }
192 190
193 spin_lock_irqsave(&contr->lock, flags); 191 local_irq_save(flags);
194 192
195 prev = irq_list + irq; 193 prev = irq_list + irq;
196 if (*prev) { 194 if (*prev) {
197 /* Can't share interrupts unless both agree to */ 195 /* Can't share interrupts unless both agree to */
198 if (!((*prev)->flags & node->flags & IRQF_SHARED)) { 196 if (!((*prev)->flags & node->flags & IRQF_SHARED)) {
199 spin_unlock_irqrestore(&contr->lock, flags); 197 local_irq_restore(flags);
200 return -EBUSY; 198 return -EBUSY;
201 } 199 }
202 while (*prev) 200 while (*prev)
@@ -204,15 +202,15 @@ int setup_irq(unsigned int irq, struct irq_node *node)
204 } 202 }
205 203
206 if (!irq_list[irq]) { 204 if (!irq_list[irq]) {
207 if (contr->startup) 205 if (contr->irq_startup)
208 contr->startup(irq); 206 contr->irq_startup(irq);
209 else 207 else
210 contr->enable(irq); 208 contr->irq_enable(irq);
211 } 209 }
212 node->next = NULL; 210 node->next = NULL;
213 *prev = node; 211 *prev = node;
214 212
215 spin_unlock_irqrestore(&contr->lock, flags); 213 local_irq_restore(flags);
216 214
217 return 0; 215 return 0;
218} 216}
@@ -244,16 +242,16 @@ EXPORT_SYMBOL(request_irq);
244 242
245void free_irq(unsigned int irq, void *dev_id) 243void free_irq(unsigned int irq, void *dev_id)
246{ 244{
247 struct irq_controller *contr; 245 struct irq_chip *contr;
248 struct irq_node **p, *node; 246 struct irq_node **p, *node;
249 unsigned long flags; 247 unsigned long flags;
250 248
251 if (irq >= NR_IRQS || !(contr = irq_controller[irq])) { 249 if (irq >= NR_IRQS || !(contr = irq_chip[irq])) {
252 printk("%s: Incorrect IRQ %d\n", __func__, irq); 250 printk("%s: Incorrect IRQ %d\n", __func__, irq);
253 return; 251 return;
254 } 252 }
255 253
256 spin_lock_irqsave(&contr->lock, flags); 254 local_irq_save(flags);
257 255
258 p = irq_list + irq; 256 p = irq_list + irq;
259 while ((node = *p)) { 257 while ((node = *p)) {
@@ -270,58 +268,58 @@ void free_irq(unsigned int irq, void *dev_id)
270 __func__, irq); 268 __func__, irq);
271 269
272 if (!irq_list[irq]) { 270 if (!irq_list[irq]) {
273 if (contr->shutdown) 271 if (contr->irq_shutdown)
274 contr->shutdown(irq); 272 contr->irq_shutdown(irq);
275 else 273 else
276 contr->disable(irq); 274 contr->irq_disable(irq);
277 } 275 }
278 276
279 spin_unlock_irqrestore(&contr->lock, flags); 277 local_irq_restore(flags);
280} 278}
281 279
282EXPORT_SYMBOL(free_irq); 280EXPORT_SYMBOL(free_irq);
283 281
284void enable_irq(unsigned int irq) 282void enable_irq(unsigned int irq)
285{ 283{
286 struct irq_controller *contr; 284 struct irq_chip *contr;
287 unsigned long flags; 285 unsigned long flags;
288 286
289 if (irq >= NR_IRQS || !(contr = irq_controller[irq])) { 287 if (irq >= NR_IRQS || !(contr = irq_chip[irq])) {
290 printk("%s: Incorrect IRQ %d\n", 288 printk("%s: Incorrect IRQ %d\n",
291 __func__, irq); 289 __func__, irq);
292 return; 290 return;
293 } 291 }
294 292
295 spin_lock_irqsave(&contr->lock, flags); 293 local_irq_save(flags);
296 if (irq_depth[irq]) { 294 if (irq_depth[irq]) {
297 if (!--irq_depth[irq]) { 295 if (!--irq_depth[irq]) {
298 if (contr->enable) 296 if (contr->irq_enable)
299 contr->enable(irq); 297 contr->irq_enable(irq);
300 } 298 }
301 } else 299 } else
302 WARN_ON(1); 300 WARN_ON(1);
303 spin_unlock_irqrestore(&contr->lock, flags); 301 local_irq_restore(flags);
304} 302}
305 303
306EXPORT_SYMBOL(enable_irq); 304EXPORT_SYMBOL(enable_irq);
307 305
308void disable_irq(unsigned int irq) 306void disable_irq(unsigned int irq)
309{ 307{
310 struct irq_controller *contr; 308 struct irq_chip *contr;
311 unsigned long flags; 309 unsigned long flags;
312 310
313 if (irq >= NR_IRQS || !(contr = irq_controller[irq])) { 311 if (irq >= NR_IRQS || !(contr = irq_chip[irq])) {
314 printk("%s: Incorrect IRQ %d\n", 312 printk("%s: Incorrect IRQ %d\n",
315 __func__, irq); 313 __func__, irq);
316 return; 314 return;
317 } 315 }
318 316
319 spin_lock_irqsave(&contr->lock, flags); 317 local_irq_save(flags);
320 if (!irq_depth[irq]++) { 318 if (!irq_depth[irq]++) {
321 if (contr->disable) 319 if (contr->irq_disable)
322 contr->disable(irq); 320 contr->irq_disable(irq);
323 } 321 }
324 spin_unlock_irqrestore(&contr->lock, flags); 322 local_irq_restore(flags);
325} 323}
326 324
327EXPORT_SYMBOL(disable_irq); 325EXPORT_SYMBOL(disable_irq);
@@ -330,7 +328,7 @@ void disable_irq_nosync(unsigned int irq) __attribute__((alias("disable_irq")));
330 328
331EXPORT_SYMBOL(disable_irq_nosync); 329EXPORT_SYMBOL(disable_irq_nosync);
332 330
333int m68k_irq_startup(unsigned int irq) 331unsigned int m68k_irq_startup(unsigned int irq)
334{ 332{
335 if (irq <= IRQ_AUTO_7) 333 if (irq <= IRQ_AUTO_7)
336 vectors[VEC_SPUR + irq] = auto_inthandler; 334 vectors[VEC_SPUR + irq] = auto_inthandler;
@@ -413,13 +411,13 @@ asmlinkage void handle_badint(struct pt_regs *regs)
413 411
414int show_interrupts(struct seq_file *p, void *v) 412int show_interrupts(struct seq_file *p, void *v)
415{ 413{
416 struct irq_controller *contr; 414 struct irq_chip *contr;
417 struct irq_node *node; 415 struct irq_node *node;
418 int i = *(loff_t *) v; 416 int i = *(loff_t *) v;
419 417
420 /* autovector interrupts */ 418 /* autovector interrupts */
421 if (irq_list[i]) { 419 if (irq_list[i]) {
422 contr = irq_controller[i]; 420 contr = irq_chip[i];
423 node = irq_list[i]; 421 node = irq_list[i];
424 seq_printf(p, "%-8s %3u: %10u %s", contr->name, i, kstat_cpu(0).irqs[i], node->devname); 422 seq_printf(p, "%-8s %3u: %10u %s", contr->name, i, kstat_cpu(0).irqs[i], node->devname);
425 while ((node = node->next)) 423 while ((node = node->next))
diff --git a/arch/m68k/mac/macints.c b/arch/m68k/mac/macints.c
index f92190c159b4..ffa1b3f7e2b7 100644
--- a/arch/m68k/mac/macints.c
+++ b/arch/m68k/mac/macints.c
@@ -193,11 +193,10 @@ irqreturn_t mac_debug_handler(int, void *);
193void mac_enable_irq(unsigned int irq); 193void mac_enable_irq(unsigned int irq);
194void mac_disable_irq(unsigned int irq); 194void mac_disable_irq(unsigned int irq);
195 195
196static struct irq_controller mac_irq_controller = { 196static struct irq_chip mac_irq_chip = {
197 .name = "mac", 197 .name = "mac",
198 .lock = __SPIN_LOCK_UNLOCKED(mac_irq_controller.lock), 198 .irq_enable = mac_enable_irq,
199 .enable = mac_enable_irq, 199 .irq_disable = mac_disable_irq,
200 .disable = mac_disable_irq,
201}; 200};
202 201
203void __init mac_init_IRQ(void) 202void __init mac_init_IRQ(void)
@@ -205,7 +204,7 @@ void __init mac_init_IRQ(void)
205#ifdef DEBUG_MACINTS 204#ifdef DEBUG_MACINTS
206 printk("mac_init_IRQ(): Setting things up...\n"); 205 printk("mac_init_IRQ(): Setting things up...\n");
207#endif 206#endif
208 m68k_setup_irq_controller(&mac_irq_controller, IRQ_USER, 207 m68k_setup_irq_chip(&mac_irq_chip, IRQ_USER,
209 NUM_MAC_SOURCES - IRQ_USER); 208 NUM_MAC_SOURCES - IRQ_USER);
210 /* Make sure the SONIC interrupt is cleared or things get ugly */ 209 /* Make sure the SONIC interrupt is cleared or things get ugly */
211#ifdef SHUTUP_SONIC 210#ifdef SHUTUP_SONIC
diff --git a/arch/m68k/q40/q40ints.c b/arch/m68k/q40/q40ints.c
index 9f0e3d59bf92..fa05a03f8dfe 100644
--- a/arch/m68k/q40/q40ints.c
+++ b/arch/m68k/q40/q40ints.c
@@ -41,14 +41,14 @@ static void q40_disable_irq(unsigned int);
41unsigned short q40_ablecount[35]; 41unsigned short q40_ablecount[35];
42unsigned short q40_state[35]; 42unsigned short q40_state[35];
43 43
44static int q40_irq_startup(unsigned int irq) 44static unsigned int q40_irq_startup(unsigned int irq)
45{ 45{
46 /* test for ISA ints not implemented by HW */ 46 /* test for ISA ints not implemented by HW */
47 switch (irq) { 47 switch (irq) {
48 case 1: case 2: case 8: case 9: 48 case 1: case 2: case 8: case 9:
49 case 11: case 12: case 13: 49 case 11: case 12: case 13:
50 printk("%s: ISA IRQ %d not implemented by HW\n", __func__, irq); 50 printk("%s: ISA IRQ %d not implemented by HW\n", __func__, irq);
51 return -ENXIO; 51 /* FIXME return -ENXIO; */
52 } 52 }
53 return 0; 53 return 0;
54} 54}
@@ -57,13 +57,12 @@ static void q40_irq_shutdown(unsigned int irq)
57{ 57{
58} 58}
59 59
60static struct irq_controller q40_irq_controller = { 60static struct irq_chip q40_irq_chip = {
61 .name = "q40", 61 .name = "q40",
62 .lock = __SPIN_LOCK_UNLOCKED(q40_irq_controller.lock), 62 .irq_startup = q40_irq_startup,
63 .startup = q40_irq_startup, 63 .irq_shutdown = q40_irq_shutdown,
64 .shutdown = q40_irq_shutdown, 64 .irq_enable = q40_enable_irq,
65 .enable = q40_enable_irq, 65 .irq_disable = q40_disable_irq,
66 .disable = q40_disable_irq,
67}; 66};
68 67
69/* 68/*
@@ -81,7 +80,7 @@ static int disabled;
81 80
82void __init q40_init_IRQ(void) 81void __init q40_init_IRQ(void)
83{ 82{
84 m68k_setup_irq_controller(&q40_irq_controller, 1, Q40_IRQ_MAX); 83 m68k_setup_irq_chip(&q40_irq_chip, 1, Q40_IRQ_MAX);
85 84
86 /* setup handler for ISA ints */ 85 /* setup handler for ISA ints */
87 m68k_setup_auto_interrupt(q40_irq_handler); 86 m68k_setup_auto_interrupt(q40_irq_handler);
diff --git a/arch/m68k/sun3/sun3ints.c b/arch/m68k/sun3/sun3ints.c
index 6464ad3ae3e6..97fa9edc5a9d 100644
--- a/arch/m68k/sun3/sun3ints.c
+++ b/arch/m68k/sun3/sun3ints.c
@@ -86,13 +86,12 @@ static void sun3_inthandle(unsigned int irq, struct pt_regs *fp)
86 __m68k_handle_int(irq, fp); 86 __m68k_handle_int(irq, fp);
87} 87}
88 88
89static struct irq_controller sun3_irq_controller = { 89static struct irq_chip sun3_irq_chip = {
90 .name = "sun3", 90 .name = "sun3",
91 .lock = __SPIN_LOCK_UNLOCKED(sun3_irq_controller.lock), 91 .irq_startup = m68k_irq_startup,
92 .startup = m68k_irq_startup, 92 .irq_shutdown = m68k_irq_shutdown,
93 .shutdown = m68k_irq_shutdown, 93 .irq_enable = sun3_enable_irq,
94 .enable = sun3_enable_irq, 94 .irq_disable = sun3_disable_irq,
95 .disable = sun3_disable_irq,
96}; 95};
97 96
98void __init sun3_init_IRQ(void) 97void __init sun3_init_IRQ(void)
@@ -100,7 +99,7 @@ void __init sun3_init_IRQ(void)
100 *sun3_intreg = 1; 99 *sun3_intreg = 1;
101 100
102 m68k_setup_auto_interrupt(sun3_inthandle); 101 m68k_setup_auto_interrupt(sun3_inthandle);
103 m68k_setup_irq_controller(&sun3_irq_controller, IRQ_AUTO_1, 7); 102 m68k_setup_irq_chip(&sun3_irq_chip, IRQ_AUTO_1, 7);
104 m68k_setup_user_interrupt(VEC_USER, 128, NULL); 103 m68k_setup_user_interrupt(VEC_USER, 128, NULL);
105 104
106 if (request_irq(IRQ_AUTO_5, sun3_int5, 0, "int5", NULL)) 105 if (request_irq(IRQ_AUTO_5, sun3_int5, 0, "int5", NULL))