diff mbox

Build error: versatile express

Message ID alpine.LFD.2.03.1308121125420.14472@syhkavp.arg (mailing list archive)
State New, archived
Headers show

Commit Message

Nicolas Pitre Aug. 12, 2013, 4:55 p.m. UTC
On Mon, 12 Aug 2013, Dave Martin wrote:

> On Mon, Aug 12, 2013 at 11:28:04AM +0100, Russell King - ARM Linux wrote:
> > arch/arm/mach-vexpress/tc2_pm.c: In function 'tc2_pm_down.clone.0':
> > arch/arm/mach-vexpress/tc2_pm.c:200:1: error: fp cannot be used in asm here
> > 
> > This is caused by the assembly code in this file clobbering R11, which
> > is incompatible with having CONFIG_FRAME_POINTER=y.
> 
> Is there any reason not to fix this just by pushing/popping r11 inside
> the asm and removing it from the clobber list?

That's most likely the best fix.  What about this?

---- >8

From: Nicolas Pitre <nicolas.pitre@linaro.org>
Date: Mon, 12 Aug 2013 12:47:13 -0400
Subject: [PATCH] ARM: vexpress/MCPM: fix cache disable sequence when
 CONFIG_FRAME_POINTER=y

If CONFIG_FRAME_POINTER=y we hget the following error:

arch/arm/mach-vexpress/tc2_pm.c: In function 'tc2_pm_down':
arch/arm/mach-vexpress/tc2_pm.c:200:1: error: fp cannot be used in asm here

Let's fix that by explicitly preserving r11 on the stack and removing it
from the clobber list.

Reported-by: Russell King <linux@arm.linux.org.uk>
Signed-off-by: Nicolas Pitre <nico@linaro.org>



> 
> Since there are no "m" constraints or similar, there should be no
> implicit references to fp or sp inside the asm which would be disrupted
> by that.
> 
> We could #ifdef it on CONFIG_FRAME_POINTER, but that probably just
> uglifies the code for no real benefit.
> 
> 
> FRAME_POINTER depends on !THUMB2_KERNEL, so we shouldn't hit the same
> issue with r7 in Thumb-2.
> 
> Cheers
> ---Dave
>

Comments

Russell King - ARM Linux Aug. 12, 2013, 5:06 p.m. UTC | #1
On Mon, Aug 12, 2013 at 12:55:23PM -0400, Nicolas Pitre wrote:
> On Mon, 12 Aug 2013, Dave Martin wrote:
> 
> > On Mon, Aug 12, 2013 at 11:28:04AM +0100, Russell King - ARM Linux wrote:
> > > arch/arm/mach-vexpress/tc2_pm.c: In function 'tc2_pm_down.clone.0':
> > > arch/arm/mach-vexpress/tc2_pm.c:200:1: error: fp cannot be used in asm here
> > > 
> > > This is caused by the assembly code in this file clobbering R11, which
> > > is incompatible with having CONFIG_FRAME_POINTER=y.
> > 
> > Is there any reason not to fix this just by pushing/popping r11 inside
> > the asm and removing it from the clobber list?
> 
> That's most likely the best fix.  What about this?
> 
> ---- >8
> 
> From: Nicolas Pitre <nicolas.pitre@linaro.org>
> Date: Mon, 12 Aug 2013 12:47:13 -0400
> Subject: [PATCH] ARM: vexpress/MCPM: fix cache disable sequence when
>  CONFIG_FRAME_POINTER=y
> 
> If CONFIG_FRAME_POINTER=y we hget the following error:
> 
> arch/arm/mach-vexpress/tc2_pm.c: In function 'tc2_pm_down':
> arch/arm/mach-vexpress/tc2_pm.c:200:1: error: fp cannot be used in asm here
> 
> Let's fix that by explicitly preserving r11 on the stack and removing it
> from the clobber list.
> 
> Reported-by: Russell King <linux@arm.linux.org.uk>
                             ^^^^^^^^^^^^^^^^^^^^^^
rmk+kernel@arm.linux.org.uk please
Nicolas Pitre Aug. 12, 2013, 5:11 p.m. UTC | #2
On Mon, 12 Aug 2013, Russell King - ARM Linux wrote:

> On Mon, Aug 12, 2013 at 12:55:23PM -0400, Nicolas Pitre wrote:
> > On Mon, 12 Aug 2013, Dave Martin wrote:
> > 
> > > On Mon, Aug 12, 2013 at 11:28:04AM +0100, Russell King - ARM Linux wrote:
> > > > arch/arm/mach-vexpress/tc2_pm.c: In function 'tc2_pm_down.clone.0':
> > > > arch/arm/mach-vexpress/tc2_pm.c:200:1: error: fp cannot be used in asm here
> > > > 
> > > > This is caused by the assembly code in this file clobbering R11, which
> > > > is incompatible with having CONFIG_FRAME_POINTER=y.
> > > 
> > > Is there any reason not to fix this just by pushing/popping r11 inside
> > > the asm and removing it from the clobber list?
> > 
> > That's most likely the best fix.  What about this?
> > 
> > ---- >8
> > 
> > From: Nicolas Pitre <nicolas.pitre@linaro.org>
> > Date: Mon, 12 Aug 2013 12:47:13 -0400
> > Subject: [PATCH] ARM: vexpress/MCPM: fix cache disable sequence when
> >  CONFIG_FRAME_POINTER=y
> > 
> > If CONFIG_FRAME_POINTER=y we hget the following error:
> > 
> > arch/arm/mach-vexpress/tc2_pm.c: In function 'tc2_pm_down':
> > arch/arm/mach-vexpress/tc2_pm.c:200:1: error: fp cannot be used in asm here
> > 
> > Let's fix that by explicitly preserving r11 on the stack and removing it
> > from the clobber list.
> > 
> > Reported-by: Russell King <linux@arm.linux.org.uk>
>                              ^^^^^^^^^^^^^^^^^^^^^^
> rmk+kernel@arm.linux.org.uk please

Sure.

By default I simply picked up the email address the report was sent with.


Nicolas
Dave Martin Aug. 13, 2013, 10:52 a.m. UTC | #3
On Mon, Aug 12, 2013 at 12:55:23PM -0400, Nicolas Pitre wrote:
> On Mon, 12 Aug 2013, Dave Martin wrote:
> 
> > On Mon, Aug 12, 2013 at 11:28:04AM +0100, Russell King - ARM Linux wrote:
> > > arch/arm/mach-vexpress/tc2_pm.c: In function 'tc2_pm_down.clone.0':
> > > arch/arm/mach-vexpress/tc2_pm.c:200:1: error: fp cannot be used in asm here
> > > 
> > > This is caused by the assembly code in this file clobbering R11, which
> > > is incompatible with having CONFIG_FRAME_POINTER=y.
> > 
> > Is there any reason not to fix this just by pushing/popping r11 inside
> > the asm and removing it from the clobber list?
> 
> That's most likely the best fix.  What about this?

Were we replacing these instances with the macro, or is that still in
flight?

Anyway, if useful:

Reviewed-by: Dave Martin <Dave.Martin@arm.com>

Cheers
---Dave

> 
> ---- >8
> 
> From: Nicolas Pitre <nicolas.pitre@linaro.org>
> Date: Mon, 12 Aug 2013 12:47:13 -0400
> Subject: [PATCH] ARM: vexpress/MCPM: fix cache disable sequence when
>  CONFIG_FRAME_POINTER=y
> 
> If CONFIG_FRAME_POINTER=y we hget the following error:
> 
> arch/arm/mach-vexpress/tc2_pm.c: In function 'tc2_pm_down':
> arch/arm/mach-vexpress/tc2_pm.c:200:1: error: fp cannot be used in asm here
> 
> Let's fix that by explicitly preserving r11 on the stack and removing it
> from the clobber list.
> 
> Reported-by: Russell King <linux@arm.linux.org.uk>
> Signed-off-by: Nicolas Pitre <nico@linaro.org>
> 
> diff --git a/arch/arm/mach-vexpress/dcscb.c b/arch/arm/mach-vexpress/dcscb.c
> index 85fffa702f..3a6384c6c4 100644
> --- a/arch/arm/mach-vexpress/dcscb.c
> +++ b/arch/arm/mach-vexpress/dcscb.c
> @@ -144,8 +144,13 @@ static void dcscb_power_down(void)
>  		 * Let's do it in the safest possible way i.e. with
>  		 * no memory access within the following sequence
>  		 * including to the stack.
> +		 *
> +		 * Note: fp is preserved to the stack explicitly prior doing
> +		 * this since adding it to the clobber list is incompatible
> +		 * with having CONFIG_FRAME_POINTER=y.
>  		 */
>  		asm volatile(
> +		"str	fp, [sp, #-4]! \n\t"
>  		"mrc	p15, 0, r0, c1, c0, 0	@ get CR \n\t"
>  		"bic	r0, r0, #"__stringify(CR_C)" \n\t"
>  		"mcr	p15, 0, r0, c1, c0, 0	@ set CR \n\t"
> @@ -156,9 +161,10 @@ static void dcscb_power_down(void)
>  		"bic	r0, r0, #(1 << 6)	@ disable local coherency \n\t"
>  		"mcr	p15, 0, r0, c1, c0, 1	@ set AUXCR \n\t"
>  		"isb	\n\t"
> -		"dsb	"
> +		"dsb	\n\t"
> +		"ldr	fp, [sp], #4"
>  		: : : "r0","r1","r2","r3","r4","r5","r6","r7",
> -		      "r9","r10","r11","lr","memory");
> +		      "r9","r10","lr","memory");
>  
>  		/*
>  		 * This is a harmless no-op.  On platforms with a real
> @@ -182,6 +188,7 @@ static void dcscb_power_down(void)
>  		 * Let's do it in the safest possible way as above.
>  		 */
>  		asm volatile(
> +		"str	fp, [sp, #-4]! \n\t"
>  		"mrc	p15, 0, r0, c1, c0, 0	@ get CR \n\t"
>  		"bic	r0, r0, #"__stringify(CR_C)" \n\t"
>  		"mcr	p15, 0, r0, c1, c0, 0	@ set CR \n\t"
> @@ -192,9 +199,10 @@ static void dcscb_power_down(void)
>  		"bic	r0, r0, #(1 << 6)	@ disable local coherency \n\t"
>  		"mcr	p15, 0, r0, c1, c0, 1	@ set AUXCR \n\t"
>  		"isb	\n\t"
> -		"dsb	"
> +		"dsb	\n\t"
> +		"ldr	fp, [sp], #4"
>  		: : : "r0","r1","r2","r3","r4","r5","r6","r7",
> -		      "r9","r10","r11","lr","memory");
> +		      "r9","r10","lr","memory");
>  	}
>  
>  	__mcpm_cpu_down(cpu, cluster);
> diff --git a/arch/arm/mach-vexpress/tc2_pm.c b/arch/arm/mach-vexpress/tc2_pm.c
> index dfb55d45b6..9419b1550a 100644
> --- a/arch/arm/mach-vexpress/tc2_pm.c
> +++ b/arch/arm/mach-vexpress/tc2_pm.c
> @@ -139,8 +139,13 @@ static void tc2_pm_down(u64 residency)
>  		 * Let's do it in the safest possible way i.e. with
>  		 * no memory access within the following sequence
>  		 * including the stack.
> +		 *
> +		 * Note: fp is preserved to the stack explicitly prior doing
> +		 * this since adding it to the clobber list is incompatible
> +		 * with having CONFIG_FRAME_POINTER=y.
>  		 */
>  		asm volatile(
> +		"str	fp, [sp, #-4]! \n\t"
>  		"mrc	p15, 0, r0, c1, c0, 0	@ get CR \n\t"
>  		"bic	r0, r0, #"__stringify(CR_C)" \n\t"
>  		"mcr	p15, 0, r0, c1, c0, 0	@ set CR \n\t"
> @@ -151,9 +156,10 @@ static void tc2_pm_down(u64 residency)
>  		"bic	r0, r0, #(1 << 6)	@ disable local coherency \n\t"
>  		"mcr	p15, 0, r0, c1, c0, 1	@ set AUXCR \n\t"
>  		"isb	\n\t"
> -		"dsb	"
> +		"dsb	\n\t"
> +		"ldr	fp, [sp], #4"
>  		: : : "r0","r1","r2","r3","r4","r5","r6","r7",
> -		      "r9","r10","r11","lr","memory");
> +		      "r9","r10","lr","memory");
>  
>  		cci_disable_port_by_cpu(mpidr);
>  
> @@ -174,6 +180,7 @@ static void tc2_pm_down(u64 residency)
>  		 * Let's do it in the safest possible way as above.
>  		 */
>  		asm volatile(
> +		"str	fp, [sp, #-4]! \n\t"
>  		"mrc	p15, 0, r0, c1, c0, 0	@ get CR \n\t"
>  		"bic	r0, r0, #"__stringify(CR_C)" \n\t"
>  		"mcr	p15, 0, r0, c1, c0, 0	@ set CR \n\t"
> @@ -184,9 +191,10 @@ static void tc2_pm_down(u64 residency)
>  		"bic	r0, r0, #(1 << 6)	@ disable local coherency \n\t"
>  		"mcr	p15, 0, r0, c1, c0, 1	@ set AUXCR \n\t"
>  		"isb	\n\t"
> -		"dsb	"
> +		"dsb	\n\t"
> +		"ldr	fp, [sp], #4"
>  		: : : "r0","r1","r2","r3","r4","r5","r6","r7",
> -		      "r9","r10","r11","lr","memory");
> +		      "r9","r10","lr","memory");
>  	}
>  
>  	__mcpm_cpu_down(cpu, cluster);
> 
> 
> > 
> > Since there are no "m" constraints or similar, there should be no
> > implicit references to fp or sp inside the asm which would be disrupted
> > by that.
> > 
> > We could #ifdef it on CONFIG_FRAME_POINTER, but that probably just
> > uglifies the code for no real benefit.
> > 
> > 
> > FRAME_POINTER depends on !THUMB2_KERNEL, so we shouldn't hit the same
> > issue with r7 in Thumb-2.
> > 
> > Cheers
> > ---Dave
> > 
> 
> _______________________________________________
> linux-arm-kernel mailing list
> linux-arm-kernel@lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
Nicolas Pitre Aug. 13, 2013, 3:50 p.m. UTC | #4
On Tue, 13 Aug 2013, Dave Martin wrote:

> On Mon, Aug 12, 2013 at 12:55:23PM -0400, Nicolas Pitre wrote:
> > On Mon, 12 Aug 2013, Dave Martin wrote:
> > 
> > > On Mon, Aug 12, 2013 at 11:28:04AM +0100, Russell King - ARM Linux wrote:
> > > > arch/arm/mach-vexpress/tc2_pm.c: In function 'tc2_pm_down.clone.0':
> > > > arch/arm/mach-vexpress/tc2_pm.c:200:1: error: fp cannot be used in asm here
> > > > 
> > > > This is caused by the assembly code in this file clobbering R11, which
> > > > is incompatible with having CONFIG_FRAME_POINTER=y.
> > > 
> > > Is there any reason not to fix this just by pushing/popping r11 inside
> > > the asm and removing it from the clobber list?
> > 
> > That's most likely the best fix.  What about this?
> 
> Were we replacing these instances with the macro, or is that still in
> flight?

I've updated the macro patch accordingly.  I prefer to submit that one 
separately.

> Anyway, if useful:
> 
> Reviewed-by: Dave Martin <Dave.Martin@arm.com>

Thanks.


Nicolas
Dave Martin Aug. 15, 2013, 9:58 a.m. UTC | #5
On Tue, Aug 13, 2013 at 11:50:17AM -0400, Nicolas Pitre wrote:
> On Tue, 13 Aug 2013, Dave Martin wrote:
> 
> > On Mon, Aug 12, 2013 at 12:55:23PM -0400, Nicolas Pitre wrote:
> > > On Mon, 12 Aug 2013, Dave Martin wrote:
> > > 
> > > > On Mon, Aug 12, 2013 at 11:28:04AM +0100, Russell King - ARM Linux wrote:
> > > > > arch/arm/mach-vexpress/tc2_pm.c: In function 'tc2_pm_down.clone.0':
> > > > > arch/arm/mach-vexpress/tc2_pm.c:200:1: error: fp cannot be used in asm here
> > > > > 
> > > > > This is caused by the assembly code in this file clobbering R11, which
> > > > > is incompatible with having CONFIG_FRAME_POINTER=y.
> > > > 
> > > > Is there any reason not to fix this just by pushing/popping r11 inside
> > > > the asm and removing it from the clobber list?
> > > 
> > > That's most likely the best fix.  What about this?
> > 
> > Were we replacing these instances with the macro, or is that still in
> > flight?
> 
> I've updated the macro patch accordingly.  I prefer to submit that one 
> separately.

OK, sounds good

Cheers
---Dave

> 
> > Anyway, if useful:
> > 
> > Reviewed-by: Dave Martin <Dave.Martin@arm.com>
> 
> Thanks.
> 
> 
> Nicolas
> 
> _______________________________________________
> linux-arm-kernel mailing list
> linux-arm-kernel@lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
diff mbox

Patch

diff --git a/arch/arm/mach-vexpress/dcscb.c b/arch/arm/mach-vexpress/dcscb.c
index 85fffa702f..3a6384c6c4 100644
--- a/arch/arm/mach-vexpress/dcscb.c
+++ b/arch/arm/mach-vexpress/dcscb.c
@@ -144,8 +144,13 @@  static void dcscb_power_down(void)
 		 * Let's do it in the safest possible way i.e. with
 		 * no memory access within the following sequence
 		 * including to the stack.
+		 *
+		 * Note: fp is preserved to the stack explicitly prior doing
+		 * this since adding it to the clobber list is incompatible
+		 * with having CONFIG_FRAME_POINTER=y.
 		 */
 		asm volatile(
+		"str	fp, [sp, #-4]! \n\t"
 		"mrc	p15, 0, r0, c1, c0, 0	@ get CR \n\t"
 		"bic	r0, r0, #"__stringify(CR_C)" \n\t"
 		"mcr	p15, 0, r0, c1, c0, 0	@ set CR \n\t"
@@ -156,9 +161,10 @@  static void dcscb_power_down(void)
 		"bic	r0, r0, #(1 << 6)	@ disable local coherency \n\t"
 		"mcr	p15, 0, r0, c1, c0, 1	@ set AUXCR \n\t"
 		"isb	\n\t"
-		"dsb	"
+		"dsb	\n\t"
+		"ldr	fp, [sp], #4"
 		: : : "r0","r1","r2","r3","r4","r5","r6","r7",
-		      "r9","r10","r11","lr","memory");
+		      "r9","r10","lr","memory");
 
 		/*
 		 * This is a harmless no-op.  On platforms with a real
@@ -182,6 +188,7 @@  static void dcscb_power_down(void)
 		 * Let's do it in the safest possible way as above.
 		 */
 		asm volatile(
+		"str	fp, [sp, #-4]! \n\t"
 		"mrc	p15, 0, r0, c1, c0, 0	@ get CR \n\t"
 		"bic	r0, r0, #"__stringify(CR_C)" \n\t"
 		"mcr	p15, 0, r0, c1, c0, 0	@ set CR \n\t"
@@ -192,9 +199,10 @@  static void dcscb_power_down(void)
 		"bic	r0, r0, #(1 << 6)	@ disable local coherency \n\t"
 		"mcr	p15, 0, r0, c1, c0, 1	@ set AUXCR \n\t"
 		"isb	\n\t"
-		"dsb	"
+		"dsb	\n\t"
+		"ldr	fp, [sp], #4"
 		: : : "r0","r1","r2","r3","r4","r5","r6","r7",
-		      "r9","r10","r11","lr","memory");
+		      "r9","r10","lr","memory");
 	}
 
 	__mcpm_cpu_down(cpu, cluster);
diff --git a/arch/arm/mach-vexpress/tc2_pm.c b/arch/arm/mach-vexpress/tc2_pm.c
index dfb55d45b6..9419b1550a 100644
--- a/arch/arm/mach-vexpress/tc2_pm.c
+++ b/arch/arm/mach-vexpress/tc2_pm.c
@@ -139,8 +139,13 @@  static void tc2_pm_down(u64 residency)
 		 * Let's do it in the safest possible way i.e. with
 		 * no memory access within the following sequence
 		 * including the stack.
+		 *
+		 * Note: fp is preserved to the stack explicitly prior doing
+		 * this since adding it to the clobber list is incompatible
+		 * with having CONFIG_FRAME_POINTER=y.
 		 */
 		asm volatile(
+		"str	fp, [sp, #-4]! \n\t"
 		"mrc	p15, 0, r0, c1, c0, 0	@ get CR \n\t"
 		"bic	r0, r0, #"__stringify(CR_C)" \n\t"
 		"mcr	p15, 0, r0, c1, c0, 0	@ set CR \n\t"
@@ -151,9 +156,10 @@  static void tc2_pm_down(u64 residency)
 		"bic	r0, r0, #(1 << 6)	@ disable local coherency \n\t"
 		"mcr	p15, 0, r0, c1, c0, 1	@ set AUXCR \n\t"
 		"isb	\n\t"
-		"dsb	"
+		"dsb	\n\t"
+		"ldr	fp, [sp], #4"
 		: : : "r0","r1","r2","r3","r4","r5","r6","r7",
-		      "r9","r10","r11","lr","memory");
+		      "r9","r10","lr","memory");
 
 		cci_disable_port_by_cpu(mpidr);
 
@@ -174,6 +180,7 @@  static void tc2_pm_down(u64 residency)
 		 * Let's do it in the safest possible way as above.
 		 */
 		asm volatile(
+		"str	fp, [sp, #-4]! \n\t"
 		"mrc	p15, 0, r0, c1, c0, 0	@ get CR \n\t"
 		"bic	r0, r0, #"__stringify(CR_C)" \n\t"
 		"mcr	p15, 0, r0, c1, c0, 0	@ set CR \n\t"
@@ -184,9 +191,10 @@  static void tc2_pm_down(u64 residency)
 		"bic	r0, r0, #(1 << 6)	@ disable local coherency \n\t"
 		"mcr	p15, 0, r0, c1, c0, 1	@ set AUXCR \n\t"
 		"isb	\n\t"
-		"dsb	"
+		"dsb	\n\t"
+		"ldr	fp, [sp], #4"
 		: : : "r0","r1","r2","r3","r4","r5","r6","r7",
-		      "r9","r10","r11","lr","memory");
+		      "r9","r10","lr","memory");
 	}
 
 	__mcpm_cpu_down(cpu, cluster);