Linux MIPS Architecture development
 help / color / mirror / Atom feed
* Strace doesn't work on linux-2.4.28 and later
@ 2005-02-01 13:43 andreev
  2005-02-07 19:28 ` David Daney
  0 siblings, 1 reply; 6+ messages in thread
From: andreev @ 2005-02-01 13:43 UTC (permalink / raw)
  To: linux-mips

Hi, list.

We are using the latest kernel from mips-linux CVS and there is a 
problem with ptrace.

When syscall with 5 or more arguments are traced, the fifth argument of 
the syscall is overwritten
by tracing code. This error causes problems with strace. For example, 
you can't trace dynamically linked
applications, because ld.so calls mmap which has 6 arguments.

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Strace doesn't work on linux-2.4.28 and later
  2005-02-01 13:43 Strace doesn't work on linux-2.4.28 and later andreev
@ 2005-02-07 19:28 ` David Daney
  2005-02-07 19:39   ` David Daney
  0 siblings, 1 reply; 6+ messages in thread
From: David Daney @ 2005-02-07 19:28 UTC (permalink / raw)
  To: andreev, Ralf Baechle; +Cc: linux-mips

andreev wrote:
> Hi, list.
> 
> We are using the latest kernel from mips-linux CVS and there is a 
> problem with ptrace.
> 
> When syscall with 5 or more arguments are traced, the fifth argument of 
> the syscall is overwritten
> by tracing code. This error causes problems with strace. For example, 
> you can't trace dynamically linked
> applications, because ld.so calls mmap which has 6 arguments.
> 

This patch broke it:

http://www.linux-mips.org/archives/linux-cvs/2004-11/msg00116.html

RCS file: /home/cvs/linux/arch/mips/kernel/Attic/scall_o32.S,v
retrieving revision 1.18.2.13
retrieving revision 1.18.2.14
diff -u -p -r1.18.2.13 -r1.18.2.14
--- linux/arch/mips/kernel/Attic/scall_o32.S	2004/04/26 15:06:02	1.18.2.13
+++ linux/arch/mips/kernel/Attic/scall_o32.S	2004/11/25 09:43:59	1.18.2.14
@@ -121,9 +121,9 @@ reschedule:

  trace_a_syscall:
  	SAVE_STATIC
-	sw	t2, PT_R1(sp)
+	sw	t2, PT_SCRATCH0(sp)
  	jal	syscall_trace
-	lw	t2, PT_R1(sp)
+	lw	t2, PT_SCRATCH0(sp)

  	lw	a0, PT_R4(sp)		# Restore argument registers
  	lw	a1, PT_R5(sp)

PT_SCRATCH0(sp) = 16(sp) which is where arg5 is stored.  This overwrites it.

In arch/mips/tools/offset.c we have:

	offset("#define PT_SCRATCH0 ", struct pt_regs, pad0[4]);
	offset("#define PT_SCRATCH1 ", struct pt_regs, pad0[5]);

I am thinking of testing a patch where I change them to:

	offset("#define PT_SCRATCH0 ", struct pt_regs, pad0[0]);
	offset("#define PT_SCRATCH1 ", struct pt_regs, pad0[1]);

Any needed argument registers are already saved in and restored from the 
regs array so overwriting the stack area reserved for them should be OK.

David Daney

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Strace doesn't work on linux-2.4.28 and later
  2005-02-07 19:28 ` David Daney
@ 2005-02-07 19:39   ` David Daney
  2005-02-07 21:08     ` Ralf Baechle
  0 siblings, 1 reply; 6+ messages in thread
From: David Daney @ 2005-02-07 19:39 UTC (permalink / raw)
  To: David Daney; +Cc: andreev, Ralf Baechle, linux-mips

David Daney wrote:
> andreev wrote:
> 
>> Hi, list.
>>
>> We are using the latest kernel from mips-linux CVS and there is a 
>> problem with ptrace.
>>
>> When syscall with 5 or more arguments are traced, the fifth argument 
>> of the syscall is overwritten
>> by tracing code. This error causes problems with strace. For example, 
>> you can't trace dynamically linked
>> applications, because ld.so calls mmap which has 6 arguments.
>>
> 
> This patch broke it:
> 
> http://www.linux-mips.org/archives/linux-cvs/2004-11/msg00116.html
> 
> RCS file: /home/cvs/linux/arch/mips/kernel/Attic/scall_o32.S,v
> retrieving revision 1.18.2.13
> retrieving revision 1.18.2.14
> diff -u -p -r1.18.2.13 -r1.18.2.14
> --- linux/arch/mips/kernel/Attic/scall_o32.S    2004/04/26 15:06:02    
> 1.18.2.13
> +++ linux/arch/mips/kernel/Attic/scall_o32.S    2004/11/25 09:43:59    
> 1.18.2.14
> @@ -121,9 +121,9 @@ reschedule:
> 
>  trace_a_syscall:
>      SAVE_STATIC
> -    sw    t2, PT_R1(sp)
> +    sw    t2, PT_SCRATCH0(sp)
>      jal    syscall_trace
> -    lw    t2, PT_R1(sp)
> +    lw    t2, PT_SCRATCH0(sp)
> 
>      lw    a0, PT_R4(sp)        # Restore argument registers
>      lw    a1, PT_R5(sp)
> 
> PT_SCRATCH0(sp) = 16(sp) which is where arg5 is stored.  This overwrites 
> it.
> 
> In arch/mips/tools/offset.c we have:
> 
>     offset("#define PT_SCRATCH0 ", struct pt_regs, pad0[4]);
>     offset("#define PT_SCRATCH1 ", struct pt_regs, pad0[5]);
> 
> I am thinking of testing a patch where I change them to:
> 
>     offset("#define PT_SCRATCH0 ", struct pt_regs, pad0[0]);
>     offset("#define PT_SCRATCH1 ", struct pt_regs, pad0[1]);
> 
> Any needed argument registers are already saved in and restored from the 
> regs array so overwriting the stack area reserved for them should be OK.
> 
I now think that is bogus reasoning as the first four slots can be 
clobbered by the compiler.

It seems that t2 must be saved somewhere in the regs list.  I am not 
sure what the problem with PT_R1(sp) was, but it seems like a good 
candidate.  Perhaps PT_R26 or PT_R27 (k0, k1) would be a better place to 
store t2 as I don't think k0 or k1 are ever stored.

David Daney.

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Strace doesn't work on linux-2.4.28 and later
  2005-02-07 19:39   ` David Daney
@ 2005-02-07 21:08     ` Ralf Baechle
  2005-02-07 21:20       ` David Daney
  0 siblings, 1 reply; 6+ messages in thread
From: Ralf Baechle @ 2005-02-07 21:08 UTC (permalink / raw)
  To: David Daney; +Cc: andreev, linux-mips

On Mon, Feb 07, 2005 at 11:39:12AM -0800, David Daney wrote:

> >    offset("#define PT_SCRATCH0 ", struct pt_regs, pad0[4]);
> >    offset("#define PT_SCRATCH1 ", struct pt_regs, pad0[5]);
> >
> >I am thinking of testing a patch where I change them to:
> >
> >    offset("#define PT_SCRATCH0 ", struct pt_regs, pad0[0]);
> >    offset("#define PT_SCRATCH1 ", struct pt_regs, pad0[1]);
> >
> >Any needed argument registers are already saved in and restored from the 
> >regs array so overwriting the stack area reserved for them should be OK.
> >
> I now think that is bogus reasoning as the first four slots can be 
> clobbered by the compiler.
> 
> It seems that t2 must be saved somewhere in the regs list.  I am not 
> sure what the problem with PT_R1(sp) was, but it seems like a good 
> candidate.  Perhaps PT_R26 or PT_R27 (k0, k1) would be a better place to 
> store t2 as I don't think k0 or k1 are ever stored.

I was always planning to backport the newer fix from 2.6 which is simply
storing the value in a caller saved register.  You now reminded me of
that omission ;-)

Patch below,

  Ralf

Index: arch/mips/kernel/scall_o32.S
===================================================================
RCS file: /home/cvs/linux/arch/mips/kernel/Attic/scall_o32.S,v
retrieving revision 1.18.2.14
diff -u -r1.18.2.14 scall_o32.S
--- arch/mips/kernel/scall_o32.S	25 Nov 2004 09:43:59 -0000	1.18.2.14
+++ arch/mips/kernel/scall_o32.S	7 Feb 2005 21:12:53 -0000
@@ -121,15 +121,14 @@
 
 trace_a_syscall:
 	SAVE_STATIC
-	sw	t2, PT_SCRATCH0(sp)
+	move	s0, sp
 	jal	syscall_trace
-	lw	t2, PT_SCRATCH0(sp)
 
 	lw	a0, PT_R4(sp)		# Restore argument registers
 	lw	a1, PT_R5(sp)
 	lw	a2, PT_R6(sp)
 	lw	a3, PT_R7(sp)
-	jalr	t2
+	jalr	s0
 
 	li	t0, -EMAXERRNO - 1	# error?
 	sltu	t0, t0, v0
Index: arch/mips/tools/offset.c
===================================================================
RCS file: /home/cvs/linux/arch/mips/tools/Attic/offset.c,v
retrieving revision 1.16.4.12
diff -u -r1.16.4.12 offset.c
--- arch/mips/tools/offset.c	25 Nov 2004 09:43:59 -0000	1.16.4.12
+++ arch/mips/tools/offset.c	7 Feb 2005 21:12:53 -0000
@@ -12,7 +12,6 @@
 #include <linux/types.h>
 #include <linux/sched.h>
 #include <linux/mm.h>
-#include <linux/signal.h>
 
 #include <asm/ptrace.h>
 #include <asm/processor.h>
@@ -37,9 +36,6 @@
 void output_ptreg_defines(void)
 {
 	text("/* MIPS pt_regs offsets. */");
-	offset("#define PT_SCRATCH0 ", struct pt_regs, pad0[4]);
-	offset("#define PT_SCRATCH1 ", struct pt_regs, pad0[5]);
-
 	offset("#define PT_R0     ", struct pt_regs, regs[0]);
 	offset("#define PT_R1     ", struct pt_regs, regs[1]);
 	offset("#define PT_R2     ", struct pt_regs, regs[2]);
Index: arch/mips64/kernel/scall_64.S
===================================================================
RCS file: /home/cvs/linux/arch/mips64/kernel/Attic/scall_64.S,v
retrieving revision 1.20.2.20
diff -u -r1.20.2.20 scall_64.S
--- arch/mips64/kernel/scall_64.S	25 Nov 2004 09:43:59 -0000	1.20.2.20
+++ arch/mips64/kernel/scall_64.S	7 Feb 2005 21:12:53 -0000
@@ -102,15 +102,14 @@
 
 trace_a_syscall:
 	SAVE_STATIC
-	sd	t2, PT_SCRATCH0(sp)
+	move	s0, t2
 	jal	syscall_trace
-	ld	t2, PT_SCRATCH0(sp)
 
 	ld	a0, PT_R4(sp)		# Restore argument registers
 	ld	a1, PT_R5(sp)
 	ld	a2, PT_R6(sp)
 	ld	a3, PT_R7(sp)
-	jalr	t2
+	jalr	s0
 
 	li	t0, -EMAXERRNO - 1	# error?
 	sltu	t0, t0, v0
Index: arch/mips64/kernel/scall_n32.S
===================================================================
RCS file: /home/cvs/linux/arch/mips64/kernel/Attic/scall_n32.S,v
retrieving revision 1.2.2.17
diff -u -r1.2.2.17 scall_n32.S
--- arch/mips64/kernel/scall_n32.S	25 Nov 2004 09:43:59 -0000	1.2.2.17
+++ arch/mips64/kernel/scall_n32.S	7 Feb 2005 21:12:53 -0000
@@ -106,15 +106,14 @@
 
 trace_a_syscall:
 	SAVE_STATIC
-	sd	t2, PT_SCRATCH0(sp)
+	move	s0, t2
 	jal	syscall_trace
-	ld	t2, PT_SCRATCH0(sp)
 
 	ld	a0, PT_R4(sp)		# Restore argument registers
 	ld	a1, PT_R5(sp)
 	ld	a2, PT_R6(sp)
 	ld	a3, PT_R7(sp)
-	jalr	t2
+	jalr	s0
 
 	li	t0, -EMAXERRNO - 1	# error?
 	sltu	t0, t0, v0
Index: arch/mips64/kernel/scall_o32.S
===================================================================
RCS file: /home/cvs/linux/arch/mips64/kernel/Attic/scall_o32.S,v
retrieving revision 1.48.2.33
diff -u -r1.48.2.33 scall_o32.S
--- arch/mips64/kernel/scall_o32.S	25 Nov 2004 09:43:59 -0000	1.48.2.33
+++ arch/mips64/kernel/scall_o32.S	7 Feb 2005 21:12:53 -0000
@@ -118,9 +118,8 @@
 	sd	a6, PT_R10(sp)
 	sd	a7, PT_R11(sp)
 
-	sd	t2, PT_SCRATCH0(sp)
+	move	s0, t2
 	jal	syscall_trace
-	ld	t2, PT_SCRATCH0(sp)
 
 	ld	a0, PT_R4(sp)		# Restore argument registers
 	ld	a1, PT_R5(sp)
@@ -129,7 +128,7 @@
 	ld	a4, PT_R8(sp)
 	ld	a5, PT_R9(sp)
 
-	jalr	t2
+	jalr	s0
 
 	li	t0, -EMAXERRNO - 1	# error?
 	sltu	t0, t0, v0

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Strace doesn't work on linux-2.4.28 and later
  2005-02-07 21:20       ` David Daney
@ 2005-02-07 21:17         ` Ralf Baechle
  0 siblings, 0 replies; 6+ messages in thread
From: Ralf Baechle @ 2005-02-07 21:17 UTC (permalink / raw)
  To: David Daney; +Cc: andreev, linux-mips

On Mon, Feb 07, 2005 at 01:20:49PM -0800, David Daney wrote:

> >@@ -121,15 +121,14 @@
> > 
> > trace_a_syscall:
> > 	SAVE_STATIC
> >-	sw	t2, PT_SCRATCH0(sp)
> >+	move	s0, sp
>          ^^^^^^^^^^^^^
> I think this should be "move s0, t2" as in scall_64.S et al.

It should and what I've actually commited in CVS doesn't have this bug.

  Ralf

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Strace doesn't work on linux-2.4.28 and later
  2005-02-07 21:08     ` Ralf Baechle
@ 2005-02-07 21:20       ` David Daney
  2005-02-07 21:17         ` Ralf Baechle
  0 siblings, 1 reply; 6+ messages in thread
From: David Daney @ 2005-02-07 21:20 UTC (permalink / raw)
  To: Ralf Baechle; +Cc: andreev, linux-mips

Ralf Baechle wrote:
> Index: arch/mips/kernel/scall_o32.S
> ===================================================================
> RCS file: /home/cvs/linux/arch/mips/kernel/Attic/scall_o32.S,v
> retrieving revision 1.18.2.14
> diff -u -r1.18.2.14 scall_o32.S
> --- arch/mips/kernel/scall_o32.S	25 Nov 2004 09:43:59 -0000	1.18.2.14
> +++ arch/mips/kernel/scall_o32.S	7 Feb 2005 21:12:53 -0000
> @@ -121,15 +121,14 @@
>  
>  trace_a_syscall:
>  	SAVE_STATIC
> -	sw	t2, PT_SCRATCH0(sp)
> +	move	s0, sp
          ^^^^^^^^^^^^^
I think this should be "move s0, t2" as in scall_64.S et al.

David Daney.

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2005-02-07 21:22 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2005-02-01 13:43 Strace doesn't work on linux-2.4.28 and later andreev
2005-02-07 19:28 ` David Daney
2005-02-07 19:39   ` David Daney
2005-02-07 21:08     ` Ralf Baechle
2005-02-07 21:20       ` David Daney
2005-02-07 21:17         ` Ralf Baechle

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox