From mboxrd@z Thu Jan 1 00:00:00 1970 From: Catalin Marinas Subject: Re: [PATCH v2] ARM: l2c: Add support for the "arm, shared-override" property Date: Thu, 7 May 2015 17:02:57 +0100 Message-ID: <20150507160257.GA11067@e104818-lin.cambridge.arm.com> References: <1430990831-23825-1-git-send-email-geert+renesas@glider.be> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Content-Disposition: inline In-Reply-To: <1430990831-23825-1-git-send-email-geert+renesas@glider.be> Sender: linux-sh-owner@vger.kernel.org To: Geert Uytterhoeven Cc: Russell King - ARM Linux , Arnd Bergmann , Simon Horman , Magnus Damm , Mark Rutland , Pawel Moll , Rob Herring , devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-sh@vger.kernel.org List-Id: devicetree@vger.kernel.org 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 (even better if a subsequent patch adds this property to all the dts files containing "arm,pl310" ;))