mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-24 07:46:48 +00:00
b04f245c39
Changelog: https://cdn.kernel.org/pub/linux/kernel/v6.x/ChangeLog-6.6.23 Removed upstreamed: pending-6.6/735-net-mediatek-mtk_eth_soc-release-MAC_MCR_FORCE_LINK-.patch[1] pending-6.6/736-net-ethernet-mtk_eth_soc-fix-PPE-hanging-issue.patch[2] mediatek/patches-6.6/232-clk-mediatek-mt7981-topckgen-flag-SGM_REG_SEL-as-cri.patch[3] Manually rebased: mediatek/patches-6.6/100-dts-update-mt7622-rfb1.patch Added: generic/backports-6.6/981-mtd-spinand-Add-support-for-5-byte-IDs.patch[4] All other patches automatically rebased. 1. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v6.6.23&id=1f32abb474c1c9bdb21d9eda74c325a0b3a162e5 2. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v6.6.23&id=943c14ece95eb1cf98d477462aebcbfdfd714633 3. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v6.6.23&id=6ff01b314149d1cf59caebc29384f0beed21cba4 4. See comments in https://github.com/openwrt/openwrt/pull/14992 regarding broken flogic/xiaomi_redmi-router-ax6000-ubootmod Build system: x86/64 Build-tested: x86/64/AMD Cezanne, flogic/xiaomi_redmi-router-ax6000-ubootmod, flogic/glinet_gl-mt6000 Run-tested: x86/64/AMD Cezannei, flogic/xiaomi_redmi-router-ax6000-ubootmod, flogic/glinet_gl-mt6000 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
|
|
@@ -1299,6 +1299,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 },
|
|
@@ -1407,12 +1439,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);
|