Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp426499pxb; Tue, 3 Nov 2020 03:22:30 -0800 (PST) X-Google-Smtp-Source: ABdhPJxns2P6k/T/zHEx1CuFYZPsjpUUjDZJZgjg25UA/UdhogKtCH0tOoV8R42S0qLBTe5kdpuN X-Received: by 2002:a17:906:c315:: with SMTP id s21mr19115730ejz.285.1604402550029; Tue, 03 Nov 2020 03:22:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604402550; cv=none; d=google.com; s=arc-20160816; b=TY+NWZrRsGXDY7dLvWicE6S9DlaMqf6w4jlN3rYg8QINrEj0FB4U9GrZDxK4gELJlw 3vg0XJWTriV6r3KocE0sxDK/+9SiLCZFBB0725brFZeQp8uL/maoFugKejRyhAwNzIlk 5G0hVoc9uPjOk5WmppsThXkxiMJxuLlVidYkuCIzv0PGy6A0JUUpvSI9IiKRcv9j1af4 3UPTYDAJohiwCFSDZBFlz4CrUwqvN2lmOldwemwUggIm4xHDO2mCNgR2CgFe1PoyCw51 H//hUNNtzECNhpnCalfXVpvGknkGJcsd1lZhrwHqKl323Tl4RQ0fubG3Ieh/Imz28Yjk EHiQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from; bh=Ut4qCl6TzZgTIS6FFqV+rt52pcMMf9eaIsLN2EG951o=; b=MkAQDo6fgxKVrL/Auc7GdyxJxp/1Z4ixRRJ+agL52WzZoTK4rnws12vpeEonsbqYx7 XuAQbrg4B4ZW7cfuSolzPPJEHdzs6Haczrzl5N1U8HFr/pMgdVEp9nRaMg8006grUJz9 duJAGqGUI47zP4UTEJGmKCJ1efGRlohvcQzH3zL7aCwW6eDwM/WZfVI5hTQm3wsqdDiw /NTyTp4tfuU8TY+UDU7GtMRM0RPrCs+3YGfvFxQRCiYAfC/fji/0wuL+n/n10Q5Q3FUV 4+IqteAlNJJQNsRVjqv1ODuawE5y2npwyc9gPNmn8U/PhSop8nod8qEwpT5lB0bqGYkg yO8Q== 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=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g10si13012870edy.201.2020.11.03.03.22.08; Tue, 03 Nov 2020 03:22:30 -0800 (PST) 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=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728806AbgKCLUG (ORCPT + 99 others); Tue, 3 Nov 2020 06:20:06 -0500 Received: from inva020.nxp.com ([92.121.34.13]:38322 "EHLO inva020.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728470AbgKCLTT (ORCPT ); Tue, 3 Nov 2020 06:19:19 -0500 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 4FB331A0905; Tue, 3 Nov 2020 12:19:17 +0100 (CET) Received: from inva024.eu-rdc02.nxp.com (inva024.eu-rdc02.nxp.com [134.27.226.22]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 40ED11A04D2; Tue, 3 Nov 2020 12:19:17 +0100 (CET) Received: from fsr-ub1664-175.ea.freescale.net (fsr-ub1664-175.ea.freescale.net [10.171.82.40]) by inva024.eu-rdc02.nxp.com (Postfix) with ESMTP id 87F862033F; Tue, 3 Nov 2020 12:19:16 +0100 (CET) From: Abel Vesa To: Mike Turquette , Stephen Boyd , Adam Ford , Marek Vasut , Lucas Stach , Rob Herring , Shawn Guo , Sascha Hauer , Fabio Estevam , Anson Huang , Jacky Bai , Peng Fan , Dong Aisheng Cc: NXP Linux Team , linux-arm-kernel@lists.infradead.org, Linux Kernel Mailing List , linux-clk@vger.kernel.org, devicetree@vger.kernel.org, Abel Vesa Subject: [PATCH v5 08/14] clk: imx8mp: Add audio shared gate Date: Tue, 3 Nov 2020 13:18:20 +0200 Message-Id: <1604402306-5348-9-git-send-email-abel.vesa@nxp.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1604402306-5348-1-git-send-email-abel.vesa@nxp.com> References: <1604402306-5348-1-git-send-email-abel.vesa@nxp.com> X-Virus-Scanned: ClamAV using ClamSMTP Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org According to the RM, the CCGR101 is shared for the following root clocks: - AUDIO_AHB_CLK_ROOT - AUDIO_AXI_CLK_ROOT - SAI2_CLK_ROOT - SAI3_CLK_ROOT - SAI5_CLK_ROOT - SAI6_CLK_ROOT - SAI7_CLK_ROOT - PDM_CLK_ROOT Signed-off-by: Abel Vesa Reviewed-by: Dong Aisheng --- drivers/clk/imx/clk-imx8mp.c | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/drivers/clk/imx/clk-imx8mp.c b/drivers/clk/imx/clk-imx8mp.c index 3cb2bc4..02469f7 100644 --- a/drivers/clk/imx/clk-imx8mp.c +++ b/drivers/clk/imx/clk-imx8mp.c @@ -17,6 +17,7 @@ static u32 share_count_nand; static u32 share_count_media; +static u32 share_count_audio; static const char * const pll_ref_sels[] = { "osc_24m", "dummy", "dummy", "dummy", }; static const char * const audio_pll1_bypass_sels[] = {"audio_pll1", "audio_pll1_ref_sel", }; @@ -725,7 +726,16 @@ static int imx8mp_clocks_probe(struct platform_device *pdev) hws[IMX8MP_CLK_HDMI_ROOT] = imx_clk_hw_gate4("hdmi_root_clk", "hdmi_axi", ccm_base + 0x45f0, 0); hws[IMX8MP_CLK_TSENSOR_ROOT] = imx_clk_hw_gate4("tsensor_root_clk", "ipg_root", ccm_base + 0x4620, 0); hws[IMX8MP_CLK_VPU_ROOT] = imx_clk_hw_gate4("vpu_root_clk", "vpu_bus", ccm_base + 0x4630, 0); - hws[IMX8MP_CLK_AUDIO_ROOT] = imx_clk_hw_gate4("audio_root_clk", "ipg_root", ccm_base + 0x4650, 0); + + hws[IMX8MP_CLK_AUDIO_AHB_ROOT] = imx_clk_hw_gate2_shared2("audio_ahb_root", "audio_ahb", ccm_base + 0x4650, 0, &share_count_audio); + hws[IMX8MP_CLK_AUDIO_AXI_ROOT] = imx_clk_hw_gate2_shared2("audio_axi_root", "audio_axi", ccm_base + 0x4650, 0, &share_count_audio); + hws[IMX8MP_CLK_SAI1_ROOT] = imx_clk_hw_gate2_shared2("sai1_root", "sai1", ccm_base + 0x4650, 0, &share_count_audio); + hws[IMX8MP_CLK_SAI2_ROOT] = imx_clk_hw_gate2_shared2("sai2_root", "sai2", ccm_base + 0x4650, 0, &share_count_audio); + hws[IMX8MP_CLK_SAI3_ROOT] = imx_clk_hw_gate2_shared2("sai3_root", "sai3", ccm_base + 0x4650, 0, &share_count_audio); + hws[IMX8MP_CLK_SAI5_ROOT] = imx_clk_hw_gate2_shared2("sai5_root", "sai5", ccm_base + 0x4650, 0, &share_count_audio); + hws[IMX8MP_CLK_SAI6_ROOT] = imx_clk_hw_gate2_shared2("sai6_root", "sai6", ccm_base + 0x4650, 0, &share_count_audio); + hws[IMX8MP_CLK_SAI7_ROOT] = imx_clk_hw_gate2_shared2("sai7_root", "sai7", ccm_base + 0x4650, 0, &share_count_audio); + hws[IMX8MP_CLK_PDM_ROOT] = imx_clk_hw_gate2_shared2("pdm_root", "pdm", ccm_base + 0x4650, 0, &share_count_audio); hws[IMX8MP_CLK_ARM] = imx_clk_hw_cpu("arm", "arm_a53_core", hws[IMX8MP_CLK_A53_CORE]->clk, -- 2.7.4