Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1645251imm; Thu, 12 Jul 2018 05:39:10 -0700 (PDT) X-Google-Smtp-Source: AAOMgpeyR5k2BIqzpllQT6p+MQ3kJaNtLuH2ihIkzaN7HDVIUuSkMcRZjs1zhh3Ty1EbfQcTIdXj X-Received: by 2002:a63:8548:: with SMTP id u69-v6mr1979278pgd.346.1531399149995; Thu, 12 Jul 2018 05:39:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531399149; cv=none; d=google.com; s=arc-20160816; b=ivJf+VzfENrfFGiXEGqqe9cDU7pMzgALcwDdEW8hMpSinT6iqwk7q1RtIqnZtXINbT 22yCDt8ZUH/1yFOGNBD/qi/NlC2L0VQI1r0lTMpVDsPG2Fskl3giTNxht29CmpEzkRYc CeOS+AAHpg3Dev300M0SYjiwWRfNYUZbRIP29sA3NG1j3YIpXI2IBcp4/1xWfdDCW11e ORDIJRqWxCaMXyZV0xelPXKcDp+phj/YI90MlP3ykZU8ZYwCvh28RwSZDBM7ihbO2CpJ ca6tBXQKle069e9dgLOoiuoAscm5X0uT/Sxq74u9RbUS/gnwF7UGEzV029d2U97nckEE zsiA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:message-id:references :in-reply-to:subject:cc:to:from:date:content-transfer-encoding :mime-version:dkim-signature:dkim-signature :arc-authentication-results; bh=QH1agRHwcinW+xIUZg4LUE82MwuVlYDcQ55JqpZRS00=; b=F1AizujrVXWay3t4rl2NV1p6Nx8Cj0nk935/uriRj52bE4jyrzXRqmkzKx++SE5g46 hkBwPoGMhyAmlPBzD5icOQEarEs8f6xPlOzvG4kyFHrZkJxgIX3+llvgpOTnHvttteUH vgVt+cp20oqV/fVuYNayVbI8LMVIRBNr7++R8SJptWaVBk8xIvnIvquRq8fvZRQDr6o0 TLY5H8lnwpeBLP2YNQRHW47OlSbYrWYpPeuJED+fH/04c6jtHJDvmbcxIccJeajIFdsi J0QXbz+lE71BW5VlkVTOP7p77pPxm3iDJ/t3svWbnA3FGSH/Bsokde9LI2Wuo+DrU6de MaGQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b="ExzKL6i/"; dkim=pass header.i=@codeaurora.org header.s=default header.b=nxnWKOCd; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 62-v6si21300934ply.176.2018.07.12.05.38.54; Thu, 12 Jul 2018 05:39:09 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b="ExzKL6i/"; dkim=pass header.i=@codeaurora.org header.s=default header.b=nxnWKOCd; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732195AbeGLMrl (ORCPT + 99 others); Thu, 12 Jul 2018 08:47:41 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:44044 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726695AbeGLMrl (ORCPT ); Thu, 12 Jul 2018 08:47:41 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 4453360B6B; Thu, 12 Jul 2018 12:38:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1531399097; bh=5agLIvinFk0qvhC1bkz67jLGLJfkdYkOC0do6/Zevck=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=ExzKL6i/qaCqsqO0YxTtRYV/qwTEB9Aa1SHNyguDu9IhcJFi8X/vBLGs2KNwhc1NQ amnpPyUtNrAzUBcbuZEuW4Lsit1ImhY3JRI93fj0pM8oO4RUrtdyMwLvnw5uTmkj0p lz0CfQ/TQVN0OKDM475aRzNmiHZeVY3rMVqe5SFs= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.8 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_SIGNED,T_DKIM_INVALID autolearn=no autolearn_force=no version=3.4.0 Received: from mail.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.codeaurora.org (Postfix) with ESMTP id 9168760250; Thu, 12 Jul 2018 12:38:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1531399096; bh=5agLIvinFk0qvhC1bkz67jLGLJfkdYkOC0do6/Zevck=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=nxnWKOCda+hlFvH2wwIsUlKcR/io8Ktm6xMRdJPbYu8OoSf9KhKcL2pf81kQIMDYH x782aoQcXTBuqaDsFHWvz5Jzpo2J8gtnopYlnhNCpGcBgwzKl4aMbiZtOl5ZQPD+C5 QSuou93Ek0M6e4LS+AfYF7nkjTtW7/wICCQmaWRI= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit Date: Thu, 12 Jul 2018 18:08:16 +0530 From: Amit Nischal To: Stephen Boyd Cc: Michael Turquette , Andy Gross , David Brown , Rajendra Nayak , Odelu Kukatla , Taniya Das , linux-arm-msm@vger.kernel.org, linux-soc@vger.kernel.org, linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 4/4] clk: qcom: Add graphics clock controller driver for SDM845 In-Reply-To: <153111645061.143105.8885901620675705971@swboyd.mtv.corp.google.com> References: <1528285308-25477-1-git-send-email-anischal@codeaurora.org> <1528285308-25477-5-git-send-email-anischal@codeaurora.org> <153111645061.143105.8885901620675705971@swboyd.mtv.corp.google.com> Message-ID: <2b041e1bf8ef290889881f77712a248f@codeaurora.org> X-Sender: anischal@codeaurora.org User-Agent: Roundcube Webmail/1.2.5 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2018-07-09 11:37, Stephen Boyd wrote: > Quoting Amit Nischal (2018-06-06 04:41:48) >> diff --git a/drivers/clk/qcom/gpucc-sdm845.c >> b/drivers/clk/qcom/gpucc-sdm845.c >> new file mode 100644 >> index 0000000..81f8926 >> --- /dev/null >> +++ b/drivers/clk/qcom/gpucc-sdm845.c >> @@ -0,0 +1,441 @@ >> +// SPDX-License-Identifier: GPL-2.0 >> +/* >> + * Copyright (c) 2018, The Linux Foundation. All rights reserved. >> + */ >> + >> +#include >> +#include >> +#include >> +#include >> + >> +#include >> + >> +#include "common.h" >> +#include "clk-alpha-pll.h" >> +#include "clk-branch.h" >> +#include "clk-pll.h" >> +#include "clk-rcg.h" >> +#include "clk-regmap.h" >> +#include "gdsc.h" >> + >> +#define CX_GMU_CBCR_SLEEP_MASK 0xf >> +#define CX_GMU_CBCR_SLEEP_SHIFT 4 >> +#define CX_GMU_CBCR_WAKE_MASK 0xf >> +#define CX_GMU_CBCR_WAKE_SHIFT 8 >> +#define CLK_DIS_WAIT_SHIFT 12 >> +#define CLK_DIS_WAIT_MASK (0xf << CLK_DIS_WAIT_SHIFT) >> + >> +#define F(f, s, h, m, n) { (f), (s), (2 * (h) - 1), (m), (n) } > > This should be removed and series can depend on Taniya's patch. > Yes sure. I will do the required change and will submit the next patch series. >> + >> +enum { >> + P_BI_TCXO, >> + P_CORE_BI_PLL_TEST_SE, >> + P_GPLL0_OUT_MAIN, >> + P_GPLL0_OUT_MAIN_DIV, > [...] >> + .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], >> + .clkr = { >> + .hw.init = &(struct clk_init_data){ >> + .name = "gpu_cc_pll0", >> + .parent_names = (const char *[]){ "bi_tcxo" }, >> + .num_parents = 1, >> + .ops = &clk_alpha_pll_fabia_ops, >> + }, >> + }, >> +}; >> + >> +static const struct clk_div_table post_div_table_fabia_even[] = { >> + { 0x0, 1 }, >> + {}, > > Drop the trailing comma, it's a sentinel presumably. > Will fix this in the next patch series. >> +}; >> + >> +static struct clk_alpha_pll_postdiv gpu_cc_pll0_out_even = { >> + .offset = 0x0, >> + .post_div_shift = 8, >> + .post_div_table = post_div_table_fabia_even, >> + .num_post_div = ARRAY_SIZE(post_div_table_fabia_even), >> + .width = 4, >> + .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], >> + .clkr.hw.init = &(struct clk_init_data){ >> + .name = "gpu_cc_pll0_out_even", >> + .parent_names = (const char *[]){ "gpu_cc_pll0" }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_alpha_pll_postdiv_fabia_ops, >> + }, >> +}; >> + >> +static struct clk_alpha_pll gpu_cc_pll1 = { >> + .offset = 0x100, >> + .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], >> + .clkr = { >> + .hw.init = &(struct clk_init_data){ >> + .name = "gpu_cc_pll1", >> + .parent_names = (const char *[]){ "bi_tcxo" }, >> + .num_parents = 1, >> + .ops = &clk_alpha_pll_fabia_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_gpu_cc_gmu_clk_src[] = { >> + F(19200000, P_BI_TCXO, 1, 0, 0), >> + F(200000000, P_GPLL0_OUT_MAIN_DIV, 1.5, 0, 0), >> + F(500000000, P_GPU_CC_PLL1_OUT_MAIN, 1, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 gpu_cc_gmu_clk_src = { >> + .cmd_rcgr = 0x1120, >> + .mnd_width = 0, >> + .hid_width = 5, >> + .parent_map = gpu_cc_parent_map_0, >> + .freq_tbl = ftbl_gpu_cc_gmu_clk_src, >> + .clkr.hw.init = &(struct clk_init_data){ >> + .name = "gpu_cc_gmu_clk_src", >> + .parent_names = gpu_cc_parent_names_0, >> + .num_parents = 6, >> + .ops = &clk_rcg2_shared_ops, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_gpu_cc_gx_gfx3d_clk_src[] = { >> + F(180000000, P_GPU_CC_PLL0_OUT_EVEN, 2, 0, 0), >> + F(257000000, P_GPU_CC_PLL0_OUT_EVEN, 2, 0, 0), >> + F(342000000, P_GPU_CC_PLL0_OUT_EVEN, 2, 0, 0), >> + F(414000000, P_GPU_CC_PLL0_OUT_EVEN, 2, 0, 0), >> + F(520000000, P_GPU_CC_PLL0_OUT_EVEN, 2, 0, 0), >> + F(596000000, P_GPU_CC_PLL0_OUT_EVEN, 2, 0, 0), >> + F(675000000, P_GPU_CC_PLL0_OUT_EVEN, 2, 0, 0), >> + F(710000000, P_GPU_CC_PLL0_OUT_EVEN, 2, 0, 0), > > Do we really need to encode anything here in this table? Why can't we > have clk_ops that hardcode this clk to be a div-2 that passes the > frequency up to the parent source? Then this frequency table doesn't > need to be here at all, and can live in DT as an OPP table used by the > GPU driver. > Thanks for the suggestion. I will address the same in the next patch series where "clk_rcg2_gfx3d_determine_rate" op will always return the best parent as ‘GPU_CC_PLL0_OUT_EVEN’ and best_parent rate equal to twice of the requested rate. This will eliminate the need of frequency table. >> + { } >> +}; >> + >> +static struct clk_rcg2 gpu_cc_gx_gfx3d_clk_src = { >> + .cmd_rcgr = 0x101c, >> + .mnd_width = 0, >> + .hid_width = 5, >> + .parent_map = gpu_cc_parent_map_1, >> + .freq_tbl = ftbl_gpu_cc_gx_gfx3d_clk_src, >> + .clkr.hw.init = &(struct clk_init_data){ >> + .name = "gpu_cc_gx_gfx3d_clk_src", >> + .parent_names = gpu_cc_parent_names_1, >> + .num_parents = 7, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_rcg2_gfx3d_ops, > [...] >> +static struct clk_branch gpu_cc_cx_gmu_clk = { >> + .halt_reg = 0x1098, >> + .halt_check = BRANCH_HALT, >> + .clkr = { >> + .enable_reg = 0x1098, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data){ >> + .name = "gpu_cc_cx_gmu_clk", >> + .parent_names = (const char *[]){ >> + "gpu_cc_gmu_clk_src", >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gpu_cc_cx_snoc_dvm_clk = { >> + .halt_reg = 0x108c, >> + .halt_check = BRANCH_HALT, >> + .clkr = { >> + .enable_reg = 0x108c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data){ >> + .name = "gpu_cc_cx_snoc_dvm_clk", >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gpu_cc_cxo_clk = { > > This isn't always on and marked critical? No, this clock is not marked critical as GCC driver doesn't control this clock. > >> + .halt_reg = 0x109c, >> + .halt_check = BRANCH_HALT, >> + .clkr = { >> + .enable_reg = 0x109c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data){ >> + .name = "gpu_cc_cxo_clk", >> + .ops = &clk_branch2_ops, >> + }, >> + }, > [...] >> + >> +static struct gdsc gpu_cx_gdsc = { >> + .gdscr = 0x106c, >> + .gds_hw_ctrl = 0x1540, >> + .pd = { >> + .name = "gpu_cx_gdsc", >> + }, >> + .pwrsts = PWRSTS_OFF_ON, >> + .flags = VOTABLE, >> +}; >> + >> +static struct gdsc gpu_gx_gdsc = { >> + .gdscr = 0x100c, >> + .clamp_io_ctrl = 0x1508, >> + .pd = { >> + .name = "gpu_gx_gdsc", >> + }, >> + .clk_hws = { >> + &gpu_cc_gx_gfx3d_clk_src.clkr.hw, > > Hmm alright. So basically the core GPU power domain needs the wrapper > domain (CX) to be powered on and clocking for GX to work? Let's talk > about it in the other patch so I can understand more. > Yes, to turn on the GPU GX GDSC it requires below to be in ON state first. 1. GPU_CX_GDSC 2. ROOT clock GFX3D clock source. >> + }, >> + .clk_count = 1, >> + .pwrsts = PWRSTS_OFF_ON, >> + .flags = CLAMP_IO | AON_RESET | POLL_CFG_GDSCR, >> +}; >> + > [...] >> + >> +static int gpu_cc_sdm845_probe(struct platform_device *pdev) >> +{ >> + struct regmap *regmap; >> + unsigned int value, mask; >> + >> + regmap = qcom_cc_map(pdev, &gpu_cc_sdm845_desc); >> + if (IS_ERR(regmap)) >> + return PTR_ERR(regmap); >> + >> + clk_fabia_pll_configure(&gpu_cc_pll0, regmap, >> &gpu_cc_pll0_config); >> + clk_fabia_pll_configure(&gpu_cc_pll1, regmap, >> &gpu_cc_pll1_config); >> + >> + /* Configure gpu_cc_cx_gmu_clk with recommended wakeup/sleep >> settings */ >> + mask = CX_GMU_CBCR_WAKE_MASK << CX_GMU_CBCR_WAKE_SHIFT; >> + mask |= CX_GMU_CBCR_SLEEP_MASK << CX_GMU_CBCR_SLEEP_SHIFT; >> + value = 0xf << CX_GMU_CBCR_WAKE_SHIFT | 0xf << >> CX_GMU_CBCR_SLEEP_SHIFT; >> + regmap_update_bits(regmap, 0x1098, mask, value); >> + >> + /* Configure clk_dis_wait for for gpu_cx_gdsc */ > > s/for // > I will address this in the next patch series. >> + regmap_update_bits(regmap, 0x106c, CLK_DIS_WAIT_MASK, >> + (8 << >> CLK_DIS_WAIT_SHIFT)); > > Remove extra parenthesis. Yes sure, I will fix this in the next patch series. > >> + >> + return qcom_cc_really_probe(pdev, &gpu_cc_sdm845_desc, >> regmap); >> +} >> + > [...] >> + >> +MODULE_LICENSE("GPL v2"); > > MODULE_DESCRIPTION? I will add the module description in the next patch series.