diff options
author | Roman Zippel <zippel@linux-m68k.org> | 2006-06-25 08:47:02 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-06-25 13:00:57 -0400 |
commit | 0aa78106c661cf6c251fd56e92f0c76a7459d244 (patch) | |
tree | 6192cf0a733e47de4e702f48303f61e0a1fecc6f /arch/m68k/apollo/config.c | |
parent | 74be8d0835f91f0f77a2f1554dfa7242f1f7b652 (diff) |
[PATCH] m68k: convert apollo irq code
Signed-off-by: Roman Zippel <zippel@linux-m68k.org>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch/m68k/apollo/config.c')
-rw-r--r-- | arch/m68k/apollo/config.c | 24 |
1 files changed, 5 insertions, 19 deletions
diff --git a/arch/m68k/apollo/config.c b/arch/m68k/apollo/config.c index d401962d9b25..99c70978aafa 100644 --- a/arch/m68k/apollo/config.c +++ b/arch/m68k/apollo/config.c | |||
@@ -28,11 +28,6 @@ u_long apollo_model; | |||
28 | 28 | ||
29 | extern void dn_sched_init(irqreturn_t (*handler)(int,void *,struct pt_regs *)); | 29 | extern void dn_sched_init(irqreturn_t (*handler)(int,void *,struct pt_regs *)); |
30 | extern void dn_init_IRQ(void); | 30 | extern void dn_init_IRQ(void); |
31 | extern int dn_request_irq(unsigned int irq, irqreturn_t (*handler)(int, void *, struct pt_regs *), unsigned long flags, const char *devname, void *dev_id); | ||
32 | extern void dn_free_irq(unsigned int irq, void *dev_id); | ||
33 | extern void dn_enable_irq(unsigned int); | ||
34 | extern void dn_disable_irq(unsigned int); | ||
35 | extern int show_dn_interrupts(struct seq_file *, void *); | ||
36 | extern unsigned long dn_gettimeoffset(void); | 31 | extern unsigned long dn_gettimeoffset(void); |
37 | extern int dn_dummy_hwclk(int, struct rtc_time *); | 32 | extern int dn_dummy_hwclk(int, struct rtc_time *); |
38 | extern int dn_dummy_set_clock_mmss(unsigned long); | 33 | extern int dn_dummy_set_clock_mmss(unsigned long); |
@@ -40,13 +35,11 @@ extern void dn_dummy_reset(void); | |||
40 | extern void dn_dummy_waitbut(void); | 35 | extern void dn_dummy_waitbut(void); |
41 | extern struct fb_info *dn_fb_init(long *); | 36 | extern struct fb_info *dn_fb_init(long *); |
42 | extern void dn_dummy_debug_init(void); | 37 | extern void dn_dummy_debug_init(void); |
43 | extern void dn_dummy_video_setup(char *,int *); | ||
44 | extern irqreturn_t dn_process_int(int irq, struct pt_regs *fp); | 38 | extern irqreturn_t dn_process_int(int irq, struct pt_regs *fp); |
45 | #ifdef CONFIG_HEARTBEAT | 39 | #ifdef CONFIG_HEARTBEAT |
46 | static void dn_heartbeat(int on); | 40 | static void dn_heartbeat(int on); |
47 | #endif | 41 | #endif |
48 | static irqreturn_t dn_timer_int(int irq,void *, struct pt_regs *); | 42 | static irqreturn_t dn_timer_int(int irq,void *, struct pt_regs *); |
49 | static irqreturn_t (*sched_timer_handler)(int, void *, struct pt_regs *)=NULL; | ||
50 | static void dn_get_model(char *model); | 43 | static void dn_get_model(char *model); |
51 | static const char *apollo_models[] = { | 44 | static const char *apollo_models[] = { |
52 | [APOLLO_DN3000-APOLLO_DN3000] = "DN3000 (Otter)", | 45 | [APOLLO_DN3000-APOLLO_DN3000] = "DN3000 (Otter)", |
@@ -164,17 +157,10 @@ void config_apollo(void) { | |||
164 | 157 | ||
165 | mach_sched_init=dn_sched_init; /* */ | 158 | mach_sched_init=dn_sched_init; /* */ |
166 | mach_init_IRQ=dn_init_IRQ; | 159 | mach_init_IRQ=dn_init_IRQ; |
167 | mach_default_handler=NULL; | ||
168 | mach_request_irq = dn_request_irq; | ||
169 | mach_free_irq = dn_free_irq; | ||
170 | enable_irq = dn_enable_irq; | ||
171 | disable_irq = dn_disable_irq; | ||
172 | mach_get_irq_list = show_dn_interrupts; | ||
173 | mach_gettimeoffset = dn_gettimeoffset; | 160 | mach_gettimeoffset = dn_gettimeoffset; |
174 | mach_max_dma_address = 0xffffffff; | 161 | mach_max_dma_address = 0xffffffff; |
175 | mach_hwclk = dn_dummy_hwclk; /* */ | 162 | mach_hwclk = dn_dummy_hwclk; /* */ |
176 | mach_set_clock_mmss = dn_dummy_set_clock_mmss; /* */ | 163 | mach_set_clock_mmss = dn_dummy_set_clock_mmss; /* */ |
177 | mach_process_int = dn_process_int; | ||
178 | mach_reset = dn_dummy_reset; /* */ | 164 | mach_reset = dn_dummy_reset; /* */ |
179 | #ifdef CONFIG_HEARTBEAT | 165 | #ifdef CONFIG_HEARTBEAT |
180 | mach_heartbeat = dn_heartbeat; | 166 | mach_heartbeat = dn_heartbeat; |
@@ -189,11 +175,13 @@ void config_apollo(void) { | |||
189 | 175 | ||
190 | } | 176 | } |
191 | 177 | ||
192 | irqreturn_t dn_timer_int(int irq, void *dev_id, struct pt_regs *fp) { | 178 | irqreturn_t dn_timer_int(int irq, void *dev_id, struct pt_regs *fp) |
179 | { | ||
180 | irqreturn_t (*timer_handler)(int, void *, struct pt_regs *) = dev_id; | ||
193 | 181 | ||
194 | volatile unsigned char x; | 182 | volatile unsigned char x; |
195 | 183 | ||
196 | sched_timer_handler(irq,dev_id,fp); | 184 | timer_handler(irq, dev_id, fp); |
197 | 185 | ||
198 | x=*(volatile unsigned char *)(timer+3); | 186 | x=*(volatile unsigned char *)(timer+3); |
199 | x=*(volatile unsigned char *)(timer+5); | 187 | x=*(volatile unsigned char *)(timer+5); |
@@ -217,9 +205,7 @@ void dn_sched_init(irqreturn_t (*timer_routine)(int, void *, struct pt_regs *)) | |||
217 | printk("*(0x10803) %02x\n",*(volatile unsigned char *)(timer+0x3)); | 205 | printk("*(0x10803) %02x\n",*(volatile unsigned char *)(timer+0x3)); |
218 | #endif | 206 | #endif |
219 | 207 | ||
220 | sched_timer_handler=timer_routine; | 208 | request_irq(IRQ_APOLLO, dn_timer_int, 0, "time", timer_routine); |
221 | request_irq(0,dn_timer_int,0,NULL,NULL); | ||
222 | |||
223 | } | 209 | } |
224 | 210 | ||
225 | unsigned long dn_gettimeoffset(void) { | 211 | unsigned long dn_gettimeoffset(void) { |