Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp1303427ybt; Thu, 25 Jun 2020 02:50:24 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwLvzOPGsM/gwRjf4kN4PtDCaxuj7lXRO5hkuYodQLJYl6XxuGdsbWO7OYe8CMuVt3CrlOP X-Received: by 2002:a17:906:6713:: with SMTP id a19mr5541973ejp.11.1593078624355; Thu, 25 Jun 2020 02:50:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593078624; cv=none; d=google.com; s=arc-20160816; b=v/EAZp45xWjW3fgBO20jDxRLM2X7wDStAz5/7643xwVLXZKu8/XYTdtecxUeyLEoMc exMWs7pbMMU131opfwKjLUkdy1d6Dtlt8r35H9S/ev15qfMWUIP4sr9vTqUlJGuUNrR4 gzDZ0m3BJVJD33tME8P0IB1OeFNLQm9mAUuNRAl6drZ+2kx+QbKMjGMfVefSb/mIPIuB NB9ERyxQ36FcICMUiQ/T4LztiRkTplx2JE6xTlxulWFkTisV3nyEmdkxswVhPCZ9DNEI WghvhbkPU8frH9stFuokzL2Dw1Hfu5QSt3QQgr9ARJUeDeJFWHxsjorr88sK9C7oiQap uNeQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:ironport-sdr:ironport-sdr; bh=O6CNi3jbwVczQDMwo4Hvwpu3Hnpm0GnZwAolLC45keg=; b=tujseZUkwFkhLdbObR10RQsSZ/RKQDCzmSEnkut/+aSRwFlqEV6rbO74GZ10NylPVH UBAEejpHZ+HQnlfLmwLwaiZGf0AjGPqdO61LrYWZHpKFkBNIhq4o9VkpADQ1iktjUc8g jnLZz6rPS1x1xu1XL6tm2y5RGT2vb8GYYFUZtm/U+8WWnjJmS3XoXG7gD+GL7MwfKIyl zCPgwPf+wJfcQMLBVlCJEPoL7byrdFzXNzPCNRCmySnGt9L9Q86XocvXKPwyDOBEHxTF Rm6jRP4b/vkW05NlokCFLUFJFTtkdtmNrunwXAbMA/lacblAyBERzOleSZe1AIKiDvYe 2DOg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i14si14457837ejz.362.2020.06.25.02.50.01; Thu, 25 Jun 2020 02:50:24 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390809AbgFYI75 (ORCPT + 99 others); Thu, 25 Jun 2020 04:59:57 -0400 Received: from mga14.intel.com ([192.55.52.115]:28658 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390799AbgFYI75 (ORCPT ); Thu, 25 Jun 2020 04:59:57 -0400 IronPort-SDR: NzKpja60UmIFCrSIA6TVNe6bP9JnZriKccdvruaxk90GAzwt3Gl5S7aKj3bh9kH7s0yyS3WJKJ rJP4U2tQvHOA== X-IronPort-AV: E=McAfee;i="6000,8403,9662"; a="143908210" X-IronPort-AV: E=Sophos;i="5.75,278,1589266800"; d="scan'208";a="143908210" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga003.jf.intel.com ([10.7.209.27]) by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 25 Jun 2020 01:59:56 -0700 IronPort-SDR: NI7sm4ZOpFRULsttxgjrTh7px59jtpVeir7TfQNWM97K7HnZ9T+6/EiB+tB9T76FT7Za3RiUKw 5vPOEJ1DbDyQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.75,278,1589266800"; d="scan'208";a="275960986" Received: from linux.intel.com ([10.54.29.200]) by orsmga003.jf.intel.com with ESMTP; 25 Jun 2020 01:59:56 -0700 Received: from [10.213.33.121] (rtanwar-MOBL.gar.corp.intel.com [10.213.33.121]) by linux.intel.com (Postfix) with ESMTP id 04F895805B5; Thu, 25 Jun 2020 01:59:52 -0700 (PDT) Subject: Re: [PATCH v2 2/2] Add PWM fan controller driver for LGM SoC To: =?UTF-8?Q?Uwe_Kleine-K=c3=b6nig?= Cc: Philipp Zabel , linux-pwm@vger.kernel.org, thierry.reding@gmail.com, robh+dt@kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, andriy.shevchenko@intel.com, songjun.Wu@intel.com, cheol.yong.kim@intel.com, qi-ming.wu@intel.com, rahul.tanwar.linux@gmail.com References: <79fefda4aad5ebeb368129375bf128b74ed12224.1592474693.git.rahul.tanwar@linux.intel.com> <41a3c509e8d72d1e1c45b6b87f52f0a75018e6b0.camel@pengutronix.de> <25560ece-5d71-562d-359a-490d70cc5453@linux.intel.com> <20200625055818.nv5snblkm4nwvxw2@taurus.defre.kleine-koenig.org> From: "Tanwar, Rahul" Message-ID: <9a8f4a3e-c94a-b5bf-2715-03b0439f9fe7@linux.intel.com> Date: Thu, 25 Jun 2020 16:59:51 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.9.0 MIME-Version: 1.0 In-Reply-To: <20200625055818.nv5snblkm4nwvxw2@taurus.defre.kleine-koenig.org> Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 25/6/2020 1:58 pm, Uwe Kleine-K?nig wrote: > On Thu, Jun 25, 2020 at 12:23:54PM +0800, Tanwar, Rahul wrote: >> Hi Philipp, >> >> On 18/6/2020 8:25 pm, Philipp Zabel wrote: >>> Hi Rahul, >>> >>> On Thu, 2020-06-18 at 20:05 +0800, Rahul Tanwar wrote: >>>> Intel Lightning Mountain(LGM) SoC contains a PWM fan controller. >>>> This PWM controller does not have any other consumer, it is a >>>> dedicated PWM controller for fan attached to the system. Add >>>> driver for this PWM fan controller. >>>> >>>> Signed-off-by: Rahul Tanwar >>>> --- >>>> drivers/pwm/Kconfig | 9 + >>>> drivers/pwm/Makefile | 1 + >>>> drivers/pwm/pwm-intel-lgm.c | 400 ++++++++++++++++++++++++++++++++++++++++++++ >>>> 3 files changed, 410 insertions(+) >>>> create mode 100644 drivers/pwm/pwm-intel-lgm.c >>>> >>> [...] >>>> diff --git a/drivers/pwm/pwm-intel-lgm.c b/drivers/pwm/pwm-intel-lgm.c >>>> new file mode 100644 >>>> index 000000000000..3c7077acb161 >>>> --- /dev/null >>>> +++ b/drivers/pwm/pwm-intel-lgm.c >>>> @@ -0,0 +1,400 @@ >>> [...] >>>> +static int lgm_pwm_probe(struct platform_device *pdev) >>>> +{ >>>> + struct lgm_pwm_chip *pc; >>>> + struct device *dev = &pdev->dev; >>>> + void __iomem *io_base; >>>> + int ret; >>>> + >>>> + pc = devm_kzalloc(dev, sizeof(*pc), GFP_KERNEL); >>>> + if (!pc) >>>> + return -ENOMEM; >>>> + >>>> + io_base = devm_platform_ioremap_resource(pdev, 0); >>>> + if (IS_ERR(io_base)) >>>> + return PTR_ERR(io_base); >>>> + >>>> + pc->regmap = devm_regmap_init_mmio(dev, io_base, &pwm_regmap_config); >>>> + if (IS_ERR(pc->regmap)) { >>>> + ret = PTR_ERR(pc->regmap); >>>> + dev_err(dev, "failed to init register map: %pe\n", pc->regmap); >>>> + return ret; >>>> + } >>>> + >>>> + pc->clk = devm_clk_get(dev, NULL); >>>> + if (IS_ERR(pc->clk)) { >>>> + ret = PTR_ERR(pc->clk); >>>> + dev_err(dev, "failed to get clock: %pe\n", pc->clk); >>>> + return ret; >>>> + } >>>> + >>>> + pc->rst = devm_reset_control_get(dev, NULL); >>>> + if (IS_ERR(pc->rst)) { >>>> + ret = PTR_ERR(pc->rst); >>>> + dev_err(dev, "failed to get reset control: %pe\n", pc->rst); >>>> + return ret; >>>> + } >>> Please use devm_reset_control_get_exclusive() to make it explicit an >>> that exclusive reset control is requested. Given how the reset control >>> is used, I think this driver could also use >>> devm_reset_control_get_shared() to potentially allow sharing a reset >>> line with other devices. >> devm_reset_control_get() is a wrapper for devm_reset_control_get_exclusive(). >> Code as below: >> static inline struct reset_control *devm_reset_control_get( >> ??????????????????????????????? struct device *dev, const char *id) >> { >> ??????? return devm_reset_control_get_exclusive(dev, id); >> } >> Am i missing something else? > Obviously you're missing the comment above of_reset_control_get about > some functions being compatibility wrappers. Oops, so sorry totally missed/overlooked that. Will update in v3. Thanks. Regards, Rahul