[OE-core] [PATCH 12/16] udev: improve udev-cache robustness
Richard Purdie
richard.purdie at linuxfoundation.org
Wed Jan 4 17:14:12 UTC 2012
On Wed, 2011-12-28 at 19:55 +0000, Otavio Salvador wrote:
> * allow udev-cache to be disabled at runtime (using
> /etc/default/udev-cache);
>
> * make cache invalidated if kernel, bootparams or device list
> changes;
>
> Signed-off-by: Otavio Salvador <otavio at ossystems.com.br>
> ---
> meta/recipes-core/udev/udev.inc | 11 ++++++++++-
> meta/recipes-core/udev/udev/init | 18 +++++++++++++++---
> meta/recipes-core/udev/udev/udev-cache | 20 +++++++++++++++++---
> meta/recipes-core/udev/udev/udev-cache.default | 4 ++++
> meta/recipes-core/udev/udev_164.bb | 2 +-
> 5 files changed, 47 insertions(+), 8 deletions(-)
> create mode 100644 meta/recipes-core/udev/udev/udev-cache.default
>
> diff --git a/meta/recipes-core/udev/udev.inc b/meta/recipes-core/udev/udev.inc
> index 198336b..a228e5f 100644
> --- a/meta/recipes-core/udev/udev.inc
> +++ b/meta/recipes-core/udev/udev.inc
> @@ -25,6 +25,7 @@ SRC_URI = "${KERNELORG_MIRROR}/linux/utils/kernel/hotplug/udev-${PV}.tar.gz \
> file://network.sh \
> file://local.rules \
> file://udev-cache \
> + file://udev-cache.default \
> file://init"
>
> inherit autotools pkgconfig update-rc.d
> @@ -56,7 +57,7 @@ FILES_libgudev = "${base_libdir}/libgudev*.so.* ${libdir}/libgudev*.so.*"
> FILES_libgudev-dbg = "${base_libdir}/.debug/libgudev*.so.* ${libdir}/.debug/libgudev*.so.*"
> FILES_libgudev-dev = "${includedir}/gudev* ${libdir}/libgudev*.so ${libdir}/libgudev*.la \
> ${libdir}/libgudev*.a ${libdir}/pkgconfig/gudev*.pc"
> -FILES_udev-cache = "${sysconfdir}/init.d/udev-cache"
> +FILES_udev-cache = "${sysconfdir}/init.d/udev-cache ${sysconfdir}/default/udev-cache"
>
> FILES_udev-acl = "${base_libdir}/udev/udev-acl ${base_libdir}/udev/rules.d/70-acl.rules"
>
> @@ -68,6 +69,14 @@ do_install_append () {
> install -m 0755 ${WORKDIR}/init ${D}${sysconfdir}/init.d/udev
> install -m 0755 ${WORKDIR}/udev-cache ${D}${sysconfdir}/init.d/udev-cache
>
> + install -d ${D}${sysconfdir}/default
> + install -m 0755 ${WORKDIR}/udev-cache.default ${D}${sysconfdir}/default/udev-cache
> +
> + touch ${D}${sysconfdir}/udev/saved.uname
> + touch ${D}${sysconfdir}/udev/saved.cmdline
> + touch ${D}${sysconfdir}/udev/saved.devices
> + touch ${D}${sysconfdir}/udev/saved.atags
> +
> install -d ${D}${sysconfdir}/udev/rules.d/
>
> install -m 0644 ${WORKDIR}/local.rules ${D}${sysconfdir}/udev/rules.d/local.rules
> diff --git a/meta/recipes-core/udev/udev/init b/meta/recipes-core/udev/udev/init
> index c2b491e..5468bd9 100644
> --- a/meta/recipes-core/udev/udev/init
> +++ b/meta/recipes-core/udev/udev/init
> @@ -14,6 +14,7 @@ export TZ=/etc/localtime
> [ -d /sys/class ] || exit 1
> [ -r /proc/mounts ] || exit 1
> [ -x /sbin/udevd ] || exit 1
> +[ -f /etc/default/udev-cache ] && . /etc/default/udev-cache
> [ -f /etc/udev/udev.conf ] && . /etc/udev/udev.conf
>
> kill_udevd() {
> @@ -35,9 +36,20 @@ mkdir -p -m 0755 /dev/pts
> mkdir -p -m 1777 /dev/shm
>
>
> -if [ -e /etc/dev.tar ]; then
> - (cd /; tar xf /etc/dev.tar 2>&1 | grep -v 'time stamp' || true)
> - not_first_boot=1
> +if [ "$DEVCACHE" != "" ]; then
> + # Invalidate udev cache if the kernel or its bootargs/cmdline have changed
> + [ -x /bin/uname ] && /bin/uname -mrspv > /dev/shm/uname || touch /dev/shm/uname
> + [ -r /proc/cmdline ] && cat /proc/cmdline > /dev/shm/cmdline || touch /dev/shm/cmdline
> + [ -r /proc/devices ] && cat /proc/devices > /dev/shm/devices || touch /dev/shm/devices
> + [ -r /proc/atags ] && cat /proc/atags > /dev/shm/atags || touch /dev/shm/atags
> + if [ -e $DEVCACHE ] && \
> + cmp -s /dev/shm/uname /etc/udev/saved.uname && \
> + cmp -s /dev/shm/cmdline /etc/udev/saved.cmdline && \
> + cmp -s /dev/shm/devices /etc/udev/saved.devices && \
> + cmp -s /dev/shm/atags /etc/udev/saved.atags; then
> + (cd /; tar xf $DEVCACHE > /dev/null 2>&1)
> + not_first_boot=1
> + fi
> fi
You're adding a ton of exec calls into the boot process here :(
Please can we find some better way to do this without all the exec()
calls?
Cheers,
Richard
More information about the Openembedded-core
mailing list