patches/glibc/2.3.2/gcc-pr-9552-workaround.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Tue May 08 17:48:32 2007 +0000 (2007-05-08)
changeset 78 c3868084d81a
permissions -rw-r--r--
Huge fixes to glibc build, so that we can build at least (and at last):
- use ports addon even when installing headers,
- use optimisation (-O) when installing headers, to avoid unnecessary warnings (thanks Robert P. J. DAY for pointing this out!),
- lowest kernel version to use is only X.Y.Z, not X.Y.Z.T,
- a bit of preparations for NPTL (RSN I hope),
- fix fixing the linker scripts (changing the backup file is kind of useless and stupid);

Shut uClibc finish step: there really is nothing to do;

Add a patch for glibc-2.3.6 weak aliases handling on some archs (ARM and ALPHA at least);

Did not catch the make errors: fixed the pattern matching in scripts/functions;

Introduce a new log level, ALL:
- send components' build messages there,
- DEBUG log level is destined only for crosstool-NG debug messages,
- migrate sub-actions to use appropriate log levels;

Update the armeb-unknown-linux-gnu sample:
- it builds!
- uses gcc-4.0.4 and glibc-2.3.6,
- updated to latest config options set.
yann@1
     1
See http://gcc.gnu.org/PR9552
yann@1
     2
yann@1
     3
Works around gcc error
yann@1
     4
  "soinit.c:25: internal compiler error: in named_section_flags, at varasm.c:412"
yann@1
     5
by fixing slightly incorrect code in glibc (the .eh_frame section used to
yann@1
     6
be read-write, but it's now readonly according to discussion in
yann@1
     7
http://sources.redhat.com/ml/binutils/2002-11/msg00592.html,
yann@1
     8
so it's arguably incorrect to continue to put variables in there that aren't const).
yann@1
     9
yann@1
    10
--- glibc-2.3.2/elf/soinit.c 2001-11-16 00:09:20.000000000 +0100
yann@1
    11
+++ glibc-2.3.2/elf/soinit.c   2003-08-12 09:13:34.000000000 +0200
yann@1
    12
@@ -25,7 +25,7 @@
yann@1
    13
 }
yann@1
    14
yann@1
    15
 #ifdef HAVE_DWARF2_UNWIND_INFO
yann@1
    16
-static char __EH_FRAME_BEGIN__[]
yann@1
    17
+const static char __EH_FRAME_BEGIN__[]
yann@1
    18
      __attribute__ ((section (".eh_frame")))
yann@1
    19
      = { };
yann@1
    20
 # ifdef HAVE_DWARF2_UNWIND_INFO_STATIC