Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp14065ybl; Tue, 27 Aug 2019 14:58:28 -0700 (PDT) X-Google-Smtp-Source: APXvYqwXRv+nN0fZSYhg9gkQ5BlBjhLdArDDcVurHVYk93Mfzj7gh1DJobvdP8l2TLXYDCUT8gd0 X-Received: by 2002:a17:90b:14c:: with SMTP id em12mr996804pjb.28.1566943107971; Tue, 27 Aug 2019 14:58:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566943107; cv=none; d=google.com; s=arc-20160816; b=DaeEtNdEdpx1y3FXIoPmG34Ja4qL++t+85EtWWOj8tdxPKXbSqPHn9pR8EnyeGvq4D hiPlrFviITKOEmTpI6lbhrLhUzxRZ/elqKi8t+zuC3l171MikeTrLiv4o9ALU+QRIMdJ RtBkGvBQOHQGEToy0eitHpo/jZlG7HS5GyY4I8Ls5Ttd5RqFJ55cylXj5bnW4xjNVGuZ APbkiOX9Y+SsM5mkiK0MxLV1Gs2MBQ4y/rDm70IotlE2aLLO7fue7wDyVrWTLv6ddlFv VrDke9i91aIewOO6B4agxrtVjljktFfajuONjojZocsU9BdleYCDWE4LU/FHgAZCK1yd otDw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=HC2RFiF7By0Has4Mh2LHjlg2LKxhwkANz9QlvqICMN4=; b=g5hELODXRhYXMbQMU3oxW6lJgSbBUL2pgcCQt3WR9GU77fv++WCukNUlyZNn+hE7H7 UZx8QcrkBNTLzJ0KwhIiwha6d580dwUvDXH7w8zzKRq9wEJu9wB+iAGPTzboMmX7W3ZG 2Ah9L+x0kVYcuRzjnWsPuz5SHBgm5VaGIrBV8cshvRACZg4NOrDQOwdi95O1AmR6/QJ+ MuQ5YLrIHN1HeU52s/fbtVeYWksrwgrly2lLi++sttb/fugNIvpHO5r5Eg8npMJuFyxm SqbpbIQZC0ABSy1qFJ7HgIFbK/4kgu9zKxCMzOX3tQP5Rdoq1KIB7J2/p3Czrk0HYEWm Wlww== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q38si478706pgk.63.2019.08.27.14.58.12; Tue, 27 Aug 2019 14:58:27 -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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726534AbfH0Vz4 (ORCPT + 99 others); Tue, 27 Aug 2019 17:55:56 -0400 Received: from mga09.intel.com ([134.134.136.24]:27694 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725835AbfH0Vzz (ORCPT ); Tue, 27 Aug 2019 17:55:55 -0400 X-Amp-Result: UNSCANNABLE X-Amp-File-Uploaded: False Received: from orsmga006.jf.intel.com ([10.7.209.51]) by orsmga102.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 27 Aug 2019 14:55:55 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.64,438,1559545200"; d="scan'208";a="185426781" Received: from hao-dev.bj.intel.com (HELO localhost) ([10.238.157.65]) by orsmga006.jf.intel.com with ESMTP; 27 Aug 2019 14:55:53 -0700 Date: Wed, 28 Aug 2019 05:38:29 +0800 From: Wu Hao To: Moritz Fischer Cc: gregkh@linuxfoundation.org, linux-fpga@vger.kernel.org, linux-kernel@vger.kernel.org, linux-api@vger.kernel.org, linux-doc@vger.kernel.org, atull@kernel.org Subject: Re: [PATCH v5 3/9] fpga: dfl: afu: convert platform_driver to use dev_groups Message-ID: <20190827213829.GA4237@hao-dev> References: <1565578204-13969-1-git-send-email-hao.wu@intel.com> <1565578204-13969-4-git-send-email-hao.wu@intel.com> <20190822150701.GB22556@archbox> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190822150701.GB22556@archbox> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Aug 22, 2019 at 08:07:01AM -0700, Moritz Fischer wrote: > Hi Hao, > > On Mon, Aug 12, 2019 at 10:49:58AM +0800, Wu Hao wrote: > > This patch takes advantage of driver core which helps to create > > and remove sysfs attribute files, so there is no need to register > > sysfs entries manually in dfl-afu platform river code. > Same nit: s/river/driver > > > > Signed-off-by: Wu Hao > Acked-by: Moritz Fischer Hi Moritz Thanks a lot for the review. : ) Have you got a chance to look into the other patches in this patchset? Thanks Hao > > --- > > drivers/fpga/dfl-afu-main.c | 69 +++++++++++++++++++++++---------------------- > > 1 file changed, 36 insertions(+), 33 deletions(-) > > > > diff --git a/drivers/fpga/dfl-afu-main.c b/drivers/fpga/dfl-afu-main.c > > index e50c45e..e955149 100644 > > --- a/drivers/fpga/dfl-afu-main.c > > +++ b/drivers/fpga/dfl-afu-main.c > > @@ -282,24 +282,17 @@ static int port_get_id(struct platform_device *pdev) > > &dev_attr_power_state.attr, > > NULL, > > }; > > -ATTRIBUTE_GROUPS(port_hdr); > > + > > +static const struct attribute_group port_hdr_group = { > > + .attrs = port_hdr_attrs, > > +}; > > > > static int port_hdr_init(struct platform_device *pdev, > > struct dfl_feature *feature) > > { > > - dev_dbg(&pdev->dev, "PORT HDR Init.\n"); > > - > > port_reset(pdev); > > > > - return device_add_groups(&pdev->dev, port_hdr_groups); > > -} > > - > > -static void port_hdr_uinit(struct platform_device *pdev, > > - struct dfl_feature *feature) > > -{ > > - dev_dbg(&pdev->dev, "PORT HDR UInit.\n"); > > - > > - device_remove_groups(&pdev->dev, port_hdr_groups); > > + return 0; > > } > > > > static long > > @@ -330,7 +323,6 @@ static void port_hdr_uinit(struct platform_device *pdev, > > > > static const struct dfl_feature_ops port_hdr_ops = { > > .init = port_hdr_init, > > - .uinit = port_hdr_uinit, > > .ioctl = port_hdr_ioctl, > > }; > > > > @@ -361,32 +353,37 @@ static void port_hdr_uinit(struct platform_device *pdev, > > &dev_attr_afu_id.attr, > > NULL > > }; > > -ATTRIBUTE_GROUPS(port_afu); > > > > -static int port_afu_init(struct platform_device *pdev, > > - struct dfl_feature *feature) > > +static umode_t port_afu_attrs_visible(struct kobject *kobj, > > + struct attribute *attr, int n) > > { > > - struct resource *res = &pdev->resource[feature->resource_index]; > > - int ret; > > - > > - dev_dbg(&pdev->dev, "PORT AFU Init.\n"); > > + struct device *dev = kobj_to_dev(kobj); > > > > - ret = afu_mmio_region_add(dev_get_platdata(&pdev->dev), > > - DFL_PORT_REGION_INDEX_AFU, resource_size(res), > > - res->start, DFL_PORT_REGION_READ | > > - DFL_PORT_REGION_WRITE | DFL_PORT_REGION_MMAP); > > - if (ret) > > - return ret; > > + /* > > + * sysfs entries are visible only if related private feature is > > + * enumerated. > > + */ > > + if (!dfl_get_feature_by_id(dev, PORT_FEATURE_ID_AFU)) > > + return 0; > > > > - return device_add_groups(&pdev->dev, port_afu_groups); > > + return attr->mode; > > } > > > > -static void port_afu_uinit(struct platform_device *pdev, > > - struct dfl_feature *feature) > > +static const struct attribute_group port_afu_group = { > > + .attrs = port_afu_attrs, > > + .is_visible = port_afu_attrs_visible, > > +}; > > + > > +static int port_afu_init(struct platform_device *pdev, > > + struct dfl_feature *feature) > > { > > - dev_dbg(&pdev->dev, "PORT AFU UInit.\n"); > Thanks. > > + struct resource *res = &pdev->resource[feature->resource_index]; > > > > - device_remove_groups(&pdev->dev, port_afu_groups); > > + return afu_mmio_region_add(dev_get_platdata(&pdev->dev), > > + DFL_PORT_REGION_INDEX_AFU, > > + resource_size(res), res->start, > > + DFL_PORT_REGION_MMAP | DFL_PORT_REGION_READ | > > + DFL_PORT_REGION_WRITE); > > } > > > > static const struct dfl_feature_id port_afu_id_table[] = { > > @@ -396,7 +393,6 @@ static void port_afu_uinit(struct platform_device *pdev, > > > > static const struct dfl_feature_ops port_afu_ops = { > > .init = port_afu_init, > > - .uinit = port_afu_uinit, > > }; > > > > static struct dfl_feature_driver port_feature_drvs[] = { > > @@ -748,9 +744,16 @@ static int afu_remove(struct platform_device *pdev) > > return 0; > > } > > > > +static const struct attribute_group *afu_dev_groups[] = { > > + &port_hdr_group, > > + &port_afu_group, > > + NULL > > +}; > > + > > static struct platform_driver afu_driver = { > > .driver = { > > - .name = DFL_FPGA_FEATURE_DEV_PORT, > > + .name = DFL_FPGA_FEATURE_DEV_PORT, > > + .dev_groups = afu_dev_groups, > > }, > > .probe = afu_probe, > > .remove = afu_remove, > > -- > > 1.8.3.1 > > > > Thanks, > Moritz