[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20150515202005.GA23133@roeck-us.net>
Date: Fri, 15 May 2015 13:20:05 -0700
From: Guenter Roeck <linux@...ck-us.net>
To: "Opensource [Steve Twiss]" <stwiss.opensource@...semi.com>
Cc: LINUXKERNEL <linux-kernel@...r.kernel.org>,
LINUXWATCHDOG <linux-watchdog@...r.kernel.org>,
Wim Van Sebroeck <wim@...ana.be>,
Alessandro Zummo <a.zummo@...ertech.it>,
DEVICETREE <devicetree@...r.kernel.org>,
David Dajun Chen <david.chen@...semi.com>,
Dmitry Torokhov <dmitry.torokhov@...il.com>,
Ian Campbell <ijc+devicetree@...lion.org.uk>,
Kumar Gala <galak@...eaurora.org>,
LINUXINPUT <linux-input@...r.kernel.org>,
Lee Jones <lee.jones@...aro.org>,
Liam Girdwood <lgirdwood@...il.com>,
Mark Brown <broonie@...nel.org>,
Mark Rutland <mark.rutland@....com>,
Pawel Moll <pawel.moll@....com>,
RTCLINUX <rtc-linux@...glegroups.com>,
Rob Herring <robh+dt@...nel.org>,
Samuel Ortiz <sameo@...ux.intel.com>,
Support Opensource <Support.Opensource@...semi.com>
Subject: Re: [PATCH V2 3/4] watchdog: da9062: DA9062 watchdog driver
On Fri, May 15, 2015 at 03:35:50PM +0000, Opensource [Steve Twiss] wrote:
>
> > > +
> > > +/* E_WDG_WARN interrupt handler */
> > > +static irqreturn_t da9062_wdt_wdg_warn_irq_handler(int irq, void *data)
> > > +{
> > > + struct da9062_watchdog *wdt = data;
> > > +
> > > + dev_notice(wdt->hw->dev, "Watchdog timeout warning trigger.\n");
> > > + return IRQ_HANDLED;
> > > +}
> > > +
>
> On 15 May 2015 13:58 Guenter Roeck wrote:
>
> [...]
>
> > >>> +
> > >>> + irq = platform_get_irq_byname(pdev, "WDG_WARN");
> > >>> + if (irq < 0) {
> > >>> + dev_err(wdt->hw->dev, "Failed to get IRQ.\n");
> > >>> + ret = irq;
> > >>> + goto error;
>
> [...]
>
> > >
> > >> Also, is the interrupt mandatory ? All it does is to display a message.
> > >> Looks very optional to me.
> > >
> > > It is a place holder for something more application specific.
> > > I could remove it, but I figured it would just get re-added when somebody takes the
> > > driver and modifies it for their needs.
> > >
> > > If this is a problem however, it can go.
> > > Please advise ..
> > >
> >
> > Then this someone should add the code. For the time being, it just increases
> > kernel size and may cause the driver to fail for no good reason. Plus, given
> > the driver apparently works without interrupt, even then it should be
> > optional, and the driver does not have to fail loading if it is not supported on a
> > given platform.
> >
>
> Hi Guenter,
>
> I'm not sure if I got my previous point across there ...
>
> Leaving this in wouldn't really do any real harm I think. If this feature is not supported
> in somebody's platform then there wouldn't be a problem, the IRQ would fire (as a
> warning that the watchdog was about to time-out), the handler function would be
> executed, it would handle the IRQ -- and that would be it. Nothing would happen apart
> from a debug print.
I didn't get my point across either. Problem is that your driver fails to load
if the interrupt is not there. With the interrupt really being optional, I don't
see the point in making it mandatory just to display a message if it fires.
>
> There are already examples of this in the kernel, I've not looked very hard ...
> http://lxr.free-electrons.com/source/drivers/mfd/qcom_rpm.c#L412
> http://lxr.free-electrons.com/source/drivers/mfd/arizona-irq.c#L72
>
Never a good argument to make with me. 100 people doing something wrong
doesn't mean you should continue to do so.
Guenter
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists