patches/glibc/2.7/120-fix-pr631.patch
author "Yann E. MORIN" <yann.morin.1998@free.fr>
Tue Oct 16 20:57:44 2012 +0200 (2012-10-16)
changeset 3079 37831a33e07e
parent 744 4bf8448536d5
permissions -rw-r--r--
kernel/linux: fix using custom location

Currently, extract and patch are skipped as thus:
- using a custom directory of pre-installed headers
- a correctly named directory already exists

Otherwise, extract and patch are done.

The current second condition is wrong, because it allows the following
sequence to happen:
- a non-custom kernel is used
- a previous build only partially extracted the non-custom sources
- that p[revious build broke during extraction (eg. incomplete tarball...)
- a subsequent build will find a properly named directory, and will
thus skip extract and patch, which is wrong

Fix that by following the conditions in this table:

Type | Extract | Patch
----------------------+---------+-------
Pre-installed headers | N | N
custom directory | N | N
custom tarball | Y | N
mainstream tarball | Y | Y

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@free.fr>
Cc: David Holsgrove <david.holsgrove@xilinx.com>
yann@434
     1
From dank@kegel.com
yann@434
     2
Wed Jun 15 09:12:43 PDT 2005
yann@434
     3
yann@434
     4
Fixes
yann@434
     5
yann@434
     6
build-glibc/libc.a(nsswitch.o)(.data+0x64): undefined reference to `_nss_files_getaliasent_r'
yann@434
     7
build-glibc/libc.a(nsswitch.o)(.data+0x6c): undefined reference to `_nss_files_endaliasent'
yann@434
     8
... 53 lines deleted ...
yann@434
     9
build-glibc/libc.a(nsswitch.o)(.data+0x21c): undefined reference to `_nss_files_getspnam_r'
yann@434
    10
collect2: ld returned 1 exit status
yann@434
    11
make[2]: *** [/build/gcc-3.4.3-glibc-2.3.5-hdrs-2.6.11.2/i686-unknown-linux-gnu/build-glibc/elf/ldconfig] Error 1
yann@434
    12
yann@434
    13
when building glibc with --enable-static-nss.
yann@434
    14
yann@434
    15
See http://sources.redhat.com/bugzilla/show_bug.cgi?id=631
yann@434
    16
yann@434
    17
--- glibc-2.3.5/Makeconfig.old	Wed Jun 15 08:13:12 2005
yann@434
    18
+++ glibc-2.3.5/Makeconfig	Wed Jun 15 08:13:14 2005
yann@434
    19
@@ -508,7 +508,7 @@
yann@434
    20
yann@434
    21
 # The static libraries.
yann@434
    22
 ifeq (yes,$(build-static))
yann@434
    23
-link-libc-static = $(common-objpfx)libc.a $(static-gnulib) $(common-objpfx)libc.a
yann@434
    24
+link-libc-static = $(common-objpfx)libc.a $(static-gnulib) $(otherlibs) $(common-objpfx)libc.a
yann@434
    25
 else
yann@434
    26
 ifeq (yes,$(build-shared))
yann@434
    27
 # We can try to link the programs with lib*_pic.a...
yann@434
    28
--- glibc-2.3.5/elf/Makefile.old	Wed Jun 15 07:46:49 2005
yann@434
    29
+++ glibc-2.3.5/elf/Makefile	Wed Jun 15 08:14:00 2005
yann@434
    30
@@ -120,6 +120,13 @@
yann@434
    31
 install-bin-script = ldd
yann@434
    32
 endif
yann@434
    33
yann@434
    34
+ifeq (yes,$(build-static-nss))
yann@434
    35
+nssobjdir := $(patsubst ../$(subdir),.,$(common-objpfx)nss)
yann@434
    36
+resolvobjdir := $(patsubst ../$(subdir),.,$(common-objpfx)resolv)
yann@434
    37
+otherlibs += $(nssobjdir)/libnss_files.a $(resolvobjdir)/libnss_dns.a \
yann@434
    38
+	     $(resolvobjdir)/libresolv.a
yann@434
    39
+endif
yann@434
    40
+
yann@434
    41
 others		= sprof sln
yann@434
    42
 install-bin	= sprof
yann@434
    43
 others-static   = sln