From mboxrd@z Thu Jan 1 00:00:00 1970 From: Alan Tull Subject: Re: [PATCH v3 11/21] fpga: dfl: fme: add header sub feature support Date: Mon, 12 Feb 2018 10:51:44 -0600 Message-ID: References: <1511764948-20972-1-git-send-email-hao.wu@intel.com> <1511764948-20972-12-git-send-email-hao.wu@intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Return-path: In-Reply-To: <1511764948-20972-12-git-send-email-hao.wu-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org> Sender: linux-api-owner-u79uwXL29TY76Z2rM5mHXA@public.gmane.org To: Wu Hao Cc: Moritz Fischer , linux-fpga-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, linux-kernel , linux-api-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, "Kang, Luwei" , "Zhang, Yi Z" , Tim Whisonant , Enno Luebbers , Shiva Rao , Christopher Rauer , Xiao Guangrong List-Id: linux-api@vger.kernel.org On Mon, Nov 27, 2017 at 12:42 AM, Wu Hao wrote: > From: Kang Luwei > > The header register set is always present for FPGA Management Engine (FME), > this patch implements init and uinit function for header sub feature and > introduce several read-only sysfs interfaces for the capability and status. > > Sysfs interfaces: > * /sys/class/fpga_region///ports_num > Read-only. Number of ports implemented > > * /sys/class/fpga_region///bitstream_id > Read-only. Blue Bitstream (static FPGA region) identifier number > > * /sys/class/fpga_region///bitstream_metadata > Read-only. Blue Bitstream (static FPGA region) meta data Please document the meta data. I don't see anywhere that describes it or how it differs from the bitstream_id. So it could be useful to document it in this header a bit, and in the code, in the sysfs document, and in the Documentation/fpga so that people don't have to go hunting. We discussed elsewhere the static region bitstream_id verses the other interface_ids, so that's been discussed. Besides that, this patch looks good and straightforward. Thanks, Alan > > Signed-off-by: Tim Whisonant > Signed-off-by: Enno Luebbers > Signed-off-by: Shiva Rao > Signed-off-by: Christopher Rauer > Signed-off-by: Kang Luwei > Signed-off-by: Xiao Guangrong > Signed-off-by: Wu Hao > ---- > v2: add sysfs documentation > v3: rename driver to fpga-dfl-fme. > improve sysfs doc and commit description. > replace bitfield. > --- > .../ABI/testing/sysfs-platform-fpga-dfl-fme | 21 ++++++++ > drivers/fpga/dfl-fme-main.c | 60 ++++++++++++++++++++++ > 2 files changed, 81 insertions(+) > create mode 100644 Documentation/ABI/testing/sysfs-platform-fpga-dfl-fme > > diff --git a/Documentation/ABI/testing/sysfs-platform-fpga-dfl-fme b/Documentation/ABI/testing/sysfs-platform-fpga-dfl-fme > new file mode 100644 > index 0000000..6b32799 > --- /dev/null > +++ b/Documentation/ABI/testing/sysfs-platform-fpga-dfl-fme > @@ -0,0 +1,21 @@ > +What: /sys/bus/platform/devices/fpga-dfl-fme.0/ports_num > +Date: November 2017 > +KernelVersion: 4.15 > +Contact: Wu Hao > +Description: Read-only. One DFL FPGA device may have more than 1 > + port/Accelerator Function Unit (AFU). It returns the > + number of ports on the FPGA device when read it. > + > +What: /sys/bus/platform/devices/fpga-dfl-fme.0/bitstream_id > +Date: November 2017 > +KernelVersion: 4.15 > +Contact: Wu Hao > +Description: Read-only. It returns Blue Bitstream (static FPGA region) > + identifier number. > + > +What: /sys/bus/platform/devices/fpga-dfl-fme.0/bitstream_meta > +Date: November 2017 > +KernelVersion: 4.15 > +Contact: Wu Hao > +Description: Read-only. It returns Blue Bitstream (static FPGA region) > + meta data. > diff --git a/drivers/fpga/dfl-fme-main.c b/drivers/fpga/dfl-fme-main.c > index f7b5f7d..d17c66a 100644 > --- a/drivers/fpga/dfl-fme-main.c > +++ b/drivers/fpga/dfl-fme-main.c > @@ -21,9 +21,68 @@ > > #include "fpga-dfl.h" > > +static ssize_t ports_num_show(struct device *dev, > + struct device_attribute *attr, char *buf) > +{ > + void __iomem *base; > + u64 v; > + > + base = get_feature_ioaddr_by_index(dev, FME_FEATURE_ID_HEADER); > + > + v = readq(base + FME_HDR_CAP); > + > + return scnprintf(buf, PAGE_SIZE, "%u\n", > + (unsigned int)FIELD_GET(FME_CAP_NUM_PORTS, v)); > +} > +static DEVICE_ATTR_RO(ports_num); > + > +static ssize_t bitstream_id_show(struct device *dev, > + struct device_attribute *attr, char *buf) > +{ > + void __iomem *base; > + u64 v; > + > + base = get_feature_ioaddr_by_index(dev, FME_FEATURE_ID_HEADER); > + > + v = readq(base + FME_HDR_BITSTREAM_ID); > + > + return scnprintf(buf, PAGE_SIZE, "0x%llx\n", (unsigned long long)v); > +} > +static DEVICE_ATTR_RO(bitstream_id); > + > +static ssize_t bitstream_metadata_show(struct device *dev, > + struct device_attribute *attr, char *buf) > +{ > + void __iomem *base; > + u64 v; > + > + base = get_feature_ioaddr_by_index(dev, FME_FEATURE_ID_HEADER); > + > + v = readq(base + FME_HDR_BITSTREAM_MD); > + > + return scnprintf(buf, PAGE_SIZE, "0x%llx\n", (unsigned long long)v); > +} > +static DEVICE_ATTR_RO(bitstream_metadata); > + > +static const struct attribute *fme_hdr_attrs[] = { > + &dev_attr_ports_num.attr, > + &dev_attr_bitstream_id.attr, > + &dev_attr_bitstream_metadata.attr, > + NULL, > +}; > + > static int fme_hdr_init(struct platform_device *pdev, struct feature *feature) > { > + void __iomem *base = feature->ioaddr; > + int ret; > + > dev_dbg(&pdev->dev, "FME HDR Init.\n"); > + dev_dbg(&pdev->dev, "FME cap %llx.\n", > + (unsigned long long)readq(base + FME_HDR_CAP)); > + > + ret = sysfs_create_files(&pdev->dev.kobj, fme_hdr_attrs); > + if (ret) > + return ret; > > return 0; > } > @@ -31,6 +90,7 @@ static int fme_hdr_init(struct platform_device *pdev, struct feature *feature) > static void fme_hdr_uinit(struct platform_device *pdev, struct feature *feature) > { > dev_dbg(&pdev->dev, "FME HDR UInit.\n"); > + sysfs_remove_files(&pdev->dev.kobj, fme_hdr_attrs); > } > > static const struct feature_ops fme_hdr_ops = { > -- > 1.8.3.1 >