From 1f99be1c14bd6e4d00c799d09ddbcb95a44adf08 Mon Sep 17 00:00:00 2001 From: Komal Shah Date: Mon, 28 Nov 2005 18:58:46 -0800 Subject: [PATCH] [PATCH] ARM: OMAP: omap-rtc: Use platform_get_irq Attached patch uses platform_get_irq for alarm and timer interrupts. Signed-off-by: Komal Shah Signed-off-by: Tony Lindgren --- drivers/char/omap-rtc.c | 31 ++++++++++++++++++++++++------- 1 file changed, 24 insertions(+), 7 deletions(-) diff --git a/drivers/char/omap-rtc.c b/drivers/char/omap-rtc.c index 814b6144d60..63ad322476e 100644 --- a/drivers/char/omap-rtc.c +++ b/drivers/char/omap-rtc.c @@ -71,6 +71,9 @@ extern spinlock_t rtc_lock; +static int omap_rtc_alarm = NO_IRQ; +static int omap_rtc_timer = NO_IRQ; + /* OMAP RTC register access macros: */ @@ -441,6 +444,20 @@ static int __init omap_rtc_probe(struct device *dev) struct platform_device *pdev = to_platform_device(dev); struct resource *res, *mem; + /* find the IRQs */ + + omap_rtc_timer = platform_get_irq(pdev, 0); + if (omap_rtc_timer <= 0) { + dev_err(&pdev->dev, "no irq for rtc timer\n"); + return -ENOENT; + } + + omap_rtc_alarm = platform_get_irq(pdev, 1); + if (omap_rtc_alarm <= 0) { + dev_err(&pdev->dev, "no irq for alarm\n"); + return -ENOENT; + } + res = platform_get_resource(pdev, IORESOURCE_MEM, 0); if (res) mem = request_mem_region(res->start, @@ -469,18 +486,18 @@ static int __init omap_rtc_probe(struct device *dev) CMOS_WRITE(OMAP_RTC_STATUS_ALARM, OMAP_RTC_STATUS_REG); } - if (request_irq(INT_RTC_TIMER, rtc_interrupt, SA_INTERRUPT, + if (request_irq(omap_rtc_timer, rtc_interrupt, SA_INTERRUPT, pdev->name, NULL)) { pr_debug("%s: RTC timer interrupt IRQ%d is not free.\n", - pdev->name, INT_RTC_TIMER); + pdev->name, omap_rtc_timer); goto fail; } - if (request_irq(INT_RTC_ALARM, rtc_interrupt, SA_INTERRUPT, + if (request_irq(omap_rtc_alarm, rtc_interrupt, SA_INTERRUPT, pdev->name, NULL)) { pr_debug("%s: RTC alarm interrupt IRQ%d is not free.\n", - pdev->name, INT_RTC_ALARM); - free_irq(INT_RTC_TIMER, NULL); + pdev->name, omap_rtc_alarm); + free_irq(omap_rtc_timer, NULL); goto fail; } @@ -504,8 +521,8 @@ fail: static int __exit omap_rtc_remove(struct device *dev) { - free_irq (INT_RTC_TIMER, NULL); - free_irq (INT_RTC_ALARM, NULL); + free_irq (omap_rtc_timer, NULL); + free_irq (omap_rtc_alarm, NULL); remove_proc_entry ("driver/rtc", NULL); misc_deregister(&rtc_dev); -- 2.41.1