Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp3639425imm; Mon, 30 Jul 2018 00:22:00 -0700 (PDT) X-Google-Smtp-Source: AAOMgpe1fcjy4uVO8TmiSt9/P9b6rSK6fNHI17+d6hQmV06mNuqRHg5/N5LqKsIJSpilEHHBWd7M X-Received: by 2002:a63:1f4d:: with SMTP id q13-v6mr15452254pgm.241.1532935320414; Mon, 30 Jul 2018 00:22:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532935320; cv=none; d=google.com; s=arc-20160816; b=BjkM/mBAq6+2qwRp/JApGDqkRSGwpGADnB7vf294Vs70rOA+iFFkC8NroG4ADd+HW7 OaKMJFooSkXyEh+asmQeT4mpwoFoeTgqodqoGRufRH7v8ntBgrbcxmsNaknW4F7jwBma o3N4/Hf3C42G7YcttXKxiDy1v4rx2XPxRLnYM1qhC/0JRTVPAdEU5qOtPFIeTv6hPZMp 8DPtNZpk9Wm5AtmtaSAm0aaBdZRmV6KUatWTtyWU+RO0exkhYuR2iEcbdoVzu8HeDF02 1dX3XFYLRt4kTJDqnE0I1KXQqrSvGglaBp1beD1JUBnZKFeiVmCYP6gas90IHQwqoR4U 5Wqw== 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=vzNN6E+A3BYnNnu09rfGY6SvTDYxPh/cSByaWmoHfhw=; b=bM5tGBc8inXKVbXm0e2wyWYmyiFqSECxIWdHIJTQRmDOqzMexq7l60BDV1FSnHSEmM GxkVdsrMzF6nO6TvsI9H7J2IetJiuHGzoKDHq/0qAGzOuAxfYevu2ttC7SstualO/Cim 3xQ//4rRyO/tOTVtFFkAOUIlqtHcjIHbXRVTleGVcjy436OuAF2ESRjkBs3QfKFHJBI0 JnHSSasHc+nojX1YIdP3/5LCQL+SJLWtpuF0KNg9FS1NAhFxxKtLzsP/p8JToG+fqEW0 0sA9axxc1XVNFSmyIsi/8TP6/OVtPserb+ORAlXkma5l8DFyliet6u7ePBAKnFuSx2g0 ve+g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=RdIvp07f; dkim=pass header.i=@codeaurora.org header.s=default header.b=itl5Rf4z; 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 d15-v6si4467948pgb.645.2018.07.30.00.21.45; Mon, 30 Jul 2018 00:22:00 -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=RdIvp07f; dkim=pass header.i=@codeaurora.org header.s=default header.b=itl5Rf4z; 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 S1726632AbeG3Iyb (ORCPT + 99 others); Mon, 30 Jul 2018 04:54:31 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:59822 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726210AbeG3Iyb (ORCPT ); Mon, 30 Jul 2018 04:54:31 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 0840F602D7; Mon, 30 Jul 2018 07:20:53 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1532935254; bh=H1SHUyo0xwJokyPVYsh36SEfh2E1jp6tRVWgSDKmVZo=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=RdIvp07fkfCsdyuHTGXzy+A2idWl876M139ftZBFv16gzqS6uwGnAzjEA6F+qX+M3 C/HMWbQOUVn5aE6DYy2a/7VQsBjHJTdWSdvkD6jygDnl0TD4JShgcV26tVxcEjD5Qk wnLrnE9ly0tYAB3MNCLVTddCTXfpzN06+MFZemhQ= 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 BD856602D7; Mon, 30 Jul 2018 07:20:52 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1532935252; bh=H1SHUyo0xwJokyPVYsh36SEfh2E1jp6tRVWgSDKmVZo=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=itl5Rf4zLBFBduv+qYvlydAXPtKvOnsZqNtz1UnGSa40LFkX39bWNVo5o7Kp/fngI sZQywk23d0Pkp3usfHygp8oKmcYyve0+BQor3NJgf1tU8nCPF/fYFZQB29KPRKcB6j JHxx5LfcaCkRRPk8NnY0Vxg4XZFS+oppaXUtG9bY= MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Mon, 30 Jul 2018 12:50:52 +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, linux-clk-owner@vger.kernel.org Subject: Re: [PATCH 2/2] clk: qcom: Add camera clock controller driver for SDM845 In-Reply-To: <153262575082.48062.16264904338225269915@swboyd.mtv.corp.google.com> References: <1532345193-18108-1-git-send-email-anischal@codeaurora.org> <1532345193-18108-3-git-send-email-anischal@codeaurora.org> <153262575082.48062.16264904338225269915@swboyd.mtv.corp.google.com> Message-ID: <614e462b0294a1ece78b654ad3e4553f@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-26 22:52, Stephen Boyd wrote: > Quoting Amit Nischal (2018-07-23 04:26:33) >> diff --git a/drivers/clk/qcom/camcc-sdm845.c >> b/drivers/clk/qcom/camcc-sdm845.c >> new file mode 100644 >> index 0000000..61e5ec2 >> --- /dev/null >> +++ b/drivers/clk/qcom/camcc-sdm845.c >> @@ -0,0 +1,1736 @@ >> +// SPDX-License-Identifier: GPL-2.0 >> +/* >> + * Copyright (c) 2018, The Linux Foundation. All rights reserved. >> + */ >> + >> +#include > > Is this include used? This is not required. I will remove this in next patch series. > >> +#include >> +#include >> +#include >> +#include >> + >> +#include >> + >> +#include "common.h" >> +#include "clk-alpha-pll.h" >> +#include "clk-branch.h" >> +#include "clk-rcg.h" >> +#include "clk-regmap.h" >> +#include "gdsc.h" >> + >> +enum { >> + P_BI_TCXO, >> + P_CAM_CC_PLL0_OUT_EVEN, >> + P_CAM_CC_PLL1_OUT_EVEN, >> + P_CAM_CC_PLL2_OUT_EVEN, >> + P_CAM_CC_PLL3_OUT_EVEN, >> + P_CORE_BI_PLL_TEST_SE, >> +}; >> + >> +static const struct parent_map cam_cc_parent_map_0[] = { >> + { P_BI_TCXO, 0 }, >> + { P_CAM_CC_PLL2_OUT_EVEN, 1 }, >> + { P_CAM_CC_PLL1_OUT_EVEN, 2 }, >> + { P_CAM_CC_PLL3_OUT_EVEN, 5 }, >> + { P_CAM_CC_PLL0_OUT_EVEN, 6 }, >> + { P_CORE_BI_PLL_TEST_SE, 7 }, >> +}; >> + >> +static const char * const cam_cc_parent_names_0[] = { >> + "bi_tcxo", >> + "cam_cc_pll2_out_even", >> + "cam_cc_pll1_out_even", >> + "cam_cc_pll3_out_even", >> + "cam_cc_pll0_out_even", >> + "core_bi_pll_test_se", >> +}; >> + >> +static struct clk_alpha_pll cam_cc_pll0 = { >> + .offset = 0x0, >> + .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], >> + .clkr = { >> + .hw.init = &(struct clk_init_data){ >> + .name = "cam_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 }, >> + { 0x1, 2 }, >> + { } >> +}; >> + >> +static struct clk_alpha_pll_postdiv cam_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 = "cam_cc_pll0_out_even", >> + .parent_names = (const char *[]){ "cam_cc_pll0" }, >> + .num_parents = 1, >> + .ops = &clk_alpha_pll_postdiv_fabia_ops, >> + }, >> +}; >> + >> +static struct clk_alpha_pll cam_cc_pll1 = { >> + .offset = 0x1000, >> + .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], >> + .clkr = { >> + .hw.init = &(struct clk_init_data){ >> + .name = "cam_cc_pll1", >> + .parent_names = (const char *[]){ "bi_tcxo" }, >> + .num_parents = 1, >> + .ops = &clk_alpha_pll_fabia_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_alpha_pll_postdiv cam_cc_pll1_out_even = { >> + .offset = 0x1000, >> + .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 = "cam_cc_pll1_out_even", >> + .parent_names = (const char *[]){ "cam_cc_pll1" }, >> + .num_parents = 1, >> + .ops = &clk_alpha_pll_postdiv_fabia_ops, >> + }, >> +}; >> + >> +static struct clk_alpha_pll cam_cc_pll2 = { >> + .offset = 0x2000, >> + .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], >> + .clkr = { >> + .hw.init = &(struct clk_init_data){ >> + .name = "cam_cc_pll2", >> + .parent_names = (const char *[]){ "bi_tcxo" }, >> + .num_parents = 1, >> + .ops = &clk_alpha_pll_fabia_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_alpha_pll_postdiv cam_cc_pll2_out_even = { >> + .offset = 0x2000, >> + .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 = "cam_cc_pll2_out_even", >> + .parent_names = (const char *[]){ "cam_cc_pll2" }, >> + .num_parents = 1, >> + .ops = &clk_alpha_pll_postdiv_fabia_ops, >> + }, >> +}; >> + >> +static struct clk_alpha_pll cam_cc_pll3 = { >> + .offset = 0x3000, >> + .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], >> + .clkr = { >> + .hw.init = &(struct clk_init_data){ >> + .name = "cam_cc_pll3", >> + .parent_names = (const char *[]){ "bi_tcxo" }, >> + .num_parents = 1, >> + .ops = &clk_alpha_pll_fabia_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_alpha_pll_postdiv cam_cc_pll3_out_even = { >> + .offset = 0x3000, >> + .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 = "cam_cc_pll3_out_even", >> + .parent_names = (const char *[]){ "cam_cc_pll3" }, >> + .num_parents = 1, >> + .ops = &clk_alpha_pll_postdiv_fabia_ops, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_cam_cc_bps_clk_src[] = { >> + F(19200000, P_BI_TCXO, 1, 0, 0), >> + F(100000000, P_CAM_CC_PLL0_OUT_EVEN, 6, 0, 0), >> + F(200000000, P_CAM_CC_PLL0_OUT_EVEN, 3, 0, 0), >> + F(404000000, P_CAM_CC_PLL1_OUT_EVEN, 2, 0, 0), >> + F(480000000, P_CAM_CC_PLL2_OUT_EVEN, 1, 0, 0), >> + F(600000000, P_CAM_CC_PLL0_OUT_EVEN, 1, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 cam_cc_bps_clk_src = { >> + .cmd_rcgr = 0x600c, >> + .mnd_width = 0, >> + .hid_width = 5, >> + .parent_map = cam_cc_parent_map_0, >> + .freq_tbl = ftbl_cam_cc_bps_clk_src, >> + .clkr.hw.init = &(struct clk_init_data){ >> + .name = "cam_cc_bps_clk_src", >> + .parent_names = cam_cc_parent_names_0, >> + .num_parents = 6, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_rcg2_shared_ops, > > Why are shared ops used in this driver? > As per HW design, most of the CAMCC RCGs needs to move to XO during clock disable so because of this we have used the shared ops. >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_cam_cc_cci_clk_src[] = { >> + F(19200000, P_BI_TCXO, 1, 0, 0), >> + F(37500000, P_CAM_CC_PLL0_OUT_EVEN, 16, 0, 0), >> + F(50000000, P_CAM_CC_PLL0_OUT_EVEN, 12, 0, 0), >> + F(100000000, P_CAM_CC_PLL0_OUT_EVEN, 6, 0, 0), >> + { } >> +}; >> + > [...] >> + .clkr.hw.init = &(struct clk_init_data){ >> + .name = "cam_cc_mclk0_clk_src", >> + .parent_names = cam_cc_parent_names_0, >> + .num_parents = 6, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_rcg2 cam_cc_mclk1_clk_src = { >> + .cmd_rcgr = 0x4024, >> + .mnd_width = 8, >> + .hid_width = 5, >> + .parent_map = cam_cc_parent_map_0, >> + .freq_tbl = ftbl_cam_cc_mclk0_clk_src, >> + .clkr.hw.init = &(struct clk_init_data){ >> + .name = "cam_cc_mclk1_clk_src", >> + .parent_names = cam_cc_parent_names_0, >> + .num_parents = 6, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_rcg2 cam_cc_mclk2_clk_src = { >> + .cmd_rcgr = 0x4044, >> + .mnd_width = 8, >> + .hid_width = 5, >> + .parent_map = cam_cc_parent_map_0, >> + .freq_tbl = ftbl_cam_cc_mclk0_clk_src, >> + .clkr.hw.init = &(struct clk_init_data){ >> + .name = "cam_cc_mclk2_clk_src", >> + .parent_names = cam_cc_parent_names_0, >> + .num_parents = 6, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_rcg2 cam_cc_mclk3_clk_src = { >> + .cmd_rcgr = 0x4064, >> + .mnd_width = 8, >> + .hid_width = 5, >> + .parent_map = cam_cc_parent_map_0, >> + .freq_tbl = ftbl_cam_cc_mclk0_clk_src, >> + .clkr.hw.init = &(struct clk_init_data){ >> + .name = "cam_cc_mclk3_clk_src", >> + .parent_names = cam_cc_parent_names_0, >> + .num_parents = 6, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_cam_cc_slow_ahb_clk_src[] = { >> + F(19200000, P_BI_TCXO, 1, 0, 0), >> + F(60000000, P_CAM_CC_PLL0_OUT_EVEN, 10, 0, 0), >> + F(66666667, P_CAM_CC_PLL0_OUT_EVEN, 9, 0, 0), >> + F(73846154, P_CAM_CC_PLL2_OUT_EVEN, 6.5, 0, 0), >> + F(80000000, P_CAM_CC_PLL2_OUT_EVEN, 6, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 cam_cc_slow_ahb_clk_src = { >> + .cmd_rcgr = 0x6054, >> + .mnd_width = 0, >> + .hid_width = 5, >> + .parent_map = cam_cc_parent_map_0, >> + .freq_tbl = ftbl_cam_cc_slow_ahb_clk_src, >> + .clkr.hw.init = &(struct clk_init_data){ >> + .name = "cam_cc_slow_ahb_clk_src", >> + .parent_names = cam_cc_parent_names_0, >> + .num_parents = 6, >> + .flags = CLK_SET_RATE_PARENT, > > Is CLK_SET_RATE_PARENT intentionally set on these RCGs so that they can > reconfigure the PLL frequency? Wouldn't that be a fixed rate PLL > frequency? > PLL2_OUT_EVEN requires to be reconfigure to 480MHz so clock sources which are using PLL2 in their frequency table requires 'CLK_SET_RATE_PARENT' flag to be set. >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + > [...] >> + >> +static int cam_cc_sdm845_probe(struct platform_device *pdev) >> +{ >> + struct regmap *regmap; >> + struct alpha_pll_config cam_cc_pll_config = { }; >> + >> + regmap = qcom_cc_map(pdev, &cam_cc_sdm845_desc); >> + if (IS_ERR(regmap)) >> + return PTR_ERR(regmap); >> + >> + cam_cc_pll_config.l = 0x1f, >> + cam_cc_pll_config.alpha = 0x4000, > > Replace these commas with semicolons. > Ok sure. I will do as suggested in the next patch series. >> + clk_fabia_pll_configure(&cam_cc_pll0, regmap, >> &cam_cc_pll_config); >> + >> + cam_cc_pll_config.l = 0x2a, >> + cam_cc_pll_config.alpha = 0x1556, >> + clk_fabia_pll_configure(&cam_cc_pll1, regmap, >> &cam_cc_pll_config); > > All over this function. > > Can you also add comments in the commit text and code describing why > oddities like CLK_SET_RATE_PARENT on RCGs and shared rcg ops is used? ok sure will add the same in the next patch series. > > -- > To unsubscribe from this list: send the line "unsubscribe linux-clk" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html