diff options
author | Peter Jung | 2023-02-12 13:40:18 +0100 |
---|---|---|
committer | Peter Jung | 2023-02-12 13:40:18 +0100 |
commit | b04c29371b602f266b82cff20e89078549aae742 (patch) | |
tree | e25403b075b14f91ac5498e925168077e8c0f05c /PKGBUILD | |
parent | 7eac2386794b0f6689acbaac5c0c5ae5c9d7a91c (diff) | |
download | aur-b04c29371b602f266b82cff20e89078549aae742.tar.gz |
Cleanup && Sync with archlinux
Signed-off-by: Peter Jung <admin@ptr1337.dev>
Diffstat (limited to 'PKGBUILD')
-rw-r--r-- | PKGBUILD | 228 |
1 files changed, 80 insertions, 148 deletions
@@ -1,3 +1,4 @@ +# Maintainer: Peter Jung ptr1337 <admin@ptr1337.dev> # Maintainer: Niko Cantero <vextium at gmail dot com> # Contributor: Eli Schwartz <eschwartz@archlinux.org> # Contributor: Earnestly <zibeon@googlemail.com> @@ -8,92 +9,67 @@ # Contributor: Dakkshesh <dakkshesh5 at gmail dot com> # Contributor: Cyber Knight <cyberknight755 at gmail dot com> -# toolchain build order: linux-api-headers->glibc(-git)->binutils->gcc->glibc(-git)->binutils->gcc +# toolchain build order: linux-api-headers->glibc->binutils->gcc->glibc->binutils->gcc # NOTE: valgrind requires rebuilt with each major glibc version -_pkgname='glibc' -_kernelver='5.18.15' -pkgbase="${_pkgname}"-git -pkgname=("${_pkgname}"-git lib32-"${_pkgname}"-git) -pkgver=2.36.r206.gba0ca36132 +pkgbase=glibc-git +pkgname=(glibc-git lib32-glibc-git) +pkgver=2.37.r63.ge42ec82219 pkgrel=1 -arch=('x86_64') -url='https://www.gnu.org/software/libc/' -license=('GPL' 'LGPL') -groups=('base-git') -makedepends=('git' 'gd' 'lib32-gcc-libs' 'python') -options=('staticlibs') -source=('git+https://sourceware.org/git/glibc.git' - 'locale.gen.txt' - 'locale-gen' - 'lib32-glibc.conf' - 'sdt.h' - 'sdt-config.h') +arch=(x86_64) +url='https://www.gnu.org/software/libc' +license=(GPL LGPL) +makedepends=(git gd lib32-gcc-libs python) +options=(staticlibs !lto) +source=(git+https://sourceware.org/git/glibc.git + locale.gen.txt + locale-gen + lib32-glibc.conf + sdt.h sdt-config.h + reenable_DT_HASH.patch +) b2sums=('SKIP' - 'c859bf2dfd361754c9e3bbd89f10de31f8e81fd95dc67b77d10cb44e23834b096ba3caa65fbc1bd655a8696c6450dfd5a096c476b3abf5c7e125123f97ae1a72' - '04fbb3b0b28705f41ccc6c15ed5532faf0105370f22133a2b49867e790df0491f5a1255220ff6ebab91a462f088d0cf299491b3eb8ea53534cb8638a213e46e3' - '7c265e6d36a5c0dff127093580827d15519b6c7205c2e1300e82f0fb5b9dd00b6accb40c56581f18179c4fbbc95bd2bf1b900ace867a83accde0969f7b609f8a' - 'a6a5e2f2a627cc0d13d11a82458cfd0aa75ec1c5a3c7647e5d5a3bb1d4c0770887a3909bfda1236803d5bc9801bfd6251e13483e9adf797e4725332cd0d91a0e' - '214e995e84b342fe7b2a7704ce011b7c7fc74c2971f98eeb3b4e677b99c860addc0a7d91b8dc0f0b8be7537782ee331999e02ba48f4ccc1c331b60f27d715678') + 'c859bf2dfd361754c9e3bbd89f10de31f8e81fd95dc67b77d10cb44e23834b096ba3caa65fbc1bd655a8696c6450dfd5a096c476b3abf5c7e125123f97ae1a72' + '04fbb3b0b28705f41ccc6c15ed5532faf0105370f22133a2b49867e790df0491f5a1255220ff6ebab91a462f088d0cf299491b3eb8ea53534cb8638a213e46e3' + '7c265e6d36a5c0dff127093580827d15519b6c7205c2e1300e82f0fb5b9dd00b6accb40c56581f18179c4fbbc95bd2bf1b900ace867a83accde0969f7b609f8a' + 'a6a5e2f2a627cc0d13d11a82458cfd0aa75ec1c5a3c7647e5d5a3bb1d4c0770887a3909bfda1236803d5bc9801bfd6251e13483e9adf797e4725332cd0d91a0e' + '214e995e84b342fe7b2a7704ce011b7c7fc74c2971f98eeb3b4e677b99c860addc0a7d91b8dc0f0b8be7537782ee331999e02ba48f4ccc1c331b60f27d715678' + '5fdd133c367af2f5454ea1eea7907de12166fb95eb59dbe33eae16aa9e26209b6585972bc1c80e36a0af4bfb04296acaf940ee78cd624cdcbab9669dff46c051') + +pkgver() { + cd glibc + # Removes .9000 tag from glibc pkgver. + git describe --exclude '*.*.9000' | sed 's/^glibc-//; s/-/.r/; s/-/./' +} prepare() { mkdir -p glibc-build lib32-glibc-build [[ -d glibc-$pkgver ]] && ln -s glibc-$pkgver glibc cd glibc -} -pkgver() { - cd glibc - # Removes .9000 tag from glibc pkgver. - git describe --exclude '*.*.9000' | sed 's/^glibc-//; s/-/.r/; s/-/./' + # Re-enable `--hash-style=both` for building shared objects due to issues with EPIC's EAC + # which relies on DT_HASH to be present in these libs. + # reconsider 2023-01 + patch -Np1 -i "${srcdir}"/reenable_DT_HASH.patch } build() { - local _configure_flags=( - --prefix=/usr - --with-headers=/usr/include - --with-bugurl=https://bugs.archlinux.org/ - --enable-memory-tagging - --enable-bind-now - --enable-cet - --enable-kernel="${_kernelver}" - --enable-multi-arch - --enable-stack-protector=strong - --enable-systemtap - --disable-crypt - --disable-profile - --disable-werror + local _configure_flags=( + --prefix=/usr + --with-headers=/usr/include + --with-bugurl=https://bugs.archlinux.org/ + --enable-bind-now + --enable-cet + --enable-kernel=5.15 + --enable-multi-arch + --enable-stack-protector=strong + --enable-systemtap + --disable-crypt + --disable-profile + --disable-werror ) - unset_flags() { - unset CFLAGS - unset CXXFLAGS - } - - configparms_fortify_source() { - echo "CFLAGS += -Wp,-D_FORTIFY_SOURCE=2" >> configparms - } - - configparms_enable_programs() { - sed -i "/build-programs=/s#no#yes#" configparms - } - - configparms_disable_programs() { - echo "build-programs=no" >> configparms - } - - make_build_64 () { - make -O CFLAGS="$MAKE_FLAGS_64_FULL" CXXFLAGS="$MAKE_FLAGS_64_FULL" -j$(nproc --all) - } - - make_build_32 () { - make -O CFLAGS="$MAKE_FLAGS_32_FULL" CXXFLAGS="$MAKE_FLAGS_32_FULL" -j$(nproc --all) - } - - MAKE_FLAGS_64="-O2 -pipe" - MAKE_FLAGS_32="-mno-tls-direct-seg-refs -O2 -pipe" - cd "${srcdir}"/glibc-build echo "slibdir=/usr/lib" >> configparms @@ -101,30 +77,27 @@ build() { echo "sbindir=/usr/bin" >> configparms echo "rootsbindir=/usr/bin" >> configparms - # Credits @dakkshesh07 & @cyberknight777 - # https://github.com/Neutron-Toolchains/glibc-pkgbuild/blob/main/PKGBUILD - # remove fortify for building libraries & configure glibc (64-bit) to point at lib directories - unset_flags + # Credits @allanmcrae + # https://github.com/allanmcrae/toolchain/blob/f18604d70c5933c31b51a320978711e4e6791cf1/glibc/PKGBUILD + # remove fortify for building libraries + CFLAGS=${CFLAGS/-Wp,-D_FORTIFY_SOURCE=2/} + "${srcdir}"/glibc/configure \ - --host=x86_64-pc-linux-gnu \ --libdir=/usr/lib \ --libexecdir=/usr/lib \ "${_configure_flags[@]}" # build libraries with fortify disabled - configparms_disable_programs - MAKE_FLAGS_64_FULL="$MAKE_FLAGS_64 -U_FORTIFY_SOURCE -ffunction-sections -fdata-sections" - make_build_64 + echo "build-programs=no" >> configparms + make -O # re-enable fortify for programs - configparms_enable_programs - unset_flags - configparms_fortify_source - MAKE_FLAGS_64_FULL="$MAKE_FLAGS_64 -Wp,-D_FORTIFY_SOURCE=2 -ffunction-sections -fdata-sections" - make_build_64 + sed -i "/build-programs=/s#no#yes#" configparms + echo "CFLAGS += -Wp,-D_FORTIFY_SOURCE=2" >> configparms + make -O # build info pages manually for reproducibility - make info -j$(nproc --all) + make info cd "${srcdir}"/lib32-glibc-build export CC="gcc -m32 -mstackrealign" @@ -134,9 +107,7 @@ build() { echo "rtlddir=/usr/lib32" >> configparms echo "sbindir=/usr/bin" >> configparms echo "rootsbindir=/usr/bin" >> configparms - - # remove fortify for building libraries & configure glibc (32-bit) to point at lib directories - unset_flags + "${srcdir}"/glibc/configure \ --host=i686-pc-linux-gnu \ --libdir=/usr/lib32 \ @@ -144,16 +115,13 @@ build() { "${_configure_flags[@]}" # build libraries with fortify disabled - configparms_disable_programs - MAKE_FLAGS_32_FULL="$MAKE_FLAGS_32 -U_FORTIFY_SOURCE -ffunction-sections -fdata-sections" - make_build_32 + echo "build-programs=no" >> configparms + make -O # re-enable fortify for programs - configparms_enable_programs - unset_flags - configparms_fortify_source - MAKE_FLAGS_32_FULL="$MAKE_FLAGS_32 -Wp,-D_FORTIFY_SOURCE=2 -ffunction-sections -fdata-sections" - make_build_32 + sed -i "/build-programs=/s#no#yes#" configparms + echo "CFLAGS += -Wp,-D_FORTIFY_SOURCE=2" >> configparms + make -O # pregenerate C.UTF-8 locale until it is built into glibc # (https://sourceware.org/glibc/wiki/Proposals/C.UTF-8, FS#74864)- @@ -194,19 +162,18 @@ check() { } package_glibc-git() { - pkgdesc='GNU C Library - git version' - depends=("linux-api-headers>=${_kernelver}" 'tzdata' 'filesystem') + pkgdesc='GNU C Library (git version)' + depends=('linux-api-headers>=5.15' tzdata filesystem) optdepends=('gd: for memusagestat' 'perl: for mtrace') # XXX Arch Linux's valgrind package requires an exact version - provides=("${_pkgname}=${pkgver%%.r*}") - conflicts=("${_pkgname}") + provides=("glibc=${pkgver%%.r*}") + conflicts=("glibc") install=glibc-git.install - backup=('etc/gai.conf' - 'etc/locale.gen' - 'etc/nscd.conf') - - # We generate these in the post-install with ldconfig -r + backup=(etc/gai.conf + etc/locale.gen + etc/nscd.conf) + make -C glibc-build install_root="${pkgdir}" install rm -f "${pkgdir}"/etc/ld.so.cache @@ -220,16 +187,16 @@ package_glibc-git() { install -m644 nscd/nscd.service "${pkgdir}"/usr/lib/systemd/system install -m644 nscd/nscd.tmpfiles "${pkgdir}"/usr/lib/tmpfiles.d/nscd.conf install -dm755 "${pkgdir}"/var/db/nscd - + install -m644 posix/gai.conf "${pkgdir}"/etc/gai.conf - install -m755 "${srcdir}"/locale-gen "${pkgdir}"/usr/bin + install -m755 "${srcdir}"/locale-gen "${pkgdir}"/usr/bin # Create /etc/locale.gen install -m644 "${srcdir}"/locale.gen.txt "${pkgdir}"/etc/locale.gen sed -e '1,3d' -e 's|/| |g' -e 's|\\| |g' -e 's|^|#|g' \ "${srcdir}"/glibc/localedata/SUPPORTED >> "${pkgdir}"/etc/locale.gen - + # Add SUPPORTED file to pkg sed -e '1,3d' -e 's|/| |g' -e 's| \\||g' \ "${srcdir}"/glibc/localedata/SUPPORTED > "${pkgdir}"/usr/share/i18n/SUPPORTED @@ -238,24 +205,7 @@ package_glibc-git() { install -dm755 "${pkgdir}"/usr/lib/locale cp -r "${srcdir}"/C.UTF-8 -t "${pkgdir}"/usr/lib/locale sed -i '/#C\.UTF-8 /d' "${pkgdir}"/etc/locale.gen - - # handle selectively stripping unless debug packages are requested - if check_option 'debug' n; then - options+=('!strip') - # I use 2> /dev/null for all of these due to many false-positives as it - # attempts to strip scripts or other unstrippable files. - find "$pkgdir"/usr/bin -type f -executable -exec strip $STRIP_BINARIES {} + 2> /dev/null || true - find "$pkgdir"/usr/lib -name '*.a' -type f -exec strip $STRIP_STATIC {} + 2> /dev/null || true - - # Do not strip these for gdb and valgrind functionality. - find "$pkgdir"/usr/lib \ - -not -name 'ld-*.so' \ - -not -name 'libc-*.so' \ - -not -name 'libpthread-*.so' \ - -not -name 'libthread_db-*.so' \ - -name '*-*.so' -type f -exec strip $STRIP_SHARED {} + 2> /dev/null || true - fi - + # Provide tracing probes to libstdc++ for exceptions, possibly for other # libraries too. Useful for gdb's catch command. install -Dm644 "${srcdir}"/sdt.h "${pkgdir}"/usr/include/sys/sdt.h @@ -263,13 +213,12 @@ package_glibc-git() { } package_lib32-glibc-git() { - pkgdesc='GNU C Library (32-bit) - git version' - depends=("${_pkgname}=${pkgver%%.r*}") - optdepends=('perl: for mtrace') - # XXX Arch Linux's valgrind package requires an exact version - provides=("lib32-${_pkgname}=${pkgver%%.r*}") - conflicts=("lib32-${_pkgname}") + pkgdesc='GNU C Library (32-bit) (git version)' + depends=("glibc-git=$pkgver") options+=('!emptydirs') + # XXX Arch Linux's valgrind package requires an exact version + provides=("lib32-glibc=${pkgver%%.r*}") + conflicts=("lib32-glibc") cd lib32-glibc-build @@ -288,21 +237,4 @@ package_lib32-glibc-git() { # Symlink /usr/lib32/locale to /usr/lib/locale ln -s ../lib/locale "${pkgdir}"/usr/lib32/locale - - # handle selectively stripping unless debug packages are requested - if check_option 'debug' n; then - options+=('!strip') - # I use 2> /dev/null for all of these due to many false-positives as it - # attempts to strip scripts or other unstrippable files. - find "$pkgdir"/usr/bin -type f -executable -exec strip $STRIP_BINARIES {} + 2> /dev/null || true - find "$pkgdir"/usr/lib32 -name '*.a' -type f -exec strip $STRIP_STATIC {} + 2> /dev/null || true - - # Do not strip these for gdb and valgrind functionality. - find "$pkgdir"/usr/lib32 \ - -not -name 'ld-*.so' \ - -not -name 'libc-*.so' \ - -not -name 'libpthread-*.so' \ - -not -name 'libthread_db-*.so' \ - -name '*-*.so' -type f -exec strip $STRIP_SHARED {} + 2> /dev/null || true - fi } |