commit:     cbe9dcd7cf925bae8cb3060592ac6031cc4d6e30
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Apr  8 06:17:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Apr  8 06:17:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cbe9dcd7

sys-apps/pciutils: add 3.12.0

Signed-off-by: Sam James <sam <AT> gentoo.org>

 sys-apps/pciutils/Manifest               |   1 +
 sys-apps/pciutils/pciutils-3.12.0.ebuild | 173 +++++++++++++++++++++++++++++++
 2 files changed, 174 insertions(+)

diff --git a/sys-apps/pciutils/Manifest b/sys-apps/pciutils/Manifest
index 5b772d6a1115..fd3bc9a2159c 100644
--- a/sys-apps/pciutils/Manifest
+++ b/sys-apps/pciutils/Manifest
@@ -1,2 +1,3 @@
 DIST pciutils-3.10.0.tar.gz 931711 BLAKE2B 
2e1255eb5508c9d1339f5bc772c2592a03cae4d8d097e8939748c9bb5d5d949be53d705d1b7d903f7ea88b2abeea91e39de16e39d2f46f0a1f62f8a9e32c6faa
 SHA512 
3da1af4af8b0fa3cf4d3f06095524e25dc292182beec10aa2c16c5c6ba751fe469d0e7f54e43413b6f3f5bcdbd1fba3c66df1d8e39d2e1962ae36a2d9c06238e
 DIST pciutils-3.11.1.tar.gz 660457 BLAKE2B 
447d0e3fa209d2d27a0310a5824a75b543b539c459caed23e9218f4ff3f9a3c2a99c65dd5ddf92a56c2b880ecfaeff6f3edc458c3e5973a1a4937325740915ac
 SHA512 
6bbb248364831a384a2f521d7300cc53b046ce3765c3f7aca08c9e839174b02687543ee697b8ffc24258bcd39ac625d1ce53d6ca02fdc718eea86a50c95a33de
+DIST pciutils-3.12.0.tar.gz 668358 BLAKE2B 
6d57b0654a26e959d2a953a102fd616ba0a0a183ec6d40f65a1274ad33330df9c81b95d4b2274edc240cbcf576ce93a0b61252bae0b6348a29df659b3fc219eb
 SHA512 
b1efd3e24efad4f80e1a942d23d6ea12acec9642714e47d24bff7f7c53ff475b0252c6f75c0053b7ec64635037e72b150b3e313229b36479dc0cbf96902096c5

diff --git a/sys-apps/pciutils/pciutils-3.12.0.ebuild 
b/sys-apps/pciutils/pciutils-3.12.0.ebuild
new file mode 100644
index 000000000000..dd3c7a05627e
--- /dev/null
+++ b/sys-apps/pciutils/pciutils-3.12.0.ebuild
@@ -0,0 +1,173 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit toolchain-funcs multilib-minimal flag-o-matic
+
+DESCRIPTION="Various utilities dealing with the PCI bus"
+HOMEPAGE="https://mj.ucw.cz/sw/pciutils/ 
https://git.kernel.org/?p=utils/pciutils/pciutils.git";
+SRC_URI="https://mj.ucw.cz/download/linux/pci/${P}.tar.gz";
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~loong ~m68k ~mips ~ppc ~ppc64 
~riscv ~s390 ~sparc ~x86 ~amd64-linux ~x86-linux"
+IUSE="dns +kmod static-libs +udev zlib"
+REQUIRED_USE="static-libs? ( !udev )"
+
+# Have the sub-libs in RDEPEND with [static-libs] since, logically,
+# our libpci.a depends on libz.a/etc... at runtime.
+LIB_DEPEND="zlib? ( 
>=sys-libs/zlib-1.2.8-r1[static-libs(+),${MULTILIB_USEDEP}] )"
+DEPEND="
+       kmod? ( sys-apps/kmod )
+       udev? ( >=virtual/libudev-208[${MULTILIB_USEDEP}] )
+       static-libs? ( ${LIB_DEPEND} )
+       !static-libs? ( ${LIB_DEPEND//static-libs([+-]),} )
+"
+RDEPEND="
+       ${DEPEND}
+       sys-apps/hwdata
+"
+# See bug #847133 re binutils check
+BDEPEND="
+       || ( >=sys-devel/binutils-2.37:* sys-devel/lld sys-devel/native-cctools 
)
+       kmod? ( virtual/pkgconfig )
+"
+
+MULTILIB_WRAPPED_HEADERS=( /usr/include/pci/config.h )
+
+switch_config() {
+       [[ $# -ne 2 ]] && return 1
+       local opt=$1 val=$2
+
+       sed "s@^\(${opt}=\).*\$@\1${val}@" -i Makefile || die
+       return 0
+}
+
+check_binutils_version() {
+       if [[ -z ${I_KNOW_WHAT_I_AM_DOING} ]] && ! tc-ld-is-gold && ! 
tc-ld-is-lld ; then
+               # Okay, hopefully it's Binutils' bfd.
+               # bug #847133
+
+               # Convert this:
+               # ```
+               # GNU ld (Gentoo 2.38 p4) 2.38
+               # Copyright (C) 2022 Free Software Foundation, Inc.
+               # This program is free software; you may redistribute it under 
the terms of
+               # the GNU General Public License version 3 or (at your option) 
a later version.
+               # This program has absolutely no warranty.
+               # ```
+               #
+               # into...
+               # ```
+               # 2.38
+               # ```
+               local ver=$($(tc-getLD) --version 2>&1 | head -n 1 | rev | cut 
-d' ' -f1 | rev)
+
+               if ! [[ ${ver} =~ [0-9].[0-9][0-9] ]] ; then
+                       # Skip if unrecognised format so we don't pass something
+                       # odd into ver_cut.
+                       return
+               fi
+
+               ver_major=$(ver_cut 1 "${ver}")
+               ver_minor=$(ver_cut 2 "${ver}")
+
+               # We use 2.37 here, not 2.35, as 
https://github.com/pciutils/pciutils/issues/98 mentions
+               # because we've had other miscompiles with older Binutils (not 
just build failures!)
+               # and we don't want people running any unsupported versions of 
Binutils. An example
+               # of this is where glibc is completely broken with old 
binutils: bug #802036. It's
+               # just not sustainable to support.
+               if [[ ${ver_major} -eq 2 && ${ver_minor} -lt 37 ]] ; then
+                       eerror "Old version of binutils activated! ${P} cannot 
be built with an old version."
+                       eerror "Please follow these steps:"
+                       eerror "1. Select a newer binutils (>= 2.37) using 
binutils-config"
+                       eerror " (If no such version is installed, run emerge 
-v1 sys-devel/binutils)"
+                       eerror "2. Run: . /etc/profile"
+                       eerror "3. Try emerging again with: emerge -v1 
${CATEGORY}/${P}"
+                       eerror "4. Complete your world upgrade if you were 
performing one."
+                       eerror "5. Perform a depclean (emerge -acv)"
+                       eerror "\tYou MUST depclean after every world upgrade 
in future!"
+                       die "Old binutils found! Change to a newer ld using 
binutils-config (bug #847133)."
+               fi
+       fi
+}
+
+pkg_pretend() {
+       [[ ${MERGE_TYPE} != binary ]] && check_binutils_version
+}
+
+pkg_setup() {
+       [[ ${MERGE_TYPE} != binary ]] && check_binutils_version
+}
+
+src_prepare() {
+       default
+
+       if use static-libs ; then
+               cp -pPR "${S}" "${S}.static" || die
+               mv "${S}.static" "${S}/static" || die
+       fi
+
+       multilib_copy_sources
+}
+
+multilib_src_configure() {
+       # bug #640836, bug #852929
+       # Still broken in 3.10.0, see 
https://github.com/pciutils/pciutils/pull/144.
+       filter-lto
+
+       # bug #471102
+       append-lfs-flags
+}
+
+pemake() {
+       emake \
+               HOST="${CHOST}" \
+               CROSS_COMPILE="${CHOST}-" \
+               CC="$(tc-getCC)" \
+               AR="$(tc-getAR)" \
+               PKG_CONFIG="$(tc-getPKG_CONFIG)" \
+               RANLIB="$(tc-getRANLIB)" \
+               DNS=$(usex dns) \
+               IDSDIR='$(SHAREDIR)/hwdata' \
+               MANDIR='$(SHAREDIR)/man' \
+               PREFIX="${EPREFIX}/usr" \
+               SHARED="yes" \
+               STRIP="" \
+               ZLIB=$(usex zlib) \
+               PCI_COMPRESSED_IDS=0 \
+               PCI_IDS=pci.ids \
+               LIBDIR="\${PREFIX}/$(get_libdir)" \
+               LIBKMOD=$(multilib_native_usex kmod) \
+               HWDB=$(usex udev) \
+               "$@"
+}
+
+multilib_src_compile() {
+       pemake OPT="${CFLAGS}" all
+
+       if use static-libs ; then
+               pemake \
+                       -C "${BUILD_DIR}"/static \
+                       OPT="${CFLAGS}" \
+                       SHARED="no" \
+                       lib/libpci.a
+       fi
+}
+
+multilib_src_install() {
+       pemake DESTDIR="${D}" install install-lib
+
+       use static-libs && dolib.a "${BUILD_DIR}"/static/lib/libpci.a
+}
+
+multilib_src_install_all() {
+       dodoc ChangeLog README TODO
+
+       rm "${ED}"/usr/sbin/update-pciids 
"${ED}"/usr/share/man/man8/update-pciids.8* || die
+       rm -r "${ED}"/usr/share/hwdata || die
+
+       newinitd "${FILESDIR}"/init.d-pciparm pciparm
+       newconfd "${FILESDIR}"/conf.d-pciparm pciparm
+}

Reply via email to