Message ID | 20180226215102.GG16043@atomide.com (mailing list archive) |
---|---|
State | Mainlined |
Delegated to: | Rafael Wysocki |
Headers | show |
On Mon, 2018-02-26 at 13:51 -0800, Tony Lindgren wrote: > * Andy Shevchenko <andriy.shevchenko@linux.intel.com> [180225 13:37]: > > On Fri, 2018-02-23 at 14:06 -0800, Tony Lindgren wrote: > > > > + wirq->name = kasprintf(GFP_KERNEL, "%s:wakeup", > + dev_name(dev)); Can it make one line? In any case, Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
On Mon, Feb 26, 2018 at 10:55 PM, Andy Shevchenko <andriy.shevchenko@linux.intel.com> wrote: > On Mon, 2018-02-26 at 13:51 -0800, Tony Lindgren wrote: >> * Andy Shevchenko <andriy.shevchenko@linux.intel.com> [180225 13:37]: >> > On Fri, 2018-02-23 at 14:06 -0800, Tony Lindgren wrote: >> > > > > >> + wirq->name = kasprintf(GFP_KERNEL, "%s:wakeup", >> + dev_name(dev)); > > Can it make one line? I can fix this up. > > In any case, > Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> I'll queue up the patch for 4.17 shortly. Thanks!
diff --git a/drivers/base/power/power.h b/drivers/base/power/power.h --- a/drivers/base/power/power.h +++ b/drivers/base/power/power.h @@ -31,6 +31,7 @@ struct wake_irq { struct device *dev; unsigned int status; int irq; + const char *name; }; extern void dev_pm_arm_wake_irq(struct wake_irq *wirq); diff --git a/drivers/base/power/wakeirq.c b/drivers/base/power/wakeirq.c --- a/drivers/base/power/wakeirq.c +++ b/drivers/base/power/wakeirq.c @@ -112,6 +112,7 @@ void dev_pm_clear_wake_irq(struct device *dev) free_irq(wirq->irq, wirq); wirq->status &= ~WAKE_IRQ_DEDICATED_MASK; } + kfree(wirq->name); kfree(wirq); } EXPORT_SYMBOL_GPL(dev_pm_clear_wake_irq); @@ -184,6 +185,13 @@ int dev_pm_set_dedicated_wake_irq(struct device *dev, int irq) if (!wirq) return -ENOMEM; + wirq->name = kasprintf(GFP_KERNEL, "%s:wakeup", + dev_name(dev)); + if (!wirq->name) { + err = -ENOMEM; + goto err_free; + } + wirq->dev = dev; wirq->irq = irq; irq_set_status_flags(irq, IRQ_NOAUTOEN); @@ -196,9 +204,9 @@ int dev_pm_set_dedicated_wake_irq(struct device *dev, int irq) * so we use a threaded irq. */ err = request_threaded_irq(irq, NULL, handle_threaded_wake_irq, - IRQF_ONESHOT, dev_name(dev), wirq); + IRQF_ONESHOT, wirq->name, wirq); if (err) - goto err_free; + goto err_free_name; err = dev_pm_attach_wake_irq(dev, irq, wirq); if (err) @@ -210,6 +218,8 @@ int dev_pm_set_dedicated_wake_irq(struct device *dev, int irq) err_free_irq: free_irq(irq, wirq); +err_free_name: + kfree(wirq->name); err_free: kfree(wirq);