diff options
author | Samuli Suominen <ssuominen@gentoo.org> | 2013-08-09 19:22:41 +0000 |
---|---|---|
committer | Samuli Suominen <ssuominen@gentoo.org> | 2013-08-09 19:22:41 +0000 |
commit | 9b13dc9d6286e52f480fdc605262a3fc90f230a8 (patch) | |
tree | 075a9e417188c8c5b1472cec6a3e33ed7fd888c1 /sys-fs | |
parent | If USE="hwdb" is missing from virtual/udev, it's always enabled. (diff) | |
download | historical-9b13dc9d6286e52f480fdc605262a3fc90f230a8.tar.gz historical-9b13dc9d6286e52f480fdc605262a3fc90f230a8.tar.bz2 historical-9b13dc9d6286e52f480fdc605262a3fc90f230a8.zip |
Remove entire USE="hwdb" which was only controlling the sys-apps/hwids dependency as suggested by WilliamH. Not having sys-apps/hwids installed is not really supported configuration.
Package-Manager: portage-2.2.0_alpha196/cvs/Linux x86_64
Manifest-Sign-Key: 0x4868F14D
Diffstat (limited to 'sys-fs')
-rw-r--r-- | sys-fs/udev/ChangeLog | 10 | ||||
-rw-r--r-- | sys-fs/udev/Manifest | 19 | ||||
-rw-r--r-- | sys-fs/udev/udev-206-r3.ebuild | 517 | ||||
-rw-r--r-- | sys-fs/udev/udev-9999.ebuild | 10 |
4 files changed, 541 insertions, 15 deletions
diff --git a/sys-fs/udev/ChangeLog b/sys-fs/udev/ChangeLog index 94a38d3628bb..7d07216b2a9b 100644 --- a/sys-fs/udev/ChangeLog +++ b/sys-fs/udev/ChangeLog @@ -1,6 +1,14 @@ # ChangeLog for sys-fs/udev # Copyright 1999-2013 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/sys-fs/udev/ChangeLog,v 1.950 2013/08/09 06:05:37 ssuominen Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-fs/udev/ChangeLog,v 1.951 2013/08/09 19:22:36 ssuominen Exp $ + +*udev-206-r3 (09 Aug 2013) + + 09 Aug 2013; Samuli Suominen <ssuominen@gentoo.org> +udev-206-r3.ebuild, + udev-9999.ebuild: + Remove entire USE="hwdb" which was only controlling the sys-apps/hwids + dependency as suggested by WilliamH. Not having sys-apps/hwids installed is + not really supported configuration. *udev-206-r2 (09 Aug 2013) diff --git a/sys-fs/udev/Manifest b/sys-fs/udev/Manifest index 682078a74777..d65bd20b690b 100644 --- a/sys-fs/udev/Manifest +++ b/sys-fs/udev/Manifest @@ -9,9 +9,10 @@ DIST udev-206-patches-2.tar.xz 1840 SHA256 02643ba4a3c4c5312a2f4c22e06925509d923 EBUILD udev-204.ebuild 13475 SHA256 5604664100abcd19d5e849e4b2ea4501706b38fa8da18389a6f147c419593661 SHA512 dc53345e87d722594a3182b2dc991938f03d89d8ab703134334a36f53340dba2112536153cd9c5ffc56ba7d57dc0e11e0afaab40c97d48700186cf5748ef635a WHIRLPOOL 0e50da3273399f8d8e5b6ddab71eca233d0993dcfa7928c90aba2644c96340a1045bfa8208f4006965c1dc466316eb90a946bd4157e71eaadc6c032180771d25 EBUILD udev-206-r1.ebuild 15182 SHA256 646a09dec1ddf5447d37e865e3f28548fe581f50c2ba72310fbdfe429a0f451a SHA512 ec6a55e345237bc8cee1d32b056ea6993dc7ded1cfe9c8dc144cf346b1b17d20aa6d7b91e64b164c13b310d128977844310ed4fe8f4febe0517cd9c0a62bc575 WHIRLPOOL a0ecc41c882e74e59e9a8adfc96806c20c545b239f96cbd9e2afe0625676ea27ef772253efe337a94f3f26d8f51dd65e2e0b5137a99cae386bcdd01e7c46b145 EBUILD udev-206-r2.ebuild 15182 SHA256 cce90d8d4c2bfc7feae7270e0db7872298858c048c634e59bb4e56738070dc05 SHA512 bba81404244453b65f9914377704342e27519c10808ae8f2fd241090fabd63339b9b48af491862a784279a7bb2c72e4378fb58f641254b7b34ea5b2bb26a5741 WHIRLPOOL e2e6e289e14b2c36276f17c9779dff84ca825ca09bea302e4e1c980d53086652117ced99c2811a5209fd9810d0f629cc5fe8521c09e83ffbe9c5e1cd798352b1 +EBUILD udev-206-r3.ebuild 15157 SHA256 5f7f0da9abbbd527d7f90475b43771b5dfd3e3d90dc5a139dd52729da5f0f1cb SHA512 15b4067eccf206b2ad0e5d185451c0f3514bf3196f0951b4d7e5cd84848a64cd3f237a995387fda3e42f1489b8d7d7bff12a52c17891d694548988638cee1d2f WHIRLPOOL 1c2bd67f011c4b724940e9bb70a2370bd427c24779f2915a38aafaee8fe35fb1a8e541d1e5bcdf0c6dcaa0c08f7cf4d5034c7cf3e9be7aac76b83aa2abaef444 EBUILD udev-206.ebuild 13978 SHA256 4952215ef7e18acb448b241dd0ca11249d47e231667c806283d8cc44911a1be3 SHA512 c93570ec155ab24fdd6b4ae6fd936a8da22c7c27cdb07f3c1a7b8603fcc8607f9930bb68af686021822b830db67ae4b686d70dafcd29f3939da056439e897493 WHIRLPOOL 2827b77a607e848b8a1886c8fda94bbdc79a0a1339d9e7dd4b6ad9118de34035aeb8a8e00ee07470ce83c8875993bfad747f5227b001f55da886e16800147405 -EBUILD udev-9999.ebuild 15181 SHA256 70f2ecb0488f01f1c287aeb505f52dd593db1f745fc3a8f4b170ec8c8e6824e4 SHA512 e4a33197a644b06bb9e4ebd8640936dede7e903042fcf15a7a8d2e3b81bd9e6de45c56514e710b42e7cbc8ec68871e176904f3da4a8ea99c2a49490e26770db9 WHIRLPOOL 4bc9232f5e78e338c2f5fe1932e973b50101772ee9f3d2d0b8f4290cf0fded585517617ca07bf033a033bc4832a20a64763c70941b38c4736970f906bfa25aa3 -MISC ChangeLog 32756 SHA256 cfef0cbf89b02fa9ea297aad049cc8086011502b252a2fdce1e7d3803f0594f1 SHA512 3ea8c9e915113d9135e41481f2ff40cbd436b4d6efc2f5596be1aa36992c9788442a257f3aa31dea04795e09006c4b3fb3b8656cec0735ac1a76179e036d644b WHIRLPOOL ce509cfbac931efad4673b466c0a4c1fd9e8db30eb57f065947b3d37304ef713245a3abe65a4e74412475b094e5e47da2cc6968b552eba9fdb02bfb6b1e9c333 +EBUILD udev-9999.ebuild 15156 SHA256 3cff448e6a1087aa2062078359af6288713ea6bc8a5ff2c5bfe505f556ee0708 SHA512 e8e9505132bee8e0827c2c1f3b3c543a9c4aab0c52b9ff028e236dc529b77b4b003915c670f89861b0ba9262dbc57b6d5052c441302ae61d1da6d40c2d0c215e WHIRLPOOL 7afaa0f4d569371b1c645fc6150aff94b2288cf3b6d868b80f10e904b7036385ecdf2b55c5805374fe2372c1d86bc7bfabbaff82f2cde680f081163dc81bc499 +MISC ChangeLog 33069 SHA256 64a64af1ab69d40d75b680e16d23ce2bacaf09cbadc60567d032206f9cbee1b7 SHA512 c2d9d1408fd87e29d3fdba28fbd188544f2a0f8aba6480d542c0856917b2d81e9c679e8cd5fcf8bb3a493f82043473da03bef92d5cf0048dd057b8536bbeb2b1 WHIRLPOOL bfa7ea8e636153ba622e0bc6f04f77a67439bdc2fe521e69f9dc6613d33825aea39cb41e2eedd8ad2a89fa018906f55f9ae5d558cf47b6d0fa33416eefb62826 MISC ChangeLog-2009 105929 SHA256 94137298457e8d6361cf25e664279d2f9b424f6758814e7ba90e9e2cbf1ea7e5 SHA512 f110e1aa70b11c28263ec5e88973c99426717bce62400c8e9ad860b9e7b67d4aadc053596a9e54faa9435a774c1e8aa0954ae8541760cf061beef26867871548 WHIRLPOOL 215252c0a5c249241813d1bb208da62e68c858e07d1df327cf9175ac739f214813a33c09a64afb4821445e93394dd6d6d500b33e35ed912c1eeccff3365cb7fb MISC ChangeLog-2010 10729 SHA256 44fe328d57b1ba342b328c7a256632e7960976a12e8e9c9791a5fc8ce52c67ca SHA512 a8c371aafe757923e24c023cbf55f3ad084f15f0f038eceaee0dffe58919a17b17bc16cb4b7b1d3f65a19c82b20330a854ec2c801f6d7c7799723ab92d255b49 WHIRLPOOL 3d34e758def921d3d2ed7369392ba5f833fc3a899181c2895fd3da6c9846cf41c9eddbf56de60a52fadd76ffd4c66d92b660b0bc6ca4dddbb2fa49fe0f93cb0b MISC ChangeLog-2011 11721 SHA256 363429a267f251b1ac1c34479e7afa5d7ea13811aa1ba46d7c5489860e542276 SHA512 be7bbaa68602c30ba9cb3e5037ee91ff94c35a0c2ff0b96c5eee14c0e81f8e52232bae44f1d01ff23acedabdb03fdc78f3d11a40cfed2cfef1c45fe2492f7bf4 WHIRLPOOL 3e85eb967f26a8224fd0ed5824009c62271fa5269a6a207da8c8abd7b09cc4308ff847021afcae5a86cedd723a5aeca1ce2f6712a187dfbd36118e097d74510f @@ -20,11 +21,11 @@ MISC metadata.xml 804 SHA256 2489d91db9d09f0d411b17dff6c8a595fb48ca65e8b6abcbdf9 -----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.20 (GNU/Linux) -iQEcBAEBCAAGBQJSBIY5AAoJEEdUh39IaPFNlnAIAKD3TBxOGWvQi726YgcVDsBE -n/Myc0mplRd4JhbPLIFDQKYyNiM598mPpIAMMrY+YP1WiDeU7IXFHbVF11co85fM -okdqhP8MYsacRQMd7jDSHAQ7GunRZVW1IwciAOAT8K1O6ZMQ9mEYln2DwSwCuGDL -S5MSdYgfOSgMXdcB3p/e/jyR+fQd0LOfbohyU6zG91rT9tvz8vIPeZ/pJaKez5Iu -+Bp4TuwOPAYjQWiYzQ9e+C4G7VZQnjOJqFCFLOZBQd40BXUv99d39u6c/Fvl39aj -M4IPBkqnQg+C6uljT7atBqQOdzcuSvuPrpc9Rr6EIj0VFTdys85l92+GtwW0Jrs= -=nuQ8 +iQEcBAEBCAAGBQJSBUEBAAoJEEdUh39IaPFN+QkIAJboezeUsIKmmZs2XxavLMxl +uXZ/CCT39zUS3VWANKZc13coeorf/bHZYQfBIHY4H5CswPlVJgEEUMc5ihak6vg/ +nPCmHCLp7ocOyS7gDi7HyC7bpLBdZiEdqTHUCvg7SmazhO0zNklIGqBkAEc5l2Y8 +lIanPpbTqPAQdExxT3l7LewATJMx4FobwNBC2oCGOWiXfMr8l37S0k7o+PZsUapP +IOyrEQxOB32mwwy9hTd1G5UqcSAjjGS8GIuk99j7R3i633Q4Pl6fPG0wofmrXIRd +YEbLuVWCeMxbTu8+IBe9NXQXagBDPJvUj9jLOun7Vsn8/fOeQsDaxVML6+vwqp8= +=V244 -----END PGP SIGNATURE----- diff --git a/sys-fs/udev/udev-206-r3.ebuild b/sys-fs/udev/udev-206-r3.ebuild new file mode 100644 index 000000000000..8c1fb9aa3766 --- /dev/null +++ b/sys-fs/udev/udev-206-r3.ebuild @@ -0,0 +1,517 @@ +# Copyright 1999-2013 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/sys-fs/udev/udev-206-r3.ebuild,v 1.1 2013/08/09 19:22:36 ssuominen Exp $ + +EAPI=5 + +# accept4() patch is only in non-live version +if [[ ${PV} = 9999* ]]; then + KV_min=2.6.39 +else + KV_min=2.6.32 +fi + +inherit autotools eutils linux-info multilib toolchain-funcs versionator multilib-minimal + +if [[ ${PV} = 9999* ]]; then + EGIT_REPO_URI="git://anongit.freedesktop.org/systemd/systemd" + inherit git-2 +else + patchset=2 + SRC_URI="http://www.freedesktop.org/software/systemd/systemd-${PV}.tar.xz" + if [[ -n "${patchset}" ]]; then + SRC_URI="${SRC_URI} + http://dev.gentoo.org/~ssuominen/${P}-patches-${patchset}.tar.xz + http://dev.gentoo.org/~williamh/dist/${P}-patches-${patchset}.tar.xz" + fi + KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86" +fi + +DESCRIPTION="Linux dynamic and persistent device naming support (aka userspace devfs)" +HOMEPAGE="http://www.freedesktop.org/wiki/Software/systemd" + +LICENSE="LGPL-2.1 MIT GPL-2" +SLOT="0" +IUSE="acl doc +firmware-loader gudev introspection +kmod +openrc selinux static-libs" + +RESTRICT="test" + +COMMON_DEPEND=">=sys-apps/util-linux-2.20 + acl? ( sys-apps/acl ) + gudev? ( >=dev-libs/glib-2 ) + introspection? ( >=dev-libs/gobject-introspection-1.31.1 ) + kmod? ( >=sys-apps/kmod-14-r1 ) + selinux? ( >=sys-libs/libselinux-2.1.9 ) + !<sys-libs/glibc-2.11 + !sys-apps/systemd + abi_x86_32? ( + !<=app-emulation/emul-linux-x86-baselibs-20130224-r7 + !app-emulation/emul-linux-x86-baselibs[-abi_x86_32(-)] + )" +DEPEND="${COMMON_DEPEND} + dev-util/gperf + >=sys-devel/make-3.82-r4 + virtual/os-headers + virtual/pkgconfig + !<sys-kernel/linux-headers-${KV_min} + doc? ( >=dev-util/gtk-doc-1.18 )" +if [[ ${PV} = 9999* ]]; then + DEPEND="${DEPEND} + app-text/docbook-xml-dtd:4.2 + app-text/docbook-xsl-stylesheets + dev-libs/libxslt + >=dev-util/intltool-0.50" +fi +RDEPEND="${COMMON_DEPEND} + openrc? ( !<sys-apps/openrc-0.9.9 ) + !sys-apps/coldplug + !<sys-fs/lvm2-2.02.97-r1 + !sys-fs/device-mapper + !<sys-fs/udev-init-scripts-22 + !<sys-kernel/dracut-017-r1 + !<sys-kernel/genkernel-3.4.25 + !<sec-policy/selinux-base-2.20120725-r10" +PDEPEND=">=virtual/udev-206-r2 + >=sys-apps/hwids-20130717-r1[udev] + openrc? ( >=sys-fs/udev-init-scripts-25 )" + +S=${WORKDIR}/systemd-${PV} + +# The multilib-build.eclass doesn't handle situation where the installed headers +# are different in ABIs. In this case, we install libgudev headers in native +# ABI but not for non-native ABI. +multilib_check_headers() { :; } + +udev_check_KV() { + if kernel_is lt ${KV_min//./ }; then + return 1 + fi + return 0 +} + +check_default_rules() { + # Make sure there are no sudden changes to upstream rules file + # (more for my own needs than anything else ...) + local udev_rules_md5=7d3733faee4203fd7c75c3f3c0d55741 + MD5=$(md5sum < "${S}"/rules/50-udev-default.rules) + MD5=${MD5/ -/} + if [[ ${MD5} != ${udev_rules_md5} ]]; then + eerror "50-udev-default.rules has been updated, please validate!" + eerror "md5sum: ${MD5}" + die "50-udev-default.rules has been updated, please validate!" + fi +} + +pkg_setup() { + CONFIG_CHECK="~BLK_DEV_BSG ~DEVTMPFS ~!IDE ~INOTIFY_USER ~!SYSFS_DEPRECATED ~!SYSFS_DEPRECATED_V2 ~SIGNALFD ~EPOLL" + + linux-info_pkg_setup + + if ! udev_check_KV; then + eerror "Your kernel version (${KV_FULL}) is too old to run ${P}" + eerror "It must be at least ${KV_min}!" + fi + + KV_FULL_SRC=${KV_FULL} + get_running_version + if ! udev_check_KV; then + eerror + eerror "Your running kernel version (${KV_FULL}) is too old" + eerror "for this version of udev." + eerror "You must upgrade your kernel or downgrade udev." + fi +} + +src_prepare() { + if ! [[ ${PV} = 9999* ]]; then + # secure_getenv() disable for non-glibc systems wrt bug #443030 + if ! [[ $(grep -r secure_getenv * | wc -l) -eq 19 ]]; then + eerror "The line count for secure_getenv() failed, see bug #443030" + die + fi + fi + + # backport some patches + if [[ -n "${patchset}" ]]; then + EPATCH_SUFFIX=patch EPATCH_FORCE=yes epatch + fi + + # These are missing from upstream 50-udev-default.rules + cat <<-EOF > "${T}"/40-gentoo.rules + # Gentoo specific usb group + SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", GROUP="usb" + # Keep this for Linux 2.6.32 kernels with accept4() support like .60 wrt #457868 + SUBSYSTEM=="mem", KERNEL=="null|zero|full|random|urandom", MODE="0666" + EOF + + # Create link to systemd-udevd.8 here to avoid parallel build problem and + # while at it, create convinience link to `man 8 udevd` even if upstream + # doesn't do that anymore + local man + for man in udevd systemd-udevd; do + echo '.so systemd-udevd.service.8' > "${T}"/${man}.8 + done + + # Remove requirements for gettext and intltool wrt bug #443028 + if ! has_version dev-util/intltool && ! [[ ${PV} = 9999* ]]; then + sed -i \ + -e '/INTLTOOL_APPLIED_VERSION=/s:=.*:=0.40.0:' \ + -e '/XML::Parser perl module is required for intltool/s|^|:|' \ + configure || die + eval export INTLTOOL_{EXTRACT,MERGE,UPDATE}=/bin/true + eval export {MSG{FMT,MERGE},XGETTEXT}=/bin/true + fi + + # apply user patches + epatch_user + + # compile with older versions of gcc #451110 + version_is_at_least 4.6 $(gcc-version) || \ + sed -i 's:static_assert:alsdjflkasjdfa:' src/shared/macro.h + + # change rules back to group uucp instead of dialout for now wrt #454556 + sed -e 's/GROUP="dialout"/GROUP="uucp"/' \ + -i rules/*.rules \ + || die "failed to change group dialout to uucp" + + if [[ ! -e configure ]]; then + if use doc; then + gtkdocize --docdir docs || die "gtkdocize failed" + else + echo 'EXTRA_DIST =' > docs/gtk-doc.make + fi + eautoreconf + else + check_default_rules + elibtoolize + fi + + # Restore possibility of running --enable-static wrt #472608 + sed -i \ + -e '/--enable-static is not supported by systemd/s:as_fn_error:echo:' \ + configure || die + + if ! use elibc_glibc; then #443030 + echo '#define secure_getenv(x) NULL' >> config.h.in + sed -i -e '/error.*secure_getenv/s:.*:#define secure_getenv(x) NULL:' src/shared/missing.h || die + fi +} + +multilib_src_configure() { + tc-export CC #463846 + + local econf_args + econf_args=( + ac_cv_search_cap_init= + ac_cv_header_sys_capability_h=yes + DBUS_CFLAGS=' ' + DBUS_LIBS=' ' + --docdir=/usr/share/doc/${PF} + --libdir=/usr/$(get_libdir) + --with-html-dir=/usr/share/doc/${PF}/html + --with-rootprefix= + --without-python + --disable-audit + --disable-coredump + --disable-hostnamed + --disable-ima + --disable-libcryptsetup + --disable-localed + --disable-logind + --disable-myhostname + --disable-nls + --disable-pam + --disable-quotacheck + --disable-readahead + --enable-split-usr + --disable-tcpwrap + --disable-timedated + --disable-xz + --disable-polkit + --disable-tmpfiles + --disable-machined + --disable-xattr + ) + if multilib_is_native_abi; then + econf_args+=( + --with-rootlibdir=/$(get_libdir) + $(use_enable acl) + $(use_enable doc gtk-doc) + $(use_enable gudev) + $(use_enable kmod) + $(use_enable selinux) + $(use_enable static-libs static) + --enable-introspection=$(usex introspection) + ) + else + econf_args+=( + --with-rootlibdir=/usr/$(get_libdir) + --disable-acl + --disable-gtk-doc + --disable-gudev + --disable-kmod + --disable-selinux + --disable-static + --enable-introspection=no + ) + fi + use firmware-loader && econf_args+=( --with-firmware-path="/lib/firmware/updates:/lib/firmware" ) + + ECONF_SOURCE=${S} econf "${econf_args[@]}" +} + +multilib_src_compile() { + echo 'BUILT_SOURCES: $(BUILT_SOURCES)' > "${T}"/Makefile.extra + emake -f Makefile -f "${T}"/Makefile.extra BUILT_SOURCES + + # Most of the parallel build problems were solved by >=sys-devel/make-3.82-r4, + # but not everything -- separate building of the binaries as a workaround, + # which will force internal libraries required for the helpers to be built + # early enough, like eg. libsystemd-shared.la + if multilib_is_native_abi; then + local lib_targets=( libudev.la ) + use gudev && lib_targets+=( libgudev-1.0.la ) + emake "${lib_targets[@]}" + + local exec_targets=( + systemd-udevd + udevadm + ) + emake "${exec_targets[@]}" + + local helper_targets=( + ata_id + cdrom_id + collect + scsi_id + v4l_id + accelerometer + mtd_probe + ) + emake "${helper_targets[@]}" + + if [[ ${PV} = 9999* ]]; then + local man_targets=( + man/udev.7 + man/udevadm.8 + man/systemd-udevd.service.8 + ) + emake "${man_targets[@]}" + fi + + if use doc; then + emake -C docs/libudev + use gudev && emake -C docs/gudev + fi + else + local lib_targets=( libudev.la ) + emake "${lib_targets[@]}" + fi +} + +multilib_src_install() { + if multilib_is_native_abi; then + local lib_LTLIBRARIES="libudev.la" \ + pkgconfiglib_DATA="src/libudev/libudev.pc" + + local targets=( + install-libLTLIBRARIES + install-includeHEADERS + install-libgudev_includeHEADERS + install-rootbinPROGRAMS + install-rootlibexecPROGRAMS + install-udevlibexecPROGRAMS + install-dist_udevconfDATA + install-dist_udevrulesDATA + install-girDATA + install-man7 + install-man8 + install-pkgconfiglibDATA + install-sharepkgconfigDATA + install-typelibsDATA + install-dist_docDATA + libudev-install-hook + install-directories-hook + install-dist_bashcompletionDATA + ) + + if use gudev; then + lib_LTLIBRARIES+=" libgudev-1.0.la" + pkgconfiglib_DATA+=" src/gudev/gudev-1.0.pc" + fi + + # add final values of variables: + targets+=( + rootlibexec_PROGRAMS=systemd-udevd + rootbin_PROGRAMS=udevadm + lib_LTLIBRARIES="${lib_LTLIBRARIES}" + MANPAGES="man/udev.7 man/udevadm.8 \ + man/systemd-udevd.service.8" + MANPAGES_ALIAS="" + pkgconfiglib_DATA="${pkgconfiglib_DATA}" + INSTALL_DIRS='$(sysconfdir)/udev/rules.d \ + $(sysconfdir)/udev/hwdb.d' + dist_bashcompletion_DATA="shell-completion/bash/udevadm" + ) + emake -j1 DESTDIR="${D}" "${targets[@]}" + + if use doc; then + emake -C docs/libudev DESTDIR="${D}" install + use gudev && emake -C docs/gudev DESTDIR="${D}" install + fi + else + local lib_LTLIBRARIES="libudev.la" \ + pkgconfiglib_DATA="src/libudev/libudev.pc" \ + include_HEADERS="src/libudev/libudev.h" + + local targets=( + install-libLTLIBRARIES + install-includeHEADERS + install-pkgconfiglibDATA + ) + + targets+=( + lib_LTLIBRARIES="${lib_LTLIBRARIES}" + pkgconfiglib_DATA="${pkgconfiglib_DATA}" + include_HEADERS="${include_HEADERS}" + ) + emake -j1 DESTDIR="${D}" "${targets[@]}" + fi +} + +multilib_src_install_all() { + dodoc TODO + + prune_libtool_files --all + rm -f \ + "${D}"/lib/udev/rules.d/99-systemd.rules \ + "${D}"/usr/share/doc/${PF}/LICENSE.* + + # see src_prepare() for content of these files + insinto /lib/udev/rules.d + doins "${T}"/40-gentoo.rules + doman "${T}"/{systemd-,}udevd.8 + + # install udevadm compatibility symlink + dosym {../bin,sbin}/udevadm + + # install udevd to /sbin and remove empty and redudant directory + # /lib/systemd because systemd is installed to /usr wrt #462750 + mv "${D}"/{lib/systemd/systemd-,sbin/}udevd || die + rm -r "${D}"/lib/systemd +} + +pkg_preinst() { + local htmldir + for htmldir in gudev libudev; do + if [[ -d ${ROOT}usr/share/gtk-doc/html/${htmldir} ]]; then + rm -rf "${ROOT}"usr/share/gtk-doc/html/${htmldir} + fi + if [[ -d ${D}/usr/share/doc/${PF}/html/${htmldir} ]]; then + dosym ../../doc/${PF}/html/${htmldir} \ + /usr/share/gtk-doc/html/${htmldir} + fi + done +} + +pkg_postinst() { + mkdir -p "${ROOT}"run + + # "losetup -f" is confused if there is an empty /dev/loop/, Bug #338766 + # So try to remove it here (will only work if empty). + rmdir "${ROOT}"dev/loop 2>/dev/null + if [[ -d ${ROOT}dev/loop ]]; then + ewarn "Please make sure your remove /dev/loop," + ewarn "else losetup may be confused when looking for unused devices." + fi + + # people want reminders, I'll give them reminders. Odds are they will + # just ignore them anyway... + + # 64-device-mapper.rules is related to sys-fs/device-mapper which we block + # in favor of sys-fs/lvm2 + old_dm_rules=${ROOT}etc/udev/rules.d/64-device-mapper.rules + if [[ -f ${old_dm_rules} ]]; then + rm -f "${old_dm_rules}" + einfo "Removed unneeded file ${old_dm_rules}" + fi + + local fstab="${ROOT}"etc/fstab dev path fstype rest + while read -r dev path fstype rest; do + if [[ ${path} == /dev && ${fstype} != devtmpfs ]]; then + ewarn "You need to edit your /dev line in ${fstab} to have devtmpfs" + ewarn "filesystem. Otherwise udev won't be able to boot." + ewarn "See, http://bugs.gentoo.org/453186" + fi + done < "${fstab}" + + if [[ -d ${ROOT}usr/lib/udev ]]; then + ewarn + ewarn "Please re-emerge all packages on your system which install" + ewarn "rules and helpers in /usr/lib/udev. They should now be in" + ewarn "/lib/udev." + ewarn + ewarn "One way to do this is to run the following command:" + ewarn "emerge -av1 \$(qfile -q -S -C /usr/lib/udev)" + ewarn "Note that qfile can be found in app-portage/portage-utils" + fi + + local old_net_name="${ROOT}"etc/udev/rules.d/80-net-name-slot.rules + if [[ -f ${old_net_name} ]]; then + local old_net_sum=bebf4bd1b6b668e9ff34a3999aa6ff32 + MD5=$(md5sum < "${old_net_name}") + MD5=${MD5/ -/} + if [[ ${MD5} == ${old_net_sum} ]]; then + ewarn "Removing unmodified file ${old_net_name} from old udev installation to enable" + ewarn "the new predictable network interface naming." + rm -f "${old_net_name}" + fi + fi + + local old_cd_rules="${ROOT}"etc/udev/rules.d/70-persistent-cd.rules + local old_net_rules="${ROOT}"etc/udev/rules.d/70-persistent-net.rules + for old_rules in "${old_cd_rules}" "${old_net_rules}"; do + if [[ -f ${old_rules} ]]; then + ewarn + ewarn "File ${old_rules} is from old udev installation but if you still use it," + ewarn "rename it to something else starting with 70- to silence this deprecation" + ewarn "warning." + fi + done + + elog + elog "Starting from version >= 200 the new predictable network interface names are" + elog "used by default, see:" + elog "http://www.freedesktop.org/wiki/Software/systemd/PredictableNetworkInterfaceNames" + elog "http://cgit.freedesktop.org/systemd/systemd/tree/src/udev/udev-builtin-net_id.c" + elog + elog "Example command to get the information for the new interface name before booting" + elog "(replace <ifname> with, for example, eth0):" + elog "# udevadm test-builtin net_id /sys/class/net/<ifname> 2> /dev/null" + elog + elog "You can use either kernel parameter \"net.ifnames=0\", create empty" + elog "file /etc/udev/rules.d/80-net-name-slot.rules, or symlink it to /dev/null" + elog "to disable the feature." + + if has_version sys-apps/biosdevname; then + ewarn + ewarn "You can replace the functionality of sys-apps/biosdevname which has been" + ewarn "detected to be installed with the new predictable network interface names." + fi + + ewarn + ewarn "You need to restart udev as soon as possible to make the upgrade go" + ewarn "into effect." + ewarn "The method you use to do this depends on your init system." + + elog + elog "For more information on udev on Gentoo, upgrading, writing udev rules, and" + elog "fixing known issues visit:" + elog "http://wiki.gentoo.org/wiki/Udev" + elog "http://wiki.gentoo.org/wiki/Udev/upgrade" + + # Update hwdb database in case the format is changed by udev version. + if has_version 'sys-apps/hwids[udev]'; then + udevadm hwdb --update --root="${ROOT%/}" + fi +} diff --git a/sys-fs/udev/udev-9999.ebuild b/sys-fs/udev/udev-9999.ebuild index b2e061dd12be..972229ecd9b1 100644 --- a/sys-fs/udev/udev-9999.ebuild +++ b/sys-fs/udev/udev-9999.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2013 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/sys-fs/udev/udev-9999.ebuild,v 1.246 2013/08/08 15:03:19 ssuominen Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-fs/udev/udev-9999.ebuild,v 1.247 2013/08/09 19:22:36 ssuominen Exp $ EAPI=5 @@ -32,7 +32,7 @@ HOMEPAGE="http://www.freedesktop.org/wiki/Software/systemd" LICENSE="LGPL-2.1 MIT GPL-2" SLOT="0" -IUSE="acl doc +firmware-loader gudev +hwdb introspection +kmod +openrc selinux static-libs" +IUSE="acl doc +firmware-loader gudev introspection +kmod +openrc selinux static-libs" RESTRICT="test" @@ -71,8 +71,8 @@ RDEPEND="${COMMON_DEPEND} !<sys-kernel/dracut-017-r1 !<sys-kernel/genkernel-3.4.25 !<sec-policy/selinux-base-2.20120725-r10" -PDEPEND=">=virtual/udev-206 - hwdb? ( >=sys-apps/hwids-20130717-r1[udev] ) +PDEPEND=">=virtual/udev-206-r2 + >=sys-apps/hwids-20130717-r1[udev] openrc? ( >=sys-fs/udev-init-scripts-25 )" S=${WORKDIR}/systemd-${PV} @@ -511,7 +511,7 @@ pkg_postinst() { elog "http://wiki.gentoo.org/wiki/Udev/upgrade" # Update hwdb database in case the format is changed by udev version. - if use hwdb && has_version 'sys-apps/hwids[udev]'; then + if has_version 'sys-apps/hwids[udev]'; then udevadm hwdb --update --root="${ROOT%/}" fi } |