patches/strace/4.5.15/130-fix-disabled-largefile-syscalls.patch
author Oron Peled <oron@actcom.co.il>
Mon Aug 03 00:49:25 2009 +0200 (2009-08-03)
changeset 1449 8ad2773e7ae3
parent 746 b150d6f590fc
permissions -rw-r--r--
[complib:mpfr] Fix building MPFR in some weird cases

The tmul test uses a compiled-in input file in $(srcdir).
The problem is that the Makefile passes it unquoted. The C code
tries to stringify it using clever macros, which may *usually* work.

In my case the source directory was named:
.../toolchain-powerpc-e500v2-linux-gnuspe-1.0-2.fc10/.../tests
And guess what? During testing I found out the program fails because
it tries to open:
.../toolchain-powerpc-e500v2-1-gnuspe-1.0-2.fc10/.../tests

Yes, CPP tokenized the macro before stringifying it and not surprisingly
the 'linux' part was converted to 1.
[on Fedora-10: cpp (GCC) 4.3.2 20081105 (Red Hat 4.3.2-7)]

So the attached patch simplify the macros and pass the path as string
from the Makefile.
     1 diff -dur strace-4.5.15.orig/syscall.c strace-4.5.15/syscall.c
     2 --- strace-4.5.15.orig/syscall.c	2007-07-14 19:21:44.000000000 +0200
     3 +++ strace-4.5.15/syscall.c	2007-07-14 19:22:49.000000000 +0200
     4 @@ -125,6 +125,18 @@
     5  #define TP TRACE_PROCESS
     6  #define TS TRACE_SIGNAL
     7  
     8 +#ifndef HAVE_STATFS64
     9 +/*
    10 + * Ugly hacks for systems that do not have LFS
    11 + */
    12 +
    13 +#define sys_truncate64  sys_truncate
    14 +#define sys_ftruncate64 sys_ftruncate
    15 +#define sys_getdents64  sys_getdents
    16 +#define sys_statfs64    sys_statfs
    17 +#define sys_fstatfs64   sys_fstatfs
    18 +#endif
    19 +
    20  static const struct sysent sysent0[] = {
    21  #include "syscallent.h"
    22  };