Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp2788870iog; Mon, 20 Jun 2022 04:59:20 -0700 (PDT) X-Google-Smtp-Source: AGRyM1tIxXMrrddarJ2bzrZXY4MuO+zeU7/YiH9ui2M7uLCewn1eDvzxAE6EwVnD2QGmsyfoOgLL X-Received: by 2002:a17:906:73cf:b0:713:f60a:8f9 with SMTP id n15-20020a17090673cf00b00713f60a08f9mr21553677ejl.124.1655726360325; Mon, 20 Jun 2022 04:59:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655726360; cv=none; d=google.com; s=arc-20160816; b=HsklcwxTpnEQah5zuuMY5kW8agePCww3z5CYUHlfs/czGHTIE0hohGbm95Ne5u3niW g1lYEAQQkUsSJC+0HLbtzaT6mCHaZOqAK+1pTXI4LT8K5Hd2mxQXIuMOwYo935gLyhLf /+uHXn2ll1Fbv/YiJ3u9KRQCSm4SSKZIswngfhNkiN3J7sXcM2sfqLrCJAqbT3ba66oH KZYBXtgf5SNyVe9tYgD/Hwa5HgfmGvU2GaYq4QeThmTMjNqBCcQlJ3lyM3Du7xAOSqpI Mk8qmg8xMJFf7HEW8Iq4H56vLB43UP5Ev5Yye2M/eCQZi2+F65vSMrWxA5qV/nm0tfc1 6T5g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=p9cScR7+8tqT8UOdrsD/iPQ6vHskmsKAJjjJIaAQlj8=; b=xEvvRkmtptzA04Wkk8p24QH7XdcYTUSMNZSQ8AAqUKXXSoP/LKHgNpMZNBW3nrsErf 9vSHvdSHWJjTGwaUXininsp0hCZGffKzqlqUViMvzZFDNFG4hUrlfUdV2hlbO2TAahi7 FBMnUiYMGHCsO+ztoeqDdZ5UA81FRpHJ43K9w3+oqupzeWR7XtlZIkCt+tic31Jnl2bW DTuawM4nIiDkAuiVArOyT6cZhRKoC6o4+PRE3qF8kHJzF3ffRE6KjdlUp+mju+BnPgv4 ZSg/Ll7HWzypgdCgd8Ejd2LvM31zUEqPzCwnQFaxJdHygHKPjtQw8tQoUfuN3KWVeZiq O9tA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b=PUoIq0RB; 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=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id q4-20020a056402248400b00435640bfdc8si9321495eda.199.2022.06.20.04.58.55; Mon, 20 Jun 2022 04:59:20 -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=@quicinc.com header.s=qcdkim header.b=PUoIq0RB; 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=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S241346AbiFTLHv (ORCPT + 99 others); Mon, 20 Jun 2022 07:07:51 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56876 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241255AbiFTLHs (ORCPT ); Mon, 20 Jun 2022 07:07:48 -0400 Received: from alexa-out.qualcomm.com (alexa-out.qualcomm.com [129.46.98.28]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 04B3C15822; Mon, 20 Jun 2022 04:07:41 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; i=@quicinc.com; q=dns/txt; s=qcdkim; t=1655723262; x=1687259262; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=p9cScR7+8tqT8UOdrsD/iPQ6vHskmsKAJjjJIaAQlj8=; b=PUoIq0RB0ciq7/T273PnI+wrCDXU4TFwczb5TcnhEpTZErRTe+0x++yu h+Byafnv59RcP2GT1qsRa0W7NSuZ0b/flPWmjZTUJnNRyUwqKChtUWczw K5TNntWmWROAc8xAMK5K8CA+73IYL/JR3mpn05jMYKNi2U6/3dEvzzfhH k=; Received: from ironmsg07-lv.qualcomm.com ([10.47.202.151]) by alexa-out.qualcomm.com with ESMTP; 20 Jun 2022 04:07:42 -0700 X-QCInternal: smtphost Received: from nasanex01c.na.qualcomm.com ([10.47.97.222]) by ironmsg07-lv.qualcomm.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 20 Jun 2022 04:07:41 -0700 Received: from nalasex01a.na.qualcomm.com (10.47.209.196) by nasanex01c.na.qualcomm.com (10.47.97.222) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Mon, 20 Jun 2022 04:07:40 -0700 Received: from [10.50.53.124] (10.80.80.8) by nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Mon, 20 Jun 2022 04:07:35 -0700 Message-ID: Date: Mon, 20 Jun 2022 16:37:31 +0530 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.9.0 Subject: Re: [PATCH V15 6/9] mfd: pm8008: Use i2c_new_dummy_device() API Content-Language: en-US To: Lee Jones CC: Bjorn Andersson , Rob Herring , Liam Girdwood , Mark Brown , , , , , , , References: <1655200111-18357-1-git-send-email-quic_c_skakit@quicinc.com> <1655200111-18357-7-git-send-email-quic_c_skakit@quicinc.com> From: "Satya Priya Kakitapalli (Temp)" In-Reply-To: Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 8bit X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01a.na.qualcomm.com (10.52.223.231) To nalasex01a.na.qualcomm.com (10.47.209.196) X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE 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 On 6/20/2022 1:50 PM, Lee Jones wrote: > On Mon, 20 Jun 2022, Satya Priya Kakitapalli (Temp) wrote: > >> On 6/17/2022 2:27 AM, Lee Jones wrote: >>> On Tue, 14 Jun 2022, Satya Priya wrote: >>> >>>> Use i2c_new_dummy_device() to register pm8008-regulator >>>> client present at a different address space, instead of >>>> defining a separate DT node. This avoids calling the probe >>>> twice for the same chip, once for each client pm8008-infra >>>> and pm8008-regulator. >>>> >>>> As a part of this define pm8008_regmap_init() to do regmap >>>> init for both the clients and define pm8008_get_regmap() to >>>> pass the regmap to the regulator driver. >>>> >>>> Signed-off-by: Satya Priya >>>> Reviewed-by: Stephen Boyd >>>> --- >>>> Changes in V15: >>>> - None. >>>> >>>> Changes in V14: >>>> - None. >>>> >>>> Changes in V13: >>>> - None. >>>> >>>> drivers/mfd/qcom-pm8008.c | 34 ++++++++++++++++++++++++++++++++-- >>>> include/linux/mfd/qcom_pm8008.h | 9 +++++++++ >>>> 2 files changed, 41 insertions(+), 2 deletions(-) >>>> create mode 100644 include/linux/mfd/qcom_pm8008.h >>>> >>>> diff --git a/drivers/mfd/qcom-pm8008.c b/drivers/mfd/qcom-pm8008.c >>>> index 569ffd50..55e2a8e 100644 >>>> --- a/drivers/mfd/qcom-pm8008.c >>>> +++ b/drivers/mfd/qcom-pm8008.c >>>> @@ -9,6 +9,7 @@ >>>> #include >>>> #include >>>> #include >>>> +#include >>>> #include >>>> #include >>>> #include >>>> @@ -57,6 +58,7 @@ enum { >>>> struct pm8008_data { >>>> struct device *dev; >>>> + struct regmap *regulators_regmap; >>>> int irq; >>>> struct regmap_irq_chip_data *irq_data; >>>> }; >>>> @@ -150,6 +152,12 @@ static struct regmap_config qcom_mfd_regmap_cfg = { >>>> .max_register = 0xFFFF, >>>> }; >>>> +struct regmap *pm8008_get_regmap(const struct pm8008_data *chip) >>>> +{ >>>> + return chip->regulators_regmap; >>>> +} >>>> +EXPORT_SYMBOL_GPL(pm8008_get_regmap); >>> Seems like abstraction for the sake of abstraction. >>> >>> Why not do the dereference inside the regulator driver? >> To derefer this in the regulator driver, we need to have the pm8008_data >> struct definition in the qcom_pm8008 header file. >> >> I think it doesn't look great to have only that structure in header and all >> other structs and enum in the mfd driver. > Then why pass 'pm8008_data' at all? There is one more option, instead of passing the pm8008_data, we could pass the pdev->dev.parent and get the pm8008 chip data directly in the pm8008_get_regmap() like below struct regmap *pm8008_get_regmap(const struct device *dev)  {      const struct pm8008_data *chip = dev_get_drvdata(dev);      return chip->regulators_regmap; } EXPORT_SYMBOL_GPL(pm8008_get_regmap); By doing this we can avoid having declaration of pm8008_data also in the header. Please let me know if this looks good. > What's preventing you from passing 'regmap'? I didn't get what you meant here, could you please elaborate a bit?