regmap: regmap-irq: Move handle_post_irq to before pm_runtime_put

Typically handle_post_irq is going to be used to manage some
additional chip specific hardware operations required on each IRQ,
these are very likely to want the chip to be resumed. For example the
current in tree user max77620 uses this to toggle a global mask bit,
which would obviously want the device resumed. It is worth noting this
device does not specify the runtime_pm flag in regmap_irq_chip, so
there is no actual issue.

Move the callback to before the pm_runtime_put, so it will be called
whilst the device is still resumed.

Signed-off-by: Charles Keepax <ckeepax@opensource.cirrus.com>
Link: https://lore.kernel.org/r/20230601101036.1499612-1-ckeepax@opensource.cirrus.com
Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
Charles Keepax 2023-06-01 11:10:35 +01:00 committed by Mark Brown
parent 3a48d2127f
commit 02534c8e96
No known key found for this signature in database
GPG Key ID: 24D68B725D5487D0

View File

@ -502,12 +502,12 @@ static irqreturn_t regmap_irq_thread(int irq, void *d)
} }
exit: exit:
if (chip->runtime_pm)
pm_runtime_put(map->dev);
if (chip->handle_post_irq) if (chip->handle_post_irq)
chip->handle_post_irq(chip->irq_drv_data); chip->handle_post_irq(chip->irq_drv_data);
if (chip->runtime_pm)
pm_runtime_put(map->dev);
if (handled) if (handled)
return IRQ_HANDLED; return IRQ_HANDLED;
else else