lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20150723073148.GA1762@pengutronix.de>
Date:	Thu, 23 Jul 2015 09:31:48 +0200
From:	Steffen Trumtrar <s.trumtrar@...gutronix.de>
To:	atull <atull@...nsource.altera.com>
Cc:	gregkh@...uxfoundation.org, jgunthorpe@...idianresearch.com,
	hpa@...or.com, monstr@...str.eu, michal.simek@...inx.com,
	rdunlap@...radead.org, linux-kernel@...r.kernel.org,
	devicetree@...r.kernel.org, pantelis.antoniou@...sulko.com,
	robh+dt@...nel.org, grant.likely@...aro.org, iws@...o.caltech.edu,
	linux-doc@...r.kernel.org, pavel@...x.de, broonie@...nel.org,
	philip@...ister.org, rubini@...dd.com, jason@...edaemon.net,
	kyle.teske@...com, nico@...aro.org, balbi@...com,
	m.chehab@...sung.com, davidb@...eaurora.org, rob@...dley.net,
	davem@...emloft.net, cesarb@...arb.net, sameo@...ux.intel.com,
	akpm@...ux-foundation.org, linus.walleij@...aro.org,
	pawel.moll@....com, mark.rutland@....com,
	ijc+devicetree@...lion.org.uk, galak@...eaurora.org,
	devel@...verdev.osuosl.org, Petr Cvek <petr.cvek@....cz>,
	delicious.quinoa@...il.com, dinguyen@...nsource.altera.com
Subject: Re: [PATCH v9 3/7] staging: add bindings document for simple fpga bus

Hi!

On Fri, Jul 17, 2015 at 04:22:07PM -0500, atull wrote:
> On Fri, 17 Jul 2015, Steffen Trumtrar wrote:
> 
> > Hi!
> > 
> > On Fri, Jul 17, 2015 at 10:51:13AM -0500, atull@...nsource.altera.com wrote:
> > > From: Alan Tull <atull@...nsource.altera.com>
> > > 
> > > New bindings document for simple fpga bus.
> > > 
> > > Signed-off-by: Alan Tull <atull@...nsource.altera.com>
> > > ---
> > >  .../Documentation/bindings/simple-fpga-bus.txt     |   61 ++++++++++++++++++++
> > >  1 file changed, 61 insertions(+)
> > >  create mode 100644 drivers/staging/fpga/Documentation/bindings/simple-fpga-bus.txt
> > > 
> > > diff --git a/drivers/staging/fpga/Documentation/bindings/simple-fpga-bus.txt b/drivers/staging/fpga/Documentation/bindings/simple-fpga-bus.txt
> > > new file mode 100644
> > > index 0000000..221e781
> > > --- /dev/null
> > > +++ b/drivers/staging/fpga/Documentation/bindings/simple-fpga-bus.txt
> > > @@ -0,0 +1,61 @@
> > > +Simple FPGA Bus
> > > +===============
> > > +
> > > +A Simple FPGA Bus is a bus that handles configuring an FPGA and its bridges
> > > +before populating the devices below its node.
> > > +
> > > +Required properties:
> > > +- compatible : should contain "simple-fpga-bus"
> > > +- #address-cells, #size-cells, ranges: must be present to handle address space
> > > +  mapping for children.
> > > +
> > > +Optional properties:
> > > +- fpga-mgr : should contain a phandle to a fpga manager.
> > > +- fpga-firmware : should contain the name of a fpga image file located on the
> > > +  firmware search path.
> > > +- partial-reconfig : boolean property should be defined if partial
> > > +  reconfiguration is to be done.
> > > +- resets : should contain a list of resets that should be released after the
> > > +  fpga has been programmed i.e. fpga bridges.
> > > +- reset-names : should contain a list of the names of the resets.
> > > +
> > > +Example:
> > > +
> > > +/dts-v1/;
> > > +/plugin/;
> > > +/ {
> > > +	fragment@0 {
> > > +		target-path="/soc";
> > > +		__overlay__ {
> > > +			#address-cells = <1>;
> > > +	                #size-cells = <1>;
> > > +
> > > +			bridge@...f200000 {
> > > +				compatible = "simple-fpga-bus";
> > > +				#address-cells = <0x2>;
> > > +				#size-cells = <0x1>;
> > > +				ranges = <0x1 0x10040 0xff210040 0x20>;
> > > +
> > > +				clocks = <0x2 0x2>;
> > > +				clock-names = "h2f_lw_axi_clock", "f2h_sdram0_clock";
> > > +
> > > +				fpga-mgr = <&hps_0_fpgamgr>;
> > > +				fpga-firmware = "soc_system.rbf";
> > > +
> > > +				resets = <&hps_fpgabridge0 0>, <&hps_fpgabridge1 0>, <&hps_fpgabridge2 0>;
> > > +				reset-names = "hps2fpga", "lwhps2fpga", "fpga2hps";
> > > +
> > > +				gpio@...00010040 {
> > > +					compatible = "altr,pio-14.0", "altr,pio-1.0";
> > > +					reg = <0x1 0x10040 0x20>;
> > > +					clocks = <0x2>;
> > > +					altr,gpio-bank-width = <0x4>;
> > > +					resetvalue = <0x0>;
> > > +					#gpio-cells = <0x2>;
> > > +					gpio-controller;
> > > +				};
> > > +			};
> > > +		};
> > > +	};
> > > +};
> > > +
> > 
> > Just some quick thougths for the Socfpga case:
> > 
> > What you are describing here is a virtual bus, that is not existing on
> > at least the Socfpga, right? I don't like this.
> > You are mixing different independent busses/devices into one and I don't
> > see why.
> 

Just to be clear: all in all I like this approach and I would prefer it to
go in the mainline kernel sooner than later. The thing is AFAIK we still
don't have a way to mark DT bindings as staging or in flux even if we do
have a staging area for drivers. That's why I want to be convinced that this
binding is "correct" from a binding perspective and not some linux driver
implementation. It's much easier to change a driver than breaking old dts files
with binding changes.

> It is a multi-interface bridge.  It is likely that a device will use more than
> one at a time.  This is normal in the kernel and the device tree supports it.
> My example is too simplistic.  It is common for a device to use the lwh2f
> bridge for register access and the h2f bridge for data.  So you'd have
> 
>    reg = <0xc0000000 0x20000000>,
>          <0xff200000 0x00200000>;
> 
> and ranges that map from those areas.
> 

Yeah, sure. I used that, too. Where is the problem with

	&hps2fpga {
		status = "okay";
		my-ip-core {
			config = <&lwhps2fpga>;
			...
		};
	};

	&lwhps2fpga {
		status = "okay";
	};

The typical "let's use syscon" case, no?!

> > I see that this is just an example, but why
> >   a) isn't the fpga-mgr the one knowing about the bitstream ?
> 
> The fpga-mgr doesn't know much.  Someone has to tell it what to load.  I think
> that is a good thing.
> 
> >      You can't have two of these busses with different bitstreams anyway
> >      And if you have multipe FPGAs you have multiple fpga-mgrs, no?
> 
> You would have one fpga-mgr and a separate set of bridges per fpga.
> 

Is that because of the framework or the hardware implementation?
What do I do, if I have a Socfpga+Bitstream and a Stratix that I program
via SPI/PCIe/whatever? Don't I have two different Managers now, hardware-wise?
System is done, dts is fixed. I would expect to provide two bitstreams in the
chosen-node and let the FPGA managers grep theirs.
But I can see, that it is not unreasonable to have this information in the bridge,
to have it describe what devices hang from it.

> >   b) shouldn't the h2f/lwh2f/f2h bridges be the "simple-bus devices" instead of
> >      just reset-controllers ?
> 
> That's an artificial division of things.  These aren't really separate busses.
> You would have a device that needs to be the child of two separate bridges then.
> 

phandle? Not an uncommon pattern, is it?!
The thing is: What level of hardware does a binding actually describe?
When I look into the TRM of the Socfpga, I see two seperate devices for HPS2FPGA
bridge and LWHPS2FPGA bridge. Both have their own address space, one port is connected
to the L3 main switch the other to the L3 Slave peripheral switch, both have different
AXI clocks and different bus width. This doesn't look like they are artificially
divided, but like they actually are divided. The TRM is the only thing I can use as
reference as a normal developer.

> > What about e.g. the bus width of the bridges?
> >      It can change depending on the bitstream. When I have an IP core that does
> >      DMA I might want my driver to be able to configure the bus width accordingly.
> >      There are other settings in the bridges that I can not set when they are just
> >      reset controllers.
> 
> I was hoping to avoid adding another framework to the kernel.  Looks like a
> bus framework will be necessary that can be controlled by the simple fpga bus.
> I'd add simple fpga bus DT bindings like
> 
>     bridges = <&hps_fpgabridge0>, <&hps_fpgabridge1>;
> 
> The bindings for the bridges have already been proposed (you didn't like them)
> and could be used in the overlay here to change bus width.
> 
>     https://lkml.org/lkml/2014/10/23/681
>

Still don't, sorry. That binding looks like it is backwards: it looks like it
starts from the use-case in linux and describes everything you need for that.
Instead of the other way around.

> I'll revive those patches, but tear out the sysfs interface and just export
> API's for enabling/disabling bridges that I could call from simple-fpga-bus.c
> 

I also posted an RFC for the bridges

http://lists.infradead.org/pipermail/linux-arm-kernel/2014-December/310181.html

and no, I'm not trying to pimp my driver ;-)

Regards,
Steffen

PS: Thanks for still working on this and trying to get a mainlineable solution
instead of just dumping something into some vendor tree.

-- 
Pengutronix e.K.                           |                             |
Industrial Linux Solutions                 | http://www.pengutronix.de/  |
Peiner Str. 6-8, 31137 Hildesheim, Germany | Phone: +49-5121-206917-0    |
Amtsgericht Hildesheim, HRA 2686           | Fax:   +49-5121-206917-5555 |
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ