[PATCH v2] ARM: l2c: Add support for the "arm, shared-override" property

Russell King - ARM Linux linux at arm.linux.org.uk
Fri May 15 03:10:28 PDT 2015


On Thu, May 07, 2015 at 05:02:57PM +0100, Catalin Marinas wrote:
> On Thu, May 07, 2015 at 11:27:11AM +0200, Geert Uytterhoeven wrote:
> > diff --git a/Documentation/devicetree/bindings/arm/l2cc.txt b/Documentation/devicetree/bindings/arm/l2cc.txt
> > index 0dbabe9a6b0abb91..2484aed78c86546d 100644
> > --- a/Documentation/devicetree/bindings/arm/l2cc.txt
> > +++ b/Documentation/devicetree/bindings/arm/l2cc.txt
> > @@ -67,6 +67,12 @@ Optional properties:
> >    disable if zero.
> >  - arm,prefetch-offset : Override prefetch offset value. Valid values are
> >    0-7, 15, 23, and 31.
> > +- arm,shared-override : The default behavior of the pl310 cache controller with
> > +  respect to the shareable attribute is to transform "normal memory
> > +  non-cacheable transactions" into "cacheable no allocate" (for reads) or
> > +  "write through no write allocate" (for writes).
> > +  On systems where this may cause DMA buffer corruption, this property must be
> > +  specified to indicate that such transforms are precluded.
> >  
> >  Example:
> >  
> > diff --git a/arch/arm/mm/cache-l2x0.c b/arch/arm/mm/cache-l2x0.c
> > index e309c8f35af5af61..86d0e7461e5b0b18 100644
> > --- a/arch/arm/mm/cache-l2x0.c
> > +++ b/arch/arm/mm/cache-l2x0.c
> > @@ -1149,6 +1149,11 @@ static void __init l2c310_of_parse(const struct device_node *np,
> >  		}
> >  	}
> >  
> > +	if (of_property_read_bool(np, "arm,shared-override")) {
> > +		*aux_val |= L2C_AUX_CTRL_SHARED_OVERRIDE;
> > +		*aux_mask &= ~L2C_AUX_CTRL_SHARED_OVERRIDE;
> > +	}
> > +
> >  	prefetch = l2x0_saved_regs.prefetch_ctrl;
> >  
> >  	ret = of_property_read_u32(np, "arm,double-linefill", &val);
> 
> It looks fine to me.
> 
> Acked-by: Catalin Marinas <catalin.marinas at arm.com>
> 
> (even better if a subsequent patch adds this property to all the dts
> files containing "arm,pl310" ;))

Even better would be for the boot loader/firmware to set the bit.

-- 
FTTC broadband for 0.8mile line: currently at 10.5Mbps down 400kbps up
according to speedtest.net.



More information about the linux-arm-kernel mailing list