diff options
author | Greg Ungerer <gerg@snapgear.com> | 2007-07-26 11:09:00 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-07-26 14:05:20 -0400 |
commit | 5c4525da3b43ab194b99ea13142fa1f98fcba2fe (patch) | |
tree | ef745f85c2faa2c2d14770838aea2a146178dbfe /arch/m68knommu/platform/5307 | |
parent | 65fdef9303a69dab1f693159f6262375322dd676 (diff) |
m68knommu: use setup_irq() in ColdFire PIT timer
Use setup_irq() instead of request_irq() to set up system timer
in ColdFire PIT timer code. With the old m68knommu irq code this
was safe, but it is not now within the generic irq framework.
Signed-off-by: Greg Ungerer <gerg@uclinux.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch/m68knommu/platform/5307')
-rw-r--r-- | arch/m68knommu/platform/5307/pit.c | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/arch/m68knommu/platform/5307/pit.c b/arch/m68knommu/platform/5307/pit.c index aa15beeb36ca..e53c446d10e4 100644 --- a/arch/m68knommu/platform/5307/pit.c +++ b/arch/m68knommu/platform/5307/pit.c | |||
@@ -5,9 +5,8 @@ | |||
5 | * hardware timer only exists in the Freescale ColdFire | 5 | * hardware timer only exists in the Freescale ColdFire |
6 | * 5270/5271, 5282 and other CPUs. | 6 | * 5270/5271, 5282 and other CPUs. |
7 | * | 7 | * |
8 | * Copyright (C) 1999-2006, Greg Ungerer (gerg@snapgear.com) | 8 | * Copyright (C) 1999-2007, Greg Ungerer (gerg@snapgear.com) |
9 | * Copyright (C) 2001-2004, SnapGear Inc. (www.snapgear.com) | 9 | * Copyright (C) 2001-2004, SnapGear Inc. (www.snapgear.com) |
10 | * | ||
11 | */ | 10 | */ |
12 | 11 | ||
13 | /***************************************************************************/ | 12 | /***************************************************************************/ |
@@ -17,8 +16,8 @@ | |||
17 | #include <linux/param.h> | 16 | #include <linux/param.h> |
18 | #include <linux/init.h> | 17 | #include <linux/init.h> |
19 | #include <linux/interrupt.h> | 18 | #include <linux/interrupt.h> |
19 | #include <linux/irq.h> | ||
20 | #include <asm/io.h> | 20 | #include <asm/io.h> |
21 | #include <asm/irq.h> | ||
22 | #include <asm/coldfire.h> | 21 | #include <asm/coldfire.h> |
23 | #include <asm/mcfpit.h> | 22 | #include <asm/mcfpit.h> |
24 | #include <asm/mcfsim.h> | 23 | #include <asm/mcfsim.h> |
@@ -43,13 +42,18 @@ void coldfire_pit_tick(void) | |||
43 | 42 | ||
44 | /***************************************************************************/ | 43 | /***************************************************************************/ |
45 | 44 | ||
45 | static struct irqaction coldfire_pit_irq = { | ||
46 | .name = "timer", | ||
47 | .flags = IRQF_DISABLED | IRQF_TIMER, | ||
48 | }; | ||
49 | |||
46 | void coldfire_pit_init(irq_handler_t handler) | 50 | void coldfire_pit_init(irq_handler_t handler) |
47 | { | 51 | { |
48 | volatile unsigned char *icrp; | 52 | volatile unsigned char *icrp; |
49 | volatile unsigned long *imrp; | 53 | volatile unsigned long *imrp; |
50 | 54 | ||
51 | request_irq(MCFINT_VECBASE + MCFINT_PIT1, handler, IRQF_DISABLED, | 55 | coldfire_pit_irq.handler = handler; |
52 | "ColdFire Timer", NULL); | 56 | setup_irq(MCFINT_VECBASE + MCFINT_PIT1, &coldfire_pit_irq); |
53 | 57 | ||
54 | icrp = (volatile unsigned char *) (MCF_IPSBAR + MCFICM_INTC0 + | 58 | icrp = (volatile unsigned char *) (MCF_IPSBAR + MCFICM_INTC0 + |
55 | MCFINTC_ICR0 + MCFINT_PIT1); | 59 | MCFINTC_ICR0 + MCFINT_PIT1); |