Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752603AbaLFNCE (ORCPT ); Sat, 6 Dec 2014 08:02:04 -0500 Received: from mail-ie0-f176.google.com ([209.85.223.176]:42296 "EHLO mail-ie0-f176.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751910AbaLFNCB (ORCPT ); Sat, 6 Dec 2014 08:02:01 -0500 MIME-Version: 1.0 In-Reply-To: References: <1414007405-32186-1-git-send-email-atull@opensource.altera.com> <1414007405-32186-3-git-send-email-atull@opensource.altera.com> <20141024105200.GA20775@amd> From: Grant Likely Date: Sat, 6 Dec 2014 13:01:40 +0000 X-Google-Sender-Auth: AJZdSHq81g7x61KwKQyFWfkBz7U Message-ID: Subject: Re: [PATCH v2 2/3] fpga manager: framework core To: atull Cc: Pantelis Antoniou , Pavel Machek , Greg Kroah-Hartman , Jason Gunthorpe , "H. Peter Anvin" , Michal Simek , Michal Simek , Randy Dunlap , linux-kernel , "devicetree@vger.kernel.org" , Rob Herring , Ira Snyder , "linux-doc@vger.kernel.org" , Mark Brown , philip@balister.org, rubini , Steffen Trumtrar , Jason , kyle.teske@ni.com, Nicolas Pitre , Felipe Balbi , Mauro Carvalho Chehab , David Brown , Rob Landley , David Miller , cesarb@cesarb.net, "sameo@linux.intel.com" , Andrew Morton , Linus Walleij , Alan Tull , dinguyen@opensource.altera.com, Yves Vandervennet Content-Type: text/plain; charset=ISO-8859-1 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Oct 24, 2014 at 3:54 PM, atull wrote: > On Fri, 24 Oct 2014, Pantelis Antoniou wrote: > >> Hi Pavel, >> >> > On Oct 24, 2014, at 1:52 PM, Pavel Machek wrote: >> > >> > Hi! >> > >> >> * /sys/class/fpga_manager//firmware >> >> Name of FPGA image file to load using firmware class. >> >> $ echo image.rbf > /sys/class/fpga_manager//firmware >> > >> > I .. still don't think this is good idea. What about namespaces? >> > The path corresponds to path in which namespace? >> > > > Hi Pavel, > > Sorry if my documentation is too brief here. The context is the > firmware class. The 'image.rbf' is a image file that is located > on the filesystem in the firmware search patch. > See Documentation/firmware_class/README. > > Basically we need some way of loading a FPGA image to the FPGA. > I don't think any one way is going to meet everybody's needs so > I wanted to export enough functions from fpga-mgr.c that other > interfaces can by built. I think firmware will work just fine > for some people and it is great in that it already exists in the > kernel. > > If I missed your point, please let me know. > >> >> FWIW the overlays patchset uses binary configfs attribute to make this work. >> > > Hi Pantelis, > > Yes I think you've mentioned that before. So that would be another > way of giving a device tree overlay to configfs, right? I should > that to the documentation in the patch header. > >> >> +int fpga_mgr_write(struct fpga_manager *mgr, const char *buf, size_t count) >> >> +{ >> >> + int ret; >> >> + >> >> + if (test_and_set_bit_lock(FPGA_MGR_BUSY, &mgr->flags)) >> >> + return -EBUSY; >> >> + >> >> + dev_info(mgr->dev, "writing buffer to %s\n", mgr->name); >> >> + >> >> + ret = __fpga_mgr_write(mgr, buf, count); >> >> + clear_bit_unlock(FPGA_MGR_BUSY, &mgr->flags); >> >> + >> >> + return ret; >> >> +} >> >> +EXPORT_SYMBOL_GPL(fpga_mgr_write); >> > >> > Is the EBUSY -- userspace please try again, but you don't know when to >> > try again -- right interface? I mean, normally kernel would wait, so >> > that userland does not have to poll? >> > > > Yes, for fpga_mgr_write it may be more useful for this to be > a blocking call. > >> >> +static ssize_t fpga_mgr_firmware_store(struct device *dev, >> >> + struct device_attribute *attr, >> >> + const char *buf, size_t count) >> >> +{ >> >> + struct fpga_manager *mgr = dev_get_drvdata(dev); >> >> + unsigned int len; >> >> + char image_name[NAME_MAX]; >> >> + int ret; >> >> + >> >> + /* lose terminating \n */ >> >> + strcpy(image_name, buf); >> >> + len = strlen(image_name); >> >> + if (image_name[len - 1] == '\n') >> >> + image_name[len - 1] = 0; >> >> + >> >> + ret = fpga_mgr_firmware_write(mgr, image_name); >> >> + if (ret) >> >> + return ret; >> >> + >> >> + return count; >> >> +} >> > >> > This shows why the interface is not right... Valid filename may >> > contain \n, right? It may even end with \n. >> > >> >> I could argue that a valid firmware file is one that's well formed and does not >> contain those characters. >> >> I guess this is only for make echo file >foo work. You could specify that echo -n file >foo is >> required. >> > > I am accustomed to doing 'echo -n' for most of sysfs anyway. Once in a > while I am a bonehead and forget the '-n' and spend a few minutes > wondering why this thing that worked last week suddenly rejects all > commands. I'm just trying to make my user interface a bit user-friendly. > > I will take out the '\n' stripping and update the documentation. I didn't > realize this would be controversial. Don't. You're doing the right thing by scrubbing your input. Requiring 'echo -n' is just stupid when it is so easy to make work easily. g. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/