summaryrefslogtreecommitdiff
path: root/meta/packages/udev/udev-158/init
diff options
context:
space:
mode:
authorQing He <qing.he@intel.com>2010-07-21 13:34:35 +0800
committerRichard Purdie <rpurdie@linux.intel.com>2010-07-24 00:07:30 +0100
commitcbea4ae33f42c1553ed99a7d3bada00ce68ff9fd (patch)
tree7fa306cd580cdaccc1d739ae08d472161f8a5bf9 /meta/packages/udev/udev-158/init
parent3a1c4561721ac0be9bb0cb1fca5f5d41d18a085c (diff)
downloadopenembedded-core-cbea4ae33f42c1553ed99a7d3bada00ce68ff9fd.tar.gz
openembedded-core-cbea4ae33f42c1553ed99a7d3bada00ce68ff9fd.tar.bz2
openembedded-core-cbea4ae33f42c1553ed99a7d3bada00ce68ff9fd.tar.xz
openembedded-core-cbea4ae33f42c1553ed99a7d3bada00ce68ff9fd.zip
udev: upgrade to version 158
older versions are kept untouched for now changes: - udev has diverged a lot, the udev.inc was based on a quite dated version, thus doesn't reflect current status of udev, create a new include file udev-new.inc to adapt - separate libudev{,-dev,-dbg} apart from udev - --with-udev-prefix is removed. change ${libexecdir} to ${base_libdir}/udev, which is described in INSTALL file. - udev.pc is provided in ${datadir}/pkgconfig, since it's used to indicate the existence of udev itself instead of development headers and libs, pack it in udev instead of udev-dev - udev-extras is disabled since we are missing libacl, this also means gudev is missing as for now - other cleanups, e.g. do_stage, do_install, EXTRA_OEMAKE todo: - udev-extras - remove old udev versions - rebase udev-145 on udev-new.inc as well Signed-off-by: Qing He <qing.he@intel.com>
Diffstat (limited to 'meta/packages/udev/udev-158/init')
-rw-r--r--meta/packages/udev/udev-158/init59
1 files changed, 59 insertions, 0 deletions
diff --git a/meta/packages/udev/udev-158/init b/meta/packages/udev/udev-158/init
new file mode 100644
index 000000000..eb5e50758
--- /dev/null
+++ b/meta/packages/udev/udev-158/init
@@ -0,0 +1,59 @@
+#!/bin/sh -e
+
+### BEGIN INIT INFO
+# Provides: udev
+# Required-Start: mountvirtfs
+# Required-Stop:
+# Default-Start: S
+# Default-Stop:
+# Short-Description: Start udevd, populate /dev and load drivers.
+### END INIT INFO
+
+export TZ=/etc/localtime
+
+[ -d /sys/class ] || exit 1
+[ -r /proc/mounts ] || exit 1
+[ -x /sbin/udevd ] || exit 1
+[ -f /etc/udev/udev.conf ] && . /etc/udev/udev.conf
+
+kill_udevd() {
+ if [ -x /sbin/pidof ]; then
+ pid=`/sbin/pidof -x udevd`
+ [ -n "$pid" ] && kill $pid
+ fi
+}
+
+export ACTION=add
+# propagate /dev from /sys
+echo -n "Starting udev"
+
+# mount the tmpfs on /dev, if not already done
+LANG=C awk "\$2 == \"/dev\" && \$4 == \"tmpfs\" { exit 1 }" /proc/mounts && {
+ mount -n -o mode=0755 -t tmpfs none "/dev"
+ mkdir -m 0755 /dev/pts
+ mkdir -m 1777 /dev/shm
+}
+
+if [ -e /etc/dev.tar ]; then
+ (cd /; tar xf /etc/dev.tar)
+ not_first_boot=1
+fi
+
+# make_extra_nodes
+kill_udevd > "/dev/null" 2>&1
+
+ # trigger the sorted events
+ echo -e '\000\000\000\000' > /proc/sys/kernel/hotplug
+ /sbin/udevd -d
+
+ /sbin/udevadm control --env=STARTUP=1
+ if [ "$not_first_boot" != "" ];then
+ /sbin/udevadm trigger --subsystem-nomatch=tty --subsystem-nomatch=mem --subsystem-nomatch=vc --subsystem-nomatch=vtconsole --subsystem-nomatch=misc --subsystem-nomatch=dcon --subsystem-nomatch=pci_bus --subsystem-nomatch=graphics --subsystem-nomatch=backlight --subsystem-nomatch=video4linux --subsystem-nomatch=platform
+ (/sbin/udevadm settle --timeout=3; /sbin/udevadm control --env=STARTUP=)&
+ else
+ /sbin/udevadm trigger
+ /sbin/udevadm settle
+ fi
+
+echo
+exit 0