diff options
author | Benoît Thébaudeau <benoit.thebaudeau@advansee.com> | 2012-07-11 17:02:32 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2012-07-16 11:47:52 -0400 |
commit | 08ccc046aa38dca8214b8a1dcef2c711d8b94f2f (patch) | |
tree | 9e15c2af64d54c74c901fd13ce6354ea26270910 /drivers/rtc | |
parent | 32ef2126fabc8a984506a1a4e83f3459ba1a2075 (diff) |
drivers/rtc/rtc-mxc.c: fix irq enabled interrupts warning
commit b59f6d1febd6cbe9fae4589bf72da0ed32bc69e0 upstream.
Fixes
WARNING: at irq/handle.c:146 handle_irq_event_percpu+0x19c/0x1b8()
irq 25 handler mxc_rtc_interrupt+0x0/0xac enabled interrupts
Modules linked in:
(unwind_backtrace+0x0/0xf0) from (warn_slowpath_common+0x4c/0x64)
(warn_slowpath_common+0x4c/0x64) from (warn_slowpath_fmt+0x30/0x40)
(warn_slowpath_fmt+0x30/0x40) from (handle_irq_event_percpu+0x19c/0x1b8)
(handle_irq_event_percpu+0x19c/0x1b8) from (handle_irq_event+0x28/0x38)
(handle_irq_event+0x28/0x38) from (handle_level_irq+0x80/0xc4)
(handle_level_irq+0x80/0xc4) from (generic_handle_irq+0x24/0x38)
(generic_handle_irq+0x24/0x38) from (handle_IRQ+0x30/0x84)
(handle_IRQ+0x30/0x84) from (avic_handle_irq+0x2c/0x4c)
(avic_handle_irq+0x2c/0x4c) from (__irq_svc+0x40/0x60)
Exception stack(0xc050bf60 to 0xc050bfa8)
bf60: 00000001 00000000 003c4208 c0018e20 c050a000 c050a000 c054a4c8 c050a000
bf80: c05157a8 4117b363 80503bb4 00000000 01000000 c050bfa8 c0018e2c c000e808
bfa0: 60000013 ffffffff
(__irq_svc+0x40/0x60) from (default_idle+0x1c/0x30)
(default_idle+0x1c/0x30) from (cpu_idle+0x68/0xa8)
(cpu_idle+0x68/0xa8) from (start_kernel+0x22c/0x26c)
Signed-off-by: Benoît Thébaudeau <benoit.thebaudeau@advansee.com>
Cc: Alessandro Zummo <a.zummo@towertech.it>
Cc: Sascha Hauer <kernel@pengutronix.de>
Acked-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/rtc')
-rw-r--r-- | drivers/rtc/rtc-mxc.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/rtc/rtc-mxc.c b/drivers/rtc/rtc-mxc.c index 39e41fbdf08..51603543def 100644 --- a/drivers/rtc/rtc-mxc.c +++ b/drivers/rtc/rtc-mxc.c | |||
@@ -191,10 +191,11 @@ static irqreturn_t mxc_rtc_interrupt(int irq, void *dev_id) | |||
191 | struct platform_device *pdev = dev_id; | 191 | struct platform_device *pdev = dev_id; |
192 | struct rtc_plat_data *pdata = platform_get_drvdata(pdev); | 192 | struct rtc_plat_data *pdata = platform_get_drvdata(pdev); |
193 | void __iomem *ioaddr = pdata->ioaddr; | 193 | void __iomem *ioaddr = pdata->ioaddr; |
194 | unsigned long flags; | ||
194 | u32 status; | 195 | u32 status; |
195 | u32 events = 0; | 196 | u32 events = 0; |
196 | 197 | ||
197 | spin_lock_irq(&pdata->rtc->irq_lock); | 198 | spin_lock_irqsave(&pdata->rtc->irq_lock, flags); |
198 | status = readw(ioaddr + RTC_RTCISR) & readw(ioaddr + RTC_RTCIENR); | 199 | status = readw(ioaddr + RTC_RTCISR) & readw(ioaddr + RTC_RTCIENR); |
199 | /* clear interrupt sources */ | 200 | /* clear interrupt sources */ |
200 | writew(status, ioaddr + RTC_RTCISR); | 201 | writew(status, ioaddr + RTC_RTCISR); |
@@ -217,7 +218,7 @@ static irqreturn_t mxc_rtc_interrupt(int irq, void *dev_id) | |||
217 | rtc_update_alarm(&pdev->dev, &pdata->g_rtc_alarm); | 218 | rtc_update_alarm(&pdev->dev, &pdata->g_rtc_alarm); |
218 | 219 | ||
219 | rtc_update_irq(pdata->rtc, 1, events); | 220 | rtc_update_irq(pdata->rtc, 1, events); |
220 | spin_unlock_irq(&pdata->rtc->irq_lock); | 221 | spin_unlock_irqrestore(&pdata->rtc->irq_lock, flags); |
221 | 222 | ||
222 | return IRQ_HANDLED; | 223 | return IRQ_HANDLED; |
223 | } | 224 | } |