> -----Original Message----- > From: Felipe Balbi [mailto:felipe.ba...@nokia.com] > Sent: Tuesday, August 17, 2010 2:59 PM > To: Hiremath, Vaibhav > Cc: linux-ker...@vger.kernel.org; a...@linux-foundation.org; > byron.bbrad...@gmail.com; linux-omap@vger.kernel.org > Subject: Re: [PATCH 1/3] RTC:s35390a: Add Alarm interrupt support > > On Tue, Aug 17, 2010 at 10:48:39AM +0200, ext hvaib...@ti.com wrote: > >From: Vaibhav Hiremath <hvaib...@ti.com> > > you need a description here. > [Hiremath, Vaibhav] Frankly, I deliberately removed the description thinking its duplication of subject line and subject like should be enough to explain about the patch.
I will add description in the next version. > >Signed-off-by: Vaibhav Hiremath <hvaib...@ti.com> > > [snip] > > >+static void s35390a_work(struct work_struct *work) > >+{ > >+ struct s35390a *s35390a; > >+ struct i2c_client *client; > >+ char buf[1]; > >+ > >+ s35390a = container_of(work, struct s35390a, work); > >+ if (!s35390a) > >+ return; > > container_of() will never return NULL. You can remove this check. You > won't need this, actually after converting to threaded_irq, see below. > [Hiremath, Vaibhav] Ok, will remove in next version. > >+static irqreturn_t s35390a_irq(int irq, void *client) > >+{ > >+ struct s35390a *s35390a; > > all the other drivers will do: > > static irqreturn_t s35390a_irq(int irq, void *_s35390a) > { > struct s35390a *s35390a = _s35390a > > [...] > > >+ if (!client) > >+ return IRQ_HANDLED; > > if client is NULL, you should let this oops. > [Hiremath, Vaibhav] Ok, will remove in next version. > >+ schedule_work(&s35390a->work); > > please don't use workqueue. Use threaded IRQ. > [Hiremath, Vaibhav] Ok, will migrate to threaded irq and submit it again. Thanks, Vaibhav > >@@ -261,15 +447,30 @@ static int s35390a_probe(struct i2c_client *client, > > if (s35390a_get_datetime(client, &tm) < 0) > > dev_warn(&client->dev, "clock needs to be set\n"); > > > >+ INIT_WORK(&s35390a->work, s35390a_work); > >+ > >+ if (client->irq > 0) { > > irq 0 is a valid number. > > >+ err = request_irq(client->irq, s35390a_irq, IRQF_TRIGGER_LOW, > >+ client->name, client); > > instead of the i2c client, you can pass s35390. Also use > request_threaded_irq(); > > -- > balbi > > DefectiveByDesign.org -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html