patches/libelf/0.8.10/100-fix-64-bit-detection.patch
author Oron Peled <oron@actcom.co.il>
Mon Aug 03 00:49:25 2009 +0200 (2009-08-03)
branch1.4
changeset 1456 94fc77c37418
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.

Manually backported from 1449:8ad2773e7ae3
     1 diff -dur libelf-0.8.10.orig/configure libelf-0.8.10/configure
     2 --- libelf-0.8.10.orig/configure	2007-09-07 14:08:06.000000000 +0200
     3 +++ libelf-0.8.10/configure	2008-10-23 22:43:19.000000000 +0200
     4 @@ -1595,7 +1595,7 @@
     5    echo $ac_n "(cached) $ac_c" 1>&6
     6  else
     7    if test "$cross_compiling" = yes; then
     8 -  ac_cv_sizeof_long_long=0
     9 +  ac_cv_sizeof_long_long=8
    10  else
    11    cat > conftest.$ac_ext <<EOF
    12  #line 1602 "configure"
    13 diff -dur libelf-0.8.10.orig/configure.in libelf-0.8.10/configure.in
    14 --- libelf-0.8.10.orig/configure.in	2007-09-07 14:07:59.000000000 +0200
    15 +++ libelf-0.8.10/configure.in	2008-10-23 22:43:10.000000000 +0200
    16 @@ -90,7 +90,7 @@
    17  AC_CHECK_SIZEOF(short,2)
    18  AC_CHECK_SIZEOF(int,4)
    19  AC_CHECK_SIZEOF(long,4)
    20 -AC_CHECK_SIZEOF(long long,0)
    21 +AC_CHECK_SIZEOF(long long,8)
    22  # Windows port
    23  AC_CHECK_SIZEOF(__int64, 0)
    24