forked from Openwrt/openwrt
3711557bdf
Changelog: https://cdn.kernel.org/pub/linux/kernel/v6.x/ChangeLog-6.6.36
Manually rebased:
generic/hack-6.6/765-mxl-gpy-control-LED-reg-from-DT.patch
bcm27xx/patches-6.6/950-0536-dmaengine-dw-axi-dmac-Fixes-for-RP1.patch
Removed upstreamed:
bmips/patches-6.6/010-v6.10-mips-bmips-BCM6358-make-sure-CBR-is-correctly-set.patch[1]
All other patches automatically rebased.
1. 7c9644a7b5
Build system: x86/64
Build-tested: x86/64/AMD Cezanne, flogic/xiaomi_redmi-router-ax6000-ubootmod, ramips/tplink_archer-a6-v3
Run-tested: x86/64/AMD Cezanne, flogic/xiaomi_redmi-router-ax6000-ubootmod, ramips/tplink_archer-a6-v3
Signed-off-by: John Audia <therealgraysky@proton.me>
84 lines
2.3 KiB
Diff
84 lines
2.3 KiB
Diff
From a1d874ef3376295ee8ed89b3b5315f4c840ff00b Mon Sep 17 00:00:00 2001
|
|
From: Balsam CHIHI <bchihi@baylibre.com>
|
|
Date: Tue, 17 Oct 2023 21:05:42 +0200
|
|
Subject: [PATCH 40/42] thermal/drivers/mediatek/lvts_thermal: Add suspend and
|
|
resume
|
|
MIME-Version: 1.0
|
|
Content-Type: text/plain; charset=UTF-8
|
|
Content-Transfer-Encoding: 8bit
|
|
|
|
Add suspend and resume support to LVTS driver.
|
|
|
|
Signed-off-by: Balsam CHIHI <bchihi@baylibre.com>
|
|
[bero@baylibre.com: suspend/resume in noirq phase]
|
|
Co-developed-by: Bernhard Rosenkränzer <bero@baylibre.com>
|
|
Signed-off-by: Bernhard Rosenkränzer <bero@baylibre.com>
|
|
Reviewed-by: Matthias Brugger <matthias.bgg@gmail.com>
|
|
Reviewed-by: Alexandre Mergnat <amergnat@baylibre.com>
|
|
Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
|
|
Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org>
|
|
Link: https://lore.kernel.org/r/20231017190545.157282-3-bero@baylibre.com
|
|
---
|
|
drivers/thermal/mediatek/lvts_thermal.c | 37 +++++++++++++++++++++++++
|
|
1 file changed, 37 insertions(+)
|
|
|
|
--- a/drivers/thermal/mediatek/lvts_thermal.c
|
|
+++ b/drivers/thermal/mediatek/lvts_thermal.c
|
|
@@ -1303,6 +1303,38 @@ static const struct lvts_ctrl_data mt798
|
|
}
|
|
};
|
|
|
|
+static int lvts_suspend(struct device *dev)
|
|
+{
|
|
+ struct lvts_domain *lvts_td;
|
|
+ int i;
|
|
+
|
|
+ lvts_td = dev_get_drvdata(dev);
|
|
+
|
|
+ for (i = 0; i < lvts_td->num_lvts_ctrl; i++)
|
|
+ lvts_ctrl_set_enable(&lvts_td->lvts_ctrl[i], false);
|
|
+
|
|
+ clk_disable_unprepare(lvts_td->clk);
|
|
+
|
|
+ return 0;
|
|
+}
|
|
+
|
|
+static int lvts_resume(struct device *dev)
|
|
+{
|
|
+ struct lvts_domain *lvts_td;
|
|
+ int i, ret;
|
|
+
|
|
+ lvts_td = dev_get_drvdata(dev);
|
|
+
|
|
+ ret = clk_prepare_enable(lvts_td->clk);
|
|
+ if (ret)
|
|
+ return ret;
|
|
+
|
|
+ for (i = 0; i < lvts_td->num_lvts_ctrl; i++)
|
|
+ lvts_ctrl_set_enable(&lvts_td->lvts_ctrl[i], true);
|
|
+
|
|
+ return 0;
|
|
+}
|
|
+
|
|
static const struct lvts_ctrl_data mt8195_lvts_mcu_data_ctrl[] = {
|
|
{
|
|
.cal_offset = { 0x04, 0x07 },
|
|
@@ -1411,12 +1443,17 @@ static const struct of_device_id lvts_of
|
|
};
|
|
MODULE_DEVICE_TABLE(of, lvts_of_match);
|
|
|
|
+static const struct dev_pm_ops lvts_pm_ops = {
|
|
+ NOIRQ_SYSTEM_SLEEP_PM_OPS(lvts_suspend, lvts_resume)
|
|
+};
|
|
+
|
|
static struct platform_driver lvts_driver = {
|
|
.probe = lvts_probe,
|
|
.remove_new = lvts_remove,
|
|
.driver = {
|
|
.name = "mtk-lvts-thermal",
|
|
.of_match_table = lvts_of_match,
|
|
+ .pm = &lvts_pm_ops,
|
|
},
|
|
};
|
|
module_platform_driver(lvts_driver);
|