patches/glibc/2.12.2/900-march-i686.patch
author Anthony Foiani <anthony.foiani@gmail.com>
Thu May 19 23:09:43 2011 +0200 (2011-05-19)
branch1.11
changeset 2465 5f98b7a90fbc
permissions -rw-r--r--
complibs/ppl: fix 0.11-0.11.2 to compile with --disable-shared

PPL 0.11 (through 0.11.2) had a small bug where it still tried to build
and test its Java interface even when shared libraries are disabled.
Since that's exactly what ct-ng does, it explodes.

This is the patch from the PPL authors (see final link below).

More information can be found in these messages/threads:

Anthony's initial report and analysis with Yann:
http://www.cygwin.com/ml/crossgcc/2011-05/msg00046.html

Ron Flory hit the same problem:
http://www.cygwin.com/ml/crossgcc/2011-05/msg00054.html

Anthony's report to the ppl-devel list:
http://www.cs.unipr.it/pipermail/ppl-devel/2011-May/017450.html

Roberto's reply with a link to the fix in the PPL git repo:
http://www.cs.unipr.it/pipermail/ppl-devel/2011-May/017455.html

Signed-Off-By: Anthony Foiani <anthony.foiani@gmail.com>
(transplanted from 139b85d70b623e51f7585e7c64ecb8c6a6cf4567)
eha@2378
     1
2007-02-15  Khem Raj  <kraj@xxxxxxxxxx>
eha@2378
     2
eha@2378
     3
       * sysdeps/unix/sysv/linux/i386/sysdep.h: Re-define __i686.
eha@2378
     4
       * nptl/sysdeps/pthread/pt-initfini.c: Ditto.
eha@2378
     5
eha@2378
     6
diff -urN glibc-2.12.2.orig/nptl/sysdeps/pthread/pt-initfini.c glibc-2.12.2/nptl/sysdeps/pthread/pt-initfini.c
eha@2378
     7
--- glibc-2.12.2.orig/nptl/sysdeps/pthread/pt-initfini.c	2009-10-30 18:17:08.000000000 +0100
eha@2378
     8
+++ glibc-2.12.2/nptl/sysdeps/pthread/pt-initfini.c	2010-12-30 11:36:19.858708534 +0100
eha@2378
     9
@@ -45,6 +45,11 @@
eha@2378
    10
 /* Embed an #include to pull in the alignment and .end directives. */
eha@2378
    11
 asm ("\n#include \"defs.h\"");
eha@2378
    12
 
eha@2378
    13
+asm ("\n#if defined __i686 && defined __ASSEMBLER__");
eha@2378
    14
+asm ("\n#undef __i686");
eha@2378
    15
+asm ("\n#define __i686 __i686");
eha@2378
    16
+asm ("\n#endif");
eha@2378
    17
+
eha@2378
    18
 /* The initial common code ends here. */
eha@2378
    19
 asm ("\n/*@HEADER_ENDS*/");
eha@2378
    20
 
eha@2378
    21
diff -urN glibc-2.12.2.orig/sysdeps/unix/sysv/linux/i386/sysdep.h glibc-2.12.2/sysdeps/unix/sysv/linux/i386/sysdep.h
eha@2378
    22
--- glibc-2.12.2.orig/sysdeps/unix/sysv/linux/i386/sysdep.h	2009-10-30 18:17:08.000000000 +0100
eha@2378
    23
+++ glibc-2.12.2/sysdeps/unix/sysv/linux/i386/sysdep.h	2010-12-30 11:36:19.858708534 +0100
eha@2378
    24
@@ -29,6 +29,10 @@
eha@2378
    25
 #include <dl-sysdep.h>
eha@2378
    26
 #include <tls.h>
eha@2378
    27
 
eha@2378
    28
+#if defined __i686 && defined __ASSEMBLER__
eha@2378
    29
+#undef __i686
eha@2378
    30
+#define __i686 __i686
eha@2378
    31
+#endif
eha@2378
    32
 
eha@2378
    33
 /* For Linux we can use the system call table in the header file
eha@2378
    34
 	/usr/include/asm/unistd.h