Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp634477ybl; Thu, 12 Dec 2019 02:21:53 -0800 (PST) X-Google-Smtp-Source: APXvYqwEHkpOTYZko67r3TojrE1cM5iCvo5CmCPW2bwNhH5b3a0/bvSOOqQKi2ps4l7bIrIqy6P+ X-Received: by 2002:a05:6830:1744:: with SMTP id 4mr670798otz.71.1576146113397; Thu, 12 Dec 2019 02:21:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1576146113; cv=none; d=google.com; s=arc-20160816; b=ehtgRCawi1VORlhSnnuHAZ2yju2hyYG2+ThtURTNhGLj+380loSZgWbhakfTGafE6o 0XthR+zBvjHD7sljO8ST2WZDde+UPlfQ/m0Tm1SfPrPmY2OnAucOBsmCxtMM05K/9FNC uT/VPfkDthl27OLYgLqYVMV1EHlC6HIXTK1rJsqOHCI9iPCEFfNNn3ZrszQ+eS5L/XDt kMCdjOYOKnlSSV6D1Q/Ua9hIMX9qJQ6sttNGgXXpn6ZGAMnxK7zVxhjcudTdxQMamMHA AgtJjIYzz7AEW0o2ijiTuj8MfoAD1GVZ9ApxgTVEoI9pgKBbgLw8pKdDlUCBy9VSDfS5 Dz9A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:in-reply-to :subject:cc:to:from:user-agent:references:dkim-signature; bh=FWshdGOlPI7yjVJAElFvMo0mlzQ6xIrNID/VuBYtMSo=; b=FVEG4m6l2EWv5RdQ+mtHsHVMMAB593u7hecvrnK6oT9Zc//Y1gJn2XO96nMYR8U5XN NOodtacjXPxxRENvGv8M9Z8dAYXSKS6dSmUTt/0/naul2OEilvbBL5YtuCVp/AbAPPzW VZVxax7O8bZbBA0xPXTnS4M0cQpXRk4pQdWTvN6HC0jZGAIyELHCCwMN1xDwvWwCUXvv t/bhmmS9DACsfBB/JVwZSB2l82d0Z1msJVycpTvo7zEub5/yhsFXAGf+6B0O2Xalvr0q TejGWmsybVLEpCdmyfxlSh24pxBRAG9xfzecoIm0rfzLKfZIlD+BwDO02VOAMxPOgreA cx8Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=Ch+J675q; 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 s22si2759641otq.10.2019.12.12.02.21.40; Thu, 12 Dec 2019 02:21:53 -0800 (PST) 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=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=Ch+J675q; 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 S1728561AbfLLKUD (ORCPT + 99 others); Thu, 12 Dec 2019 05:20:03 -0500 Received: from mail-wr1-f67.google.com ([209.85.221.67]:37006 "EHLO mail-wr1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728345AbfLLKUD (ORCPT ); Thu, 12 Dec 2019 05:20:03 -0500 Received: by mail-wr1-f67.google.com with SMTP id w15so2108680wru.4 for ; Thu, 12 Dec 2019 02:20:00 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=references:user-agent:from:to:cc:subject:in-reply-to:date :message-id:mime-version; bh=FWshdGOlPI7yjVJAElFvMo0mlzQ6xIrNID/VuBYtMSo=; b=Ch+J675qtJbBX8NFcLS7CYqYDrNctC1O0yw6s4DcnHprhA91RaEmIlTNuyNTsQwWrC hvbgwH5ipBMwZN/Ar5J6GQJPFZwa49XYAT5QK12dmuqXkFJ0ZMPa8A24SpxxohwxxDIj S5KM2WaPLDMe6iu+lTejbUH7fGBZnQGwsexvq9rgMDEX9KjE9q5UJDGKhGFrNhSVAq+D xJWnK6ThYoeS8N9wQg0AWif5xusWzRBrA5KLqeo8coRGQUVOFs8e6o34T/CfPalY1nPl 7K7IlI+Tg35SVoDo2AnDk4E0bjXPrZ+iNJn28zUBHamlbQDZxtlLAeg+ce0MtasPGheL RmPw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:references:user-agent:from:to:cc:subject :in-reply-to:date:message-id:mime-version; bh=FWshdGOlPI7yjVJAElFvMo0mlzQ6xIrNID/VuBYtMSo=; b=b+/gdRJjN1avl9n9CKw9ylUCJvlUUmrcqVPuXaN7aq0QJDB1Ne1PDlN+DRduAGvuzP +uRuusXGi0o2yu0mqxNahbmeqFFRi3sfW3Zyxx7WHrLlmuszNvlVcW3SZzHKmqwLqRjY LnfjrR+cvUzNG+fOIVJaVnGEwpv8sDlLXsO9Y+4+mH8QCZfffHymnKpzy5s0yV/bsr0G nAsDrtfnDW9M1nA1kyMRIBaTmMvtxfYmKWPn2+eMpZdX2fo+OQyD5n5dRcDEyu8ocfg8 ek7iWfkHLPgBqkyMHMS7HbypKGyuiwQxram2nyoBVrzIzKelz3RghaYF1qq0HUlnvSv9 jYnA== X-Gm-Message-State: APjAAAUBOmA+VCapqmw0RpOnzt1CQxIUssQE4mHrvaGngODa0tWIXrfR k8wKykD7iUzuhBRbVvM34mPeMw== X-Received: by 2002:adf:ffc7:: with SMTP id x7mr5320534wrs.159.1576146000146; Thu, 12 Dec 2019 02:20:00 -0800 (PST) Received: from localhost (laubervilliers-658-1-213-31.w90-63.abo.wanadoo.fr. [90.63.244.31]) by smtp.gmail.com with ESMTPSA id e6sm5485646wru.44.2019.12.12.02.19.59 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 12 Dec 2019 02:19:59 -0800 (PST) References: <20191206074052.15557-1-jian.hu@amlogic.com> <20191206074052.15557-4-jian.hu@amlogic.com> User-agent: mu4e 1.3.3; emacs 26.2 From: Jerome Brunet To: Jian Hu , Neil Armstrong Cc: Kevin Hilman , "Rob Herring" , Martin Blumenstingl , Michael Turquette , Stephen Boyd , Qiufang Dai , Jianxin Pan , Victor Wan , Chandle Zou , linux-clk@vger.kernel.org, linux-amlogic@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v4 3/6] clk: meson: eeclk: refactor eeclk common driver to support A1 In-reply-to: <20191206074052.15557-4-jian.hu@amlogic.com> Date: Thu, 12 Dec 2019 11:19:59 +0100 Message-ID: <1j7e31lub4.fsf@starbuckisacylon.baylibre.com> MIME-Version: 1.0 Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri 06 Dec 2019 at 08:40, Jian Hu wrote: > Introduce a common probe function for A1 series, the way to get > regmap is different between A1 series and the previous series. > The register region is only for one clock driver, the function of > meson_eeclkc_probe is not fit for A1, So it is necessary to > introduce a new function. Please drop this patch #1 you are patching the EE driver for something that is no longer an EE driver #2 Let's get the basics right, you can move (re)factoring afterward Your probe function is simple enough. Just properly write it in each driver for now. > > Signed-off-by: Jian Hu > --- > drivers/clk/meson/meson-eeclk.c | 59 +++++++++++++++++++++++++++------ > drivers/clk/meson/meson-eeclk.h | 1 + > 2 files changed, 50 insertions(+), 10 deletions(-) > > diff --git a/drivers/clk/meson/meson-eeclk.c b/drivers/clk/meson/meson-eeclk.c > index a7cb1e7aedc4..12ceb1caabd8 100644 > --- a/drivers/clk/meson/meson-eeclk.c > +++ b/drivers/clk/meson/meson-eeclk.c > @@ -13,25 +13,37 @@ > #include "clk-regmap.h" > #include "meson-eeclk.h" > > -int meson_eeclkc_probe(struct platform_device *pdev) > +static struct regmap_config clkc_regmap_config = { > + .reg_bits = 32, > + .val_bits = 32, > + .reg_stride = 4, > +}; > + > +static struct regmap *meson_regmap_resource(struct platform_device *pdev) > +{ > + struct resource *res; > + void __iomem *base; > + struct device *dev = &pdev->dev; > + > + res = platform_get_resource(pdev, IORESOURCE_MEM, 0); > + > + base = devm_ioremap_resource(dev, res); > + if (IS_ERR(base)) > + return ERR_CAST(base); > + > + return devm_regmap_init_mmio(dev, base, &clkc_regmap_config); > +} > + > +static int meson_common_probe(struct platform_device *pdev, struct regmap *map) > { > const struct meson_eeclkc_data *data; > struct device *dev = &pdev->dev; > - struct regmap *map; > int ret, i; > > data = of_device_get_match_data(dev); > if (!data) > return -EINVAL; > > - /* Get the hhi system controller node */ > - map = syscon_node_to_regmap(of_get_parent(dev->of_node)); > - if (IS_ERR(map)) { > - dev_err(dev, > - "failed to get HHI regmap\n"); > - return PTR_ERR(map); > - } > - > if (data->init_count) > regmap_multi_reg_write(map, data->init_regs, data->init_count); > > @@ -54,3 +66,30 @@ int meson_eeclkc_probe(struct platform_device *pdev) > return devm_of_clk_add_hw_provider(dev, of_clk_hw_onecell_get, > data->hw_onecell_data); > } > + > +int meson_eeclkc_probe(struct platform_device *pdev) > +{ > + struct device *dev = &pdev->dev; > + struct regmap *map; > + > + /* Get the hhi system controller node */ > + map = syscon_node_to_regmap(of_get_parent(dev->of_node)); > + if (IS_ERR(map)) { > + dev_err(dev, > + "failed to get HHI regmap\n"); > + return PTR_ERR(map); > + } > + > + return meson_common_probe(pdev, map); > +} > + > +int meson_clkc_probe(struct platform_device *pdev) > +{ > + struct regmap *map; > + > + map = meson_regmap_resource(pdev); > + if (IS_ERR(map)) > + return PTR_ERR(map); > + > + return meson_common_probe(pdev, map); > +} > diff --git a/drivers/clk/meson/meson-eeclk.h b/drivers/clk/meson/meson-eeclk.h > index 77316207bde1..a2e9ab3a4f6b 100644 > --- a/drivers/clk/meson/meson-eeclk.h > +++ b/drivers/clk/meson/meson-eeclk.h > @@ -21,5 +21,6 @@ struct meson_eeclkc_data { > }; > > int meson_eeclkc_probe(struct platform_device *pdev); > +int meson_clkc_probe(struct platform_device *pdev); > > #endif /* __MESON_CLKC_H */