* [PATCH v3 0/2] Add Mediatek watchdog suspend resume and shutdown
@ 2015-07-24 7:28 Eddie Huang
2015-07-24 7:28 ` [PATCH v3 1/2] watchdog: mtk_wdt: add suspend/resume support Eddie Huang
2015-07-24 7:28 ` [PATCH v3 2/2] watchdog: mtk_wdt: add wdt shutdown callback to disable wdt if enabled Eddie Huang
0 siblings, 2 replies; 3+ messages in thread
From: Eddie Huang @ 2015-07-24 7:28 UTC (permalink / raw)
To: linux-arm-kernel
This series add Mediatek watchdog suspend, resume and shutdown support.
These patches are based on v4.2-rc1
Change in v3:
Add mtk_wdt in subject line
Change in v2:
Use watchdog_active() to check whether watchdog been active.
Change to register suspend,resume function to dev_pm_ops
^ permalink raw reply [flat|nested] 3+ messages in thread
* [PATCH v3 1/2] watchdog: mtk_wdt: add suspend/resume support
2015-07-24 7:28 [PATCH v3 0/2] Add Mediatek watchdog suspend resume and shutdown Eddie Huang
@ 2015-07-24 7:28 ` Eddie Huang
2015-07-24 7:28 ` [PATCH v3 2/2] watchdog: mtk_wdt: add wdt shutdown callback to disable wdt if enabled Eddie Huang
1 sibling, 0 replies; 3+ messages in thread
From: Eddie Huang @ 2015-07-24 7:28 UTC (permalink / raw)
To: linux-arm-kernel
From: Greta Zhang <greta.zhang@mediatek.com>
add mediatek watchdog driver suspend/resume support
Signed-off-by: Greta Zhang <greta.zhang@mediatek.com>
Signed-off-by: Roger Lu <roger.lu@mediatek.com>
Signed-off-by: Eddie Huang <eddie.huang@mediatek.com>
Acked-by: Matthias Brugger <matthias.bgg@gmail.com>
Reviewed-by: Guenter Roeck <linux@roeck-us.net>
---
drivers/watchdog/mtk_wdt.c | 30 ++++++++++++++++++++++++++++++
1 file changed, 30 insertions(+)
diff --git a/drivers/watchdog/mtk_wdt.c b/drivers/watchdog/mtk_wdt.c
index 938b987..056412c 100644
--- a/drivers/watchdog/mtk_wdt.c
+++ b/drivers/watchdog/mtk_wdt.c
@@ -221,17 +221,47 @@ static int mtk_wdt_remove(struct platform_device *pdev)
return 0;
}
+#ifdef CONFIG_PM_SLEEP
+static int mtk_wdt_suspend(struct device *dev)
+{
+ struct mtk_wdt_dev *mtk_wdt = dev_get_drvdata(dev);
+
+ if (watchdog_active(&mtk_wdt->wdt_dev))
+ mtk_wdt_stop(&mtk_wdt->wdt_dev);
+
+ return 0;
+}
+
+static int mtk_wdt_resume(struct device *dev)
+{
+ struct mtk_wdt_dev *mtk_wdt = dev_get_drvdata(dev);
+
+ if (watchdog_active(&mtk_wdt->wdt_dev)) {
+ mtk_wdt_start(&mtk_wdt->wdt_dev);
+ mtk_wdt_ping(&mtk_wdt->wdt_dev);
+ }
+
+ return 0;
+}
+#endif
+
static const struct of_device_id mtk_wdt_dt_ids[] = {
{ .compatible = "mediatek,mt6589-wdt" },
{ /* sentinel */ }
};
MODULE_DEVICE_TABLE(of, mtk_wdt_dt_ids);
+static const struct dev_pm_ops mtk_wdt_pm_ops = {
+ SET_SYSTEM_SLEEP_PM_OPS(mtk_wdt_suspend,
+ mtk_wdt_resume)
+};
+
static struct platform_driver mtk_wdt_driver = {
.probe = mtk_wdt_probe,
.remove = mtk_wdt_remove,
.driver = {
.name = DRV_NAME,
+ .pm = &mtk_wdt_pm_ops,
.of_match_table = mtk_wdt_dt_ids,
},
};
--
1.8.1.1.dirty
^ permalink raw reply related [flat|nested] 3+ messages in thread
* [PATCH v3 2/2] watchdog: mtk_wdt: add wdt shutdown callback to disable wdt if enabled
2015-07-24 7:28 [PATCH v3 0/2] Add Mediatek watchdog suspend resume and shutdown Eddie Huang
2015-07-24 7:28 ` [PATCH v3 1/2] watchdog: mtk_wdt: add suspend/resume support Eddie Huang
@ 2015-07-24 7:28 ` Eddie Huang
1 sibling, 0 replies; 3+ messages in thread
From: Eddie Huang @ 2015-07-24 7:28 UTC (permalink / raw)
To: linux-arm-kernel
From: Greta Zhang <greta.zhang@mediatek.com>
Without .shutdown(), watchdog might reset the system during power off.
For example, if watchdog's timeout is set to 30s, then it is reset to
zero by mtk_wdt_ping(). During power off, no app will ping watchdog,
but watchdog is still running and may trigger reset.
Signed-off-by: Greta Zhang <greta.zhang@mediatek.com>
Signed-off-by: Eddie Huang <eddie.huang@mediatek.com>
Acked-by: Matthias Brugger <matthias.bgg@gmail.com>
Reviewed-by: Guenter Roeck <linux@roeck-us.net>
---
drivers/watchdog/mtk_wdt.c | 9 +++++++++
1 file changed, 9 insertions(+)
diff --git a/drivers/watchdog/mtk_wdt.c b/drivers/watchdog/mtk_wdt.c
index 056412c..6ad9df9 100644
--- a/drivers/watchdog/mtk_wdt.c
+++ b/drivers/watchdog/mtk_wdt.c
@@ -210,6 +210,14 @@ static int mtk_wdt_probe(struct platform_device *pdev)
return 0;
}
+static void mtk_wdt_shutdown(struct platform_device *pdev)
+{
+ struct mtk_wdt_dev *mtk_wdt = platform_get_drvdata(pdev);
+
+ if (watchdog_active(&mtk_wdt->wdt_dev))
+ mtk_wdt_stop(&mtk_wdt->wdt_dev);
+}
+
static int mtk_wdt_remove(struct platform_device *pdev)
{
struct mtk_wdt_dev *mtk_wdt = platform_get_drvdata(pdev);
@@ -259,6 +267,7 @@ static const struct dev_pm_ops mtk_wdt_pm_ops = {
static struct platform_driver mtk_wdt_driver = {
.probe = mtk_wdt_probe,
.remove = mtk_wdt_remove,
+ .shutdown = mtk_wdt_shutdown,
.driver = {
.name = DRV_NAME,
.pm = &mtk_wdt_pm_ops,
--
1.8.1.1.dirty
^ permalink raw reply related [flat|nested] 3+ messages in thread
end of thread, other threads:[~2015-07-24 7:28 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-07-24 7:28 [PATCH v3 0/2] Add Mediatek watchdog suspend resume and shutdown Eddie Huang
2015-07-24 7:28 ` [PATCH v3 1/2] watchdog: mtk_wdt: add suspend/resume support Eddie Huang
2015-07-24 7:28 ` [PATCH v3 2/2] watchdog: mtk_wdt: add wdt shutdown callback to disable wdt if enabled Eddie Huang
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).