From: atull <atull@opensource.altera.com>
To: Pantelis Antoniou <pantelis.antoniou@konsulko.com>
Cc: One Thousand Gnomes <gnomes@lxorguk.ukuu.org.uk>,
Jason Gunthorpe <jgunthorpe@obsidianresearch.com>,
Pavel Machek <pavel@denx.de>,
Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
hpa@zytor.com, Michal Simek <monstr@monstr.eu>,
Michal Simek <michal.simek@xilinx.com>,
rdunlap@infradead.org,
Linux Kernel Mailing List <linux-kernel@vger.kernel.org>,
devicetree@vger.kernel.org, robh+dt@kernel.org,
Grant Likely <grant.likely@linaro.org>,
iws@ovro.caltech.edu, linux-doc@vger.kernel.org,
Mark Brown <broonie@kernel.org>,
philip@balister.org, rubini@gnudd.com,
Steffen Trumtrar <s.trumtrar@pengutronix.de>,
jason@lakedaemon.net, kyle.teske@ni.com, nico@linaro.org,
Felipe Balbi <balbi@ti.com>,
m.chehab@samsung.com, davidb@codeaurora.org,
Rob Landley <rob@landley.net>,
davem@davemloft.net, cesarb@cesarb.net, sameo@linux.intel.com,
akpm@linux-found
Subject: Re: [PATCH v8 2/4] fpga manager: add sysfs interface document
Date: Tue, 13 Jan 2015 13:44:01 -0600 [thread overview]
Message-ID: <alpine.DEB.2.02.1501131336220.29145@linuxheads99> (raw)
In-Reply-To: <027665D5-EB1F-47D1-B727-FE236C009FA7@konsulko.com>
[-- Attachment #1: Type: text/plain, Size: 4632 bytes --]
On Tue, 13 Jan 2015, Pantelis Antoniou wrote:
> Hi Alan,
>
> > On Jan 13, 2015, at 18:28 , One Thousand Gnomes <gnomes@lxorguk.ukuu.org.uk> wrote:
> >
> > On Mon, 12 Jan 2015 14:43:14 -0700
> > Jason Gunthorpe <jgunthorpe@obsidianresearch.com> wrote:
> >
> >> On Mon, Jan 12, 2015 at 09:01:34PM +0000, One Thousand Gnomes wrote:
> >>> There are plenty of people today who treat the FPGA as an entirely
> >>> dynamic resource. It's not like flashing a controller, its near
> >>> immediate.
> >>
> >> But this is a completely different use case. Remember, there are
> >> *megabytes* of internal state in a FPGA, and it isn't really feasible
> >> to dump/restore that state.
> >
> > People already do it with cases where it makes sense
> >
>
> Those people have failed to show up and provide input and/or code.
>
> >> It is one thing to context switch a maths algorithm that is built to
> >> be stateless, it is quite another to context switch between, say an
> >> ethernet core with an operating Linux Net driver doing DMA and a maths
> >> algorithm.
> >
> > And people already do it with thins like maths algorithms.
> >
>
> Again those people have failed to show up and provide input and/or code.
>
> >> A DT overlay approach where the overlay has to be unloaded to 'free'
> >> the FPGA makes alot of sense to me for the stateful kernel driver
> >> environment, and open/close/etc makes alot of sense for the stateless
> >> switchable userspace environment - other than sharing configuration
> >> code, is there any overlap between these use cases????
> >
> > There is a lot of code overlap in things like loading the bitstreams,
> > there is also some overlap because you want to be able to assign FPGA
> > resources. For example if you have four FPGAs and you want to use one for
> > OS stuff (say video) you want the other three to be open/close
> > accessible, but if you've not got a video driver loaded and are running
> > the same board headless you'd like all four to be handed out as normal
> > resources.
> >
> > So IMHO it's no different to say kmalloc. We don't pre-empt kernel memory
> > and give it to users but we don't reserve memory for kernel and not use
> > it.
> >
> >>> Its completely dynamic and it will get more so as we switch from the
> >>> painful world of VHDL and friends to high level parallel aware language
> >>> compilers for FPGAs and everyone will be knocking up quick FPGA hacks.
> >>
> >> Only for some users. In my world FPGAs are filled with bus interface
> >> logic, ethernet controllers, memory controllers, packet processing
> >> engines, etc. This is all incredibly stateful - both in the FPGA
> >> itself, and in the Linux side w/ drviers. It certainly will not ever
> >> work in the model you are talking about.
> >
> > For those cases I mostly agree (the state in the FPGA isn't always a
> > problem as you can program an FPGA to DMA its state out).
> >
> >> Even if the digital state could somehow be frozen, dumped and
> >> restored, all the FPGA external interface logic has *ANALOG* state
> >> that cannot ever be dump/restored. It just isn't feasible for that
> >> class of application.
> >
> > Yes, however as we are starting to get things like OpenCL for FPGA they
> > become extremely attractive for a wide range of purposes that don't
> > involve glueing them to electronica in quite the same way. All the 'GPU
> > as CPU' type uses and more begin to apply.
> >
>
> Your points are valid, but they are mostly academic right now.
>
> We have a lot of well known use cases that this patchset addresses
> satisfactorily. The possible users of the cases you point out are
> welcome to provide input and working code to address their needs.
>
> At this point in time, no-one has showed up; is there a reason for
> this needed capability to be delayed in order to address something
> that no-one has expressed interest for?
>
> > Alan
> > —
>
> Regards
>
> — Pantelis
>
>
There has been a lot of discussion in the past. It is possible that
some of the use models are conflicting, but that doesn't really mean
that one model is more valid and needs to be the
winner that determines the only valid way to use FPGAs under Linux.
I like the dynamic usage model and the DT overlays model both. It
is likely that both will be added and used.
This set of patches gets something started. The sysfs interface
is built on a set of functions that can be used to build other
interfaces. An earlier set of patches included DT overlay support,
but I've taken that out for the moment. It's going into
drivers/staging so that we can use it and grow it.
Alan
next prev parent reply other threads:[~2015-01-13 19:44 UTC|newest]
Thread overview: 64+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-01-06 20:13 [PATCH v8 0/4] FPGA Manager Framework atull
2015-01-06 20:13 ` [PATCH v8 1/4] doc: add bindings document for altera fpga manager atull
2015-01-06 22:05 ` Rob Herring
2015-01-06 22:34 ` atull
2015-01-09 15:50 ` Rob Herring
[not found] ` <CAL_Jsq+pn5MW6veUivEL49FLSQxZOWRq0gU9Q6iD5jzurKK3rQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2015-01-09 18:58 ` atull
2015-01-06 20:13 ` [PATCH v8 2/4] fpga manager: add sysfs interface document atull
2015-01-07 8:48 ` Pavel Machek
2015-01-09 19:14 ` atull
2015-01-09 20:56 ` Pavel Machek
2015-01-10 8:10 ` Pantelis Antoniou
2015-01-10 15:11 ` Pavel Machek
2015-01-11 16:29 ` atull
2015-01-12 8:45 ` Pavel Machek
2015-01-12 13:48 ` Michal Simek
2015-01-13 7:28 ` Pavel Machek
2015-01-13 7:40 ` Pantelis Antoniou
2015-01-13 7:56 ` Pavel Machek
2015-01-13 17:27 ` atull
2015-01-12 16:05 ` Rob Herring
2015-01-12 16:26 ` Mark Brown
2015-01-12 18:06 ` Jason Gunthorpe
2015-01-13 16:21 ` One Thousand Gnomes
2015-01-15 21:52 ` Pavel Machek
2015-01-12 21:01 ` One Thousand Gnomes
2015-01-12 21:43 ` Jason Gunthorpe
2015-01-13 16:28 ` One Thousand Gnomes
2015-01-13 17:26 ` Pantelis Antoniou
2015-01-13 19:44 ` atull [this message]
2015-01-14 15:58 ` One Thousand Gnomes
2015-01-13 20:00 ` Jason Gunthorpe
2015-01-13 21:37 ` atull
2015-01-13 22:24 ` Jason Gunthorpe
2015-01-14 16:06 ` One Thousand Gnomes
2015-01-14 18:12 ` Jason Gunthorpe
2015-01-14 19:01 ` Pantelis Antoniou
2015-01-15 11:36 ` One Thousand Gnomes
2015-01-15 11:44 ` Mark Brown
2015-01-15 16:34 ` atull
2015-01-15 18:47 ` Jason Gunthorpe
2015-01-15 20:45 ` One Thousand Gnomes
2015-01-15 20:54 ` Pantelis Antoniou
2015-01-21 16:01 ` One Thousand Gnomes
[not found] ` <20150121160151.453ba403-qBU/x9rampVanCEyBjwyrvXRex20P6io@public.gmane.org>
2015-01-21 16:33 ` Pantelis Antoniou
[not found] ` <D466D9FF-25DA-4765-9469-128733BEBC4D-OWPKS81ov/FWk0Htik3J/w@public.gmane.org>
2015-01-21 20:27 ` Jason Gunthorpe
2015-01-21 20:32 ` Pantelis Antoniou
2015-02-15 22:40 ` Pavel Machek
2015-02-17 17:07 ` Rob Landley
2015-02-17 19:17 ` Pavel Machek
2015-02-19 12:46 ` Michal Simek
2015-02-21 6:31 ` atull
2015-02-17 18:12 ` Jason Gunthorpe
2015-01-15 21:42 ` Jason Gunthorpe
2015-01-17 21:11 ` Pavel Machek
2015-01-06 20:13 ` [PATCH v8 3/4] staging: fpga manager: framework core atull
2015-01-06 20:13 ` [PATCH v8 4/4] staging: fpga manager: add driver for socfpga fpga manager atull
2015-01-10 18:11 ` [PATCH v8 0/4] FPGA Manager Framework Konrad Zapalowicz
2015-01-11 16:08 ` atull
2015-01-11 16:24 ` Konrad Zapalowicz
2015-01-11 19:52 ` Pavel Machek
2015-01-11 20:58 ` Konrad Zapalowicz
2015-01-11 21:31 ` Pavel Machek
2015-01-12 13:50 ` Michal Simek
2015-01-12 14:06 ` Dan Carpenter
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=alpine.DEB.2.02.1501131336220.29145@linuxheads99 \
--to=atull@opensource.altera.com \
--cc=akpm@linux-found \
--cc=balbi@ti.com \
--cc=broonie@kernel.org \
--cc=cesarb@cesarb.net \
--cc=davem@davemloft.net \
--cc=davidb@codeaurora.org \
--cc=devicetree@vger.kernel.org \
--cc=gnomes@lxorguk.ukuu.org.uk \
--cc=grant.likely@linaro.org \
--cc=gregkh@linuxfoundation.org \
--cc=hpa@zytor.com \
--cc=iws@ovro.caltech.edu \
--cc=jason@lakedaemon.net \
--cc=jgunthorpe@obsidianresearch.com \
--cc=kyle.teske@ni.com \
--cc=linux-doc@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=m.chehab@samsung.com \
--cc=michal.simek@xilinx.com \
--cc=monstr@monstr.eu \
--cc=nico@linaro.org \
--cc=pantelis.antoniou@konsulko.com \
--cc=pavel@denx.de \
--cc=philip@balister.org \
--cc=rdunlap@infradead.org \
--cc=rob@landley.net \
--cc=robh+dt@kernel.org \
--cc=rubini@gnudd.com \
--cc=s.trumtrar@pengutronix.de \
--cc=sameo@linux.intel.com \
/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