diff options
Diffstat (limited to 'drivers/mfd')
| -rw-r--r-- | drivers/mfd/tps65912-irq.c | 4 | ||||
| -rw-r--r-- | drivers/mfd/tps65912-spi.c | 23 |
2 files changed, 27 insertions, 0 deletions
diff --git a/drivers/mfd/tps65912-irq.c b/drivers/mfd/tps65912-irq.c index 96e7b6a34b0..110d714421b 100644 --- a/drivers/mfd/tps65912-irq.c +++ b/drivers/mfd/tps65912-irq.c @@ -81,6 +81,7 @@ static irqreturn_t tps65912_irq(int irq, void *irq_data) int i; pr_debug("tps65912 handle irq %d\n", irq); + mutex_lock(&tps65912->pm_lock); tps65912->read(tps65912, TPS65912_INT_STS, 1, ®); irq_sts = reg; @@ -93,6 +94,7 @@ static irqreturn_t tps65912_irq(int irq, void *irq_data) irq_sts &= ~tps65912->irq_mask; if (!irq_sts) { + mutex_unlock(&tps65912->pm_lock); pr_debug("tps65912 %d IRQ_NONE\n", irq); return IRQ_NONE; } @@ -121,6 +123,8 @@ static irqreturn_t tps65912_irq(int irq, void *irq_data) if (reg) tps65912->write(tps65912, TPS65912_INT_STS4, 1, ®); + mutex_unlock(&tps65912->pm_lock); + pr_debug("tps65912 %d IRQ_HANDLED\n", irq); return IRQ_HANDLED; } diff --git a/drivers/mfd/tps65912-spi.c b/drivers/mfd/tps65912-spi.c index bf520899b13..922cc482ff4 100644 --- a/drivers/mfd/tps65912-spi.c +++ b/drivers/mfd/tps65912-spi.c @@ -103,6 +103,8 @@ static int tps65912_spi_probe(struct spi_device *spi) tps65912->read = tps65912_spi_read; tps65912->write = tps65912_spi_write; + mutex_init(&tps65912->pm_lock); + spi_set_drvdata(spi, tps65912); return tps65912_device_init(tps65912); @@ -117,9 +119,30 @@ static int tps65912_spi_remove(struct spi_device *spi) return 0; } +int tps65912_spi_suspend_late(struct device *dev) +{ + struct tps65912 *tps65912 = dev_get_drvdata(dev); + if (tps65912) + mutex_lock(&tps65912->pm_lock); + return 0; +} +int tps65912_spi_resume_early(struct device *dev) +{ + struct tps65912 *tps65912 = dev_get_drvdata(dev); + if (tps65912) + mutex_unlock(&tps65912->pm_lock); + return 0; +} + +static struct dev_pm_ops tps65912_pm_ops = { + .suspend_late = tps65912_spi_suspend_late, + .resume_early = tps65912_spi_resume_early, +}; + static struct spi_driver tps65912_spi_driver = { .driver = { .name = "tps65912", + .pm = &tps65912_pm_ops, .bus = &spi_bus_type, .owner = THIS_MODULE, .of_match_table = of_match_ptr(tps65912_of_match), |