Re: [PATCH 8/8] ARM: mvebu: a38x: Enable A38x XOR engine features
From: Maxime Ripard
Date: Wed May 13 2015 - 04:35:10 EST
On Wed, May 13, 2015 at 07:16:34AM +0000, Lior Amsalem wrote:
> > From: Andrew Lunn [mailto:andrew@xxxxxxx]
> > Sent: Tuesday, May 12, 2015 7:13 PM
> >
> > On Tue, May 12, 2015 at 05:37:43PM +0200, Maxime Ripard wrote:
> > > From: Lior Amsalem <alior@xxxxxxxxxxx>
> > >
> > > The new XOR engine has a new compatible of its own, together with new
> > > channel capabilities.
> > >
> > > Use that new compatible now that we have a driver that can handle it.
> > >
> > > Signed-off-by: Lior Amsalem <alior@xxxxxxxxxxx>
> > > Reviewed-by: Ofer Heifetz <oferh@xxxxxxxxxxx>
> > > Reviewed-by: Nadav Haklai <nadavh@xxxxxxxxxxx>
> > > Tested-by: Nadav Haklai <nadavh@xxxxxxxxxxx>
> > > ---
> > > arch/arm/boot/dts/armada-38x.dtsi | 20 ++++++--------------
> > > 1 file changed, 6 insertions(+), 14 deletions(-)
> > >
> > > diff --git a/arch/arm/boot/dts/armada-38x.dtsi
> > > b/arch/arm/boot/dts/armada-38x.dtsi
> > > index ed2dd8ba4080..6d07b7389415 100644
> > > --- a/arch/arm/boot/dts/armada-38x.dtsi
> > > +++ b/arch/arm/boot/dts/armada-38x.dtsi
> > > @@ -448,7 +448,7 @@
> > > };
> > >
> > > xor@60800 {
> > > - compatible = "marvell,orion-xor";
> > > + compatible = "marvell,a38x-xor";
> > > reg = <0x60800 0x100
> > > 0x60a00 0x100>;
> > > clocks = <&gateclk 22>;
> > > @@ -458,17 +458,13 @@
> > > interrupts = <GIC_SPI 22
> > IRQ_TYPE_LEVEL_HIGH>;
> > > dmacap,memcpy;
> > > dmacap,xor;
> > > - };
> > > - xor01 {
> > > - interrupts = <GIC_SPI 23
> > IRQ_TYPE_LEVEL_HIGH>;
> > > - dmacap,memcpy;
> > > - dmacap,xor;
> > > - dmacap,memset;
> > > + dmacap,pq;
> > > + dmacap,interrupt;
> >
> > Does this mean the hardware only has one channel?
> > And memset is no longer supported?
> >
>
> The hardware has two channels per engine and two engines.
> However, both on HW side (both channels are on the same "bus port")
> and SW (the dma subsystem will assign one channel per CPU).
> we found it's better (performance wise) to use only one channel on each engine
> and let the framework assign one per CPU.
> This way, descriptors chaining was better (cause of the depended descriptors
> problem) and overall interrupt number reduced.
>
> Yes, since memset is a problematic one. It can only be done via registers
> (and not on descriptors level) plus no one really needs it...
And memset support has been removed from dmaengine since 3.11, so it
doesn't look like anyone really needs it :)
We're talking about reintroducing it for some platforms that actually
need it, but it wasn't really used on marvell anyway...
Maxime
--
Maxime Ripard, Free Electrons
Embedded Linux, Kernel and Android engineering
http://free-electrons.com
Attachment:
signature.asc
Description: Digital signature