busybox: S01mdev: fix module autoloading
authorPeter Korsgaard <peter@korsgaard.com>
Mon, 7 May 2018 18:35:01 +0000 (20:35 +0200)
committerThomas Petazzoni <thomas.petazzoni@bootlin.com>
Tue, 8 May 2018 13:01:34 +0000 (15:01 +0200)
Commit b4fc5a180c (package/busybox: support spaces in module aliases in
mdev) changed the mdev coldplugging to handle sysfs path elements and
modalias values containing spaces.  This unfortunately doesn't work as was
recently reported:

http://lists.busybox.net/pipermail/buildroot/2018-May/220903.html

The problem is that sort -z also expects the fields of the input files to be
zero terminated, which is not the case for modalias sysfs entries.

So drop the -z option to sort.  Spaces in modalias entries could be handled
with the xargs -d '\n' option, but that is unfortunately not supported by
the busybox applet.  Instead, use tr to convert newlines to zeros so we can
use xargs -0.

Reported-by: Daniel Palmer <daniel@0x0f.com>
Signed-off-by: Peter Korsgaard <peter@korsgaard.com>
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
package/busybox/S10mdev

index 63ca955b1c551671dc18adac4f7e961430c1a675..7075b770166fe10ee587a6c87a4bdd92769b9674 100644 (file)
@@ -9,7 +9,8 @@ case "$1" in
        echo /sbin/mdev >/proc/sys/kernel/hotplug
        /sbin/mdev -s
        # coldplug modules
-       find /sys/ -name modalias -print0 | xargs -0 sort -u -z | xargs -0 modprobe -abq
+       find /sys/ -name modalias -print0 | xargs -0 sort -u | tr '\n' '\0' | \
+           xargs -0 modprobe -abq
        ;;
   stop)
        ;;