summaryrefslogtreecommitdiff
path: root/drivers/mfd
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/mfd')
-rw-r--r--drivers/mfd/tps65912-irq.c4
-rw-r--r--drivers/mfd/tps65912-spi.c23
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, &reg);
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, &reg);
+ 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),