summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Frysinger <vapier@gentoo.org>2007-04-17 00:14:33 +0000
committerMike Frysinger <vapier@gentoo.org>2007-04-17 00:14:33 +0000
commit989a1d97018c374c9daf9fab09cf7008a248ae31 (patch)
treebca2b22df36c4aa1fa25a87143dcdb1a53bdaa69
parentStable on Alpha, bug 174312. (diff)
downloadgentoo-2-989a1d97018c374c9daf9fab09cf7008a248ae31.tar.gz
gentoo-2-989a1d97018c374c9daf9fab09cf7008a248ae31.tar.bz2
gentoo-2-989a1d97018c374c9daf9fab09cf7008a248ae31.zip
Make an addon for mdev startup.
(Portage version: 2.1.2.3)
-rw-r--r--sys-apps/busybox/ChangeLog6
-rw-r--r--sys-apps/busybox/busybox-1.5.0.ebuild5
-rwxr-xr-xsys-apps/busybox/files/mdev-start.sh93
3 files changed, 102 insertions, 2 deletions
diff --git a/sys-apps/busybox/ChangeLog b/sys-apps/busybox/ChangeLog
index 1f0ea75605fa..54ff03eced73 100644
--- a/sys-apps/busybox/ChangeLog
+++ b/sys-apps/busybox/ChangeLog
@@ -1,6 +1,10 @@
# ChangeLog for sys-apps/busybox
# Copyright 1999-2007 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/sys-apps/busybox/ChangeLog,v 1.136 2007/04/07 08:49:36 opfer Exp $
+# $Header: /var/cvsroot/gentoo-x86/sys-apps/busybox/ChangeLog,v 1.137 2007/04/17 00:14:33 vapier Exp $
+
+ 17 Apr 2007; Mike Frysinger <vapier@gentoo.org> +files/mdev-start.sh,
+ busybox-1.5.0.ebuild:
+ Make an addon for mdev startup.
07 Apr 2007; Christian Faulhammer <opfer@gentoo.org>
busybox-1.4.1-r2.ebuild:
diff --git a/sys-apps/busybox/busybox-1.5.0.ebuild b/sys-apps/busybox/busybox-1.5.0.ebuild
index 85d98b5a14f6..03d8e0d3b6d8 100644
--- a/sys-apps/busybox/busybox-1.5.0.ebuild
+++ b/sys-apps/busybox/busybox-1.5.0.ebuild
@@ -1,6 +1,6 @@
# Copyright 1999-2007 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/sys-apps/busybox/busybox-1.5.0.ebuild,v 1.5 2007/04/06 00:21:59 vapier Exp $
+# $Header: /var/cvsroot/gentoo-x86/sys-apps/busybox/busybox-1.5.0.ebuild,v 1.6 2007/04/17 00:14:33 vapier Exp $
inherit eutils flag-o-matic
@@ -183,6 +183,9 @@ src_install() {
|| dobin bb
dosym bb /bin/busybox.static
+ insinto /$(get_libdir)/rcscripts/addons
+ doins "${FILESDIR}"/mdev-start.sh || die
+
# bundle up the symlink files for use later
emake install || die
rm _install/bin/busybox
diff --git a/sys-apps/busybox/files/mdev-start.sh b/sys-apps/busybox/files/mdev-start.sh
new file mode 100755
index 000000000000..bd2c60f137c2
--- /dev/null
+++ b/sys-apps/busybox/files/mdev-start.sh
@@ -0,0 +1,93 @@
+# Copyright 1999-2007 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+populate_mdev() {
+ # populate /dev with devices already found by the kernel
+
+ if get_bootparam "nocoldplug" ; then
+ RC_COLDPLUG="no"
+ ewarn "Skipping mdev coldplug as requested in kernel cmdline"
+ fi
+
+ ebegin "Populating /dev with existing devices with mdev -s"
+ mdev -s
+ eend $?
+
+ return 0
+}
+
+seed_dev() {
+ # Seed /dev with some things that we know we need
+ ebegin "Seeding /dev with needed nodes"
+
+ # creating /dev/console and /dev/tty1 to be able to write
+ # to $CONSOLE with/without bootsplash before mdev creates it
+ [ ! -c /dev/console ] && mknod /dev/console c 5 1
+ [ ! -c /dev/tty1 ] && mknod /dev/tty1 c 4 1
+
+ # copy over any persistant things
+ if [ -d /lib/mdev/devices ] ; then
+ cp --preserve=all --recursive --update /lib/mdev/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
+ eend 0
+}
+
+main() {
+ # Setup temporary storage for /dev
+ ebegin "Mounting /dev for mdev"
+ if [ "${RC_USE_FSTAB}" = "yes" ] ; then
+ mntcmd=$(get_mount_fstab /dev)
+ else
+ unset mntcmd
+ fi
+ if [ -n "${mntcmd}" ] ; then
+ try mount -n ${mntcmd}
+ else
+ if grep -Eq "[[:space:]]+tmpfs$" /proc/filesystems ; then
+ mntcmd="tmpfs"
+ else
+ mntcmd="ramfs"
+ fi
+ # many video drivers require exec access in /dev #92921
+ try mount -n -t "${mntcmd}" -o exec,nosuid,mode=0755 mdev /dev
+ fi
+ eend $?
+
+ # 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 ] && [ -c /selinux/null ] ; then
+ restorecon /dev > /selinux/null
+ fi
+
+ seed_dev
+
+ # Setup hotplugging (if possible)
+ if [ -e /proc/sys/kernel/hotplug ] ; then
+ ebegin "Setting up proper hotplug agent"
+ eindent
+ einfo "Setting /sbin/mdev as hotplug agent ..."
+ echo "/sbin/mdev" > /proc/sys/kernel/hotplug
+ eoutdent
+ eend 0
+ fi
+
+ populate_mdev
+}
+
+main
+
+# vim:ts=4