rtc: bunch of drivers: fix 'no irq' case handing

This patch fixes a bunch of irq checking misuses.  Most drivers were
getting irq via platform_get_irq(), which returns -ENXIO or r->start.

rtc-cmos.c is special.  It is using PNP and platform bindings.  Hopefully
nobody is using PNP IRQ 0 for RTC.  So the changes should be safe.

rtc-sh.c is using platform_get_irq, but was storing a result into an
unsigned type, then was checking for < 0.  This is fixed now.

Signed-off-by: Anton Vorontsov <avorontsov@ru.mvista.com>
Cc: Alessandro Zummo <a.zummo@towertech.it>
Acked-by: David Brownell <dbrownell@users.sourceforge.net>
Acked-by: Paul Mundt <lethal@linux-sh.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
Anton Vorontsov 2009-01-06 14:42:11 -08:00 committed by Linus Torvalds
parent d4afc76c0b
commit 2fac6674dd
9 changed files with 40 additions and 40 deletions

View file

@ -205,7 +205,7 @@ static int __init at32_rtc_probe(struct platform_device *pdev)
{ {
struct resource *regs; struct resource *regs;
struct rtc_at32ap700x *rtc; struct rtc_at32ap700x *rtc;
int irq = -1; int irq;
int ret; int ret;
rtc = kzalloc(sizeof(struct rtc_at32ap700x), GFP_KERNEL); rtc = kzalloc(sizeof(struct rtc_at32ap700x), GFP_KERNEL);
@ -222,7 +222,7 @@ static int __init at32_rtc_probe(struct platform_device *pdev)
} }
irq = platform_get_irq(pdev, 0); irq = platform_get_irq(pdev, 0);
if (irq < 0) { if (irq <= 0) {
dev_dbg(&pdev->dev, "could not get irq\n"); dev_dbg(&pdev->dev, "could not get irq\n");
ret = -ENXIO; ret = -ENXIO;
goto out; goto out;

View file

@ -58,7 +58,7 @@ struct cmos_rtc {
}; };
/* both platform and pnp busses use negative numbers for invalid irqs */ /* both platform and pnp busses use negative numbers for invalid irqs */
#define is_valid_irq(n) ((n) >= 0) #define is_valid_irq(n) ((n) > 0)
static const char driver_name[] = "rtc_cmos"; static const char driver_name[] = "rtc_cmos";

View file

@ -326,9 +326,9 @@ ds1511_rtc_set_alarm(struct device *dev, struct rtc_wkalrm *alrm)
struct platform_device *pdev = to_platform_device(dev); struct platform_device *pdev = to_platform_device(dev);
struct rtc_plat_data *pdata = platform_get_drvdata(pdev); struct rtc_plat_data *pdata = platform_get_drvdata(pdev);
if (pdata->irq < 0) { if (pdata->irq <= 0)
return -EINVAL; return -EINVAL;
}
pdata->alrm_mday = alrm->time.tm_mday; pdata->alrm_mday = alrm->time.tm_mday;
pdata->alrm_hour = alrm->time.tm_hour; pdata->alrm_hour = alrm->time.tm_hour;
pdata->alrm_min = alrm->time.tm_min; pdata->alrm_min = alrm->time.tm_min;
@ -346,9 +346,9 @@ ds1511_rtc_read_alarm(struct device *dev, struct rtc_wkalrm *alrm)
struct platform_device *pdev = to_platform_device(dev); struct platform_device *pdev = to_platform_device(dev);
struct rtc_plat_data *pdata = platform_get_drvdata(pdev); struct rtc_plat_data *pdata = platform_get_drvdata(pdev);
if (pdata->irq < 0) { if (pdata->irq <= 0)
return -EINVAL; return -EINVAL;
}
alrm->time.tm_mday = pdata->alrm_mday < 0 ? 0 : pdata->alrm_mday; alrm->time.tm_mday = pdata->alrm_mday < 0 ? 0 : pdata->alrm_mday;
alrm->time.tm_hour = pdata->alrm_hour < 0 ? 0 : pdata->alrm_hour; alrm->time.tm_hour = pdata->alrm_hour < 0 ? 0 : pdata->alrm_hour;
alrm->time.tm_min = pdata->alrm_min < 0 ? 0 : pdata->alrm_min; alrm->time.tm_min = pdata->alrm_min < 0 ? 0 : pdata->alrm_min;
@ -385,7 +385,7 @@ ds1511_rtc_ioctl(struct device *dev, unsigned int cmd, unsigned long arg)
struct platform_device *pdev = to_platform_device(dev); struct platform_device *pdev = to_platform_device(dev);
struct rtc_plat_data *pdata = platform_get_drvdata(pdev); struct rtc_plat_data *pdata = platform_get_drvdata(pdev);
if (pdata->irq < 0) { if (pdata->irq <= 0) {
return -ENOIOCTLCMD; /* fall back into rtc-dev's emulation */ return -ENOIOCTLCMD; /* fall back into rtc-dev's emulation */
} }
switch (cmd) { switch (cmd) {
@ -503,7 +503,6 @@ ds1511_rtc_probe(struct platform_device *pdev)
if (!pdata) { if (!pdata) {
return -ENOMEM; return -ENOMEM;
} }
pdata->irq = -1;
pdata->size = res->end - res->start + 1; pdata->size = res->end - res->start + 1;
if (!request_mem_region(res->start, pdata->size, pdev->name)) { if (!request_mem_region(res->start, pdata->size, pdev->name)) {
ret = -EBUSY; ret = -EBUSY;
@ -545,13 +544,13 @@ ds1511_rtc_probe(struct platform_device *pdev)
* if the platform has an interrupt in mind for this device, * if the platform has an interrupt in mind for this device,
* then by all means, set it * then by all means, set it
*/ */
if (pdata->irq >= 0) { if (pdata->irq > 0) {
rtc_read(RTC_CMD1); rtc_read(RTC_CMD1);
if (request_irq(pdata->irq, ds1511_interrupt, if (request_irq(pdata->irq, ds1511_interrupt,
IRQF_DISABLED | IRQF_SHARED, pdev->name, pdev) < 0) { IRQF_DISABLED | IRQF_SHARED, pdev->name, pdev) < 0) {
dev_warn(&pdev->dev, "interrupt not available.\n"); dev_warn(&pdev->dev, "interrupt not available.\n");
pdata->irq = -1; pdata->irq = 0;
} }
} }
@ -572,7 +571,7 @@ ds1511_rtc_probe(struct platform_device *pdev)
if (pdata->rtc) { if (pdata->rtc) {
rtc_device_unregister(pdata->rtc); rtc_device_unregister(pdata->rtc);
} }
if (pdata->irq >= 0) { if (pdata->irq > 0) {
free_irq(pdata->irq, pdev); free_irq(pdata->irq, pdev);
} }
if (ds1511_base) { if (ds1511_base) {
@ -595,7 +594,7 @@ ds1511_rtc_remove(struct platform_device *pdev)
sysfs_remove_bin_file(&pdev->dev.kobj, &ds1511_nvram_attr); sysfs_remove_bin_file(&pdev->dev.kobj, &ds1511_nvram_attr);
rtc_device_unregister(pdata->rtc); rtc_device_unregister(pdata->rtc);
pdata->rtc = NULL; pdata->rtc = NULL;
if (pdata->irq >= 0) { if (pdata->irq > 0) {
/* /*
* disable the alarm interrupt * disable the alarm interrupt
*/ */

View file

@ -162,7 +162,7 @@ static int ds1553_rtc_set_alarm(struct device *dev, struct rtc_wkalrm *alrm)
struct platform_device *pdev = to_platform_device(dev); struct platform_device *pdev = to_platform_device(dev);
struct rtc_plat_data *pdata = platform_get_drvdata(pdev); struct rtc_plat_data *pdata = platform_get_drvdata(pdev);
if (pdata->irq < 0) if (pdata->irq <= 0)
return -EINVAL; return -EINVAL;
pdata->alrm_mday = alrm->time.tm_mday; pdata->alrm_mday = alrm->time.tm_mday;
pdata->alrm_hour = alrm->time.tm_hour; pdata->alrm_hour = alrm->time.tm_hour;
@ -179,7 +179,7 @@ static int ds1553_rtc_read_alarm(struct device *dev, struct rtc_wkalrm *alrm)
struct platform_device *pdev = to_platform_device(dev); struct platform_device *pdev = to_platform_device(dev);
struct rtc_plat_data *pdata = platform_get_drvdata(pdev); struct rtc_plat_data *pdata = platform_get_drvdata(pdev);
if (pdata->irq < 0) if (pdata->irq <= 0)
return -EINVAL; return -EINVAL;
alrm->time.tm_mday = pdata->alrm_mday < 0 ? 0 : pdata->alrm_mday; alrm->time.tm_mday = pdata->alrm_mday < 0 ? 0 : pdata->alrm_mday;
alrm->time.tm_hour = pdata->alrm_hour < 0 ? 0 : pdata->alrm_hour; alrm->time.tm_hour = pdata->alrm_hour < 0 ? 0 : pdata->alrm_hour;
@ -213,7 +213,7 @@ static int ds1553_rtc_ioctl(struct device *dev, unsigned int cmd,
struct platform_device *pdev = to_platform_device(dev); struct platform_device *pdev = to_platform_device(dev);
struct rtc_plat_data *pdata = platform_get_drvdata(pdev); struct rtc_plat_data *pdata = platform_get_drvdata(pdev);
if (pdata->irq < 0) if (pdata->irq <= 0)
return -ENOIOCTLCMD; /* fall back into rtc-dev's emulation */ return -ENOIOCTLCMD; /* fall back into rtc-dev's emulation */
switch (cmd) { switch (cmd) {
case RTC_AIE_OFF: case RTC_AIE_OFF:
@ -301,7 +301,6 @@ static int __devinit ds1553_rtc_probe(struct platform_device *pdev)
pdata = kzalloc(sizeof(*pdata), GFP_KERNEL); pdata = kzalloc(sizeof(*pdata), GFP_KERNEL);
if (!pdata) if (!pdata)
return -ENOMEM; return -ENOMEM;
pdata->irq = -1;
if (!request_mem_region(res->start, RTC_REG_SIZE, pdev->name)) { if (!request_mem_region(res->start, RTC_REG_SIZE, pdev->name)) {
ret = -EBUSY; ret = -EBUSY;
goto out; goto out;
@ -327,13 +326,13 @@ static int __devinit ds1553_rtc_probe(struct platform_device *pdev)
if (readb(ioaddr + RTC_FLAGS) & RTC_FLAGS_BLF) if (readb(ioaddr + RTC_FLAGS) & RTC_FLAGS_BLF)
dev_warn(&pdev->dev, "voltage-low detected.\n"); dev_warn(&pdev->dev, "voltage-low detected.\n");
if (pdata->irq >= 0) { if (pdata->irq > 0) {
writeb(0, ioaddr + RTC_INTERRUPTS); writeb(0, ioaddr + RTC_INTERRUPTS);
if (request_irq(pdata->irq, ds1553_rtc_interrupt, if (request_irq(pdata->irq, ds1553_rtc_interrupt,
IRQF_DISABLED | IRQF_SHARED, IRQF_DISABLED | IRQF_SHARED,
pdev->name, pdev) < 0) { pdev->name, pdev) < 0) {
dev_warn(&pdev->dev, "interrupt not available.\n"); dev_warn(&pdev->dev, "interrupt not available.\n");
pdata->irq = -1; pdata->irq = 0;
} }
} }
@ -353,7 +352,7 @@ static int __devinit ds1553_rtc_probe(struct platform_device *pdev)
out: out:
if (pdata->rtc) if (pdata->rtc)
rtc_device_unregister(pdata->rtc); rtc_device_unregister(pdata->rtc);
if (pdata->irq >= 0) if (pdata->irq > 0)
free_irq(pdata->irq, pdev); free_irq(pdata->irq, pdev);
if (ioaddr) if (ioaddr)
iounmap(ioaddr); iounmap(ioaddr);
@ -369,7 +368,7 @@ static int __devexit ds1553_rtc_remove(struct platform_device *pdev)
sysfs_remove_bin_file(&pdev->dev.kobj, &ds1553_nvram_attr); sysfs_remove_bin_file(&pdev->dev.kobj, &ds1553_nvram_attr);
rtc_device_unregister(pdata->rtc); rtc_device_unregister(pdata->rtc);
if (pdata->irq >= 0) { if (pdata->irq > 0) {
writeb(0, pdata->ioaddr + RTC_INTERRUPTS); writeb(0, pdata->ioaddr + RTC_INTERRUPTS);
free_irq(pdata->irq, pdev); free_irq(pdata->irq, pdev);
} }

View file

@ -450,7 +450,7 @@ static int __devinit m48t59_rtc_probe(struct platform_device *pdev)
* the mode without IRQ. * the mode without IRQ.
*/ */
m48t59->irq = platform_get_irq(pdev, 0); m48t59->irq = platform_get_irq(pdev, 0);
if (m48t59->irq < 0) if (m48t59->irq <= 0)
m48t59->irq = NO_IRQ; m48t59->irq = NO_IRQ;
if (m48t59->irq != NO_IRQ) { if (m48t59->irq != NO_IRQ) {

View file

@ -89,7 +89,9 @@ struct sh_rtc {
void __iomem *regbase; void __iomem *regbase;
unsigned long regsize; unsigned long regsize;
struct resource *res; struct resource *res;
unsigned int alarm_irq, periodic_irq, carry_irq; int alarm_irq;
int periodic_irq;
int carry_irq;
struct rtc_device *rtc_dev; struct rtc_device *rtc_dev;
spinlock_t lock; spinlock_t lock;
unsigned long capabilities; /* See asm-sh/rtc.h for cap bits */ unsigned long capabilities; /* See asm-sh/rtc.h for cap bits */
@ -578,7 +580,7 @@ static int __devinit sh_rtc_probe(struct platform_device *pdev)
/* get periodic/carry/alarm irqs */ /* get periodic/carry/alarm irqs */
ret = platform_get_irq(pdev, 0); ret = platform_get_irq(pdev, 0);
if (unlikely(ret < 0)) { if (unlikely(ret <= 0)) {
ret = -ENOENT; ret = -ENOENT;
dev_err(&pdev->dev, "No IRQ for period\n"); dev_err(&pdev->dev, "No IRQ for period\n");
goto err_badres; goto err_badres;
@ -586,7 +588,7 @@ static int __devinit sh_rtc_probe(struct platform_device *pdev)
rtc->periodic_irq = ret; rtc->periodic_irq = ret;
ret = platform_get_irq(pdev, 1); ret = platform_get_irq(pdev, 1);
if (unlikely(ret < 0)) { if (unlikely(ret <= 0)) {
ret = -ENOENT; ret = -ENOENT;
dev_err(&pdev->dev, "No IRQ for carry\n"); dev_err(&pdev->dev, "No IRQ for carry\n");
goto err_badres; goto err_badres;
@ -594,7 +596,7 @@ static int __devinit sh_rtc_probe(struct platform_device *pdev)
rtc->carry_irq = ret; rtc->carry_irq = ret;
ret = platform_get_irq(pdev, 2); ret = platform_get_irq(pdev, 2);
if (unlikely(ret < 0)) { if (unlikely(ret <= 0)) {
ret = -ENOENT; ret = -ENOENT;
dev_err(&pdev->dev, "No IRQ for alarm\n"); dev_err(&pdev->dev, "No IRQ for alarm\n");
goto err_badres; goto err_badres;

View file

@ -170,7 +170,7 @@ static int stk17ta8_rtc_set_alarm(struct device *dev, struct rtc_wkalrm *alrm)
struct platform_device *pdev = to_platform_device(dev); struct platform_device *pdev = to_platform_device(dev);
struct rtc_plat_data *pdata = platform_get_drvdata(pdev); struct rtc_plat_data *pdata = platform_get_drvdata(pdev);
if (pdata->irq < 0) if (pdata->irq <= 0)
return -EINVAL; return -EINVAL;
pdata->alrm_mday = alrm->time.tm_mday; pdata->alrm_mday = alrm->time.tm_mday;
pdata->alrm_hour = alrm->time.tm_hour; pdata->alrm_hour = alrm->time.tm_hour;
@ -187,7 +187,7 @@ static int stk17ta8_rtc_read_alarm(struct device *dev, struct rtc_wkalrm *alrm)
struct platform_device *pdev = to_platform_device(dev); struct platform_device *pdev = to_platform_device(dev);
struct rtc_plat_data *pdata = platform_get_drvdata(pdev); struct rtc_plat_data *pdata = platform_get_drvdata(pdev);
if (pdata->irq < 0) if (pdata->irq <= 0)
return -EINVAL; return -EINVAL;
alrm->time.tm_mday = pdata->alrm_mday < 0 ? 0 : pdata->alrm_mday; alrm->time.tm_mday = pdata->alrm_mday < 0 ? 0 : pdata->alrm_mday;
alrm->time.tm_hour = pdata->alrm_hour < 0 ? 0 : pdata->alrm_hour; alrm->time.tm_hour = pdata->alrm_hour < 0 ? 0 : pdata->alrm_hour;
@ -221,7 +221,7 @@ static int stk17ta8_rtc_ioctl(struct device *dev, unsigned int cmd,
struct platform_device *pdev = to_platform_device(dev); struct platform_device *pdev = to_platform_device(dev);
struct rtc_plat_data *pdata = platform_get_drvdata(pdev); struct rtc_plat_data *pdata = platform_get_drvdata(pdev);
if (pdata->irq < 0) if (pdata->irq <= 0)
return -ENOIOCTLCMD; /* fall back into rtc-dev's emulation */ return -ENOIOCTLCMD; /* fall back into rtc-dev's emulation */
switch (cmd) { switch (cmd) {
case RTC_AIE_OFF: case RTC_AIE_OFF:
@ -303,7 +303,6 @@ static int __init stk17ta8_rtc_probe(struct platform_device *pdev)
pdata = kzalloc(sizeof(*pdata), GFP_KERNEL); pdata = kzalloc(sizeof(*pdata), GFP_KERNEL);
if (!pdata) if (!pdata)
return -ENOMEM; return -ENOMEM;
pdata->irq = -1;
if (!request_mem_region(res->start, RTC_REG_SIZE, pdev->name)) { if (!request_mem_region(res->start, RTC_REG_SIZE, pdev->name)) {
ret = -EBUSY; ret = -EBUSY;
goto out; goto out;
@ -329,13 +328,13 @@ static int __init stk17ta8_rtc_probe(struct platform_device *pdev)
if (readb(ioaddr + RTC_FLAGS) & RTC_FLAGS_PF) if (readb(ioaddr + RTC_FLAGS) & RTC_FLAGS_PF)
dev_warn(&pdev->dev, "voltage-low detected.\n"); dev_warn(&pdev->dev, "voltage-low detected.\n");
if (pdata->irq >= 0) { if (pdata->irq > 0) {
writeb(0, ioaddr + RTC_INTERRUPTS); writeb(0, ioaddr + RTC_INTERRUPTS);
if (request_irq(pdata->irq, stk17ta8_rtc_interrupt, if (request_irq(pdata->irq, stk17ta8_rtc_interrupt,
IRQF_DISABLED | IRQF_SHARED, IRQF_DISABLED | IRQF_SHARED,
pdev->name, pdev) < 0) { pdev->name, pdev) < 0) {
dev_warn(&pdev->dev, "interrupt not available.\n"); dev_warn(&pdev->dev, "interrupt not available.\n");
pdata->irq = -1; pdata->irq = 0;
} }
} }
@ -355,7 +354,7 @@ static int __init stk17ta8_rtc_probe(struct platform_device *pdev)
out: out:
if (pdata->rtc) if (pdata->rtc)
rtc_device_unregister(pdata->rtc); rtc_device_unregister(pdata->rtc);
if (pdata->irq >= 0) if (pdata->irq > 0)
free_irq(pdata->irq, pdev); free_irq(pdata->irq, pdev);
if (ioaddr) if (ioaddr)
iounmap(ioaddr); iounmap(ioaddr);
@ -371,7 +370,7 @@ static int __devexit stk17ta8_rtc_remove(struct platform_device *pdev)
sysfs_remove_bin_file(&pdev->dev.kobj, &stk17ta8_nvram_attr); sysfs_remove_bin_file(&pdev->dev.kobj, &stk17ta8_nvram_attr);
rtc_device_unregister(pdata->rtc); rtc_device_unregister(pdata->rtc);
if (pdata->irq >= 0) { if (pdata->irq > 0) {
writeb(0, pdata->ioaddr + RTC_INTERRUPTS); writeb(0, pdata->ioaddr + RTC_INTERRUPTS);
free_irq(pdata->irq, pdev); free_irq(pdata->irq, pdev);
} }

View file

@ -19,6 +19,7 @@
*/ */
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/errno.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/types.h> #include <linux/types.h>
@ -415,8 +416,8 @@ static int __devinit twl4030_rtc_probe(struct platform_device *pdev)
int irq = platform_get_irq(pdev, 0); int irq = platform_get_irq(pdev, 0);
u8 rd_reg; u8 rd_reg;
if (irq < 0) if (irq <= 0)
return irq; return -EINVAL;
rtc = rtc_device_register(pdev->name, rtc = rtc_device_register(pdev->name,
&pdev->dev, &twl4030_rtc_ops, THIS_MODULE); &pdev->dev, &twl4030_rtc_ops, THIS_MODULE);

View file

@ -84,8 +84,8 @@ static DEFINE_SPINLOCK(rtc_lock);
static char rtc_name[] = "RTC"; static char rtc_name[] = "RTC";
static unsigned long periodic_count; static unsigned long periodic_count;
static unsigned int alarm_enabled; static unsigned int alarm_enabled;
static int aie_irq = -1; static int aie_irq;
static int pie_irq = -1; static int pie_irq;
static inline unsigned long read_elapsed_second(void) static inline unsigned long read_elapsed_second(void)
{ {
@ -360,7 +360,7 @@ static int __devinit rtc_probe(struct platform_device *pdev)
spin_unlock_irq(&rtc_lock); spin_unlock_irq(&rtc_lock);
aie_irq = platform_get_irq(pdev, 0); aie_irq = platform_get_irq(pdev, 0);
if (aie_irq < 0 || aie_irq >= nr_irqs) { if (aie_irq <= 0) {
retval = -EBUSY; retval = -EBUSY;
goto err_device_unregister; goto err_device_unregister;
} }
@ -371,7 +371,7 @@ static int __devinit rtc_probe(struct platform_device *pdev)
goto err_device_unregister; goto err_device_unregister;
pie_irq = platform_get_irq(pdev, 1); pie_irq = platform_get_irq(pdev, 1);
if (pie_irq < 0 || pie_irq >= nr_irqs) if (pie_irq <= 0)
goto err_free_irq; goto err_free_irq;
retval = request_irq(pie_irq, rtclong1_interrupt, IRQF_DISABLED, retval = request_irq(pie_irq, rtclong1_interrupt, IRQF_DISABLED,