[arch-projects] [mkinitcpio] [PATCH 2/2] autodetect: read modaliases from uevent files

Dave Reisner dreisner at archlinux.org
Sat Sep 21 19:57:59 EDT 2013


As suggested by Harald Hoyer, this is more accurate for the sake of
following where udev gets its modaliases from. In some rare cases, it
may even be more complete than scraping the raw modalias files.

Also, introduce a wrapper around modprobe so that the options passed
are never ommitted, or wrongly specified. In this case, a subtle bug
with the -r flag is fixed due to using the wrong variable with
modprobe's -d flag.

Signed-off-by: Dave Reisner <dreisner at archlinux.org>
---
 functions          | 12 +++++++-----
 install/autodetect |  3 +--
 2 files changed, 8 insertions(+), 7 deletions(-)

diff --git a/functions b/functions
index 4f231b1..f0dce80 100644
--- a/functions
+++ b/functions
@@ -251,16 +251,18 @@ list_hookpoints() {
     in_array run_cleanuphook "${funcs[@]}" && msg2 "cleanup hook"
 }
 
+modprobe() {
+    command modprobe -d "$_optmoduleroot" -S "$KERNELVERSION" "$@"
+}
+
 auto_modules() {
     # Perform auto detection of modules via sysfs.
 
     local mods=
 
-    IFS=$'\n' read -rd '' -a mods < \
-        <(find /sys/devices -name modalias -exec sort -u {} + |
-        # delimit each input by a newline, expanded in place
-        xargs -d $'\n' modprobe -d "$MODULEROOT" -qaRS "$KERNELVERSION" |
-        sort -u)
+    mapfile -t mods < <(find /sys/devices -name uevent \
+        -exec sort -u {} + | awk -F= '$1 == "MODALIAS" && !_[$0]++')
+    mapfile -t mods < <(modprobe -qaR "${mods[@]#MODALIAS=}")
 
     (( ${#mods[*]} )) && printf "%s\n" "${mods[@]//-/_}"
 }
diff --git a/install/autodetect b/install/autodetect
index b3db536..43e8df2 100644
--- a/install/autodetect
+++ b/install/autodetect
@@ -10,8 +10,7 @@ build() {
         # treat this as an alias, since ext3 might be aliased to ext4. also, as
         # of linux 3.9, we can find any filesystem by the alias "fs-$name"
         # rather than having to guess at the corresponding module name.
-        IFS=$'\n' read -rd '' -a resolved < \
-            <(modprobe -d "$_optmoduleroot" -S "$KERNELVERSION" -Ra {fs-,}"$1" 2>/dev/null)
+        IFS=$'\n' read -rd '' -a resolved < <(modprobe -Ra {fs-,}"$1" 2>/dev/null)
 
         for r in "${resolved[@]}"; do
             _autodetect_cache["$r"]=1
-- 
1.8.4



More information about the arch-projects mailing list