Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp451943pxj; Wed, 16 Jun 2021 06:19:02 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwuT6erHgroyXZGyfDwsFRREIZA3r9lA1xLQNXQ8roL2qkowrDRCrLOIVY6KTRlWiBorMrr X-Received: by 2002:a05:6e02:4ae:: with SMTP id e14mr3642150ils.186.1623849542558; Wed, 16 Jun 2021 06:19:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623849542; cv=none; d=google.com; s=arc-20160816; b=G28ziwFKsSKppimoYrtbx6vviTzbRilK1aNX+oCEIuFN0xpNlcZHY0GZO/JX6DKZSQ 3PQqJyWxDAIU2b9a19dYy3fnRg8K6y0ESxaem5qBsgskTKLMgHT+Oh72aAKfhGEFmqVy qjozQpGi3l19ndfpzBFgknddGohwzl8uBq8VOUEBCL+BZmE/h8utDsSTMOnyJpA4XaZu hfaUIMBssx0QrXyex6Bsm26vF8+VOJihj2G+Obv6uNhaVCpXFR7li9rlM3dEPnW3MLNB Y2ubVHdGtl/gXTSC/5vpMCL1I8ezNozG9RaWMRoqv3g9cOhUoLDXIXCIXKvLYHLxMAg9 LUsQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from; bh=VP6g1Hkssf/dbFIgwFGGr3o0H4QVa6BFyJJVGbMyzkY=; b=wlhR13FdD0Vr1u1IcRtHRDjHRZsNnXlnai086GlI3hC6hUfFhWldt68FczK8hFW7g5 hVxhcOU80VugSj7z7JxcnqcQRDVtp6gykqp+a1n46/Ww9Mag3VIrZK0B+bZyZH3usoCQ ncfdBpE0dcfArmBrqdne1q3wk67VkCjKMJULjn0Lrwg+hKvTbuBwYnwJ6cazHZR8Noxf 8XJr8FYYudAj5/9j5GRBEmbiomudInCEhGaOx0geoi9DlayZja+m6SqeqfQaCyd30Wqx CmYHEqOPuI7/fqrixM9KD9ynABCwfCADU70OrkOcEAJRW0T/+i4C9W+T8WCv/KWLrzP1 m1+g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f6si1970777iox.103.2021.06.16.06.18.28; Wed, 16 Jun 2021 06:19:02 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232618AbhFPLrT (ORCPT + 99 others); Wed, 16 Jun 2021 07:47:19 -0400 Received: from mailgw01.mediatek.com ([210.61.82.183]:32935 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S230087AbhFPLrR (ORCPT ); Wed, 16 Jun 2021 07:47:17 -0400 X-UUID: b2b255ea32b248c187703587b5d9d101-20210616 X-UUID: b2b255ea32b248c187703587b5d9d101-20210616 Received: from mtkcas10.mediatek.inc [(172.21.101.39)] by mailgw01.mediatek.com (envelope-from ) (Generic MTA with TLSv1.2 ECDHE-RSA-AES256-SHA384 256/256) with ESMTP id 2001647873; Wed, 16 Jun 2021 19:45:09 +0800 Received: from mtkcas07.mediatek.inc (172.21.101.84) by mtkmbs08n1.mediatek.inc (172.21.101.55) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Wed, 16 Jun 2021 19:44:54 +0800 Received: from localhost.localdomain (10.17.3.153) by mtkcas07.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1497.2 via Frontend Transport; Wed, 16 Jun 2021 19:44:53 +0800 From: Yong Wu To: Krzysztof Kozlowski , Rob Herring , Matthias Brugger CC: Krzysztof Kozlowski , Joerg Roedel , Will Deacon , Robin Murphy , "Tomasz Figa" , , , , , , , , , , , Subject: [PATCH 6/9] memory: mtk-smi: Add smi sub common support Date: Wed, 16 Jun 2021 19:43:43 +0800 Message-ID: <20210616114346.18812-7-yong.wu@mediatek.com> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20210616114346.18812-1-yong.wu@mediatek.com> References: <20210616114346.18812-1-yong.wu@mediatek.com> MIME-Version: 1.0 Content-Type: text/plain X-MTK: N Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch adds smi-sub-common support. some larbs may connect with the smi-sub-common, then connect with smi-common. Before we create device link between smi-larb with smi-common, If we have sub-common, we should use device link the smi-larb and smi-sub-common, then use device link between the smi-sub-common with smi-common. This is for enabling clock/power automatically. Move the device link code to a new interface for reusing. there is no SW extra setting for smi-sub-common. Signed-off-by: Yong Wu --- drivers/memory/mtk-smi.c | 78 ++++++++++++++++++++++++++-------------- 1 file changed, 52 insertions(+), 26 deletions(-) diff --git a/drivers/memory/mtk-smi.c b/drivers/memory/mtk-smi.c index 6858877ac859..fa3a14605dc2 100644 --- a/drivers/memory/mtk-smi.c +++ b/drivers/memory/mtk-smi.c @@ -60,7 +60,8 @@ enum mtk_smi_type { MTK_SMI_GEN1, - MTK_SMI_GEN2 + MTK_SMI_GEN2, /* gen2 smi common */ + MTK_SMI_GEN2_SUB_COMM, /* gen2 smi sub common */ }; #define MTK_SMI_CLK_NR_MAX 4 @@ -93,13 +94,14 @@ struct mtk_smi { void __iomem *smi_ao_base; /* only for gen1 */ void __iomem *base; /* only for gen2 */ }; + struct device *smi_common_dev; /* for sub common */ const struct mtk_smi_common_plat *plat; }; struct mtk_smi_larb { /* larb: local arbiter */ struct mtk_smi smi; void __iomem *base; - struct device *smi_common_dev; + struct device *smi_common_dev; /* common or sub-common dev */ const struct mtk_smi_larb_gen *larb_gen; int larbid; u32 *mmu; @@ -206,6 +208,39 @@ mtk_smi_larb_unbind(struct device *dev, struct device *master, void *data) /* Do nothing as the iommu is always enabled. */ } +static int mtk_smi_device_link_common(struct device *dev, struct device **com_dev) +{ + struct platform_device *smi_com_pdev; + struct device_node *smi_com_node; + struct device *smi_com_dev; + struct device_link *link; + + smi_com_node = of_parse_phandle(dev->of_node, "mediatek,smi", 0); + if (!smi_com_node) + return -EINVAL; + + smi_com_pdev = of_find_device_by_node(smi_com_node); + of_node_put(smi_com_node); + if (smi_com_pdev) { + /* smi common is the supplier, Make sure it is ready before */ + if (!platform_get_drvdata(smi_com_pdev)) + return -EPROBE_DEFER; + smi_com_dev = &smi_com_pdev->dev; + link = device_link_add(dev, smi_com_dev, + DL_FLAG_PM_RUNTIME | DL_FLAG_STATELESS); + if (!link) { + dev_err(dev, "Unable to link smi-common dev\n"); + return -ENODEV; + } + *com_dev = smi_com_dev; + } else { + dev_err(dev, "Failed to get the smi_common device\n"); + return -EINVAL; + } + + return 0; +} + static const struct component_ops mtk_smi_larb_component_ops = { .bind = mtk_smi_larb_bind, .unbind = mtk_smi_larb_unbind, @@ -267,9 +302,6 @@ static int mtk_smi_larb_probe(struct platform_device *pdev) struct mtk_smi_larb *larb; struct resource *res; struct device *dev = &pdev->dev; - struct device_node *smi_node; - struct platform_device *smi_pdev; - struct device_link *link; int i, ret; larb = devm_kzalloc(dev, sizeof(*larb), GFP_KERNEL); @@ -291,27 +323,9 @@ static int mtk_smi_larb_probe(struct platform_device *pdev) return ret; larb->smi.dev = dev; - - smi_node = of_parse_phandle(dev->of_node, "mediatek,smi", 0); - if (!smi_node) - return -EINVAL; - - smi_pdev = of_find_device_by_node(smi_node); - of_node_put(smi_node); - if (smi_pdev) { - if (!platform_get_drvdata(smi_pdev)) - return -EPROBE_DEFER; - larb->smi_common_dev = &smi_pdev->dev; - link = device_link_add(dev, larb->smi_common_dev, - DL_FLAG_PM_RUNTIME | DL_FLAG_STATELESS); - if (!link) { - dev_err(dev, "Unable to link smi-common dev\n"); - return -ENODEV; - } - } else { - dev_err(dev, "Failed to get the smi_common device\n"); - return -EINVAL; - } + ret = mtk_smi_device_link_common(dev, &larb->smi_common_dev); + if (ret < 0) + return ret; pm_runtime_enable(dev); platform_set_drvdata(pdev, larb); @@ -451,6 +465,14 @@ static int mtk_smi_common_probe(struct platform_device *pdev) if (IS_ERR(common->base)) return PTR_ERR(common->base); } + + /* link its smi-common if this is smi-sub-common */ + if (common->plat->type == MTK_SMI_GEN2_SUB_COMM) { + ret = mtk_smi_device_link_common(dev, &common->smi_common_dev); + if (ret < 0) + return ret; + } + pm_runtime_enable(dev); platform_set_drvdata(pdev, common); return 0; @@ -458,6 +480,10 @@ static int mtk_smi_common_probe(struct platform_device *pdev) static int mtk_smi_common_remove(struct platform_device *pdev) { + struct mtk_smi *common = dev_get_drvdata(&pdev->dev); + + if (common->plat->type == MTK_SMI_GEN2_SUB_COMM) + device_link_remove(&pdev->dev, common->smi_common_dev); pm_runtime_disable(&pdev->dev); return 0; } -- 2.18.0