[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20190423141414.24264-3-jiada_wang@mentor.com>
Date: Tue, 23 Apr 2019 23:14:14 +0900
From: Jiada Wang <jiada_wang@...tor.com>
To: <rui.zhang@...el.com>, <edubezval@...il.com>,
<daniel.lezcano@...aro.org>
CC: <linux-pm@...r.kernel.org>, <linux-kernel@...r.kernel.org>,
<jiada_wang@...tor.com>, <horms+renesas@...ge.net.au>,
<niklas.soderlund+renesas@...natech.se>, <geert+renesas@...der.be>,
<sergei.shtylyov@...entembedded.com>,
<marek.vasut+renesas@...il.com>,
<kuninori.morimoto.gx@...esas.com>, <hien.dang.eb@...esas.com>,
<fabrizio.castro@...renesas.com>, <dien.pham.ry@...esas.com>,
<biju.das@...renesas.com>, <erosca@...adit-jv.com>,
<george_davis@...tor.com>, <joshua_frkuska@...tor.com>
Subject: [PATCH v3 2/2] thermal: rcar_gen3_thermal: disable interrupt in .remove
Currently IRQ is remain enabled after .remove, later if device is probed,
IRQ is requested before .thermal_init, this may cause IRQ function be
called before device is initialized.
this patch by disable interrupt in .remove, to ensure irq function
only be called after device is fully initialized.
Signed-off-by: Jiada Wang <jiada_wang@...tor.com>
---
drivers/thermal/rcar_gen3_thermal.c | 3 +++
1 file changed, 3 insertions(+)
diff --git a/drivers/thermal/rcar_gen3_thermal.c b/drivers/thermal/rcar_gen3_thermal.c
index ebbaef5a3cf1..c63a86d3dac6 100644
--- a/drivers/thermal/rcar_gen3_thermal.c
+++ b/drivers/thermal/rcar_gen3_thermal.c
@@ -309,6 +309,9 @@ MODULE_DEVICE_TABLE(of, rcar_gen3_thermal_dt_ids);
static int rcar_gen3_thermal_remove(struct platform_device *pdev)
{
struct device *dev = &pdev->dev;
+ struct rcar_gen3_thermal_priv *priv = dev_get_drvdata(dev);
+
+ rcar_thermal_irq_set(priv, false);
pm_runtime_put(dev);
pm_runtime_disable(dev);
--
2.19.2
Powered by blists - more mailing lists