> -----Original Message----- > From: Felipe Balbi [mailto:felipe.balbi@xxxxxxxxx] > Sent: Tuesday, August 17, 2010 2:59 PM > To: Hiremath, Vaibhav > Cc: linux-kernel@xxxxxxxxxxxxxxx; akpm@xxxxxxxxxxxxxxxxxxxx; > byron.bbradley@xxxxxxxxx; linux-omap@xxxxxxxxxxxxxxx > Subject: Re: [PATCH 1/3] RTC:s35390a: Add Alarm interrupt support > > On Tue, Aug 17, 2010 at 10:48:39AM +0200, ext hvaibhav@xxxxxx wrote: > >From: Vaibhav Hiremath <hvaibhav@xxxxxx> > > 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 <hvaibhav@xxxxxx> > > [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 majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html