Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp1958514rwd; Fri, 9 Jun 2023 04:55:55 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ4GVe9MzvH2jqUFxUT7w6Qpe1+S0jvHofNTLRUf6yHUHwsXQd09Q2hII3FiU/FCenUDjTjm X-Received: by 2002:a17:902:e541:b0:1b1:8ca9:10ca with SMTP id n1-20020a170902e54100b001b18ca910camr6022846plf.33.1686311755058; Fri, 09 Jun 2023 04:55:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1686311755; cv=none; d=google.com; s=arc-20160816; b=tDXSZ8lkQQaYwGF5DmFyypvbtd8WAa6lrGmNPwOUQe2tSwNDrLGx1PRYoDnizGW4oz 8nc7hcHClNJYVp/X/s+LNzq+PnePOF9cJEZE/cyhTFxBjNV9Hr4Z6W8jf3EN0EWoib4o bYbNgoN+OVV5d+899KHmPqm9DrmjsYIHxfEXHgm+cKjLDoSuGpZ4XBb9yl1iw8Feu7bS QYgECiCLCQtCp+r9tOzIU/8V23kmglUlDQGdy9foK0h6O9/ZOH8mwGqzpZ5ZHhX5do6T jZ40MoDGrVdMWa7fGXJFZkw5o4cI48GLAr2wfnfS+2btgvHe3d7k6RTiIMJiz2vpslwK 3ymw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=i8mNs2rF54Ol0kXxFcSbg3Rj4NqvtmjvBxJgpQRfSPo=; b=aQaf0NQMHG/VxqXSs/ZzZHO8x2wfdEz9t93iENa/KW9K4hYA2XHLFUG1GyvyaEyAzC V9niaXvzjLSkEmpj9igvu9fokmLqfsOY7CbAq37kSUvfamOuIe/6xdDmGpFHc8Mhjqym 5tB5V9M0HndAWhaI0XN3LCa+TAWW29mczKw3JDs1ow4oygkxDVCsqpzjfpNjspqBlrPo x4DcW2A/V3IawYxB8myAcuxdZzmE+Oeq9AwQB8HXca+Xiz+yoDjVbss6PWpRcxm6gGkT uv40YbRIeGLnqoJIlwC6KY8uFdOVhei9XU7vPBT6uDp+PYKZTwpKEvbrBLViijsC02gG hI6w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@sberdevices.ru header.s=mail header.b=Q1l9oXPe; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=sberdevices.ru Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 185-20020a6306c2000000b005301151503esi2521690pgg.186.2023.06.09.04.55.42; Fri, 09 Jun 2023 04:55:55 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@sberdevices.ru header.s=mail header.b=Q1l9oXPe; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=sberdevices.ru Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231948AbjFILsz (ORCPT + 99 others); Fri, 9 Jun 2023 07:48:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40782 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231172AbjFILsx (ORCPT ); Fri, 9 Jun 2023 07:48:53 -0400 Received: from mx.sberdevices.ru (mx.sberdevices.ru [45.89.227.171]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 37D06358B; Fri, 9 Jun 2023 04:48:50 -0700 (PDT) Received: from s-lin-edge02.sberdevices.ru (localhost [127.0.0.1]) by mx.sberdevices.ru (Postfix) with ESMTP id 981665FD8E; Fri, 9 Jun 2023 14:48:48 +0300 (MSK) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sberdevices.ru; s=mail; t=1686311328; bh=i8mNs2rF54Ol0kXxFcSbg3Rj4NqvtmjvBxJgpQRfSPo=; h=Date:From:To:Subject:Message-ID:MIME-Version:Content-Type; b=Q1l9oXPeAJIm6jGSa7PBxKhYShkKytHT8QEWYzUuWbL0hPQZe+Yb2+gd+DWbuRzCi ukswtpwIlfYtlogBMoLh0dN5S6QooTbhfVnq+Pzwx9tB4zaPUWAVrOywWB/7ttvRj3 MqhqWtFav0ojgOn7ukSYBc9n82vclzjSgeLEFponi1wdJvw6+Snxi8iqm56F7qQaIq wLyu3Aok17REBop1qvsHizZf5+aFOW4+yRTvLGDQZCrYwk/VI1gvw7/1FNokj15gXq 1ZeXEaahADg9F4vRxXpljKbt1QTF4qTG1jVcTWdsMSF3rR0dqpF9WJ8q3Jur6ifVv3 2KDO+bqdWIWiA== Received: from S-MS-EXCH02.sberdevices.ru (S-MS-EXCH02.sberdevices.ru [172.16.1.5]) by mx.sberdevices.ru (Postfix) with ESMTP; Fri, 9 Jun 2023 14:48:48 +0300 (MSK) Date: Fri, 9 Jun 2023 14:48:47 +0300 From: Dmitry Rokosov To: Neil Armstrong CC: Jerome Brunet , Michael Turquette , Stephen Boyd , Kevin Hilman , Martin Blumenstingl , Rob Herring , Krzysztof Kozlowski , Conor Dooley , , , , , Subject: Re: [PATCH 03/18] clk: meson: migrate a1 clock drivers out of hw_onecell_data to drop NR_CLKS Message-ID: <20230609114847.x24by2foebojbchq@CAB-WSD-L081021> References: <20230607-topic-amlogic-upstream-clkid-public-migration-v1-0-9676afa6b22c@linaro.org> <20230607-topic-amlogic-upstream-clkid-public-migration-v1-3-9676afa6b22c@linaro.org> <1jlegu9l5d.fsf@starbuckisacylon.baylibre.com> <638206ba-e2da-bb8e-a2e4-138af84648b4@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Disposition: inline In-Reply-To: <638206ba-e2da-bb8e-a2e4-138af84648b4@linaro.org> User-Agent: NeoMutt/20220415 X-Originating-IP: [172.16.1.6] X-ClientProxiedBy: S-MS-EXCH02.sberdevices.ru (172.16.1.5) To p-i-exch-sc-m01.sberdevices.ru (172.16.192.107) X-KSMG-Rule-ID: 4 X-KSMG-Message-Action: clean X-KSMG-AntiSpam-Status: not scanned, disabled by settings X-KSMG-AntiSpam-Interceptor-Info: not scanned X-KSMG-AntiPhishing: not scanned, disabled by settings X-KSMG-AntiVirus: Kaspersky Secure Mail Gateway, version 1.1.2.30, bases: 2023/06/09 07:08:00 #21465535 X-KSMG-AntiVirus-Status: Clean, skipped X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_NONE,SPF_NONE, T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello Neil, On Thu, Jun 08, 2023 at 02:53:50PM +0200, Neil Armstrong wrote: > On 08/06/2023 14:45, Jerome Brunet wrote: > > > +struct meson_a1_pll_clks { > > > + struct clk_hw **hw_clks; > > > + unsigned int hw_clk_num; > > > +}; > > > + > > > +static struct meson_a1_pll_clks a1_pll_clks = { > > > + .hw_clks = a1_pll_hw_clks, > > > + .hw_clk_num = ARRAY_SIZE(a1_pll_hw_clks), > > > +}; > > > + > > > +static struct clk_hw *meson_a1_pll_hw_get(struct of_phandle_args *clkspec, void *clk_data) > > > +{ > > > + const struct meson_a1_pll_clks *data = clk_data; > > > + unsigned int idx = clkspec->args[0]; > > > + > > > + if (idx >= data->hw_clk_num) { > > > + pr_err("%s: invalid index %u\n", __func__, idx); > > > + return ERR_PTR(-EINVAL); > > > + } > > > + > > > + return data->hw_clks[idx]; > > > +} > > > > I'd prefer to have a single struct type and and single custom > > callback for the different SoC please. > > Sure, I've written a common code for that, but I have a hard time finding > a proper naming for it... so I choosed meson-clkc since it could have > more common helper code for duplicated code over the clk driver: > > ===================================><============================================================================ > diff --git a/drivers/clk/meson/Kconfig b/drivers/clk/meson/Kconfig > index 8ce846fdbe43..9070dcfd9e71 100644 > --- a/drivers/clk/meson/Kconfig > +++ b/drivers/clk/meson/Kconfig > @@ -30,6 +30,9 @@ config COMMON_CLK_MESON_VID_PLL_DIV > tristate > select COMMON_CLK_MESON_REGMAP > > +config COMMON_CLK_MESON_CLKC > + tristate > + > config COMMON_CLK_MESON_AO_CLKC > tristate > select COMMON_CLK_MESON_REGMAP > diff --git a/drivers/clk/meson/Makefile b/drivers/clk/meson/Makefile > index d5288662881d..13c6db466986 100644 > --- a/drivers/clk/meson/Makefile > +++ b/drivers/clk/meson/Makefile > @@ -1,6 +1,7 @@ > # SPDX-License-Identifier: GPL-2.0-only > # Amlogic clock drivers > > +obj-$(CONFIG_COMMON_CLK_MESON_CLKC) += meson-clkc.o > obj-$(CONFIG_COMMON_CLK_MESON_AO_CLKC) += meson-aoclk.o > obj-$(CONFIG_COMMON_CLK_MESON_CPU_DYNDIV) += clk-cpu-dyndiv.o > obj-$(CONFIG_COMMON_CLK_MESON_DUALDIV) += clk-dualdiv.o > diff --git a/drivers/clk/meson/meson-clkc.c b/drivers/clk/meson/meson-clkc.c > new file mode 100644 > index 000000000000..fa98b9d09011 > --- /dev/null > +++ b/drivers/clk/meson/meson-clkc.c > @@ -0,0 +1,25 @@ > +// SPDX-License-Identifier: GPL-2.0+ > +/* > + * Copyright (c) 2023 Neil Armstrong > + */ > + > +#include > +#include > +#include > +#include "meson-clkc.h" > + > +struct clk_hw *meson_clk_hw_get(struct of_phandle_args *clkspec, void *clk_hw_data) > +{ > + const struct meson_clk_hw_data *data = clk_hw_data; > + unsigned int idx = clkspec->args[0]; > + > + if (idx >= data->num) { > + pr_err("%s: invalid index %u\n", __func__, idx); > + return ERR_PTR(-EINVAL); > + } > + > + return data->hws[idx]; > +} > +EXPORT_SYMBOL_GPL(meson_clk_hw_get); > + > +MODULE_LICENSE("GPL v2"); > diff --git a/drivers/clk/meson/meson-clkc.h b/drivers/clk/meson/meson-clkc.h > new file mode 100644 > index 000000000000..e3bad2aa17eb > --- /dev/null > +++ b/drivers/clk/meson/meson-clkc.h > @@ -0,0 +1,19 @@ > +/* SPDX-License-Identifier: (GPL-2.0+ OR MIT) */ > +/* > + * Copyright (c) 2023 Neil Armstrong > + */ > + > +#ifndef __MESON_HW_CLKC_H__ > +#define __MESON_HW_CLKC_H__ > + > +#include > +#include > + > +struct meson_clk_hw_data { > + struct clk_hw **hws; > + unsigned int num; > +}; > + > +struct clk_hw *meson_clk_hw_get(struct of_phandle_args *clkspec, void *clk_hw_data); > + > +#endif > ===================================><============================================================================ > > If it's ok I'll send a v2 using this. > > Thanks, > Neil In addition, I propose consolidating the probe() routine of the a1 clocks into a common part, which can be utilized for s4 and other similar clocks. This solution was presented in the early a1 review stages of this patch set. https://lore.kernel.org/linux-amlogic/20221201225703.6507-7-ddrokosov@sberdevices.ru/ Maybe, it can be generalized for the all meson clock controller drivers. -- Thank you, Dmitry