patches/strace/4.5.16/120-fix-arm-bad-syscall.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Thu Feb 17 21:54:07 2011 +0100 (2011-02-17)
changeset 2301 a3818c3b03e0
parent 746 b150d6f590fc
permissions -rw-r--r--
internals: fix stripping host binaries

The gcc used by linaro has a version number specific to Linaro, but
identifies itself with its upstream version numbering scheme.

This breaks the strip in the finish step, because the actual gcc version
is not the same as the configured one (eg. 4.5.2 vs. linaro-4.5-2011.02-0).

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
     1 diff -dur strace-4.5.16.orig/syscall.c strace-4.5.16/syscall.c
     2 --- strace-4.5.16.orig/syscall.c	2006-12-21 23:13:33.000000000 +0100
     3 +++ strace-4.5.16/syscall.c	2007-07-14 19:21:44.000000000 +0200
     4 @@ -1045,6 +1045,15 @@
     5  		/*
     6  		 * Note: we only deal with only 32-bit CPUs here.
     7  		 */
     8 +
     9 +		if (!(tcp->flags & TCB_INSYSCALL) &&
    10 +		    (tcp->flags & TCB_WAITEXECVE)) {
    11 +			/* caught a fake syscall from the execve's exit */
    12 +			tcp->flags &= ~TCB_WAITEXECVE;
    13 +			return 0;
    14 +		}
    15 +
    16 +
    17  		if (regs.ARM_cpsr & 0x20) {
    18  			/*
    19  			 * Get the Thumb-mode system call number