Harald Hoyer d9da66
From b925f7f5d97259dd81e9d562fd1c6433e4b04f30 Mon Sep 17 00:00:00 2001
Harald Hoyer d9da66
From: Harald Hoyer <harald@hoyer.xyz>
Harald Hoyer d9da66
Date: Mon, 15 Jan 2018 09:04:12 +0100
Harald Hoyer d9da66
Subject: [PATCH] Merge pull request #347 from danimo/81cio_ignore
Harald Hoyer d9da66
Harald Hoyer d9da66
81cio_ignore: handle cio_ignore commandline
Harald Hoyer d9da66
---
Harald Hoyer d9da66
 dracut.cmdline.7.asc                       | 15 +++++++++++
Harald Hoyer d9da66
 modules.d/81cio_ignore/module-setup.sh     | 40 ++++++++++++++++++++++++++++++
Harald Hoyer d9da66
 modules.d/81cio_ignore/parse-cio_accept.sh | 22 ++++++++++++++++
Harald Hoyer d9da66
 3 files changed, 77 insertions(+)
Harald Hoyer d9da66
Harald Hoyer d9da66
diff --git a/dracut.cmdline.7.asc b/dracut.cmdline.7.asc
Harald Hoyer d9da66
index f95f4d63..8f83405e 100644
Harald Hoyer d9da66
--- a/dracut.cmdline.7.asc
Harald Hoyer d9da66
+++ b/dracut.cmdline.7.asc
Harald Hoyer d9da66
@@ -1015,6 +1015,21 @@ ZIPL
Harald Hoyer d9da66
 rd.zipl=UUID=0fb28157-99e3-4395-adef-da3f7d44835a
Harald Hoyer d9da66
 --
Harald Hoyer d9da66
 
Harald Hoyer d9da66
+CIO_IGNORE
Harald Hoyer d9da66
+~~~~~~~~~~
Harald Hoyer d9da66
+**rd.cio_accept=**__<device-ids>__::
Harald Hoyer d9da66
+    Remove the devices listed in <device-ids> from the default
Harald Hoyer d9da66
+    cio_ignore kernel command-line settings.
Harald Hoyer d9da66
+    <device-ids> is a list of comma-separated CCW device ids.
Harald Hoyer d9da66
+    The default for this value is taken from the
Harald Hoyer d9da66
+    _/boot/zipl/active_devices.txt_ file.
Harald Hoyer d9da66
++
Harald Hoyer d9da66
+[listing]
Harald Hoyer d9da66
+.Example
Harald Hoyer d9da66
+--
Harald Hoyer d9da66
+rd.cio_accept=0.0.0180,0.0.0800,0.0.0801,0.0.0802
Harald Hoyer d9da66
+--
Harald Hoyer d9da66
+
Harald Hoyer d9da66
 Plymouth Boot Splash
Harald Hoyer d9da66
 ~~~~~~~~~~~~~~~~~~~~
Harald Hoyer d9da66
 **plymouth.enable=0**::
Harald Hoyer d9da66
diff --git a/modules.d/81cio_ignore/module-setup.sh b/modules.d/81cio_ignore/module-setup.sh
Harald Hoyer d9da66
new file mode 100755
Harald Hoyer d9da66
index 00000000..37b414bf
Harald Hoyer d9da66
--- /dev/null
Harald Hoyer d9da66
+++ b/modules.d/81cio_ignore/module-setup.sh
Harald Hoyer d9da66
@@ -0,0 +1,40 @@
Harald Hoyer d9da66
+#!/bin/bash
Harald Hoyer d9da66
+# -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
Harald Hoyer d9da66
+# ex: ts=8 sw=4 sts=4 et filetype=sh
Harald Hoyer d9da66
+
Harald Hoyer d9da66
+# called by dracut
Harald Hoyer d9da66
+check() {
Harald Hoyer d9da66
+# do not add this module by default
Harald Hoyer d9da66
+    local arch=$(uname -m)
Harald Hoyer d9da66
+    [ "$arch" = "s390" -o "$arch" = "s390x" ] || return 1
Harald Hoyer d9da66
+    return 0
Harald Hoyer d9da66
+}
Harald Hoyer d9da66
+
Harald Hoyer d9da66
+cmdline() {
Harald Hoyer d9da66
+    local cio_accept
Harald Hoyer d9da66
+
Harald Hoyer d9da66
+    if [ -e /boot/zipl/active_devices.txt ] ; then
Harald Hoyer d9da66
+        while read dev etc ; do
Harald Hoyer d9da66
+            [ "$dev" = "#" -o "$dev" = "" ] && continue;
Harald Hoyer d9da66
+            if [ -z "$cio_accept" ] ; then
Harald Hoyer d9da66
+                cio_accept="$dev"
Harald Hoyer d9da66
+            else
Harald Hoyer d9da66
+                cio_accept="${cio_accept},${dev}"
Harald Hoyer d9da66
+            fi
Harald Hoyer d9da66
+        done < /boot/zipl/active_devices.txt
Harald Hoyer d9da66
+    fi
Harald Hoyer d9da66
+    if [ -n "$cio_accept" ] ; then
Harald Hoyer d9da66
+	echo "rd.cio_accept=${cio_accept}"
Harald Hoyer d9da66
+    fi
Harald Hoyer d9da66
+}
Harald Hoyer d9da66
+
Harald Hoyer d9da66
+# called by dracut
Harald Hoyer d9da66
+install() {
Harald Hoyer d9da66
+    if [[ $hostonly_cmdline == "yes" ]] ; then
Harald Hoyer d9da66
+        local _cio_accept=$(cmdline)
Harald Hoyer d9da66
+        [[ $_cio_accept ]] && printf "%s\n" "$_cio_accept" >> "${initdir}/etc/cmdline.d/01cio_accept.conf"
Harald Hoyer d9da66
+    fi
Harald Hoyer d9da66
+
Harald Hoyer d9da66
+    inst_hook cmdline 20 "$moddir/parse-cio_accept.sh"
Harald Hoyer d9da66
+    inst_multiple cio_ignore
Harald Hoyer d9da66
+}
Harald Hoyer d9da66
diff --git a/modules.d/81cio_ignore/parse-cio_accept.sh b/modules.d/81cio_ignore/parse-cio_accept.sh
Harald Hoyer d9da66
new file mode 100755
Harald Hoyer d9da66
index 00000000..4f899d25
Harald Hoyer d9da66
--- /dev/null
Harald Hoyer d9da66
+++ b/modules.d/81cio_ignore/parse-cio_accept.sh
Harald Hoyer d9da66
@@ -0,0 +1,22 @@
Harald Hoyer d9da66
+#!/bin/sh
Harald Hoyer d9da66
+# -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
Harald Hoyer d9da66
+# ex: ts=8 sw=4 sts=4 et filetype=sh
Harald Hoyer d9da66
+
Harald Hoyer d9da66
+CIO_IGNORE=$(getarg cio_ignore)
Harald Hoyer d9da66
+CIO_ACCEPT=$(getarg rd.cio_accept)
Harald Hoyer d9da66
+
Harald Hoyer d9da66
+if [ -z $CIO_IGNORE ] ; then
Harald Hoyer d9da66
+    info "cio_ignored disabled on commandline"
Harald Hoyer d9da66
+    return
Harald Hoyer d9da66
+fi
Harald Hoyer d9da66
+if [ -n "$CIO_ACCEPT" ] ; then
Harald Hoyer d9da66
+    OLDIFS="$IFS"
Harald Hoyer d9da66
+    IFS=,
Harald Hoyer d9da66
+    set -- $CIO_ACCEPT
Harald Hoyer d9da66
+    while (($# > 0)) ; do
Harald Hoyer d9da66
+        info "Enabling device $1"
Harald Hoyer d9da66
+        cio_ignore --remove $1
Harald Hoyer d9da66
+        shift
Harald Hoyer d9da66
+    done
Harald Hoyer d9da66
+    IFS="$OLDIFS"
Harald Hoyer d9da66
+fi
Harald Hoyer d9da66