From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Google-Smtp-Source: AB8JxZorZKnlJTa0xrgcp4tH1soOiKS5OhklAxhCT/Fysqf/25D6ZdJfwwT6nVWN0f3+lkKKSQJV ARC-Seal: i=1; a=rsa-sha256; t=1524821098; cv=none; d=google.com; s=arc-20160816; b=TSflIsIBe1W1nbo1zFpiL4OY4/8PvVFBp5iYr2zGcAJHs37WQ6ARch3mn+2cR4p2ES G1XEpKmAEDCINDJetRExTecB49ibU0MhX05Ss3bEsZUrYf2/V03cjO0yNPfKOlf5agFC /e8dURwseqa7MsI+CoKEJyKD88wVYgTf6go+COi/0hAha44VQ8RrfI0QLMUU3J6sEKUM 5WyeodQOYYZpuDQ7YOgrPeZ46iMRmx5RDolJ2/6RjLZXede/L6V80f4uolsHLYV0Tff9 qBNd14XvFLnTffRuJx9CKDBQlqOVC2Mp1HU+ygsFEtk5EtVayJbPnlb8KfBs3hzRWtMs A9mg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=references:in-reply-to:references:in-reply-to:message-id:date :subject:cc:to:from:dmarc-filter:arc-authentication-results; bh=Fq4aBtV21HR25K2Nj2rwLpjpU199amEIgcEzjpwZr88=; b=uJXhoQLzRu/HfaXRU/wNdnGorAFUvPTbrJljxPLD9p0Q4Dj/Jqu+c4CjnIiTujlsmr ezfYNPklrnNAoe6owOqz+r3ffBahxJmdm7gAIeqcTab5dTC4En4YR1+jHGlG0DeemN1+ G0uInQJYI5ISHSdaF5x1DEcuzjIh5NxboffDRwCwbq8tjI5RB8H8j6Mpfo7z+Ojbt/5E LBIHzRecjMrFgQMgLAJYebL+Optp9+lshJKMIXJ7wTPsHvTat/6kPiszqctGEeIEa6gw UkAzZvMCe59RsNa/Jkwm6kWwIweBTMrV/XxV91Vm3NXYhKRTnac2mgEr0R5nNszlpB8r vFXw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of matthias.bgg@kernel.org designates 198.145.29.99 as permitted sender) smtp.mailfrom=matthias.bgg@kernel.org Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of matthias.bgg@kernel.org designates 198.145.29.99 as permitted sender) smtp.mailfrom=matthias.bgg@kernel.org DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org BB64B2187A Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=kernel.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=matthias.bgg@kernel.org From: matthias.bgg@kernel.org To: ulrich.hecht+renesas@gmail.com, laurent.pinchart@ideasonboard.com, ck.hu@mediatek.com, p.zabel@pengutronix.de, airlied@linux.ie, robh+dt@kernel.org, mark.rutland@arm.com, mturquette@baylibre.com, sboyd@codeaurora.org, lee.jones@linaro.org Cc: davem@davemloft.net, gregkh@linuxfoundation.org, mchehab@kernel.org, rdunlap@infradead.org, sean.wang@mediatek.com, linux-clk@vger.kernel.org, linux@armlinux.org.uk, matthias.bgg@gmail.com, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, Matthias Brugger Subject: [v3 08/10] clk: mediatek: mt8173-mm: switch to mfd device Date: Fri, 27 Apr 2018 11:24:00 +0200 Message-Id: <228863cbbde4a4c682a6596343a8071119b913e7.1524820923.git.mbrugger@suse.com> X-Mailer: git-send-email 2.16.3 In-Reply-To: References: In-Reply-To: References: X-getmail-retrieved-from-mailbox: INBOX X-GMAIL-THRID: =?utf-8?q?1598890808120115238?= X-GMAIL-MSGID: =?utf-8?q?1598890808120115238?= X-Mailing-List: linux-kernel@vger.kernel.org List-ID: From: Matthias Brugger As the new mfd device is in place, switch probing for the MMSYS to support invocation from the mfd device. Signed-off-by: Matthias Brugger Acked-by: Stephen Boyd --- drivers/clk/mediatek/clk-mt8173.c | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/drivers/clk/mediatek/clk-mt8173.c b/drivers/clk/mediatek/clk-mt8173.c index 96c292c3e440..e31b3ee3e968 100644 --- a/drivers/clk/mediatek/clk-mt8173.c +++ b/drivers/clk/mediatek/clk-mt8173.c @@ -15,6 +15,7 @@ #include #include #include +#include #include "clk-mtk.h" #include "clk-gate.h" @@ -791,7 +792,7 @@ static const struct mtk_gate_regs mm1_cg_regs __initconst = { .ops = &mtk_clk_gate_ops_setclr, \ } -static const struct mtk_gate mm_clks[] __initconst = { +static const struct mtk_gate mm_clks[] = { /* MM0 */ GATE_MM0(CLK_MM_SMI_COMMON, "mm_smi_common", "mm_sel", 0), GATE_MM0(CLK_MM_SMI_LARB0, "mm_smi_larb0", "mm_sel", 1), @@ -1152,10 +1153,13 @@ static void __init mtk_imgsys_init(struct device_node *node) } CLK_OF_DECLARE(mtk_imgsys, "mediatek,mt8173-imgsys", mtk_imgsys_init); -static void __init mtk_mmsys_init(struct device_node *node) +static int mtk_mmsys_probe(struct platform_device *pdev) { struct clk_onecell_data *clk_data; int r; + struct device_node *node; + + node = pdev->dev.parent->of_node; clk_data = mtk_alloc_clk_data(CLK_MM_NR_CLK); @@ -1166,8 +1170,17 @@ static void __init mtk_mmsys_init(struct device_node *node) if (r) pr_err("%s(): could not register clock provider: %d\n", __func__, r); + + return r; } -CLK_OF_DECLARE(mtk_mmsys, "mediatek,mt8173-mmsys", mtk_mmsys_init); + +static struct platform_driver clk_mt8173_mm_drv = { + .probe = mtk_mmsys_probe, + .driver = { + .name = "clk-mt8173-mm", + }, +}; +builtin_platform_driver(clk_mt8173_mm_drv); static void __init mtk_vdecsys_init(struct device_node *node) { -- 2.16.3 From mboxrd@z Thu Jan 1 00:00:00 1970 From: matthias.bgg@kernel.org Subject: [v3 08/10] clk: mediatek: mt8173-mm: switch to mfd device Date: Fri, 27 Apr 2018 11:24:00 +0200 Message-ID: <228863cbbde4a4c682a6596343a8071119b913e7.1524820923.git.mbrugger@suse.com> References: Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: In-Reply-To: In-Reply-To: References: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" To: ulrich.hecht+renesas@gmail.com, laurent.pinchart@ideasonboard.com, ck.hu@mediatek.com, p.zabel@pengutronix.de, airlied@linux.ie, robh+dt@kernel.org, mark.rutland@arm.com, mturquette@baylibre.com, sboyd@codeaurora.org, lee.jones@linaro.org Cc: sean.wang@mediatek.com, gregkh@linuxfoundation.org, rdunlap@infradead.org, linux@armlinux.org.uk, dri-devel@lists.freedesktop.org, linux-clk@vger.kernel.org, Matthias Brugger , linux-mediatek@lists.infradead.org, linux-arm-kernel@lists.infradead.org, matthias.bgg@gmail.com, mchehab@kernel.org, davem@davemloft.net, linux-kernel@vger.kernel.org List-Id: linux-mediatek@lists.infradead.org RnJvbTogTWF0dGhpYXMgQnJ1Z2dlciA8bWJydWdnZXJAc3VzZS5jb20+CgpBcyB0aGUgbmV3IG1m ZCBkZXZpY2UgaXMgaW4gcGxhY2UsIHN3aXRjaCBwcm9iaW5nCmZvciB0aGUgTU1TWVMgdG8gc3Vw cG9ydCBpbnZvY2F0aW9uIGZyb20gdGhlIG1mZCBkZXZpY2UuCgpTaWduZWQtb2ZmLWJ5OiBNYXR0 aGlhcyBCcnVnZ2VyIDxtYnJ1Z2dlckBzdXNlLmNvbT4KQWNrZWQtYnk6IFN0ZXBoZW4gQm95ZCA8 c2JveWRAY29kZWF1cm9yYS5vcmc+Ci0tLQogZHJpdmVycy9jbGsvbWVkaWF0ZWsvY2xrLW10ODE3 My5jIHwgMTkgKysrKysrKysrKysrKysrKy0tLQogMSBmaWxlIGNoYW5nZWQsIDE2IGluc2VydGlv bnMoKyksIDMgZGVsZXRpb25zKC0pCgpkaWZmIC0tZ2l0IGEvZHJpdmVycy9jbGsvbWVkaWF0ZWsv Y2xrLW10ODE3My5jIGIvZHJpdmVycy9jbGsvbWVkaWF0ZWsvY2xrLW10ODE3My5jCmluZGV4IDk2 YzI5MmMzZTQ0MC4uZTMxYjNlZTNlOTY4IDEwMDY0NAotLS0gYS9kcml2ZXJzL2Nsay9tZWRpYXRl ay9jbGstbXQ4MTczLmMKKysrIGIvZHJpdmVycy9jbGsvbWVkaWF0ZWsvY2xrLW10ODE3My5jCkBA IC0xNSw2ICsxNSw3IEBACiAjaW5jbHVkZSA8bGludXgvY2xrLmg+CiAjaW5jbHVkZSA8bGludXgv b2YuaD4KICNpbmNsdWRlIDxsaW51eC9vZl9hZGRyZXNzLmg+CisjaW5jbHVkZSA8bGludXgvcGxh dGZvcm1fZGV2aWNlLmg+CiAKICNpbmNsdWRlICJjbGstbXRrLmgiCiAjaW5jbHVkZSAiY2xrLWdh dGUuaCIKQEAgLTc5MSw3ICs3OTIsNyBAQCBzdGF0aWMgY29uc3Qgc3RydWN0IG10a19nYXRlX3Jl Z3MgbW0xX2NnX3JlZ3MgX19pbml0Y29uc3QgPSB7CiAJCS5vcHMgPSAmbXRrX2Nsa19nYXRlX29w c19zZXRjbHIsCQlcCiAJfQogCi1zdGF0aWMgY29uc3Qgc3RydWN0IG10a19nYXRlIG1tX2Nsa3Nb XSBfX2luaXRjb25zdCA9IHsKK3N0YXRpYyBjb25zdCBzdHJ1Y3QgbXRrX2dhdGUgbW1fY2xrc1td ID0gewogCS8qIE1NMCAqLwogCUdBVEVfTU0wKENMS19NTV9TTUlfQ09NTU9OLCAibW1fc21pX2Nv bW1vbiIsICJtbV9zZWwiLCAwKSwKIAlHQVRFX01NMChDTEtfTU1fU01JX0xBUkIwLCAibW1fc21p X2xhcmIwIiwgIm1tX3NlbCIsIDEpLApAQCAtMTE1MiwxMCArMTE1MywxMyBAQCBzdGF0aWMgdm9p ZCBfX2luaXQgbXRrX2ltZ3N5c19pbml0KHN0cnVjdCBkZXZpY2Vfbm9kZSAqbm9kZSkKIH0KIENM S19PRl9ERUNMQVJFKG10a19pbWdzeXMsICJtZWRpYXRlayxtdDgxNzMtaW1nc3lzIiwgbXRrX2lt Z3N5c19pbml0KTsKIAotc3RhdGljIHZvaWQgX19pbml0IG10a19tbXN5c19pbml0KHN0cnVjdCBk ZXZpY2Vfbm9kZSAqbm9kZSkKK3N0YXRpYyBpbnQgbXRrX21tc3lzX3Byb2JlKHN0cnVjdCBwbGF0 Zm9ybV9kZXZpY2UgKnBkZXYpCiB7CiAJc3RydWN0IGNsa19vbmVjZWxsX2RhdGEgKmNsa19kYXRh OwogCWludCByOworCXN0cnVjdCBkZXZpY2Vfbm9kZSAqbm9kZTsKKworCW5vZGUgPSBwZGV2LT5k ZXYucGFyZW50LT5vZl9ub2RlOwogCiAJY2xrX2RhdGEgPSBtdGtfYWxsb2NfY2xrX2RhdGEoQ0xL X01NX05SX0NMSyk7CiAKQEAgLTExNjYsOCArMTE3MCwxNyBAQCBzdGF0aWMgdm9pZCBfX2luaXQg bXRrX21tc3lzX2luaXQoc3RydWN0IGRldmljZV9ub2RlICpub2RlKQogCWlmIChyKQogCQlwcl9l cnIoIiVzKCk6IGNvdWxkIG5vdCByZWdpc3RlciBjbG9jayBwcm92aWRlcjogJWRcbiIsCiAJCQlf X2Z1bmNfXywgcik7CisKKwlyZXR1cm4gcjsKIH0KLUNMS19PRl9ERUNMQVJFKG10a19tbXN5cywg Im1lZGlhdGVrLG10ODE3My1tbXN5cyIsIG10a19tbXN5c19pbml0KTsKKworc3RhdGljIHN0cnVj dCBwbGF0Zm9ybV9kcml2ZXIgY2xrX210ODE3M19tbV9kcnYgPSB7CisJLnByb2JlID0gbXRrX21t c3lzX3Byb2JlLAorCS5kcml2ZXIgPSB7CisJCS5uYW1lID0gImNsay1tdDgxNzMtbW0iLAorCX0s Cit9OworYnVpbHRpbl9wbGF0Zm9ybV9kcml2ZXIoY2xrX210ODE3M19tbV9kcnYpOwogCiBzdGF0 aWMgdm9pZCBfX2luaXQgbXRrX3ZkZWNzeXNfaW5pdChzdHJ1Y3QgZGV2aWNlX25vZGUgKm5vZGUp CiB7Ci0tIAoyLjE2LjMKCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fCmRyaS1kZXZlbCBtYWlsaW5nIGxpc3QKZHJpLWRldmVsQGxpc3RzLmZyZWVkZXNrdG9w Lm9yZwpodHRwczovL2xpc3RzLmZyZWVkZXNrdG9wLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2RyaS1k ZXZlbAo= From mboxrd@z Thu Jan 1 00:00:00 1970 From: matthias.bgg@kernel.org (matthias.bgg at kernel.org) Date: Fri, 27 Apr 2018 11:24:00 +0200 Subject: [v3 08/10] clk: mediatek: mt8173-mm: switch to mfd device In-Reply-To: References: Message-ID: <228863cbbde4a4c682a6596343a8071119b913e7.1524820923.git.mbrugger@suse.com> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org From: Matthias Brugger As the new mfd device is in place, switch probing for the MMSYS to support invocation from the mfd device. Signed-off-by: Matthias Brugger Acked-by: Stephen Boyd --- drivers/clk/mediatek/clk-mt8173.c | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/drivers/clk/mediatek/clk-mt8173.c b/drivers/clk/mediatek/clk-mt8173.c index 96c292c3e440..e31b3ee3e968 100644 --- a/drivers/clk/mediatek/clk-mt8173.c +++ b/drivers/clk/mediatek/clk-mt8173.c @@ -15,6 +15,7 @@ #include #include #include +#include #include "clk-mtk.h" #include "clk-gate.h" @@ -791,7 +792,7 @@ static const struct mtk_gate_regs mm1_cg_regs __initconst = { .ops = &mtk_clk_gate_ops_setclr, \ } -static const struct mtk_gate mm_clks[] __initconst = { +static const struct mtk_gate mm_clks[] = { /* MM0 */ GATE_MM0(CLK_MM_SMI_COMMON, "mm_smi_common", "mm_sel", 0), GATE_MM0(CLK_MM_SMI_LARB0, "mm_smi_larb0", "mm_sel", 1), @@ -1152,10 +1153,13 @@ static void __init mtk_imgsys_init(struct device_node *node) } CLK_OF_DECLARE(mtk_imgsys, "mediatek,mt8173-imgsys", mtk_imgsys_init); -static void __init mtk_mmsys_init(struct device_node *node) +static int mtk_mmsys_probe(struct platform_device *pdev) { struct clk_onecell_data *clk_data; int r; + struct device_node *node; + + node = pdev->dev.parent->of_node; clk_data = mtk_alloc_clk_data(CLK_MM_NR_CLK); @@ -1166,8 +1170,17 @@ static void __init mtk_mmsys_init(struct device_node *node) if (r) pr_err("%s(): could not register clock provider: %d\n", __func__, r); + + return r; } -CLK_OF_DECLARE(mtk_mmsys, "mediatek,mt8173-mmsys", mtk_mmsys_init); + +static struct platform_driver clk_mt8173_mm_drv = { + .probe = mtk_mmsys_probe, + .driver = { + .name = "clk-mt8173-mm", + }, +}; +builtin_platform_driver(clk_mt8173_mm_drv); static void __init mtk_vdecsys_init(struct device_node *node) { -- 2.16.3