Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751947AbdHDHcn (ORCPT ); Fri, 4 Aug 2017 03:32:43 -0400 Received: from mail.free-electrons.com ([62.4.15.54]:49968 "EHLO mail.free-electrons.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751316AbdHDHcl (ORCPT ); Fri, 4 Aug 2017 03:32:41 -0400 Date: Fri, 4 Aug 2017 09:32:40 +0200 From: Boris Brezillon To: Arnd Bergmann Cc: David Woodhouse , Brian Norris , Marek Vasut , Richard Weinberger , Cyrille Pitchen , Jingoo Han , Simon Baatz , Masahiro Yamada , Arvind Yadav , linux-mtd@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] mtd: orion-nand: fix build error with ARMv4 Message-ID: <20170804093240.25753a23@bbrezillon> In-Reply-To: <20170721203814.3363448-1-arnd@arndb.de> References: <20170721203814.3363448-1-arnd@arndb.de> X-Mailer: Claws Mail 3.13.2 (GTK+ 2.24.30; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2019 Lines: 65 On Fri, 21 Jul 2017 22:38:06 +0200 Arnd Bergmann wrote: > orion_nand_read_buf uses an inline assembly with the "ldrd" > instruction, which is only available from ARMv5 upwards. This > used to be fine, since all users have an ARMv5 or ARMv7 CPU, > but now we can also build a multiplatform kernel with ARMv4 > support enabled in addition to the "kirkwood" (mvebu) platform. > > This provides an alternative to call the readsl() function that > is supposed to have the same effect and is also optimized for > performance. > > I first posted a version of this patch back in 2014, and there > was some discussion about it then. This fixes the bugs identified > back then and should be a reasonable alternative for the rare > corner case. Looks good to me. Applied to nand/next. Let's see if anyone complains before the merge window. Thanks, Boris > > Link: https://patchwork.kernel.org/patch/4144791/ > Cc: Jingoo Han > Signed-off-by: Arnd Bergmann > --- > drivers/mtd/nand/orion_nand.c | 7 +++++++ > 1 file changed, 7 insertions(+) > > diff --git a/drivers/mtd/nand/orion_nand.c b/drivers/mtd/nand/orion_nand.c > index 209170ed2b76..41cb7acfc044 100644 > --- a/drivers/mtd/nand/orion_nand.c > +++ b/drivers/mtd/nand/orion_nand.c > @@ -54,13 +54,16 @@ static void orion_nand_read_buf(struct mtd_info *mtd, uint8_t *buf, int len) > { > struct nand_chip *chip = mtd_to_nand(mtd); > void __iomem *io_base = chip->IO_ADDR_R; > +#if __LINUX_ARM_ARCH__ >= 5 > uint64_t *buf64; > +#endif > int i = 0; > > while (len && (unsigned long)buf & 7) { > *buf++ = readb(io_base); > len--; > } > +#if __LINUX_ARM_ARCH__ >= 5 > buf64 = (uint64_t *)buf; > while (i < len/8) { > /* > @@ -74,6 +77,10 @@ static void orion_nand_read_buf(struct mtd_info *mtd, uint8_t *buf, int len) > buf64[i++] = x; > } > i *= 8; > +#else > + readsl(io_base, buf, len/4); > + i = len / 4 * 4; > +#endif > while (i < len) > buf[i++] = readb(io_base); > }