Blob Blame History Raw
From 9edf1b206b69a9f6d6d038d333d8b855145ed4d6 Mon Sep 17 00:00:00 2001
From: Harald Hoyer <harald@redhat.com>
Date: Fri, 18 Feb 2011 13:27:31 +0100
Subject: [PATCH] init: set cdrom polling in kernel

and reset to -1 after we are done.
---
 modules.d/99base/init |   22 +++++++++++++++++-----
 1 files changed, 17 insertions(+), 5 deletions(-)

diff --git a/modules.d/99base/init b/modules.d/99base/init
index 0a05e91..b49c87a 100755
--- a/modules.d/99base/init
+++ b/modules.d/99base/init
@@ -203,15 +203,19 @@ while :; do
     # dirty hack for some cdrom drives,
     # which report no medium for quiet
     # some time.
-    if [ ! -e /sys/module/block/parameters/events_dfl_poll_msecs ]; then
-        for cdrom in /sys/block/sr*; do
-            [ -e "$cdrom" ] || continue       
+    for cdrom in /sys/block/sr*; do
+        [ -e "$cdrom" ] || continue 
+        if [ -e "$cdrom"/events_poll_msecs ]; then
+            msecs=$(while read a; do echo $a;done < "$cdrom"/events_poll_msecs)
+            [ "$msecs" = "-1" ] && \
+                echo 1000 > "$cdrom"/events_poll_msecs
+        else
             # skip, if cdrom medium was already found
             strstr "$(udevadm info --query=env --path=${cdrom##/sys})" \
                 ID_CDROM_MEDIA && continue
             echo change > "$cdrom/uevent"        
-        done
-    fi
+        fi
+    done
     
     i=$(($i+1))
     [ $i -gt $RDRETRY ] \
@@ -220,6 +224,14 @@ done
 unset job
 unset queuetriggered
 
+# reset cdrom polling
+for cdrom in /sys/block/sr*; do
+    [ -e "$cdrom" ] || continue 
+    if [ -e "$cdrom"/events_poll_msecs ]; then
+        echo -1 > "$cdrom"/events_poll_msecs
+    fi
+done
+
 # pre-mount happens before we try to mount the root filesystem,
 # and happens once.
 getarg 'rd.break=pre-mount' 'rdbreak=pre-mount' && emergency_shell -n pre-mount "Break pre-mount"