From mboxrd@z Thu Jan 1 00:00:00 1970 From: Uwe =?iso-8859-1?Q?Kleine-K=F6nig?= Subject: Re: [PATCH] arm: prevent inlining in arxescsi.c causing build failures Date: Thu, 1 Dec 2011 09:06:14 +0100 Message-ID: <20111201080613.GF26618@pengutronix.de> References: <1322713611-30003-1-git-send-email-paul.gortmaker@windriver.com> Mime-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Transfer-Encoding: QUOTED-PRINTABLE Return-path: Content-Disposition: inline In-Reply-To: <1322713611-30003-1-git-send-email-paul.gortmaker@windriver.com> Sender: linux-kernel-owner@vger.kernel.org To: Paul Gortmaker Cc: JBottomley@parallels.com, linux-arm-kernel@lists.infradead.org, linux-scsi@vger.kernel.org, linux-kernel@vger.kernel.org List-Id: linux-scsi@vger.kernel.org On Wed, Nov 30, 2011 at 11:26:51PM -0500, Paul Gortmaker wrote: > The following failure is seen in routine coverage builds: >=20 > CC [M] drivers/scsi/arm/arxescsi.o > /tmp/cccEyiO7.s: Assembler messages: > /tmp/cccEyiO7.s:334: Error: symbol `.loop_1' is already defined > /tmp/cccEyiO7.s:337: Error: symbol `.loop_2' is already defined > /tmp/cccEyiO7.s:343: Error: symbol `.loop_3' is already defined > /tmp/cccEyiO7.s:365: Error: symbol `.loop_1' is already defined > /tmp/cccEyiO7.s:368: Error: symbol `.loop_2' is already defined > /tmp/cccEyiO7.s:374: Error: symbol `.loop_3' is already defined > make[4]: *** [drivers/scsi/arm/arxescsi.o] Error 1 >=20 > It is caused by multiple inline of arxescsi_pseudo_dma_write() > which is responsible for the above labels. Marking the fcn > as non-inline fixes the issue. >=20 > Signed-off-by: Paul Gortmaker Is that a compiler or a code issue? If it's the compiler please fix that. If it's the code, then please document why you added the noinline= =2E Having said that, "my" compiler compiles drivers/scsi/arm/arxescsi.o just fine (using rpc_defconfig on v3.2-rc2). > diff --git a/drivers/scsi/arm/arxescsi.c b/drivers/scsi/arm/arxescsi.= c > index a750aa7..2608a9e 100644 > --- a/drivers/scsi/arm/arxescsi.c > +++ b/drivers/scsi/arm/arxescsi.c > @@ -72,7 +72,8 @@ arxescsi_dma_setup(struct Scsi_Host *host, struct s= csi_pointer *SCp, > return fasdma_pseudo; > } > =20 > -static void arxescsi_pseudo_dma_write(unsigned char *addr, void __io= mem *base) > +static noinline void > +arxescsi_pseudo_dma_write(unsigned char *addr, void __iomem *base) Shouldn't this line get some indention? > { > __asm__ __volatile__( > " stmdb sp!, {r0-r12}\n" Best regards Uwe --=20 Pengutronix e.K. | Uwe Kleine-K=F6nig = | Industrial Linux Solutions | http://www.pengutronix.de/= |