Hi Venu, thanks for you reply
El Thu, Aug 02, 2012 at 10:28:47AM +0530 Venu Byravarasu ha dit: > > -----Original Message----- > > From: Matthias Kaehlcke [mailto:matthias.l...@kaehlcke.net] > > Sent: Thursday, August 02, 2012 1:48 AM > > To: Venu Byravarasu > > Cc: a.zu...@towertech.it; sa...@linux.intel.com; > > broo...@opensource.wolfsonmicro.com; Laxman Dewangan; > > kyle.ma...@fuel7.com; sb...@codeaurora.org; rtc- > > li...@googlegroups.com; linux-kernel@vger.kernel.org > > Subject: Re: [PATCH v2] rtc: tps65910: Add RTC driver for TPS65910 PMIC RTC > > > > hi, > > > > El Wed, Aug 01, 2012 at 11:52:37AM +0530 Venu Byravarasu ha dit: > > > > > TPS65910 PMIC is a MFD with RTC as one of the device. > > > Adding RTC driver for supporting RTC device present > > > inside TPS65910 PMIC. > > > > > > Only support for RTC alarm is implemented as part of this patch. > > > > > > Signed-off-by: Venu Byravarasu <vbyravar...@nvidia.com> > > > --- > > > > ... > > > > > +static irqreturn_t tps65910_rtc_interrupt(int irq, void *rtc) > > > +{ > > > + struct device *dev = rtc; > > > + unsigned long events = 0; > > > + struct tps65910 *tps = dev_get_drvdata(dev->parent); > > > + struct tps65910_rtc *tps_rtc = dev_get_drvdata(dev); > > > > > > ... > > > > > > +static int __devinit tps65910_rtc_probe(struct platform_device *pdev) > > > +{ > > > > > > ... > > > > > > + ret = devm_request_threaded_irq(&pdev->dev, irq, NULL, > > > + tps65910_rtc_interrupt, IRQF_TRIGGER_LOW, > > > + "rtc-tps65910", &pdev->dev); > > > + if (ret < 0) { > > > + dev_err(&pdev->dev, "IRQ is not free.\n"); > > > + return ret; > > > + } > > > + device_init_wakeup(&pdev->dev, 1); > > > + > > > + tps_rtc->rtc = rtc_device_register(pdev->name, &pdev->dev, > > > + &tps65910_rtc_ops, THIS_MODULE); > > > + if (IS_ERR(tps_rtc->rtc)) { > > > + ret = PTR_ERR(tps_rtc->rtc); > > > + dev_err(&pdev->dev, "RTC device register: err %d\n", ret); > > > + return ret; > > > + } > > > + > > > + platform_set_drvdata(pdev, tps_rtc); > > > > the interrupt should be requested after this call. otherwise > > tps65910_rtc_interrupt() could be executed before the RTC device is > > registered and the driver data set. normally this shouldn't happen as > > the RTC interrupts are disabled after reset, but the interrupts could > > have been enabled for example by the bootloader > > Hi Matthias, > > Thanks for your comments. > All pending RTC interrupts are being cleared in probe, before enabling RTC > itself. > Hence chances of stray interrupts from boot loader cannot cause any trouble > here. > > The only possible way of getting interrupt by kernel driver is by enabling > tps65910_rtc_alarm_irq_enable() && setting alarm time using > tps65910_rtc_set_alarm. > However before probe gets completed as these two APIs will not get > called together by the client, I do not see any false interrupt getting > generated. i was thinking in the periodic interrupts, but now noticed that the driver only registers to the alarm interrupts, so this is not a problem kind regards -- Matthias Kaehlcke Embedded Linux Developer Amsterdam El optimista tiene siempre un proyecto; el pesimista, una excusa .''`. using free software / Debian GNU/Linux | http://debian.org : :' : `. `'` gpg --keyserver pgp.mit.edu --recv-keys 47D8E5D4 `- -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/