diff options
| author | Greg Ungerer <gerg@snapgear.com> | 2006-11-20 00:46:22 -0500 |
|---|---|---|
| committer | Linus Torvalds <torvalds@woody.osdl.org> | 2006-11-20 13:16:49 -0500 |
| commit | ace5f1d425beaa272b6e91cecc87b2c075d7feb2 (patch) | |
| tree | 9445f6ba8d8be95e999fdd2496027cee48713b72 | |
| parent | 49a1cd00b599d12c3f397e5a32f81f6e2aab0d74 (diff) | |
[PATCH] m68knommu: fix up for the irq_handler_t changes
Switch to using irq_handler_t for interrupt function handler pointers.
Change name of m68knommu's irq_hanlder_t data structure so it doesn't
clash with the common type (include/linux/interrupt.h).
Signed-off-by: Greg Ungerer <gerg@uclinux.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
| -rw-r--r-- | arch/m68knommu/kernel/setup.c | 2 | ||||
| -rw-r--r-- | arch/m68knommu/kernel/time.c | 2 | ||||
| -rw-r--r-- | arch/m68knommu/platform/5307/ints.c | 17 | ||||
| -rw-r--r-- | include/asm-m68knommu/irq_regs.h | 1 | ||||
| -rw-r--r-- | include/asm-m68knommu/irqnode.h | 8 | ||||
| -rw-r--r-- | include/asm-m68knommu/machdep.h | 2 |
6 files changed, 16 insertions, 16 deletions
diff --git a/arch/m68knommu/kernel/setup.c b/arch/m68knommu/kernel/setup.c index bde9811cf98c..7b21959eaeae 100644 --- a/arch/m68knommu/kernel/setup.c +++ b/arch/m68knommu/kernel/setup.c | |||
| @@ -62,7 +62,7 @@ int (*mach_kbdrate) (struct kbd_repeat *); | |||
| 62 | void (*mach_kbd_leds) (unsigned int); | 62 | void (*mach_kbd_leds) (unsigned int); |
| 63 | /* machine dependent irq functions */ | 63 | /* machine dependent irq functions */ |
| 64 | void (*mach_init_IRQ) (void); | 64 | void (*mach_init_IRQ) (void); |
| 65 | irqreturn_t (*(*mach_default_handler)[]) (int, void *, struct pt_regs *); | 65 | irq_handler_t mach_default_handler; |
| 66 | int (*mach_get_irq_list) (struct seq_file *, void *); | 66 | int (*mach_get_irq_list) (struct seq_file *, void *); |
| 67 | void (*mach_process_int) (int irq, struct pt_regs *fp); | 67 | void (*mach_process_int) (int irq, struct pt_regs *fp); |
| 68 | void (*mach_trap_init) (void); | 68 | void (*mach_trap_init) (void); |
diff --git a/arch/m68knommu/kernel/time.c b/arch/m68knommu/kernel/time.c index c5667bdddd5e..9226264abf1a 100644 --- a/arch/m68knommu/kernel/time.c +++ b/arch/m68knommu/kernel/time.c | |||
| @@ -54,7 +54,7 @@ static irqreturn_t timer_interrupt(int irq, void *dummy, struct pt_regs * regs) | |||
| 54 | update_process_times(user_mode(regs)); | 54 | update_process_times(user_mode(regs)); |
| 55 | #endif | 55 | #endif |
| 56 | if (current->pid) | 56 | if (current->pid) |
| 57 | profile_tick(CPU_PROFILING, regs); | 57 | profile_tick(CPU_PROFILING); |
| 58 | 58 | ||
| 59 | /* | 59 | /* |
| 60 | * If we have an externally synchronized Linux clock, then update | 60 | * If we have an externally synchronized Linux clock, then update |
diff --git a/arch/m68knommu/platform/5307/ints.c b/arch/m68knommu/platform/5307/ints.c index b4b55093ae7e..a57239ec6c8c 100644 --- a/arch/m68knommu/platform/5307/ints.c +++ b/arch/m68knommu/platform/5307/ints.c | |||
| @@ -33,7 +33,7 @@ | |||
| 33 | /* | 33 | /* |
| 34 | * This table stores the address info for each vector handler. | 34 | * This table stores the address info for each vector handler. |
| 35 | */ | 35 | */ |
| 36 | irq_handler_t irq_list[SYS_IRQS]; | 36 | struct irq_entry irq_list[SYS_IRQS]; |
| 37 | 37 | ||
| 38 | #define NUM_IRQ_NODES 16 | 38 | #define NUM_IRQ_NODES 16 |
| 39 | static irq_node_t nodes[NUM_IRQ_NODES]; | 39 | static irq_node_t nodes[NUM_IRQ_NODES]; |
| @@ -44,7 +44,7 @@ volatile unsigned int num_spurious; | |||
| 44 | unsigned int local_bh_count[NR_CPUS]; | 44 | unsigned int local_bh_count[NR_CPUS]; |
| 45 | unsigned int local_irq_count[NR_CPUS]; | 45 | unsigned int local_irq_count[NR_CPUS]; |
| 46 | 46 | ||
| 47 | static irqreturn_t default_irq_handler(int irq, void *ptr, struct pt_regs *regs) | 47 | static irqreturn_t default_irq_handler(int irq, void *ptr) |
| 48 | { | 48 | { |
| 49 | #if 1 | 49 | #if 1 |
| 50 | printk(KERN_INFO "%s(%d): default irq handler vec=%d [0x%x]\n", | 50 | printk(KERN_INFO "%s(%d): default irq handler vec=%d [0x%x]\n", |
| @@ -70,7 +70,7 @@ void __init init_IRQ(void) | |||
| 70 | 70 | ||
| 71 | for (i = 0; i < SYS_IRQS; i++) { | 71 | for (i = 0; i < SYS_IRQS; i++) { |
| 72 | if (mach_default_handler) | 72 | if (mach_default_handler) |
| 73 | irq_list[i].handler = (*mach_default_handler)[i]; | 73 | irq_list[i].handler = mach_default_handler; |
| 74 | else | 74 | else |
| 75 | irq_list[i].handler = default_irq_handler; | 75 | irq_list[i].handler = default_irq_handler; |
| 76 | irq_list[i].flags = IRQ_FLG_STD; | 76 | irq_list[i].flags = IRQ_FLG_STD; |
| @@ -100,7 +100,7 @@ irq_node_t *new_irq_node(void) | |||
| 100 | 100 | ||
| 101 | int request_irq( | 101 | int request_irq( |
| 102 | unsigned int irq, | 102 | unsigned int irq, |
| 103 | irqreturn_t (*handler)(int, void *, struct pt_regs *), | 103 | irq_handler_t handler, |
| 104 | unsigned long flags, | 104 | unsigned long flags, |
| 105 | const char *devname, | 105 | const char *devname, |
| 106 | void *dev_id) | 106 | void *dev_id) |
| @@ -157,7 +157,7 @@ void free_irq(unsigned int irq, void *dev_id) | |||
| 157 | } | 157 | } |
| 158 | 158 | ||
| 159 | if (mach_default_handler) | 159 | if (mach_default_handler) |
| 160 | irq_list[irq].handler = (*mach_default_handler)[irq]; | 160 | irq_list[irq].handler = mach_default_handler; |
| 161 | else | 161 | else |
| 162 | irq_list[irq].handler = default_irq_handler; | 162 | irq_list[irq].handler = default_irq_handler; |
| 163 | irq_list[irq].flags = IRQ_FLG_STD; | 163 | irq_list[irq].flags = IRQ_FLG_STD; |
| @@ -168,8 +168,7 @@ void free_irq(unsigned int irq, void *dev_id) | |||
| 168 | EXPORT_SYMBOL(free_irq); | 168 | EXPORT_SYMBOL(free_irq); |
| 169 | 169 | ||
| 170 | 170 | ||
| 171 | int sys_request_irq(unsigned int irq, | 171 | int sys_request_irq(unsigned int irq, irq_handler_t handler, |
| 172 | irqreturn_t (*handler)(int, void *, struct pt_regs *), | ||
| 173 | unsigned long flags, const char *devname, void *dev_id) | 172 | unsigned long flags, const char *devname, void *dev_id) |
| 174 | { | 173 | { |
| 175 | if (irq > IRQ7) { | 174 | if (irq > IRQ7) { |
| @@ -211,7 +210,7 @@ void sys_free_irq(unsigned int irq, void *dev_id) | |||
| 211 | printk(KERN_WARNING "%s: Removing probably wrong IRQ %d from %s\n", | 210 | printk(KERN_WARNING "%s: Removing probably wrong IRQ %d from %s\n", |
| 212 | __FUNCTION__, irq, irq_list[irq].devname); | 211 | __FUNCTION__, irq, irq_list[irq].devname); |
| 213 | 212 | ||
| 214 | irq_list[irq].handler = (*mach_default_handler)[irq]; | 213 | irq_list[irq].handler = mach_default_handler; |
| 215 | irq_list[irq].flags = 0; | 214 | irq_list[irq].flags = 0; |
| 216 | irq_list[irq].dev_id = NULL; | 215 | irq_list[irq].dev_id = NULL; |
| 217 | irq_list[irq].devname = NULL; | 216 | irq_list[irq].devname = NULL; |
| @@ -241,7 +240,7 @@ asmlinkage void process_int(unsigned long vec, struct pt_regs *fp) | |||
| 241 | if (vec >= VEC_INT1 && vec <= VEC_INT7) { | 240 | if (vec >= VEC_INT1 && vec <= VEC_INT7) { |
| 242 | vec -= VEC_SPUR; | 241 | vec -= VEC_SPUR; |
| 243 | kstat_cpu(0).irqs[vec]++; | 242 | kstat_cpu(0).irqs[vec]++; |
| 244 | irq_list[vec].handler(vec, irq_list[vec].dev_id, fp); | 243 | irq_list[vec].handler(vec, irq_list[vec].dev_id); |
| 245 | } else { | 244 | } else { |
| 246 | if (mach_process_int) | 245 | if (mach_process_int) |
| 247 | mach_process_int(vec, fp); | 246 | mach_process_int(vec, fp); |
diff --git a/include/asm-m68knommu/irq_regs.h b/include/asm-m68knommu/irq_regs.h new file mode 100644 index 000000000000..3dd9c0b70270 --- /dev/null +++ b/include/asm-m68knommu/irq_regs.h | |||
| @@ -0,0 +1 @@ | |||
| #include <asm-generic/irq_regs.h> | |||
diff --git a/include/asm-m68knommu/irqnode.h b/include/asm-m68knommu/irqnode.h index a2503dfc554c..6132a9858b52 100644 --- a/include/asm-m68knommu/irqnode.h +++ b/include/asm-m68knommu/irqnode.h | |||
| @@ -8,7 +8,7 @@ | |||
| 8 | * interrupt source (if it supports chaining). | 8 | * interrupt source (if it supports chaining). |
| 9 | */ | 9 | */ |
| 10 | typedef struct irq_node { | 10 | typedef struct irq_node { |
| 11 | irqreturn_t (*handler)(int, void *, struct pt_regs *); | 11 | irq_handler_t handler; |
| 12 | unsigned long flags; | 12 | unsigned long flags; |
| 13 | void *dev_id; | 13 | void *dev_id; |
| 14 | const char *devname; | 14 | const char *devname; |
| @@ -18,12 +18,12 @@ typedef struct irq_node { | |||
| 18 | /* | 18 | /* |
| 19 | * This structure has only 4 elements for speed reasons | 19 | * This structure has only 4 elements for speed reasons |
| 20 | */ | 20 | */ |
| 21 | typedef struct irq_handler { | 21 | struct irq_entry { |
| 22 | irqreturn_t (*handler)(int, void *, struct pt_regs *); | 22 | irq_handler_t handler; |
| 23 | unsigned long flags; | 23 | unsigned long flags; |
| 24 | void *dev_id; | 24 | void *dev_id; |
| 25 | const char *devname; | 25 | const char *devname; |
| 26 | } irq_handler_t; | 26 | }; |
| 27 | 27 | ||
| 28 | /* count of spurious interrupts */ | 28 | /* count of spurious interrupts */ |
| 29 | extern volatile unsigned int num_spurious; | 29 | extern volatile unsigned int num_spurious; |
diff --git a/include/asm-m68knommu/machdep.h b/include/asm-m68knommu/machdep.h index 27c90afd3339..6ce28f8e0ead 100644 --- a/include/asm-m68knommu/machdep.h +++ b/include/asm-m68knommu/machdep.h | |||
| @@ -18,7 +18,7 @@ extern int (*mach_kbdrate) (struct kbd_repeat *); | |||
| 18 | extern void (*mach_kbd_leds) (unsigned int); | 18 | extern void (*mach_kbd_leds) (unsigned int); |
| 19 | /* machine dependent irq functions */ | 19 | /* machine dependent irq functions */ |
| 20 | extern void (*mach_init_IRQ) (void); | 20 | extern void (*mach_init_IRQ) (void); |
| 21 | extern irqreturn_t (*(*mach_default_handler)[]) (int, void *, struct pt_regs *); | 21 | extern irq_handler_t mach_default_handler; |
| 22 | extern int (*mach_request_irq) (unsigned int irq, void (*handler)(int, void *, struct pt_regs *), | 22 | extern int (*mach_request_irq) (unsigned int irq, void (*handler)(int, void *, struct pt_regs *), |
| 23 | unsigned long flags, const char *devname, void *dev_id); | 23 | unsigned long flags, const char *devname, void *dev_id); |
| 24 | extern void (*mach_free_irq) (unsigned int irq, void *dev_id); | 24 | extern void (*mach_free_irq) (unsigned int irq, void *dev_id); |
