Re: [PATCH 2/3] memory: mtk-smi: Add a flag skip_rpm

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Il 20/03/25 08:36, Xueqi Zhang ha scritto:
MT8196 SMI commons is backed up/restored by RTFF HW.
It doesn't need SW control the register backup/store
in the runtime callback.Therefore, add a flag skip_rpm
to help skip RPM operations for SMI commons.

Signed-off-by: Xueqi Zhang <xueqi.zhang@xxxxxxxxxxxx>

So the MT8196 SMI common doesn't require any clocks?

That's fine for me, but this looks bloody similar to MT6989's SMI common, which
is SMI GEN3 and not GEN2....

....so, are you sure that you need a `skip_rpm` flag and not new MTK_SMI_GEN3 and
MTK_SMI_GEN3_SUB_COMM types? :-)

Regards,
Angelo

---
  drivers/memory/mtk-smi.c | 11 ++++++++---
  1 file changed, 8 insertions(+), 3 deletions(-)

diff --git a/drivers/memory/mtk-smi.c b/drivers/memory/mtk-smi.c
index a8f5467d6b31..b9affa3c3185 100644
--- a/drivers/memory/mtk-smi.c
+++ b/drivers/memory/mtk-smi.c
@@ -123,6 +123,7 @@ static const char * const mtk_smi_common_clks[] = {"apb", "smi", "gals0", "gals1
  struct mtk_smi_common_plat {
  	enum mtk_smi_type	type;
  	bool			has_gals;
+	bool			skip_rpm;
  	u32			bus_sel; /* Balance some larbs to enter mmu0 or mmu1 */
const struct mtk_smi_reg_pair *init;
@@ -547,6 +548,9 @@ static int mtk_smi_dts_clk_init(struct device *dev, struct mtk_smi *smi,
  {
  	int i, ret;
+ if (smi->plat->skip_rpm)
+		return 0;
+
  	for (i = 0; i < clk_nr_required; i++)
  		smi->clks[i].id = clks[i];
  	ret = devm_clk_bulk_get(dev, clk_nr_required, smi->clks);
@@ -783,7 +787,7 @@ static int mtk_smi_common_probe(struct platform_device *pdev)
  	common->dev = dev;
  	common->plat = of_device_get_match_data(dev);
- if (common->plat->has_gals) {
+	if (!common->plat->skip_rpm && common->plat->has_gals) {
  		if (common->plat->type == MTK_SMI_GEN2)
  			clk_required = MTK_SMI_COM_GALS_REQ_CLK_NR;
  		else if (common->plat->type == MTK_SMI_GEN2_SUB_COMM)
@@ -814,13 +818,14 @@ static int mtk_smi_common_probe(struct platform_device *pdev)
  	}
/* link its smi-common if this is smi-sub-common */
-	if (common->plat->type == MTK_SMI_GEN2_SUB_COMM) {
+	if (common->plat->type == MTK_SMI_GEN2_SUB_COMM && !common->plat->skip_rpm) {
  		ret = mtk_smi_device_link_common(dev, &common->smi_common_dev);
  		if (ret < 0)
  			return ret;
  	}
- pm_runtime_enable(dev);
+	if (!common->plat->skip_rpm)
+		pm_runtime_enable(dev);
  	platform_set_drvdata(pdev, common);
  	return 0;
  }






[Index of Archives]     [Device Tree Compilter]     [Device Tree Spec]     [Linux Driver Backports]     [Video for Linux]     [Linux USB Devel]     [Linux PCI Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Yosemite Backpacking]


  Powered by Linux