diff options
author | Matthias Schwarzott <zzam@gentoo.org> | 2008-11-23 20:05:19 +0000 |
---|---|---|
committer | Matthias Schwarzott <zzam@gentoo.org> | 2008-11-23 20:05:19 +0000 |
commit | 0313a032b4b1a583886e9b4064ea3937c5f2e689 (patch) | |
tree | 40e819ebf3582eec17177b10df909738dbbcb742 /sys-fs | |
parent | Kill libdir cruft (diff) | |
download | gentoo-2-0313a032b4b1a583886e9b4064ea3937c5f2e689.tar.gz gentoo-2-0313a032b4b1a583886e9b4064ea3937c5f2e689.tar.bz2 gentoo-2-0313a032b4b1a583886e9b4064ea3937c5f2e689.zip |
Add switch to disable persistent-net, Bug #246312.
(Portage version: 2.2_rc15/cvs/Linux 2.6.27-gentoo-r1 i686)
Diffstat (limited to 'sys-fs')
-rw-r--r-- | sys-fs/udev/ChangeLog | 6 | ||||
-rw-r--r-- | sys-fs/udev/files/udev-start-133.sh | 254 | ||||
-rw-r--r-- | sys-fs/udev/files/udev.confd | 8 | ||||
-rw-r--r-- | sys-fs/udev/udev-133.ebuild | 9 |
4 files changed, 274 insertions, 3 deletions
diff --git a/sys-fs/udev/ChangeLog b/sys-fs/udev/ChangeLog index 5d73ef355e8d..f83331feb933 100644 --- a/sys-fs/udev/ChangeLog +++ b/sys-fs/udev/ChangeLog @@ -1,6 +1,10 @@ # ChangeLog for sys-fs/udev # Copyright 1999-2008 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/sys-fs/udev/ChangeLog,v 1.418 2008/11/19 21:20:02 zzam Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-fs/udev/ChangeLog,v 1.419 2008/11/23 20:05:19 zzam Exp $ + + 23 Nov 2008; Matthias Schwarzott <zzam@gentoo.org> + +files/udev-start-133.sh, +files/udev.confd, udev-133.ebuild: + Add switch to disable persistent-net, Bug #246312. 19 Nov 2008; Matthias Schwarzott <zzam@gentoo.org> udev-133.ebuild: No longer change Makefiles and call eautoreconf just to change install diff --git a/sys-fs/udev/files/udev-start-133.sh b/sys-fs/udev/files/udev-start-133.sh new file mode 100644 index 000000000000..24a4d9ef8098 --- /dev/null +++ b/sys-fs/udev/files/udev-start-133.sh @@ -0,0 +1,254 @@ +# Copyright 1999-2007 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 + +[ -e /etc/udev/udev.conf ] && . /etc/udev/udev.conf +[ -e /etc/conf.d/udev ] && . /etc/conf.d/udev +. /lib/udev/shell-compat.sh + +rc_coldplug=${rc_coldplug:-${RC_COLDPLUG:-YES}} +rc_device_tarball=${rc_device_tarball:-${RC_DEVICE_TARBALL:-NO}} + +cleanup() +{ + # fail more gracely and not leave udevd running + start-stop-daemon --stop --exec /sbin/udevd + exit 1 +} + +# FIXME +# Instead of this script testing kernel version, udev itself should +# Maybe something like udevd --test || exit $? +check_kernel() +{ + if [ $(get_KV) -lt $(KV_to_int '2.6.15') ]; then + eerror "Your kernel is too old to work with this version of udev." + eerror "Current udev only supports Linux kernel 2.6.15 and newer." + return 1 + fi + if [ $(get_KV) -lt $(KV_to_int '2.6.18') ]; then + ewarn "You need at least Linux kernel 2.6.18 for reliable operation of udev." + fi + return 0 +} + + +mount_dev_directory() +{ + # No options are processed here as they should all be in /etc/fstab + ebegin "Mounting /dev" + if fstabinfo --quiet /dev; then + mount -n /dev + else + # Some devices require exec, Bug #92921 + mount -n -t tmpfs -o "exec,nosuid,mode=0755,size=10M" udev /dev + fi + eend $? +} + +unpack_device_tarball() +{ + local device_tarball=/lib/udev/state/devices.tar.bz2 + if yesno "${rc_device_tarball}" && \ + [ -s "${device_tarball}" ] + then + ebegin "Populating /dev with saved device nodes" + tar -jxpf "${device_tarball}" -C /dev + eend $? + fi +} + +seed_dev() +{ + # Seed /dev with some things that we know we need + + # creating /dev/console and /dev/tty1 to be able to write + # to $CONSOLE with/without bootsplash before udevd creates it + [ -c /dev/console ] || mknod /dev/console c 5 1 + [ -c /dev/tty1 ] || mknod /dev/tty1 c 4 1 + + # udevd will dup its stdin/stdout/stderr to /dev/null + # and we do not want a file which gets buffered in ram + [ -c /dev/null ] || mknod /dev/null c 1 3 + + # copy over any persistant things + if [ -d /lib/udev/devices ]; then + cp -RPp /lib/udev/devices/* /dev 2>/dev/null + fi + + # Not provided by sysfs but needed + ln -snf /proc/self/fd /dev/fd + ln -snf fd/0 /dev/stdin + ln -snf fd/1 /dev/stdout + ln -snf fd/2 /dev/stderr + [ -e /proc/kcore ] && ln -snf /proc/kcore /dev/core + + # Create problematic directories + mkdir -p /dev/pts /dev/shm + return 0 +} + +disable_hotplug_agent() +{ + if [ -e /proc/sys/kernel/hotplug ]; then + echo "" >/proc/sys/kernel/hotplug + fi +} + +root_link() +{ + /lib/udev/write_root_link_rule +} + +persistent_net_switch() +{ + # this function disables rules files + # by creating new files with the same name + # in a temp rules directory with higher priority + local d=/dev/.udev/rules.d + if yesno "${persistent_net_disable:-no}"; then + mkdir -p "$d" + echo "# This file disables persistent-net due to /etc/conf.d/udev" \ + > "$d"/75-persistent-net-generator.rules + fi +} + +start_udevd() +{ + # load unix domain sockets if built as module, Bug #221253 + if [ -e /proc/modules ] ; then + modprobe -q unix 2>/dev/null + fi + ebegin "Starting udevd" + start-stop-daemon --start --exec /sbin/udevd -- --daemon + eend $? +} + +# populate /dev with devices already found by the kernel +populate_dev() +{ + if get_bootparam "nocoldplug" ; then + rc_coldplug="NO" + ewarn "Skipping udev coldplug as requested in kernel cmdline" + fi + + ebegin "Populating /dev with existing devices through uevents" + if yesno "${rc_coldplug}"; then + udevadm trigger + else + # Do not run any init-scripts, Bug #206518 + udevadm control --env do_not_run_plug_service=1 + + # only create device nodes + udevadm trigger --attr-match=dev + + # run persistent-net stuff, bug 191466 + udevadm trigger --subsystem-match=net + fi + eend $? + + ebegin "Waiting for uevents to be processed" + udevadm settle --timeout=60 + eend $? + + udevadm control --env do_not_run_plug_service= + return 0 +} + +compat_volume_nodes() +{ + # Only do this for baselayout-1* + if [ ! -e /lib/librc.so ]; then + + # Create nodes that udev can't + [ -x /sbin/lvm ] && \ + /sbin/lvm vgscan -P --mknodes --ignorelockingfailure &>/dev/null + # Running evms_activate on a LiveCD causes lots of headaches + [ -z "${CDBOOT}" -a -x /sbin/evms_activate ] && \ + /sbin/evms_activate -q &>/dev/null + fi +} + +check_persistent_net() +{ + # check if there are problems with persistent-net + local syspath= devs= problem=false + for syspath in /sys/class/net/*_rename*; do + if [ -d "${syspath}" ]; then + devs="${devs} ${syspath##*/}" + problem=true + fi + done + + ${problem} || return 0 + + eerror "UDEV: Your system has a problem assigning persistent names" + eerror "to these network interfaces: ${devs}" + + einfo "Checking persistent-net rules:" + # the sed-expression lists all duplicate lines + # from the input, like "uniq -d" does, but uniq + # is installed into /usr/bin and not available at boot. + dups=$( + RULES_FILE='/etc/udev/rules.d/70-persistent-net.rules' + . /lib/udev/rule_generator.functions + find_all_rules 'NAME=' '.*' | \ + tr ' ' '\n' | \ + sort | \ + sed '$!N; s/^\(.*\)\n\1$/\1/; t; D' + ) + if [ -n "${dups}" ]; then + ewarn "The rules create multiple entries assigning these names:" + eindent + ewarn "${dups}" + eoutdent + else + ewarn "Found no duplicate names in persistent-net rules," + ewarn "there must be some other problem!" + fi + return 1 +} + +check_udev_works() +{ + # should exist on every system, else udev failed + if [ ! -e /dev/zero ]; then + eerror "Assuming udev failed somewhere, as /dev/zero does not exist." + return 1 + fi + return 0 +} + + + +check_kernel || cleanup +mount_dev_directory || cleanup + +# Create a file so that our rc system knows it's still in sysinit. +# Existance means init scripts will not directly run. +# rc will remove the file when done with sysinit. +touch /dev/.rcsysinit + +# Selinux lovin; /selinux should be mounted by selinux-patched init +if [ -x /sbin/restorecon -a -c /selinux/null ]; then + restorecon /dev > /selinux/null +fi + +unpack_device_tarball +seed_dev +root_link +persistent_net_switch +disable_hotplug_agent + +start_udevd || cleanup +populate_dev || cleanup + +compat_volume_nodes +check_persistent_net + +# trigger executing initscript when /etc is writable +IN_HOTPLUG=1 /etc/init.d/udev-postmount start >/dev/null 2>&1 + +check_udev_works || cleanup + +# udev started successfully +exit 0 diff --git a/sys-fs/udev/files/udev.confd b/sys-fs/udev/files/udev.confd new file mode 100644 index 000000000000..0a0ca7d77983 --- /dev/null +++ b/sys-fs/udev/files/udev.confd @@ -0,0 +1,8 @@ +# /etc/conf.d/udev: config file for udev + +# We discourage to disable persistent-net!! +# this may lead to random interface naming + +# Disable adding new rules for persistent-net +persistent_net_disable="no" + diff --git a/sys-fs/udev/udev-133.ebuild b/sys-fs/udev/udev-133.ebuild index 4bc9e21f1ce3..8e34b8a5ac58 100644 --- a/sys-fs/udev/udev-133.ebuild +++ b/sys-fs/udev/udev-133.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2008 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/sys-fs/udev/udev-133.ebuild,v 1.2 2008/11/19 21:20:02 zzam Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-fs/udev/udev-133.ebuild,v 1.3 2008/11/23 20:05:19 zzam Exp $ inherit eutils flag-o-matic multilib toolchain-funcs versionator @@ -110,6 +110,8 @@ src_install() { into / emake DESTDIR="${D}" install || die "make install failed" if [[ "$(get_libdir)" != "lib" ]]; then + # we can not just rename /lib to /lib64, because + # make install creates /lib64 and /lib mkdir -p "${D}/$(get_libdir)" mv "${D}"/lib/* "${D}/$(get_libdir)/" rmdir "${D}"/lib @@ -156,7 +158,7 @@ src_install() { # our udev hooks into the rc system insinto /$(get_libdir)/rcscripts/addons - newins "${FILESDIR}"/udev-start-126.sh udev-start.sh + newins "${FILESDIR}"/udev-start-133.sh udev-start.sh newins "${FILESDIR}"/udev-stop-126.sh udev-stop.sh # The udev-post init-script @@ -165,6 +167,9 @@ src_install() { # init-script for >=openrc-0.3.1, Bug #240984 newinitd "${FILESDIR}/udev.initd" udev + # config file for init-script and start-addon + newconfd "${FILESDIR}/udev.confd" udev + insinto /etc/modprobe.d newins "${FILESDIR}"/blacklist-110 blacklist doins "${FILESDIR}"/pnp-aliases |