From: Wu Hao <hao.wu@intel.com>
To: Moritz Fischer <mdf@kernel.org>
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
Date: Wed, 28 Aug 2019 05:38:29 +0800 [thread overview]
Message-ID: <20190827213829.GA4237@hao-dev> (raw)
In-Reply-To: <20190822150701.GB22556@archbox>
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 <hao.wu@intel.com>
> Acked-by: Moritz Fischer <mdf@kernel.org>
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
next prev parent reply other threads:[~2019-08-27 21:55 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-08-12 2:49 [PATCH v5 0/9] FPGA DFL updates Wu Hao
2019-08-12 2:49 ` [PATCH v5 1/9] fpga: dfl: make init callback optional Wu Hao
2019-08-21 3:24 ` Moritz Fischer
2019-08-21 5:12 ` Wu Hao
2019-08-12 2:49 ` [PATCH v5 2/9] fpga: dfl: fme: convert platform_driver to use dev_groups Wu Hao
2019-08-21 3:28 ` Moritz Fischer
2019-08-12 2:49 ` [PATCH v5 3/9] fpga: dfl: afu: " Wu Hao
2019-08-22 15:07 ` Moritz Fischer
2019-08-27 21:38 ` Wu Hao [this message]
2019-08-12 2:49 ` [PATCH v5 4/9] fpga: dfl: afu: add userclock sysfs interfaces Wu Hao
2019-08-12 2:50 ` [PATCH v5 5/9] fpga: dfl: afu: expose __afu_port_enable/disable function Wu Hao
2019-08-12 2:50 ` [PATCH v5 6/9] fpga: dfl: afu: add error reporting support Wu Hao
2019-08-12 2:50 ` [PATCH v5 7/9] fpga: dfl: afu: add STP (SignalTap) support Wu Hao
2019-08-12 2:50 ` [PATCH v5 8/9] fpga: dfl: fme: add global error reporting support Wu Hao
2019-08-12 2:50 ` [PATCH v5 9/9] Documentation: fpga: dfl: add descriptions for virtualization and new interfaces Wu Hao
2019-08-19 5:31 ` [PATCH v5 0/9] FPGA DFL updates Wu Hao
2019-08-19 20:51 ` Greg KH
2019-08-20 3:14 ` Wu Hao
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20190827213829.GA4237@hao-dev \
--to=hao.wu@intel.com \
--cc=atull@kernel.org \
--cc=gregkh@linuxfoundation.org \
--cc=linux-api@vger.kernel.org \
--cc=linux-doc@vger.kernel.org \
--cc=linux-fpga@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mdf@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).