diff options
author | Sam James <sam@gentoo.org> | 2022-09-03 02:55:19 +0100 |
---|---|---|
committer | Sam James <sam@gentoo.org> | 2022-09-03 02:55:19 +0100 |
commit | d15a8504e74114febbbbee439493a282f4450c5c (patch) | |
tree | f1125746eb06a6414cd47e12890c95fa3e86c9b2 | |
parent | scripts/rsync-generation/update-rsync-master: zap any changes before pull (diff) | |
download | prefix-d15a8504e74114febbbbee439493a282f4450c5c.tar.gz prefix-d15a8504e74114febbbbee439493a282f4450c5c.tar.bz2 prefix-d15a8504e74114febbbbee439493a282f4450c5c.zip |
scripts/bootstrap-prefix.sh: fix for >= glibc-2.35 in stage3
slyfox explains it well in the linked bugs, but
the gist is that we mostly got lucky for a while.
We would mix system crt*.o with just-built libc_nonshared.a/libc.so
which led to issues like:
```
configure:4383: x86_64-pc-linux-gnu-gcc -O2 -pipe -O2 -pipe -L/home/share/gentoo/usr/lib64 -Wl,--dynamic-linker=/home/share/gentoo/lib64/ld-linux-x86-64.so.2 conftest.c >&5
/home/share/gentoo/tmp/usr/lib/gcc/x86_64-pc-linux-gnu/10.3.0/../../../../x86_64-pc-linux-gnu/bin/ld: /lib/../lib64/Scrt1.o: in function `_start':
(.text+0x16): undefined reference to `__libc_csu_fini'
/home/share/gentoo/tmp/usr/lib/gcc/x86_64-pc-linux-gnu/10.3.0/../../../../x86_64-pc-linux-gnu/bin/ld: (.text+0x1d): undefined reference to `__libc_csu_init'
```
We need to force GCC to use the Prefix version
of glibc we just built.
Bug: https://github.com/NixOS/nixpkgs/issues/158042
Closes: https://bugs.gentoo.org/824482
Thanks-to: Bart Oldeman <bartoldeman@gmail.com>
Thanks-to: Sergei Trofimovich <slyich@gmail.com>
Signed-off-by: Sam James <sam@gentoo.org>
-rwxr-xr-x | scripts/bootstrap-prefix.sh | 39 |
1 files changed, 8 insertions, 31 deletions
diff --git a/scripts/bootstrap-prefix.sh b/scripts/bootstrap-prefix.sh index 0635887745..4795d87ee5 100755 --- a/scripts/bootstrap-prefix.sh +++ b/scripts/bootstrap-prefix.sh @@ -503,35 +503,6 @@ bootstrap_setup() { einfo "Your profile is set to ${fullprofile}." fi - # bug #788613 avoid gcc-11 during stage 2/3 prior sync/emerge -e - is-rap && cat >> "${ROOT}"/etc/portage/make.profile/package.mask <<-EOF - # during bootstrap mask, bug #788613 - >=sys-devel/gcc-11 - EOF - - # bug #824482 avoid glibc-2.34 - if is-rap; then - if ! [ -d "${ROOT}"/etc/portage/package.mask ]; then - mkdir "${ROOT}"/etc/portage/package.mask - fi - - if ! [ -d "${ROOT}"/etc/portage/package.unmask ]; then - mkdir "${ROOT}"/etc/portage/package.unmask - fi - - cat >> "${ROOT}"/etc/portage/package.mask/glibc <<-EOF - # Temporary mask for newer glibc until bootstrapping issues are fixed. - # bug #824482: Avoid glibc-2.34 for now. See package.unmask/glibc too. - >=sys-libs/glibc-2.34 - EOF - - cat >> "${ROOT}"/etc/portage/package.unmask/glibc <<-EOF - # Temporary mask for newer glibc until bootstrapping issues are fixed. - # bug #824482: Avoid glibc-2.34 for now. See package.mask/glibc too. - >=sys-libs/glibc-2.34_p1 - EOF - fi - # Use package.use to disable in the portage tree to be shared between # stage2 and stage3. The hack will be undone during tree sync in stage3. cat >> "${ROOT}"/etc/portage/make.profile/package.use <<-EOF @@ -2131,8 +2102,14 @@ bootstrap_stage3() { ${linker} ) # use the new dynamic linker in place of rpath from now on. - RAP_DLINKER=$(echo "${ROOT}"/$(get_libdir)/ld*.so.[0-9]) + RAP_DLINKER=$(echo "${ROOT}"/$(get_libdir)/ld*.so.[0-9] | sed s"!${ROOT}/$(get_libdir)/ld-lsb.*!!") export LDFLAGS="-L${ROOT}/usr/$(get_libdir) -Wl,--dynamic-linker=${RAP_DLINKER}" + if [[ ${compiler_type} == gcc ]] ; then + # make sure these flags are used even in places that ignore/strip CPPFLAGS/LDFLAGS + export LDFLAGS="-B${ROOT}/usr/$(get_libdir) ${LDFLAGS}" + export CC="gcc ${CPPFLAGS} ${LDFLAGS}" + export CXX="g++ ${CPPFLAGS} ${LDFLAGS}" + fi BOOTSTRAP_RAP=yes \ pre_emerge_pkgs --nodeps "${pkgs[@]}" || return 1 @@ -2189,7 +2166,7 @@ bootstrap_stage3() { # Undo libgcc_s.so path of stage2 # Now we have the compiler right there - unset CXX CPPFLAGS LDFLAGS + unset CC CXX CPPFLAGS LDFLAGS rm -f "${ROOT}"/etc/ld.so.conf.d/stage2.conf |