forked from pool/s390-tools
Accepting request 555142 from Base:System
OBS-URL: https://build.opensuse.org/request/show/555142 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/s390-tools?expand=0&rev=15
This commit is contained in:
commit
cfaef81101
@ -106,11 +106,11 @@ else DEV_TYPE="ctc"
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "${ON_OFF}" == 0 ]; then
|
if [ "${ON_OFF}" == 0 ]; then
|
||||||
debug_mesg "chzdev -d ${DEV_TYPE} ${CTC_READ_CHAN}"
|
debug_mesg "chzdev -d ${DEV_TYPE} --no-root-update ${CTC_READ_CHAN}"
|
||||||
chzdev -d ${DEV_TYPE} ${CTC_READ_CHAN}
|
chzdev -d ${DEV_TYPE} --no-root-update ${CTC_READ_CHAN}
|
||||||
elif [ "${ON_OFF}" == 1 ]; then
|
elif [ "${ON_OFF}" == 1 ]; then
|
||||||
debug_mesg "chzdev -e ${DEV_TYPE} ${CTC_READ_CHAN} ${PARM_LIST}"
|
debug_mesg "chzdev -e ${DEV_TYPE} --no-root-update ${CTC_READ_CHAN} ${PARM_LIST}"
|
||||||
chzdev -e ${DEV_TYPE} ${CTC_READ_CHAN} ${PARM_LIST}
|
chzdev -e ${DEV_TYPE} --no-root-update ${CTC_READ_CHAN} ${PARM_LIST}
|
||||||
else mesg "You must specify a 0 or a 1 for the online/offline attribute."
|
else mesg "You must specify a 0 or a 1 for the online/offline attribute."
|
||||||
usage
|
usage
|
||||||
exit 1
|
exit 1
|
||||||
|
@ -125,11 +125,11 @@ else PARM_LIST="${PARM_LIST} use_diag=0"
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "${ON_OFF}" == 0 ]; then
|
if [ "${ON_OFF}" == 0 ]; then
|
||||||
debug_mesg "chzdev -d dasd ${CCW_CHAN_ID}"
|
debug_mesg "chzdev -d dasd --no-root-update ${CCW_CHAN_ID}"
|
||||||
chzdev -d dasd ${CCW_CHAN_ID}
|
chzdev -d dasd --no-root-update ${CCW_CHAN_ID}
|
||||||
elif [ "${ON_OFF}" == 1 ]; then
|
elif [ "${ON_OFF}" == 1 ]; then
|
||||||
debug_mesg "chzdev -e dasd ${CCW_CHAN_ID} ${PARM_LIST}"
|
debug_mesg "chzdev -e dasd --no-root-update ${CCW_CHAN_ID} ${PARM_LIST}"
|
||||||
chzdev -e dasd ${CCW_CHAN_ID} ${PARM_LIST}
|
chzdev -e dasd --no-root-update ${CCW_CHAN_ID} ${PARM_LIST}
|
||||||
else mesg "You must specify a 0 or a 1 for the online/offline attribute."
|
else mesg "You must specify a 0 or a 1 for the online/offline attribute."
|
||||||
usage
|
usage
|
||||||
exit 1
|
exit 1
|
||||||
|
@ -151,11 +151,11 @@ if [ -z "${QETH_READ_CHAN}" ] || [ -z "${QETH_WRITE_CHAN}" ] || [ -z "${QETH_DAT
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "${ON_OFF}" == 0 ]; then
|
if [ "${ON_OFF}" == 0 ]; then
|
||||||
debug_mesg "chzdev -d qeth ${QETH_READ_CHAN}"
|
debug_mesg "chzdev -d qeth --no-root-update ${QETH_READ_CHAN}"
|
||||||
chzdev -d qeth ${QETH_READ_CHAN}
|
chzdev -d qeth --no-root-update ${QETH_READ_CHAN}
|
||||||
elif [ "${ON_OFF}" == 1 ]; then
|
elif [ "${ON_OFF}" == 1 ]; then
|
||||||
debug_mesg "chzdev -e qeth ${LAYER_MODE} ${PARM_LIST} ${QETH_READ_CHAN}"
|
debug_mesg "chzdev -e qeth --no-root-update ${LAYER_MODE} ${PARM_LIST} ${QETH_READ_CHAN}"
|
||||||
chzdev -e qeth ${LAYER_MODE} ${PARM_LIST} ${QETH_READ_CHAN}
|
chzdev -e qeth ${LAYER_MODE} --no-root-update ${PARM_LIST} ${QETH_READ_CHAN}
|
||||||
else mesg "You must specify a 0 or a 1 for the online/offline attribute."
|
else mesg "You must specify a 0 or a 1 for the online/offline attribute."
|
||||||
usage
|
usage
|
||||||
exit 1
|
exit 1
|
||||||
|
27
s390-tools-sles15-cpi-add-unit-install-section.patch
Normal file
27
s390-tools-sles15-cpi-add-unit-install-section.patch
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
Subject: [PATCH] [BZ 160944] cpi: add missing Install section to service unit
|
||||||
|
From: Hendrik Brueckner <brueckner@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
Description: cpi: add missing Install section to service unit
|
||||||
|
Symptom: Enabling the cpi service unit fails because it
|
||||||
|
does not include information about where to install
|
||||||
|
it.
|
||||||
|
Problem: An install section is missing.
|
||||||
|
Solution: Add an install section.
|
||||||
|
Reproduction: Issue systemctl enable cpi.
|
||||||
|
Upstream-ID: -
|
||||||
|
Problem-ID: 160944
|
||||||
|
|
||||||
|
Signed-off-by: Hendrik Brueckner <brueckner@linux.vnet.ibm.com>
|
||||||
|
---
|
||||||
|
systemd/cpi.service.in | 3 +++
|
||||||
|
1 file changed, 3 insertions(+)
|
||||||
|
|
||||||
|
--- a/systemd/cpi.service.in
|
||||||
|
+++ b/systemd/cpi.service.in
|
||||||
|
@@ -38,3 +38,6 @@ EnvironmentFile=/etc/sysconfig/cpi
|
||||||
|
#
|
||||||
|
# Sending data to the HMC/SE
|
||||||
|
ExecStart=@toolslib_path@/cpictl -e
|
||||||
|
+
|
||||||
|
+[Install]
|
||||||
|
+WantedBy=multi-user.target
|
@ -0,0 +1,202 @@
|
|||||||
|
Subject: [PATCH] [BZ 161563] cpuplugd: Improve systemctl start error handling
|
||||||
|
From: Gerald Schaefer <gerald.schaefer@de.ibm.com>
|
||||||
|
|
||||||
|
Description: cpuplugd, mon_tools: Improve systemctl start error handling
|
||||||
|
Symptom: "systemctl start cpuplugd/mon_procd/mon_fsstatd" does not
|
||||||
|
report any errors in case the startup fails.
|
||||||
|
Problem: For type=simple, systemd forks/execs the process and if that
|
||||||
|
is successful, it immediately returns. There is no way to
|
||||||
|
find out if the initial startup fails.
|
||||||
|
Solution: Use type=fork and run the process in the background. In this
|
||||||
|
case systemd waits until the initial process returns.
|
||||||
|
In addition, use PIDFile and ensure that the pid file is
|
||||||
|
already available when the initial process returns. To
|
||||||
|
achieve this, use startup synchronization via pipe.
|
||||||
|
Reproduction: Add invalid values to the config files and start the daemons
|
||||||
|
with "systemctl start cpuplugd/mon_procd/mon_fsstatd".
|
||||||
|
Upstream-ID: 82c8148983fc09e9bfa5bf852b2d39571f8475a0
|
||||||
|
Problem-ID: 161563
|
||||||
|
|
||||||
|
Upstream-Description:
|
||||||
|
|
||||||
|
cpuplugd: Improve systemctl start error handling
|
||||||
|
|
||||||
|
Currently "systemctl start cpuplugd" does not report any errors in
|
||||||
|
case the startup fails.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
# mv /etc/cpuplugd.conf /etc/cpuplugd.conf.xxx
|
||||||
|
# systemctl start cpuplugd
|
||||||
|
|
||||||
|
The reason is that for type=simple systemd forks/execs cpuplugd and if
|
||||||
|
that is successful immediately returns. There is no way to find out
|
||||||
|
if the initial startup fails.
|
||||||
|
|
||||||
|
Fix this by using type=fork and running cpuplugd in the background. In
|
||||||
|
this case systemd waits until the initial process returns.
|
||||||
|
|
||||||
|
In addition use PIDFile and ensure that the pid file is already available
|
||||||
|
when the initial cpuplugd process returns. To achieve this, replace the
|
||||||
|
daemon() function by our own implementation that introduces startup
|
||||||
|
synchronization via pipe. Without that systemd would print the following
|
||||||
|
warning:
|
||||||
|
|
||||||
|
systemd[1]: cpuplugd.service: PID file /var/run/cpuplugd.pid not readable
|
||||||
|
(yet?) after start: No such file or directory
|
||||||
|
|
||||||
|
With this patch, an early startup error like in the example above, is now
|
||||||
|
reported correctly in "systemctl start":
|
||||||
|
|
||||||
|
# systemctl start cpuplugd
|
||||||
|
Job for cpuplugd.service failed because the control process exited...
|
||||||
|
See "systemctl status cpuplugd.service" and "journalctl -xe" for ...
|
||||||
|
# journalctl -ex | grep cpuplugd
|
||||||
|
Nov 16 15:52:27 ... cpuplugd[5096]: Opening configuration file failed:
|
||||||
|
No such file or directory
|
||||||
|
|
||||||
|
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
Acked-by: Gerald Schaefer <gerald.schaefer@de.ibm.com>
|
||||||
|
|
||||||
|
|
||||||
|
Signed-off-by: Gerald Schaefer <gerald.schaefer@de.ibm.com>
|
||||||
|
---
|
||||||
|
cpuplugd/cpuplugd.h | 2 -
|
||||||
|
cpuplugd/daemon.c | 60 ++++++++++++++++++++++++++++++++++++++++++--
|
||||||
|
cpuplugd/main.c | 4 --
|
||||||
|
systemd/cpuplugd.service.in | 5 ++-
|
||||||
|
4 files changed, 63 insertions(+), 8 deletions(-)
|
||||||
|
|
||||||
|
--- a/cpuplugd/cpuplugd.h
|
||||||
|
+++ b/cpuplugd/cpuplugd.h
|
||||||
|
@@ -197,10 +197,10 @@ int is_online(int cpuid);
|
||||||
|
long get_cmmpages_size();
|
||||||
|
void parse_options(int argc, char **argv);
|
||||||
|
void check_if_started_twice();
|
||||||
|
-void store_pid(void);
|
||||||
|
void handle_signals(void);
|
||||||
|
void handle_sighup(void);
|
||||||
|
void reload_daemon(void);
|
||||||
|
+int daemonize(void);
|
||||||
|
int check_cmmfiles(void);
|
||||||
|
void check_config();
|
||||||
|
void set_cmm_pages(long size);
|
||||||
|
--- a/cpuplugd/daemon.c
|
||||||
|
+++ b/cpuplugd/daemon.c
|
||||||
|
@@ -9,6 +9,10 @@
|
||||||
|
* it under the terms of the MIT license. See LICENSE for details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
+#include <fcntl.h>
|
||||||
|
+#include <sys/stat.h>
|
||||||
|
+#include <sys/types.h>
|
||||||
|
+
|
||||||
|
#include "cpuplugd.h"
|
||||||
|
|
||||||
|
const char *name = NAME;
|
||||||
|
@@ -49,7 +53,7 @@ void print_version()
|
||||||
|
/*
|
||||||
|
* Store daemon's pid so it can be stopped
|
||||||
|
*/
|
||||||
|
-void store_pid(void)
|
||||||
|
+static int store_pid(void)
|
||||||
|
{
|
||||||
|
FILE *filp;
|
||||||
|
|
||||||
|
@@ -57,10 +61,62 @@ void store_pid(void)
|
||||||
|
if (!filp) {
|
||||||
|
cpuplugd_error("cannot open pid file %s: %s\n", pid_file,
|
||||||
|
strerror(errno));
|
||||||
|
- exit(1);
|
||||||
|
+ return -1;
|
||||||
|
}
|
||||||
|
fprintf(filp, "%d\n", getpid());
|
||||||
|
fclose(filp);
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+/*
|
||||||
|
+ * Run daemon in background and write pid file
|
||||||
|
+ */
|
||||||
|
+int daemonize(void)
|
||||||
|
+{
|
||||||
|
+ int fd, pipe_fds[2], startup_rc = 1;
|
||||||
|
+ pid_t pid;
|
||||||
|
+
|
||||||
|
+ if (pipe(pipe_fds) == -1) {
|
||||||
|
+ cpuplugd_error("cannot create pipe\n");
|
||||||
|
+ return -1;
|
||||||
|
+ }
|
||||||
|
+ pid = fork();
|
||||||
|
+ if (pid < 0)
|
||||||
|
+ goto close_pipe;
|
||||||
|
+ if (pid != 0) {
|
||||||
|
+ /* Wait for startup return code from daemon */
|
||||||
|
+ if (read(pipe_fds[0], &startup_rc, sizeof(startup_rc)) == -1)
|
||||||
|
+ cpuplugd_error("cannot read from pipe\n");
|
||||||
|
+ /* On success daemon has written pid file at this point */
|
||||||
|
+ exit(startup_rc);
|
||||||
|
+ }
|
||||||
|
+ /* Create new session */
|
||||||
|
+ if (setsid() < 0)
|
||||||
|
+ goto notify_parent;
|
||||||
|
+ /* Redirect stdin/out/err to /dev/null */
|
||||||
|
+ fd = open("/dev/null", O_RDWR, 0);
|
||||||
|
+ if (fd == -1)
|
||||||
|
+ goto notify_parent;
|
||||||
|
+ if (dup2(fd, STDIN_FILENO) < 0)
|
||||||
|
+ goto notify_parent;
|
||||||
|
+ if (dup2(fd, STDOUT_FILENO) < 0)
|
||||||
|
+ goto notify_parent;
|
||||||
|
+ if (dup2(fd, STDERR_FILENO) < 0)
|
||||||
|
+ goto notify_parent;
|
||||||
|
+ /* Create pid file */
|
||||||
|
+ if (store_pid() < 0)
|
||||||
|
+ goto notify_parent;
|
||||||
|
+ startup_rc = 0;
|
||||||
|
+notify_parent:
|
||||||
|
+ /* Inform waiting parent about startup return code */
|
||||||
|
+ if (write(pipe_fds[1], &startup_rc, sizeof(startup_rc)) == -1) {
|
||||||
|
+ cpuplugd_error("cannot write to pipe\n");
|
||||||
|
+ startup_rc = 1;
|
||||||
|
+ }
|
||||||
|
+close_pipe:
|
||||||
|
+ close(pipe_fds[0]);
|
||||||
|
+ close(pipe_fds[1]);
|
||||||
|
+ return startup_rc ? -1 : 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
--- a/cpuplugd/main.c
|
||||||
|
+++ b/cpuplugd/main.c
|
||||||
|
@@ -418,13 +418,11 @@ int main(int argc, char *argv[])
|
||||||
|
check_config();
|
||||||
|
|
||||||
|
if (!foreground) {
|
||||||
|
- rc = daemon(1, 0);
|
||||||
|
+ rc = daemonize();
|
||||||
|
if (rc < 0)
|
||||||
|
cpuplugd_exit("Detach from terminal failed: %s\n",
|
||||||
|
strerror(errno));
|
||||||
|
}
|
||||||
|
- /* Store daemon pid */
|
||||||
|
- store_pid();
|
||||||
|
/* Unlock lock file */
|
||||||
|
flock(fd, LOCK_UN);
|
||||||
|
close(fd);
|
||||||
|
--- a/systemd/cpuplugd.service.in
|
||||||
|
+++ b/systemd/cpuplugd.service.in
|
||||||
|
@@ -13,10 +13,11 @@ Documentation=man:cpuplugd(8) man:cpuplu
|
||||||
|
After=remote-fs.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
-ExecStart=@usrsbin_path@/cpuplugd -f -c /etc/cpuplugd.conf
|
||||||
|
+ExecStart=@usrsbin_path@/cpuplugd -c /etc/cpuplugd.conf
|
||||||
|
ExecReload=/bin/kill -HUP $MAINPID
|
||||||
|
KillMode=process
|
||||||
|
-Type=simple
|
||||||
|
+Type=forking
|
||||||
|
+PIDFile=/var/run/cpuplugd.pid
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
@ -0,0 +1,110 @@
|
|||||||
|
Subject: [PATCH] [BZ 161888] lsluns: clarify discovery use case, relation to NPIV and to zfcp auto LUN scan
|
||||||
|
From: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
Description: lsluns: Fix filter handling and documentation enhancements.
|
||||||
|
Symptom: lsluns lists all LUNs discovered in the FC SAN despite user
|
||||||
|
given filter(s) that do not match anything:
|
||||||
|
# lsluns -c 0.0.5080
|
||||||
|
No valid combination found for adapter '0.0.5080'. Removing
|
||||||
|
from resource list.
|
||||||
|
No valid parameters left, using all available resources in
|
||||||
|
system.
|
||||||
|
Scanning for LUNs on adapter 0.0.5090
|
||||||
|
...
|
||||||
|
|
||||||
|
lsluns prints the message "No valid combination found for
|
||||||
|
{adapter|port} '...'. Removing from resource list." for every
|
||||||
|
adapter and port filter that does not contribute to the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
lsluns is used in unexpected or even unsupported ways.
|
||||||
|
Problem: Scanning can be resource consumptive. So if a user already wants
|
||||||
|
to filter, possibly to reduce resource consumption, he does not
|
||||||
|
want to happen to scan everything and thus consume the worst case
|
||||||
|
of resources.
|
||||||
|
|
||||||
|
The message "No valid combination found for {adapter|port} '...'.
|
||||||
|
Removing from resource list." is potentially confusing. It is
|
||||||
|
unclear which combination is being referred to, especially if
|
||||||
|
only one single adapter or port filter was specified. There is
|
||||||
|
also no differentiation whether the denoted adapter or port
|
||||||
|
exists for its own or not. It just does not exist in the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
The lsluns usage text and lsluns (8) man page lack the
|
||||||
|
information on the intended use cases, requirements, and
|
||||||
|
restrictions.
|
||||||
|
Solution: Print a message and exit when all filters match nothing.
|
||||||
|
|
||||||
|
Do not print confusing messages when a filter matches nothing.
|
||||||
|
|
||||||
|
Fix man page formatting.
|
||||||
|
|
||||||
|
Enhance usage text and man page. Clarify discovery use case,
|
||||||
|
relation to NPIV and to zfcp auto LUN scan. Point out
|
||||||
|
IBM Storwize configuration requirements. Document restriction to
|
||||||
|
zfcp-only systems.
|
||||||
|
Reproduction: Use lsluns and specify adapter bus-ID and/or target port WWPN
|
||||||
|
filter(s) that do not match anything. Either specify inexistent
|
||||||
|
bus-IDs and/or WWPNs or invalid filter arguments.
|
||||||
|
Upstream-ID: 0daa7ba0b558ff22fa1c1e014e754cbd08366c00
|
||||||
|
Problem-ID: 161888
|
||||||
|
|
||||||
|
Upstream-Description:
|
||||||
|
|
||||||
|
lsluns: clarify discovery use case, relation to NPIV and to zfcp auto LUN scan
|
||||||
|
|
||||||
|
Signed-off-by: Steffen Maier <maier@linux.vnet.ibm.com>
|
||||||
|
Reviewed-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
|
||||||
|
Signed-off-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
---
|
||||||
|
zconf/lsluns | 3 +++
|
||||||
|
zconf/lsluns.8 | 18 ++++++++++++++++++
|
||||||
|
2 files changed, 21 insertions(+)
|
||||||
|
|
||||||
|
--- a/zconf/lsluns
|
||||||
|
+++ b/zconf/lsluns
|
||||||
|
@@ -174,6 +174,9 @@ $PROGRAM_NAME [-c <busid>] ... [-p <wwpn
|
||||||
|
|
||||||
|
List LUNs discovered in the Fibre Channel (FC) Storage Area Network (SAN).
|
||||||
|
This causes extra SAN traffic for each target port WWPN.
|
||||||
|
+ Discovering LUNs only makes sense for NPIV-enabled FCP devices
|
||||||
|
+ without zfcp automatic LUN scan. zfcp automatic LUN scan is available
|
||||||
|
+ as of kernel version 2.6.37, if not disabled with zfcp.allow_lun_scan=0.
|
||||||
|
|
||||||
|
$PROGRAM_NAME -a [-c <busid>] ... [-p <wwpn>] ... [-h] [-v]
|
||||||
|
|
||||||
|
--- a/zconf/lsluns.8
|
||||||
|
+++ b/zconf/lsluns.8
|
||||||
|
@@ -46,6 +46,24 @@ encryption, use other tools such as
|
||||||
|
or
|
||||||
|
.BR "lsscsi \-tv" .
|
||||||
|
|
||||||
|
+.SS Details on lsluns without -a option
|
||||||
|
+
|
||||||
|
+.TP
|
||||||
|
+Prerequisite
|
||||||
|
+Discovering LUNs only makes sense for NPIV-enabled FCP devices
|
||||||
|
+without zfcp automatic LUN scan. zfcp automatic LUN scan is available
|
||||||
|
+as of kernel version 2.6.37, if not disabled with zfcp.allow_lun_scan=0.
|
||||||
|
+
|
||||||
|
+With available and enabled zfcp automatic LUN scan,
|
||||||
|
+the kernel already performs LUN discovery.
|
||||||
|
+
|
||||||
|
+.TP
|
||||||
|
+Temporary LUN Attachment
|
||||||
|
+If not attached already, lsluns temporarily attaches LUN 0
|
||||||
|
+(or if this fails the WLUN 0xc101000000000000) during runtime.
|
||||||
|
+Do not terminate lsluns with a signal. Signals interfere
|
||||||
|
+with the removal of temporarily attached LUNs.
|
||||||
|
+
|
||||||
|
.SH OPTIONS
|
||||||
|
.TP
|
||||||
|
.BR \-a ", " \-\-active
|
@ -0,0 +1,104 @@
|
|||||||
|
Subject: [PATCH] [BZ 161888] lsluns: complement alternative tools with lszdev
|
||||||
|
From: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
Description: lsluns: Fix filter handling and documentation enhancements.
|
||||||
|
Symptom: lsluns lists all LUNs discovered in the FC SAN despite user
|
||||||
|
given filter(s) that do not match anything:
|
||||||
|
# lsluns -c 0.0.5080
|
||||||
|
No valid combination found for adapter '0.0.5080'. Removing
|
||||||
|
from resource list.
|
||||||
|
No valid parameters left, using all available resources in
|
||||||
|
system.
|
||||||
|
Scanning for LUNs on adapter 0.0.5090
|
||||||
|
...
|
||||||
|
|
||||||
|
lsluns prints the message "No valid combination found for
|
||||||
|
{adapter|port} '...'. Removing from resource list." for every
|
||||||
|
adapter and port filter that does not contribute to the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
lsluns is used in unexpected or even unsupported ways.
|
||||||
|
Problem: Scanning can be resource consumptive. So if a user already wants
|
||||||
|
to filter, possibly to reduce resource consumption, he does not
|
||||||
|
want to happen to scan everything and thus consume the worst case
|
||||||
|
of resources.
|
||||||
|
|
||||||
|
The message "No valid combination found for {adapter|port} '...'.
|
||||||
|
Removing from resource list." is potentially confusing. It is
|
||||||
|
unclear which combination is being referred to, especially if
|
||||||
|
only one single adapter or port filter was specified. There is
|
||||||
|
also no differentiation whether the denoted adapter or port
|
||||||
|
exists for its own or not. It just does not exist in the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
The lsluns usage text and lsluns (8) man page lack the
|
||||||
|
information on the intended use cases, requirements, and
|
||||||
|
restrictions.
|
||||||
|
Solution: Print a message and exit when all filters match nothing.
|
||||||
|
|
||||||
|
Do not print confusing messages when a filter matches nothing.
|
||||||
|
|
||||||
|
Fix man page formatting.
|
||||||
|
|
||||||
|
Enhance usage text and man page. Clarify discovery use case,
|
||||||
|
relation to NPIV and to zfcp auto LUN scan. Point out
|
||||||
|
IBM Storwize configuration requirements. Document restriction to
|
||||||
|
zfcp-only systems.
|
||||||
|
Reproduction: Use lsluns and specify adapter bus-ID and/or target port WWPN
|
||||||
|
filter(s) that do not match anything. Either specify inexistent
|
||||||
|
bus-IDs and/or WWPNs or invalid filter arguments.
|
||||||
|
Upstream-ID: e5f9279295780bd297f58cc23319878fadbc80f1
|
||||||
|
Problem-ID: 161888
|
||||||
|
|
||||||
|
Upstream-Description:
|
||||||
|
|
||||||
|
lsluns: complement alternative tools with lszdev
|
||||||
|
|
||||||
|
Signed-off-by: Steffen Maier <maier@linux.vnet.ibm.com>
|
||||||
|
Reviewed-by: Benjamin Block <bblock@linux.vnet.ibm.com>
|
||||||
|
Reviewed-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
|
||||||
|
Signed-off-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
---
|
||||||
|
zconf/lsluns | 3 ++-
|
||||||
|
zconf/lsluns.8 | 7 +++++--
|
||||||
|
2 files changed, 7 insertions(+), 3 deletions(-)
|
||||||
|
|
||||||
|
--- a/zconf/lsluns
|
||||||
|
+++ b/zconf/lsluns
|
||||||
|
@@ -192,7 +192,8 @@ $PROGRAM_NAME -a [-c <busid>] ... [-p <w
|
||||||
|
This causes extra SAN traffic for each attached LUN.
|
||||||
|
|
||||||
|
For all other uses, such as listing attached LUNs or properties other than
|
||||||
|
-encryption, use other tools such as "lszfcp -D" or "lsscsi -tv".
|
||||||
|
+encryption, use other tools such as "lszfcp -D" or "lsscsi -tv"
|
||||||
|
+or "lszdev zfcp-lun -ii".
|
||||||
|
|
||||||
|
Limit the listing by specifying one or more adapters (FCP device
|
||||||
|
bus-IDs) or target port WWPNs or both.
|
||||||
|
--- a/zconf/lsluns.8
|
||||||
|
+++ b/zconf/lsluns.8
|
||||||
|
@@ -48,7 +48,9 @@ For all other uses, such as listing atta
|
||||||
|
encryption, use other tools such as
|
||||||
|
.B lszfcp \-D
|
||||||
|
or
|
||||||
|
-.BR "lsscsi \-tv" .
|
||||||
|
+.BR "lsscsi \-tv"
|
||||||
|
+or
|
||||||
|
+.BR "lszdev zfcp-lun \-ii" .
|
||||||
|
|
||||||
|
.SS Details on lsluns without -a option
|
||||||
|
|
||||||
|
@@ -135,4 +137,5 @@ indicates that the device is encrypted.
|
||||||
|
|
||||||
|
.SH "SEE ALSO"
|
||||||
|
.BR lszfcp (8),
|
||||||
|
-.BR lsscsi (8)
|
||||||
|
+.BR lsscsi (8),
|
||||||
|
+.BR lszdev (8)
|
@ -0,0 +1,125 @@
|
|||||||
|
Subject: [PATCH] [BZ 161888] lsluns: do not print confusing messages when a filter matches nothing
|
||||||
|
From: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
Description: lsluns: Fix filter handling and documentation enhancements.
|
||||||
|
Symptom: lsluns lists all LUNs discovered in the FC SAN despite user
|
||||||
|
given filter(s) that do not match anything:
|
||||||
|
# lsluns -c 0.0.5080
|
||||||
|
No valid combination found for adapter '0.0.5080'. Removing
|
||||||
|
from resource list.
|
||||||
|
No valid parameters left, using all available resources in
|
||||||
|
system.
|
||||||
|
Scanning for LUNs on adapter 0.0.5090
|
||||||
|
...
|
||||||
|
|
||||||
|
lsluns prints the message "No valid combination found for
|
||||||
|
{adapter|port} '...'. Removing from resource list." for every
|
||||||
|
adapter and port filter that does not contribute to the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
lsluns is used in unexpected or even unsupported ways.
|
||||||
|
Problem: Scanning can be resource consumptive. So if a user already wants
|
||||||
|
to filter, possibly to reduce resource consumption, he does not
|
||||||
|
want to happen to scan everything and thus consume the worst case
|
||||||
|
of resources.
|
||||||
|
|
||||||
|
The message "No valid combination found for {adapter|port} '...'.
|
||||||
|
Removing from resource list." is potentially confusing. It is
|
||||||
|
unclear which combination is being referred to, especially if
|
||||||
|
only one single adapter or port filter was specified. There is
|
||||||
|
also no differentiation whether the denoted adapter or port
|
||||||
|
exists for its own or not. It just does not exist in the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
The lsluns usage text and lsluns (8) man page lack the
|
||||||
|
information on the intended use cases, requirements, and
|
||||||
|
restrictions.
|
||||||
|
Solution: Print a message and exit when all filters match nothing.
|
||||||
|
|
||||||
|
Do not print confusing messages when a filter matches nothing.
|
||||||
|
|
||||||
|
Fix man page formatting.
|
||||||
|
|
||||||
|
Enhance usage text and man page. Clarify discovery use case,
|
||||||
|
relation to NPIV and to zfcp auto LUN scan. Point out
|
||||||
|
IBM Storwize configuration requirements. Document restriction to
|
||||||
|
zfcp-only systems.
|
||||||
|
Reproduction: Use lsluns and specify adapter bus-ID and/or target port WWPN
|
||||||
|
filter(s) that do not match anything. Either specify inexistent
|
||||||
|
bus-IDs and/or WWPNs or invalid filter arguments.
|
||||||
|
Upstream-ID: c993ad89c544dd162005a9a1e582b51667c46b66
|
||||||
|
Problem-ID: 161888
|
||||||
|
|
||||||
|
Upstream-Description:
|
||||||
|
|
||||||
|
lsluns: do not print confusing messages when a filter matches nothing
|
||||||
|
|
||||||
|
lsluns printed potentially confusing messages when a filter or combination
|
||||||
|
of filters matched nothing:
|
||||||
|
|
||||||
|
No valid combination found for adapter '0.0.1906'. Removing from
|
||||||
|
resource list.
|
||||||
|
No valid combination found for port '0x50050763071845e3'. Removing from
|
||||||
|
resource list.
|
||||||
|
...
|
||||||
|
|
||||||
|
To the user it is potentially unclear which 'combination' is actually being
|
||||||
|
referred to, as only one part of the combination is mentioned, and what the
|
||||||
|
ominous 'resource list' is. The later information is merely useful for a
|
||||||
|
developer to debug the script.
|
||||||
|
|
||||||
|
Such a message was written for every user supplied filter that did not
|
||||||
|
contribute anything to the resulting subset that is being listed, although
|
||||||
|
the filter actually might match something when used standalone.
|
||||||
|
|
||||||
|
Additionally those messages were printed to stdout instead of stderr. As
|
||||||
|
there is no debug or verbose switch and the information level of those
|
||||||
|
messages is low, we may simply discard them.
|
||||||
|
|
||||||
|
Reported-by: Steffen Maier <maier@linux.vnet.ibm.com>
|
||||||
|
Signed-off-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
Reviewed-by: Steffen Maier <maier@linux.vnet.ibm.com>
|
||||||
|
Reviewed-by: Benjamin Block <bblock@linux.vnet.ibm.com>
|
||||||
|
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
|
||||||
|
Signed-off-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
---
|
||||||
|
zconf/lsluns | 15 ---------------
|
||||||
|
1 file changed, 15 deletions(-)
|
||||||
|
|
||||||
|
--- a/zconf/lsluns
|
||||||
|
+++ b/zconf/lsluns
|
||||||
|
@@ -215,7 +215,6 @@ sub get_env_list
|
||||||
|
my $p_ref_list = shift();
|
||||||
|
my @res ;
|
||||||
|
my %res_hash;
|
||||||
|
- my @t_arr;
|
||||||
|
|
||||||
|
@res = </sys/bus/ccw/drivers/zfcp/*.*.*/0x*>;
|
||||||
|
return () if (!@res);
|
||||||
|
@@ -226,20 +225,6 @@ sub get_env_list
|
||||||
|
next if (@$p_ref_list && "@$p_ref_list" !~ /$p/);
|
||||||
|
push @{ $res_hash{$a} }, $p;
|
||||||
|
}
|
||||||
|
- foreach my $a (sort @$a_ref_list) {
|
||||||
|
- if ("@{[keys %res_hash]}" !~ /$a/) {
|
||||||
|
- print "\tNo valid combination found for adapter '$a'. ",
|
||||||
|
- "Removing from resource list.\n";
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- push @t_arr, map { @{$res_hash{$_}} } keys %res_hash;
|
||||||
|
- foreach my $p (@$p_ref_list) {
|
||||||
|
- if ("@t_arr" !~ /$p/) {
|
||||||
|
- print "\tNo valid combination found for port '$p'. ",
|
||||||
|
- "Removing from resource list.\n";
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
|
||||||
|
if (!%res_hash) {
|
||||||
|
print "$PROGRAM_NAME: Adapter and/or port filter(s) did not match anything\n";
|
@ -0,0 +1,111 @@
|
|||||||
|
Subject: [PATCH] [BZ 161888] lsluns: do not scan (all) if filters match nothing
|
||||||
|
From: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
Description: lsluns: Fix filter handling and documentation enhancements.
|
||||||
|
Symptom: lsluns lists all LUNs discovered in the FC SAN despite user
|
||||||
|
given filter(s) that do not match anything:
|
||||||
|
# lsluns -c 0.0.5080
|
||||||
|
No valid combination found for adapter '0.0.5080'. Removing
|
||||||
|
from resource list.
|
||||||
|
No valid parameters left, using all available resources in
|
||||||
|
system.
|
||||||
|
Scanning for LUNs on adapter 0.0.5090
|
||||||
|
...
|
||||||
|
|
||||||
|
lsluns prints the message "No valid combination found for
|
||||||
|
{adapter|port} '...'. Removing from resource list." for every
|
||||||
|
adapter and port filter that does not contribute to the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
lsluns is used in unexpected or even unsupported ways.
|
||||||
|
Problem: Scanning can be resource consumptive. So if a user already wants
|
||||||
|
to filter, possibly to reduce resource consumption, he does not
|
||||||
|
want to happen to scan everything and thus consume the worst case
|
||||||
|
of resources.
|
||||||
|
|
||||||
|
The message "No valid combination found for {adapter|port} '...'.
|
||||||
|
Removing from resource list." is potentially confusing. It is
|
||||||
|
unclear which combination is being referred to, especially if
|
||||||
|
only one single adapter or port filter was specified. There is
|
||||||
|
also no differentiation whether the denoted adapter or port
|
||||||
|
exists for its own or not. It just does not exist in the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
The lsluns usage text and lsluns (8) man page lack the
|
||||||
|
information on the intended use cases, requirements, and
|
||||||
|
restrictions.
|
||||||
|
Solution: Print a message and exit when all filters match nothing.
|
||||||
|
|
||||||
|
Do not print confusing messages when a filter matches nothing.
|
||||||
|
|
||||||
|
Fix man page formatting.
|
||||||
|
|
||||||
|
Enhance usage text and man page. Clarify discovery use case,
|
||||||
|
relation to NPIV and to zfcp auto LUN scan. Point out
|
||||||
|
IBM Storwize configuration requirements. Document restriction to
|
||||||
|
zfcp-only systems.
|
||||||
|
Reproduction: Use lsluns and specify adapter bus-ID and/or target port WWPN
|
||||||
|
filter(s) that do not match anything. Either specify inexistent
|
||||||
|
bus-IDs and/or WWPNs or invalid filter arguments.
|
||||||
|
Upstream-ID: 398f9ceac8c20705f573671bde4bc482967f5c13
|
||||||
|
Problem-ID: 161888
|
||||||
|
|
||||||
|
Upstream-Description:
|
||||||
|
|
||||||
|
lsluns: do not scan (all) if filters match nothing
|
||||||
|
|
||||||
|
Fix the following undesired behavior of lsluns to scan all resources if the
|
||||||
|
user provided filters did not match anything:
|
||||||
|
|
||||||
|
No valid combination found for adapter '5080'. Removing from resource
|
||||||
|
list.
|
||||||
|
No valid parameters left, using all available resources in system.
|
||||||
|
Scanning for LUNs on adapter 0.0.5080
|
||||||
|
...
|
||||||
|
|
||||||
|
Scanning can be resource consumptive. So if a user already wants to filter,
|
||||||
|
possibly to reduce resource consumption, he does not want to happen to scan
|
||||||
|
everything and thus consume the worst case of resources.
|
||||||
|
|
||||||
|
Instead print a message to inform the user why nothing was scanned.
|
||||||
|
|
||||||
|
Reported-by: Steffen Maier <maier@linux.vnet.ibm.com>
|
||||||
|
Signed-off-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
Reviewed-by: Steffen Maier <maier@linux.vnet.ibm.com>
|
||||||
|
Reviewed-by: Benjamin Block <bblock@linux.vnet.ibm.com>
|
||||||
|
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
|
||||||
|
Signed-off-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
---
|
||||||
|
zconf/lsluns | 8 +-------
|
||||||
|
1 file changed, 1 insertion(+), 7 deletions(-)
|
||||||
|
|
||||||
|
--- a/zconf/lsluns
|
||||||
|
+++ b/zconf/lsluns
|
||||||
|
@@ -219,7 +219,6 @@ sub get_env_list
|
||||||
|
|
||||||
|
@res = </sys/bus/ccw/drivers/zfcp/*.*.*/0x*>;
|
||||||
|
return () if (!@res);
|
||||||
|
-reload:
|
||||||
|
foreach my $entry (@res) {
|
||||||
|
my $a = ${[split('/', $entry)]}[-2];
|
||||||
|
my $p = ${[split('/', $entry)]}[-1];
|
||||||
|
@@ -243,12 +242,7 @@ reload:
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!%res_hash) {
|
||||||
|
- print "\nNo valid parameters left, ",
|
||||||
|
- "using all available resources in system.\n\n";
|
||||||
|
- @$a_ref_list = ();
|
||||||
|
- @$p_ref_list = ();
|
||||||
|
- @t_arr = ();
|
||||||
|
- goto reload;
|
||||||
|
+ print "$PROGRAM_NAME: Adapter and/or port filter(s) did not match anything\n";
|
||||||
|
}
|
||||||
|
return %res_hash;
|
||||||
|
}
|
@ -0,0 +1,108 @@
|
|||||||
|
Subject: [PATCH] [BZ 161888] lsluns: document restriction to zfcp-only systems
|
||||||
|
From: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
Description: lsluns: Fix filter handling and documentation enhancements.
|
||||||
|
Symptom: lsluns lists all LUNs discovered in the FC SAN despite user
|
||||||
|
given filter(s) that do not match anything:
|
||||||
|
# lsluns -c 0.0.5080
|
||||||
|
No valid combination found for adapter '0.0.5080'. Removing
|
||||||
|
from resource list.
|
||||||
|
No valid parameters left, using all available resources in
|
||||||
|
system.
|
||||||
|
Scanning for LUNs on adapter 0.0.5090
|
||||||
|
...
|
||||||
|
|
||||||
|
lsluns prints the message "No valid combination found for
|
||||||
|
{adapter|port} '...'. Removing from resource list." for every
|
||||||
|
adapter and port filter that does not contribute to the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
lsluns is used in unexpected or even unsupported ways.
|
||||||
|
Problem: Scanning can be resource consumptive. So if a user already wants
|
||||||
|
to filter, possibly to reduce resource consumption, he does not
|
||||||
|
want to happen to scan everything and thus consume the worst case
|
||||||
|
of resources.
|
||||||
|
|
||||||
|
The message "No valid combination found for {adapter|port} '...'.
|
||||||
|
Removing from resource list." is potentially confusing. It is
|
||||||
|
unclear which combination is being referred to, especially if
|
||||||
|
only one single adapter or port filter was specified. There is
|
||||||
|
also no differentiation whether the denoted adapter or port
|
||||||
|
exists for its own or not. It just does not exist in the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
The lsluns usage text and lsluns (8) man page lack the
|
||||||
|
information on the intended use cases, requirements, and
|
||||||
|
restrictions.
|
||||||
|
Solution: Print a message and exit when all filters match nothing.
|
||||||
|
|
||||||
|
Do not print confusing messages when a filter matches nothing.
|
||||||
|
|
||||||
|
Fix man page formatting.
|
||||||
|
|
||||||
|
Enhance usage text and man page. Clarify discovery use case,
|
||||||
|
relation to NPIV and to zfcp auto LUN scan. Point out
|
||||||
|
IBM Storwize configuration requirements. Document restriction to
|
||||||
|
zfcp-only systems.
|
||||||
|
Reproduction: Use lsluns and specify adapter bus-ID and/or target port WWPN
|
||||||
|
filter(s) that do not match anything. Either specify inexistent
|
||||||
|
bus-IDs and/or WWPNs or invalid filter arguments.
|
||||||
|
Upstream-ID: 55f0b001d15b3984967e7f87d6118232078e3fe5
|
||||||
|
Problem-ID: 161888
|
||||||
|
|
||||||
|
Upstream-Description:
|
||||||
|
|
||||||
|
lsluns: document restriction to zfcp-only systems
|
||||||
|
|
||||||
|
Signed-off-by: Steffen Maier <maier@linux.vnet.ibm.com>
|
||||||
|
Reviewed-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
|
||||||
|
Signed-off-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
---
|
||||||
|
zconf/lsluns | 4 ++++
|
||||||
|
zconf/lsluns.8 | 8 ++++++--
|
||||||
|
2 files changed, 10 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
--- a/zconf/lsluns
|
||||||
|
+++ b/zconf/lsluns
|
||||||
|
@@ -170,6 +170,10 @@ sub get_lun_hash
|
||||||
|
sub lsluns_usage {
|
||||||
|
print <<EOD;
|
||||||
|
Usage:
|
||||||
|
+This tool is designed for environments where all SCSI devices are attached
|
||||||
|
+through the zfcp device driver. Expect error messages in mixed environments
|
||||||
|
+such as with iSCSI.
|
||||||
|
+
|
||||||
|
$PROGRAM_NAME [-c <busid>] ... [-p <wwpn>] ... [-h] [-v]
|
||||||
|
|
||||||
|
List LUNs discovered in the Fibre Channel (FC) Storage Area Network (SAN).
|
||||||
|
--- a/zconf/lsluns.8
|
||||||
|
+++ b/zconf/lsluns.8
|
||||||
|
@@ -4,8 +4,8 @@
|
||||||
|
.\"
|
||||||
|
.TH LSLUNS 8 "2017-02-17" "s390-tools"
|
||||||
|
.SH NAME
|
||||||
|
-lsluns \- list LUNs discovered in the FC SAN, or show encryption state of
|
||||||
|
-attached LUNs
|
||||||
|
+lsluns \- list LUNs discovered in the FC SAN through zfcp, or show encryption state of
|
||||||
|
+zfcp-attached LUNs
|
||||||
|
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B lsluns
|
||||||
|
@@ -28,6 +28,10 @@ attached LUNs
|
||||||
|
|
||||||
|
.SH DESCRIPTION
|
||||||
|
.PP
|
||||||
|
+This tool is designed for environments where all SCSI devices are attached
|
||||||
|
+through the zfcp device driver. Expect error messages in mixed environments
|
||||||
|
+such as with iSCSI.
|
||||||
|
+
|
||||||
|
.B lsluns
|
||||||
|
lists all logical unit numbers (LUNs) discovered in the
|
||||||
|
Fibre Channel (FC) Storage Area Network (SAN).
|
@ -0,0 +1,283 @@
|
|||||||
|
Subject: [PATCH] [BZ 161888] lsluns: enhance usage statement and man page
|
||||||
|
From: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
Description: lsluns: Fix filter handling and documentation enhancements.
|
||||||
|
Symptom: lsluns lists all LUNs discovered in the FC SAN despite user
|
||||||
|
given filter(s) that do not match anything:
|
||||||
|
# lsluns -c 0.0.5080
|
||||||
|
No valid combination found for adapter '0.0.5080'. Removing
|
||||||
|
from resource list.
|
||||||
|
No valid parameters left, using all available resources in
|
||||||
|
system.
|
||||||
|
Scanning for LUNs on adapter 0.0.5090
|
||||||
|
...
|
||||||
|
|
||||||
|
lsluns prints the message "No valid combination found for
|
||||||
|
{adapter|port} '...'. Removing from resource list." for every
|
||||||
|
adapter and port filter that does not contribute to the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
lsluns is used in unexpected or even unsupported ways.
|
||||||
|
Problem: Scanning can be resource consumptive. So if a user already wants
|
||||||
|
to filter, possibly to reduce resource consumption, he does not
|
||||||
|
want to happen to scan everything and thus consume the worst case
|
||||||
|
of resources.
|
||||||
|
|
||||||
|
The message "No valid combination found for {adapter|port} '...'.
|
||||||
|
Removing from resource list." is potentially confusing. It is
|
||||||
|
unclear which combination is being referred to, especially if
|
||||||
|
only one single adapter or port filter was specified. There is
|
||||||
|
also no differentiation whether the denoted adapter or port
|
||||||
|
exists for its own or not. It just does not exist in the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
The lsluns usage text and lsluns (8) man page lack the
|
||||||
|
information on the intended use cases, requirements, and
|
||||||
|
restrictions.
|
||||||
|
Solution: Print a message and exit when all filters match nothing.
|
||||||
|
|
||||||
|
Do not print confusing messages when a filter matches nothing.
|
||||||
|
|
||||||
|
Fix man page formatting.
|
||||||
|
|
||||||
|
Enhance usage text and man page. Clarify discovery use case,
|
||||||
|
relation to NPIV and to zfcp auto LUN scan. Point out
|
||||||
|
IBM Storwize configuration requirements. Document restriction to
|
||||||
|
zfcp-only systems.
|
||||||
|
Reproduction: Use lsluns and specify adapter bus-ID and/or target port WWPN
|
||||||
|
filter(s) that do not match anything. Either specify inexistent
|
||||||
|
bus-IDs and/or WWPNs or invalid filter arguments.
|
||||||
|
Upstream-ID: e748fff3479f8f4ae7e8262b4913f6d08ff78f66
|
||||||
|
Problem-ID: 161888
|
||||||
|
|
||||||
|
Upstream-Description:
|
||||||
|
|
||||||
|
lsluns: enhance usage statement and man page
|
||||||
|
|
||||||
|
The wording in the lsluns usage statement and man page was misleading
|
||||||
|
in several aspects:
|
||||||
|
|
||||||
|
* lsluns does not list all LUNs, just those discovered in the FC SAN
|
||||||
|
* lsluns -a should only be used to display the LUN encryption status
|
||||||
|
|
||||||
|
Fix filter option arguments. Clarify filter option usage. Refer to
|
||||||
|
lszfcp and lsscsi.
|
||||||
|
|
||||||
|
Reported-by: Steffen Maier <maier@linux.vnet.ibm.com>
|
||||||
|
Signed-off-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
Reviewed-by: Steffen Maier <maier@linux.vnet.ibm.com>
|
||||||
|
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
|
||||||
|
Signed-off-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
---
|
||||||
|
zconf/lsluns | 45 +++++++++++++++------------
|
||||||
|
zconf/lsluns.8 | 93 +++++++++++++++++++++++++++++++++++++++------------------
|
||||||
|
2 files changed, 91 insertions(+), 47 deletions(-)
|
||||||
|
|
||||||
|
--- a/zconf/lsluns
|
||||||
|
+++ b/zconf/lsluns
|
||||||
|
@@ -1,6 +1,6 @@
|
||||||
|
#!/usr/bin/perl
|
||||||
|
#
|
||||||
|
-# lsluns - Tool to list all available LUNs
|
||||||
|
+# lsluns - list LUNs discovered in the FC SAN, or show encryption state of attached LUNs
|
||||||
|
#
|
||||||
|
# Copyright IBM Corp. 2008, 2017
|
||||||
|
#
|
||||||
|
@@ -169,32 +169,39 @@ sub get_lun_hash
|
||||||
|
|
||||||
|
sub lsluns_usage {
|
||||||
|
print <<EOD;
|
||||||
|
-Usage: $PROGRAM_NAME [<options>]
|
||||||
|
+Usage:
|
||||||
|
+$PROGRAM_NAME [-c <busid>] ... [-p <wwpn>] ... [-h] [-v]
|
||||||
|
|
||||||
|
- lsluns provides information for LUNs.
|
||||||
|
+ List LUNs discovered in the Fibre Channel (FC) Storage Area Network (SAN).
|
||||||
|
+ This causes extra SAN traffic for each target port WWPN.
|
||||||
|
|
||||||
|
- The default is to list all LUNs that are available via the attached ports.
|
||||||
|
- The display can be limited by specifying an adapter or a port.
|
||||||
|
+$PROGRAM_NAME -a [-c <busid>] ... [-p <wwpn>] ... [-h] [-v]
|
||||||
|
+
|
||||||
|
+ Show encryption state of the attached LUNs.
|
||||||
|
+ This causes extra SAN traffic for each attached LUN.
|
||||||
|
+
|
||||||
|
+For all other uses, such as listing attached LUNs or properties other than
|
||||||
|
+encryption, use other tools such as "lszfcp -D" or "lsscsi -tv".
|
||||||
|
+
|
||||||
|
+Limit the listing by specifying one or more adapters (FCP device
|
||||||
|
+bus-IDs) or target port WWPNs or both.
|
||||||
|
|
||||||
|
Options:
|
||||||
|
- -a, --active
|
||||||
|
- Shows all activated LUNs.
|
||||||
|
- In addition LUN encryption information is provided.
|
||||||
|
- e.g. "lsluns -a"
|
||||||
|
-
|
||||||
|
- -c, --ccw
|
||||||
|
- Shows LUNs for a specific ccw device.
|
||||||
|
- e.g. "lsluns -c 0.0.3922"
|
||||||
|
-
|
||||||
|
- -p, --port
|
||||||
|
- Shows LUNs for a specific port.
|
||||||
|
- e.g. "lsluns -p 0x5005123456789000"
|
||||||
|
+ -c <busid>, --ccw <busid>
|
||||||
|
+ Filter LUNs by adapter with the specified FCP device bus-ID. Can be
|
||||||
|
+ specified multiple times.
|
||||||
|
+ For example: "$PROGRAM_NAME -c 0.0.3922"
|
||||||
|
+
|
||||||
|
+ -p <wwpn>, --port <wwpn>
|
||||||
|
+ Filter LUNs by target port with the specified WWPN. Can be specified
|
||||||
|
+ multiple times.
|
||||||
|
+ For example: "$PROGRAM_NAME -p 0x5005123456789000"
|
||||||
|
|
||||||
|
-h, --help
|
||||||
|
- Print help message and exit.
|
||||||
|
+ Print help message and exit.
|
||||||
|
|
||||||
|
-v, --version
|
||||||
|
- Display version info and exit.
|
||||||
|
+ Display version information and exit.
|
||||||
|
EOD
|
||||||
|
exit 0;
|
||||||
|
}
|
||||||
|
--- a/zconf/lsluns.8
|
||||||
|
+++ b/zconf/lsluns.8
|
||||||
|
@@ -2,61 +2,93 @@
|
||||||
|
.\" s390-tools is free software; you can redistribute it and/or modify
|
||||||
|
.\" it under the terms of the MIT license. See LICENSE for details.
|
||||||
|
.\"
|
||||||
|
-.TH LSLUNS 8 "June 2008" "s390-tools"
|
||||||
|
+.TH LSLUNS 8 "2017-02-17" "s390-tools"
|
||||||
|
.SH NAME
|
||||||
|
-lsluns \- list available LUNs
|
||||||
|
+lsluns \- list LUNs discovered in the FC SAN, or show encryption state of
|
||||||
|
+attached LUNs
|
||||||
|
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B lsluns
|
||||||
|
+.RB [\| \-c
|
||||||
|
+.IR busid \|]\ .\|.\|.
|
||||||
|
+.RB [\| \-p
|
||||||
|
+.IR wwpn \|]\ .\|.\|.
|
||||||
|
+.\" --active
|
||||||
|
+.br
|
||||||
|
+.B lsluns \-a
|
||||||
|
+.RB [\| \-c
|
||||||
|
+.IR busid \|]\ .\|.\|.
|
||||||
|
+.RB [\| \-p
|
||||||
|
+.IR wwpn \|]\ .\|.\|.
|
||||||
|
+.\" --help and --version
|
||||||
|
+.br
|
||||||
|
+.B lsluns
|
||||||
|
.RB [\| \-h \|]
|
||||||
|
.RB [\| \-v \|]
|
||||||
|
-.RB [\| \-c
|
||||||
|
-.IR adapter\ id:0.0.XXXX \|]\ .\|.\|.
|
||||||
|
-.RB [ \-p
|
||||||
|
-.IR port\ number:0xXXXXXXXXXXXXXXXX \|]\ .\|.\|.
|
||||||
|
|
||||||
|
.SH DESCRIPTION
|
||||||
|
.PP
|
||||||
|
.B lsluns
|
||||||
|
-does a listing of all available LUNs.
|
||||||
|
-
|
||||||
|
-The default is to list all LUNs that are found. The listing can be
|
||||||
|
-limited by specifying an adapter or a port.
|
||||||
|
+lists all logical unit numbers (LUNs) discovered in the
|
||||||
|
+Fibre Channel (FC) Storage Area Network (SAN).
|
||||||
|
+This causes extra SAN traffic for each target port WWPN.
|
||||||
|
+
|
||||||
|
+.B lsluns -a
|
||||||
|
+shows the encryption state of the attached LUNs.
|
||||||
|
+This causes extra SAN traffic for each attached LUN.
|
||||||
|
+
|
||||||
|
+Limit the listing by specifying one or more adapters (FCP device
|
||||||
|
+bus-IDs) or target port WWPNs or both.
|
||||||
|
+
|
||||||
|
+For all other uses, such as listing attached LUNs or properties other than
|
||||||
|
+encryption, use other tools such as
|
||||||
|
+.B lszfcp \-D
|
||||||
|
+or
|
||||||
|
+.BR "lsscsi \-tv" .
|
||||||
|
|
||||||
|
.SH OPTIONS
|
||||||
|
.TP
|
||||||
|
+.BR \-a ", " \-\-active
|
||||||
|
+Show the encryption state of the attached LUNs. Encrypted devices are indicated
|
||||||
|
+with a bracketed X immediately following the LUN number.
|
||||||
|
+.TP
|
||||||
|
+.BI \-c\ busid \fR,\ \fB\-\-ccw= busid
|
||||||
|
+Filter LUNs by adapter with the specified FCP device bus-ID. This option can be
|
||||||
|
+specified multiple times. When used in conjunction with \fB\-p\fR, only those
|
||||||
|
+LUNs are listed that also satisfy at least one of the \fB\-p\fR constraints.
|
||||||
|
+.TP
|
||||||
|
+.BI \-p\ wwpn \fR,\ \fB\-\-port= wwpn
|
||||||
|
+Filter LUNs by target port with the specified WWPN. This option can be
|
||||||
|
+specified multiple times. When used in conjunction with \fB\-c\fR, only those
|
||||||
|
+LUNs are listed that also satisfy at least one of the \fB\-c\fR constraints.
|
||||||
|
+.TP
|
||||||
|
.BR \-h ", " \-\-help
|
||||||
|
Print help message and exit.
|
||||||
|
.TP
|
||||||
|
.BR \-v ", " \-\-version
|
||||||
|
-Display version info and exit.
|
||||||
|
-.TP
|
||||||
|
-.BI \-c\ adapter \fR,\ \fB\-\-ccw= adapter
|
||||||
|
-Shows LUNs for a specific adapter.
|
||||||
|
-.TP
|
||||||
|
-.BI \-p\ port \fR,\ \fB\-\-port= port
|
||||||
|
-Shows LUNs for a specific port.
|
||||||
|
-.TP
|
||||||
|
-.BR \-a ", " \-\-active
|
||||||
|
-Shows all activated LUNs. In addition information is provided
|
||||||
|
-whether the LUN is encrypted or not. This is indicated with a bracketed X
|
||||||
|
-right after the LUN number.
|
||||||
|
+Display version information and exit.
|
||||||
|
|
||||||
|
.SH EXAMPLES
|
||||||
|
.TP
|
||||||
|
.B "lsluns"
|
||||||
|
.RS
|
||||||
|
-Shows all available LUNs.
|
||||||
|
+Lists all LUNs discovered in the FC SAN.
|
||||||
|
.RE
|
||||||
|
.TP
|
||||||
|
.BI "lsluns \-c " 0.0.3922
|
||||||
|
-Shows all LUNs found on adapter \fI0.0.3922\fR.
|
||||||
|
+Lists all LUNs discovered in the FC SAN on adapter \fI0.0.3922\fR.
|
||||||
|
.TP
|
||||||
|
.BI "lsluns \-p " 0x5005123456789000
|
||||||
|
-Shows all LUNs for port \fI0x5005123456789000\fR.
|
||||||
|
+Lists all LUNs discovered in the FC SAN on target port
|
||||||
|
+\fI0x5005123456789000\fR.
|
||||||
|
.TP
|
||||||
|
-.BI "lsluns \-c " 0.0.3922 " \-p " 0x5005123456789000
|
||||||
|
-Shows all LUNs for adapter \fI0.0.3922\fR and port \fI0x5005123456789000\fR.
|
||||||
|
+.BI "lsluns \-c " 0.0.3922 " \-c " 0.0.fc00 \
|
||||||
|
+" \-p " 0x5005123456789000 " \-p " 0x5005abcdefabc000
|
||||||
|
+Lists all LUNs discovered in the FC SAN on:
|
||||||
|
+adpater \fI0.0.3922\fR and port \fI0x5005123456789000\fR,
|
||||||
|
+adapter \fI0.0.3922\fR and port \fI0x5005abcdefabc000\fR,
|
||||||
|
+adapter \fI0.0.fc00\fR and port \fI0x5005123456789000\fR, or
|
||||||
|
+adapter \fI0.0.fc00\fR and port \fI0x5005abcdefabc000\fR.
|
||||||
|
.TP
|
||||||
|
.B "lsluns -a"
|
||||||
|
adapter = 0.0.3c02
|
||||||
|
@@ -64,4 +96,9 @@ adapter = 0.0.3c02
|
||||||
|
lun = 0x401040a200000000(X) /dev/sg0 Disk IBM:2107900
|
||||||
|
lun = 0x401040a300000000 /dev/sg1 Disk IBM:2107900
|
||||||
|
|
||||||
|
-Shows all active LUNs including the information whether the device is encrypted or not.
|
||||||
|
+Shows the encryption status of attached LUNs. A bracketed X suffixed to a LUN
|
||||||
|
+indicates that the device is encrypted.
|
||||||
|
+
|
||||||
|
+.SH "SEE ALSO"
|
||||||
|
+.BR lszfcp (8),
|
||||||
|
+.BR lsscsi (8)
|
170
s390-tools-sles15-lsluns-fix-flawed-formatting-of-man-page.patch
Normal file
170
s390-tools-sles15-lsluns-fix-flawed-formatting-of-man-page.patch
Normal file
@ -0,0 +1,170 @@
|
|||||||
|
Subject: [PATCH] [BZ 161888] lsluns: fix flawed formatting of man page
|
||||||
|
From: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
Description: lsluns: Fix filter handling and documentation enhancements.
|
||||||
|
Symptom: lsluns lists all LUNs discovered in the FC SAN despite user
|
||||||
|
given filter(s) that do not match anything:
|
||||||
|
# lsluns -c 0.0.5080
|
||||||
|
No valid combination found for adapter '0.0.5080'. Removing
|
||||||
|
from resource list.
|
||||||
|
No valid parameters left, using all available resources in
|
||||||
|
system.
|
||||||
|
Scanning for LUNs on adapter 0.0.5090
|
||||||
|
...
|
||||||
|
|
||||||
|
lsluns prints the message "No valid combination found for
|
||||||
|
{adapter|port} '...'. Removing from resource list." for every
|
||||||
|
adapter and port filter that does not contribute to the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
lsluns is used in unexpected or even unsupported ways.
|
||||||
|
Problem: Scanning can be resource consumptive. So if a user already wants
|
||||||
|
to filter, possibly to reduce resource consumption, he does not
|
||||||
|
want to happen to scan everything and thus consume the worst case
|
||||||
|
of resources.
|
||||||
|
|
||||||
|
The message "No valid combination found for {adapter|port} '...'.
|
||||||
|
Removing from resource list." is potentially confusing. It is
|
||||||
|
unclear which combination is being referred to, especially if
|
||||||
|
only one single adapter or port filter was specified. There is
|
||||||
|
also no differentiation whether the denoted adapter or port
|
||||||
|
exists for its own or not. It just does not exist in the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
The lsluns usage text and lsluns (8) man page lack the
|
||||||
|
information on the intended use cases, requirements, and
|
||||||
|
restrictions.
|
||||||
|
Solution: Print a message and exit when all filters match nothing.
|
||||||
|
|
||||||
|
Do not print confusing messages when a filter matches nothing.
|
||||||
|
|
||||||
|
Fix man page formatting.
|
||||||
|
|
||||||
|
Enhance usage text and man page. Clarify discovery use case,
|
||||||
|
relation to NPIV and to zfcp auto LUN scan. Point out
|
||||||
|
IBM Storwize configuration requirements. Document restriction to
|
||||||
|
zfcp-only systems.
|
||||||
|
Reproduction: Use lsluns and specify adapter bus-ID and/or target port WWPN
|
||||||
|
filter(s) that do not match anything. Either specify inexistent
|
||||||
|
bus-IDs and/or WWPNs or invalid filter arguments.
|
||||||
|
Upstream-ID: d81c4234295f481559a74fb5ad5f498692ff5738
|
||||||
|
Problem-ID: 161888
|
||||||
|
|
||||||
|
Upstream-Description:
|
||||||
|
|
||||||
|
lsluns: fix flawed formatting of man page
|
||||||
|
|
||||||
|
The formatting in the SYNOPSIS, OPTIONS, and EXAMPLES sections was flawed
|
||||||
|
in the lsluns(8) man page:
|
||||||
|
|
||||||
|
* The comma between short and long options were erroneously formatted in
|
||||||
|
bold, which would indicate to be typed exactly as shown. [see man(1)]
|
||||||
|
|
||||||
|
* The option parameters (e.g. adapter and port) were erroneously formatted
|
||||||
|
in bold instead of italic text (usually displayed as underlined on the
|
||||||
|
console), which would again indicate to be typed exactly as shown instead
|
||||||
|
of to be replaced with the appropriate argument. [see man(1)]
|
||||||
|
|
||||||
|
* Ellipses were missing after the the options that may be specified multiple
|
||||||
|
times (e.g. adapter and port). [see man(1)]
|
||||||
|
|
||||||
|
* Dashes in options in the SYNOPSIS and OPTIONS section needed to be
|
||||||
|
escaped. [see man-pages(7)]
|
||||||
|
|
||||||
|
* User input in example shell sessions should have been formatted in bold.
|
||||||
|
[see man-pages(7)]
|
||||||
|
|
||||||
|
Correct formatting based on man(7) and man-pages(7) man pages as reference.
|
||||||
|
Add proper spacing between options and their surrounding square brackets and
|
||||||
|
between the three periods of ellipses.
|
||||||
|
|
||||||
|
Signed-off-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
Reviewed-by: Steffen Maier <maier@linux.vnet.ibm.com>
|
||||||
|
Reviewed-by: Benjamin Block <bblock@linux.vnet.ibm.com>
|
||||||
|
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
|
||||||
|
Signed-off-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
---
|
||||||
|
zconf/lsluns.8 | 42 +++++++++++++++++++++++-------------------
|
||||||
|
1 file changed, 23 insertions(+), 19 deletions(-)
|
||||||
|
|
||||||
|
--- a/zconf/lsluns.8
|
||||||
|
+++ b/zconf/lsluns.8
|
||||||
|
@@ -8,12 +8,12 @@ lsluns \- list available LUNs
|
||||||
|
|
||||||
|
.SH SYNOPSIS
|
||||||
|
.B lsluns
|
||||||
|
-.RB [ \-h]
|
||||||
|
-.RB [ \-v]
|
||||||
|
-.RB [ \-c
|
||||||
|
-.IR adapter id:0.0.XXXX ]
|
||||||
|
+.RB [\| \-h \|]
|
||||||
|
+.RB [\| \-v \|]
|
||||||
|
+.RB [\| \-c
|
||||||
|
+.IR adapter\ id:0.0.XXXX \|]\ .\|.\|.
|
||||||
|
.RB [ \-p
|
||||||
|
-.IR port number:0xXXXXXXXXXXXXXXXX ]
|
||||||
|
+.IR port\ number:0xXXXXXXXXXXXXXXXX \|]\ .\|.\|.
|
||||||
|
|
||||||
|
.SH DESCRIPTION
|
||||||
|
.PP
|
||||||
|
@@ -25,36 +25,40 @@ limited by specifying an adapter or a po
|
||||||
|
|
||||||
|
.SH OPTIONS
|
||||||
|
.TP
|
||||||
|
-.B -h, --help
|
||||||
|
+.BR \-h ", " \-\-help
|
||||||
|
Print help message and exit.
|
||||||
|
.TP
|
||||||
|
-.B -v, --version
|
||||||
|
+.BR \-v ", " \-\-version
|
||||||
|
Display version info and exit.
|
||||||
|
.TP
|
||||||
|
-.B -c, --ccw
|
||||||
|
+.BI \-c\ adapter \fR,\ \fB\-\-ccw= adapter
|
||||||
|
Shows LUNs for a specific adapter.
|
||||||
|
.TP
|
||||||
|
-.B -p, --port
|
||||||
|
+.BI \-p\ port \fR,\ \fB\-\-port= port
|
||||||
|
Shows LUNs for a specific port.
|
||||||
|
.TP
|
||||||
|
-.B -a, --active
|
||||||
|
+.BR \-a ", " \-\-active
|
||||||
|
Shows all activated LUNs. In addition information is provided
|
||||||
|
whether the LUN is encrypted or not. This is indicated with a bracketed X
|
||||||
|
right after the LUN number.
|
||||||
|
|
||||||
|
.SH EXAMPLES
|
||||||
|
-.PP
|
||||||
|
-.IP "lsluns"
|
||||||
|
+.TP
|
||||||
|
+.B "lsluns"
|
||||||
|
.RS
|
||||||
|
Shows all available LUNs.
|
||||||
|
.RE
|
||||||
|
-.IP "lsluns -c 0.0.3922"
|
||||||
|
-Shows all LUNs found on adapter 0.0.3922.
|
||||||
|
-.IP "lsluns -p 0x5005123456789000"
|
||||||
|
-Shows all LUNs for port 0x5005123456789000.
|
||||||
|
-.IP "lsluns -c 0.0.3922 -p 0x5005123456789000"
|
||||||
|
-Shows all LUNs for adapter 0.0.3922 and port 0x5005123456789000.
|
||||||
|
-.IP "lsluns -a "
|
||||||
|
+.TP
|
||||||
|
+.BI "lsluns \-c " 0.0.3922
|
||||||
|
+Shows all LUNs found on adapter \fI0.0.3922\fR.
|
||||||
|
+.TP
|
||||||
|
+.BI "lsluns \-p " 0x5005123456789000
|
||||||
|
+Shows all LUNs for port \fI0x5005123456789000\fR.
|
||||||
|
+.TP
|
||||||
|
+.BI "lsluns \-c " 0.0.3922 " \-p " 0x5005123456789000
|
||||||
|
+Shows all LUNs for adapter \fI0.0.3922\fR and port \fI0x5005123456789000\fR.
|
||||||
|
+.TP
|
||||||
|
+.B "lsluns -a"
|
||||||
|
adapter = 0.0.3c02
|
||||||
|
port = 0x500507630300c562
|
||||||
|
lun = 0x401040a200000000(X) /dev/sg0 Disk IBM:2107900
|
@ -0,0 +1,105 @@
|
|||||||
|
Subject: [PATCH] [BZ 161888] lsluns: point out IBM Storwize configuration requirements
|
||||||
|
From: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
Description: lsluns: Fix filter handling and documentation enhancements.
|
||||||
|
Symptom: lsluns lists all LUNs discovered in the FC SAN despite user
|
||||||
|
given filter(s) that do not match anything:
|
||||||
|
# lsluns -c 0.0.5080
|
||||||
|
No valid combination found for adapter '0.0.5080'. Removing
|
||||||
|
from resource list.
|
||||||
|
No valid parameters left, using all available resources in
|
||||||
|
system.
|
||||||
|
Scanning for LUNs on adapter 0.0.5090
|
||||||
|
...
|
||||||
|
|
||||||
|
lsluns prints the message "No valid combination found for
|
||||||
|
{adapter|port} '...'. Removing from resource list." for every
|
||||||
|
adapter and port filter that does not contribute to the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
lsluns is used in unexpected or even unsupported ways.
|
||||||
|
Problem: Scanning can be resource consumptive. So if a user already wants
|
||||||
|
to filter, possibly to reduce resource consumption, he does not
|
||||||
|
want to happen to scan everything and thus consume the worst case
|
||||||
|
of resources.
|
||||||
|
|
||||||
|
The message "No valid combination found for {adapter|port} '...'.
|
||||||
|
Removing from resource list." is potentially confusing. It is
|
||||||
|
unclear which combination is being referred to, especially if
|
||||||
|
only one single adapter or port filter was specified. There is
|
||||||
|
also no differentiation whether the denoted adapter or port
|
||||||
|
exists for its own or not. It just does not exist in the final
|
||||||
|
filtered results.
|
||||||
|
|
||||||
|
The formatting of the lsluns (8) man page is flawed.
|
||||||
|
|
||||||
|
The lsluns usage text and lsluns (8) man page lack the
|
||||||
|
information on the intended use cases, requirements, and
|
||||||
|
restrictions.
|
||||||
|
Solution: Print a message and exit when all filters match nothing.
|
||||||
|
|
||||||
|
Do not print confusing messages when a filter matches nothing.
|
||||||
|
|
||||||
|
Fix man page formatting.
|
||||||
|
|
||||||
|
Enhance usage text and man page. Clarify discovery use case,
|
||||||
|
relation to NPIV and to zfcp auto LUN scan. Point out
|
||||||
|
IBM Storwize configuration requirements. Document restriction to
|
||||||
|
zfcp-only systems.
|
||||||
|
Reproduction: Use lsluns and specify adapter bus-ID and/or target port WWPN
|
||||||
|
filter(s) that do not match anything. Either specify inexistent
|
||||||
|
bus-IDs and/or WWPNs or invalid filter arguments.
|
||||||
|
Upstream-ID: 5f768dd52d87efddbd7efa23d57c6da62281728b
|
||||||
|
Problem-ID: 161888
|
||||||
|
|
||||||
|
Upstream-Description:
|
||||||
|
|
||||||
|
lsluns: point out IBM Storwize configuration requirements
|
||||||
|
|
||||||
|
Signed-off-by: Steffen Maier <maier@linux.vnet.ibm.com>
|
||||||
|
Reviewed-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
|
||||||
|
Signed-off-by: Jens Remus <jremus@linux.vnet.ibm.com>
|
||||||
|
---
|
||||||
|
zconf/lsluns | 4 ++++
|
||||||
|
zconf/lsluns.8 | 12 ++++++++++++
|
||||||
|
2 files changed, 16 insertions(+)
|
||||||
|
|
||||||
|
--- a/zconf/lsluns
|
||||||
|
+++ b/zconf/lsluns
|
||||||
|
@@ -177,6 +177,10 @@ $PROGRAM_NAME [-c <busid>] ... [-p <wwpn
|
||||||
|
Discovering LUNs only makes sense for NPIV-enabled FCP devices
|
||||||
|
without zfcp automatic LUN scan. zfcp automatic LUN scan is available
|
||||||
|
as of kernel version 2.6.37, if not disabled with zfcp.allow_lun_scan=0.
|
||||||
|
+ For storage products that do not support a REPORT LUNS
|
||||||
|
+ well-known logical unit (such as IBM Storwize products),
|
||||||
|
+ ensure that LUN 0 represents a valid peripheral device type.
|
||||||
|
+ See the man page for more information.
|
||||||
|
|
||||||
|
$PROGRAM_NAME -a [-c <busid>] ... [-p <wwpn>] ... [-h] [-v]
|
||||||
|
|
||||||
|
--- a/zconf/lsluns.8
|
||||||
|
+++ b/zconf/lsluns.8
|
||||||
|
@@ -64,6 +64,18 @@ If not attached already, lsluns temporar
|
||||||
|
Do not terminate lsluns with a signal. Signals interfere
|
||||||
|
with the removal of temporarily attached LUNs.
|
||||||
|
|
||||||
|
+.TP
|
||||||
|
+Storage Products
|
||||||
|
+Some storage products return a peripheral device type of 31==0x1f
|
||||||
|
+with peripheral qualifier 0 in a SCSI standard INQUIRY command
|
||||||
|
+for an unmapped FCP LUN 0. Examples are: IBM Storwize products,
|
||||||
|
+including IBM V7000, IBM V840, IBM V9000, and IBM SAN Volume Controller.
|
||||||
|
+For lsluns to work with such storage products,
|
||||||
|
+you must have a host mapping on the storage, which maps some volume
|
||||||
|
+to exported FCP LUN 0x0000000000000000 (Storwize host map property "SCSI ID" 0)
|
||||||
|
+for each used FCP-device initiator WWPN. The volume can be
|
||||||
|
+a minimum-sized thin-provisioned shared stand-in volume.
|
||||||
|
+
|
||||||
|
.SH OPTIONS
|
||||||
|
.TP
|
||||||
|
.BR \-a ", " \-\-active
|
@ -0,0 +1,290 @@
|
|||||||
|
Subject: [PATCH] [BZ 161563] mon_tools: Improve systemctl start error handling
|
||||||
|
From: Gerald Schaefer <gerald.schaefer@de.ibm.com>
|
||||||
|
|
||||||
|
Description: cpuplugd, mon_tools: Improve systemctl start error handling
|
||||||
|
Symptom: "systemctl start cpuplugd/mon_procd/mon_fsstatd" does not
|
||||||
|
report any errors in case the startup fails.
|
||||||
|
Problem: For type=simple, systemd forks/execs the process and if that
|
||||||
|
is successful, it immediately returns. There is no way to
|
||||||
|
find out if the initial startup fails.
|
||||||
|
Solution: Use type=fork and run the process in the background. In this
|
||||||
|
case systemd waits until the initial process returns.
|
||||||
|
In addition, use PIDFile and ensure that the pid file is
|
||||||
|
already available when the initial process returns. To
|
||||||
|
achieve this, use startup synchronization via pipe.
|
||||||
|
Reproduction: Add invalid values to the config files and start the daemons
|
||||||
|
with "systemctl start cpuplugd/mon_procd/mon_fsstatd".
|
||||||
|
Upstream-ID: 780133f825687bc931489aaf13959c793d2a4501
|
||||||
|
Problem-ID: 161563
|
||||||
|
|
||||||
|
Upstream-Description:
|
||||||
|
|
||||||
|
mon_tools: Improve systemctl start error handling
|
||||||
|
|
||||||
|
This fixes the same issue as in commit 82c8148983fc ("cpuplugd: Improve
|
||||||
|
systemctl start error handling") for mon_tools (mon_procd and mon_fsstatd).
|
||||||
|
|
||||||
|
Currently "systemctl start mon_procd/fsstatd" does not report any errors
|
||||||
|
in case the startup fails.
|
||||||
|
|
||||||
|
Example (with mon_procd):
|
||||||
|
|
||||||
|
(change interval in /etc/sysconfig/mon_procd to an invalid value "abc")
|
||||||
|
# systemctl start mon_procd
|
||||||
|
|
||||||
|
The reason is that for type=simple systemd forks/execs mon_procd and if
|
||||||
|
that is successful immediately returns. There is no way to find out if the
|
||||||
|
initial startup fails.
|
||||||
|
|
||||||
|
Fix this by using type=fork and running the process in the background. In
|
||||||
|
this case systemd waits until the initial process returns.
|
||||||
|
|
||||||
|
In addition use PIDFile and ensure that the pid file is already available
|
||||||
|
when the initial process returns. To achieve this, use startup
|
||||||
|
synchronization via pipe. Without that systemd would print the following
|
||||||
|
warning:
|
||||||
|
|
||||||
|
systemd[1]: mon_procd.service: PID file /var/run/mon_procd.pid not readable
|
||||||
|
(yet?) after start: No such file or directory
|
||||||
|
|
||||||
|
With this patch, an early startup error like in the example above, is now
|
||||||
|
reported correctly in "systemctl start":
|
||||||
|
|
||||||
|
# systemctl start mon_procd
|
||||||
|
Job for mon_procd.service failed because the control process exited...
|
||||||
|
See "systemctl status mon_procd.service" and "journalctl -xe" for ...
|
||||||
|
# journalctl -xe | grep mon_procd
|
||||||
|
mon_procd[3184]: Error: Invalid interval (needs to be greater than 0)
|
||||||
|
|
||||||
|
Signed-off-by: Gerald Schaefer <gerald.schaefer@de.ibm.com>
|
||||||
|
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
|
||||||
|
Signed-off-by: Gerald Schaefer <gerald.schaefer@de.ibm.com>
|
||||||
|
---
|
||||||
|
mon_tools/mon_fsstatd.c | 40 ++++++++++++++++++++++++++++++++--------
|
||||||
|
mon_tools/mon_procd.c | 40 ++++++++++++++++++++++++++++++++--------
|
||||||
|
systemd/mon_fsstatd.service.in | 5 +++--
|
||||||
|
systemd/mon_procd.service.in | 5 +++--
|
||||||
|
4 files changed, 70 insertions(+), 20 deletions(-)
|
||||||
|
|
||||||
|
--- a/mon_tools/mon_fsstatd.c
|
||||||
|
+++ b/mon_tools/mon_fsstatd.c
|
||||||
|
@@ -90,17 +90,18 @@ static void fsstatd_open_monwriter(void)
|
||||||
|
/*
|
||||||
|
* Store daemon's pid so it can be stopped
|
||||||
|
*/
|
||||||
|
-static void store_pid(void)
|
||||||
|
+static int store_pid(void)
|
||||||
|
{
|
||||||
|
FILE *f = fopen(pid_file, "w");
|
||||||
|
|
||||||
|
if (!f) {
|
||||||
|
syslog(LOG_ERR, "cannot open pid file %s: %s", pid_file,
|
||||||
|
strerror(errno));
|
||||||
|
- exit(1);
|
||||||
|
+ return -1;
|
||||||
|
}
|
||||||
|
fprintf(f, "%d\n", getpid());
|
||||||
|
fclose(f);
|
||||||
|
+ return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@@ -244,41 +245,64 @@ static void fsstatd_write_ent(struct mnt
|
||||||
|
*/
|
||||||
|
static void fsstatd_daemonize(void)
|
||||||
|
{
|
||||||
|
+ int pipe_fds[2], startup_rc = 1;
|
||||||
|
pid_t pid;
|
||||||
|
|
||||||
|
+ if (pipe(pipe_fds) == -1) {
|
||||||
|
+ syslog(LOG_ERR, "pipe error: %s\n", strerror(errno));
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
/* Fork off the parent process */
|
||||||
|
pid = fork();
|
||||||
|
if (pid < 0) {
|
||||||
|
syslog(LOG_ERR, "fork error: %s\n", strerror(errno));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
- if (pid > 0)
|
||||||
|
- exit(0);
|
||||||
|
+ if (pid > 0) {
|
||||||
|
+ /* Wait for startup return code from daemon */
|
||||||
|
+ if (read(pipe_fds[0], &startup_rc, sizeof(startup_rc)) == -1)
|
||||||
|
+ syslog(LOG_ERR, "pipe read error: %s\n", strerror(errno));
|
||||||
|
+ /* With startup_rc == 0, pid file was written at this point */
|
||||||
|
+ exit(startup_rc);
|
||||||
|
+ }
|
||||||
|
|
||||||
|
/* Change the file mode mask */
|
||||||
|
umask(0);
|
||||||
|
|
||||||
|
- /* Store daemon pid */
|
||||||
|
- store_pid();
|
||||||
|
/* Catch SIGINT and SIGTERM to clean up pid file on exit */
|
||||||
|
fsstatd_handle_signals();
|
||||||
|
|
||||||
|
/* Create a new SID for the child process */
|
||||||
|
if (setsid() < 0) {
|
||||||
|
syslog(LOG_ERR, "setsid error: %s\n", strerror(errno));
|
||||||
|
- exit(1);
|
||||||
|
+ goto notify_parent;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Change the current working directory */
|
||||||
|
if (chdir("/") < 0) {
|
||||||
|
syslog(LOG_ERR, "chdir error: %s\n", strerror(errno));
|
||||||
|
- exit(1);
|
||||||
|
+ goto notify_parent;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Close out the standard file descriptors */
|
||||||
|
close(STDIN_FILENO);
|
||||||
|
close(STDOUT_FILENO);
|
||||||
|
close(STDERR_FILENO);
|
||||||
|
+
|
||||||
|
+ /* Store daemon pid */
|
||||||
|
+ if (store_pid() < 0)
|
||||||
|
+ goto notify_parent;
|
||||||
|
+ startup_rc = 0;
|
||||||
|
+
|
||||||
|
+notify_parent:
|
||||||
|
+ /* Inform waiting parent about startup return code */
|
||||||
|
+ if (write(pipe_fds[1], &startup_rc, sizeof(startup_rc)) == -1) {
|
||||||
|
+ syslog(LOG_ERR, "pipe write error: %s\n", strerror(errno));
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+ if (startup_rc != 0)
|
||||||
|
+ exit(startup_rc);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int fsstatd_do_work(void)
|
||||||
|
--- a/mon_tools/mon_procd.c
|
||||||
|
+++ b/mon_tools/mon_procd.c
|
||||||
|
@@ -109,17 +109,18 @@ static void procd_open_monwriter(void)
|
||||||
|
/*
|
||||||
|
* Store daemon's pid so it can be stopped
|
||||||
|
*/
|
||||||
|
-static void store_pid(void)
|
||||||
|
+static int store_pid(void)
|
||||||
|
{
|
||||||
|
FILE *f = fopen(pid_file, "w");
|
||||||
|
|
||||||
|
if (!f) {
|
||||||
|
syslog(LOG_ERR, "cannot open pid file %s: %s", pid_file,
|
||||||
|
strerror(errno));
|
||||||
|
- exit(1);
|
||||||
|
+ return -1;
|
||||||
|
}
|
||||||
|
fprintf(f, "%d\n", getpid());
|
||||||
|
fclose(f);
|
||||||
|
+ return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@@ -897,41 +898,64 @@ static void read_tasks(void)
|
||||||
|
*/
|
||||||
|
static void procd_daemonize(void)
|
||||||
|
{
|
||||||
|
+ int pipe_fds[2], startup_rc = 1;
|
||||||
|
pid_t pid;
|
||||||
|
|
||||||
|
+ if (pipe(pipe_fds) == -1) {
|
||||||
|
+ syslog(LOG_ERR, "pipe error: %s\n", strerror(errno));
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
/* Fork off the parent process */
|
||||||
|
pid = fork();
|
||||||
|
if (pid < 0) {
|
||||||
|
syslog(LOG_ERR, "fork error: %s\n", strerror(errno));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
- if (pid > 0)
|
||||||
|
- exit(0);
|
||||||
|
+ if (pid > 0) {
|
||||||
|
+ /* Wait for startup return code from daemon */
|
||||||
|
+ if (read(pipe_fds[0], &startup_rc, sizeof(startup_rc)) == -1)
|
||||||
|
+ syslog(LOG_ERR, "pipe read error: %s\n", strerror(errno));
|
||||||
|
+ /* With startup_rc == 0, pid file was written at this point */
|
||||||
|
+ exit(startup_rc);
|
||||||
|
+ }
|
||||||
|
|
||||||
|
/* Change the file mode mask */
|
||||||
|
umask(0);
|
||||||
|
|
||||||
|
- /* Store daemon pid */
|
||||||
|
- store_pid();
|
||||||
|
/* Catch SIGINT and SIGTERM to clean up pid file on exit */
|
||||||
|
procd_handle_signals();
|
||||||
|
|
||||||
|
/* Create a new SID for the child process */
|
||||||
|
if (setsid() < 0) {
|
||||||
|
syslog(LOG_ERR, "setsid error: %s\n", strerror(errno));
|
||||||
|
- exit(1);
|
||||||
|
+ goto notify_parent;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Change the current working directory */
|
||||||
|
if (chdir("/") < 0) {
|
||||||
|
syslog(LOG_ERR, "chdir error: %s\n", strerror(errno));
|
||||||
|
- exit(1);
|
||||||
|
+ goto notify_parent;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Close out the standard file descriptors */
|
||||||
|
close(STDIN_FILENO);
|
||||||
|
close(STDOUT_FILENO);
|
||||||
|
close(STDERR_FILENO);
|
||||||
|
+
|
||||||
|
+ /* Store daemon pid */
|
||||||
|
+ if (store_pid() < 0)
|
||||||
|
+ goto notify_parent;
|
||||||
|
+ startup_rc = 0;
|
||||||
|
+
|
||||||
|
+notify_parent:
|
||||||
|
+ /* Inform waiting parent about startup return code */
|
||||||
|
+ if (write(pipe_fds[1], &startup_rc, sizeof(startup_rc)) == -1) {
|
||||||
|
+ syslog(LOG_ERR, "pipe write error: %s\n", strerror(errno));
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+ if (startup_rc != 0)
|
||||||
|
+ exit(startup_rc);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int procd_do_work(void)
|
||||||
|
--- a/systemd/mon_fsstatd.service.in
|
||||||
|
+++ b/systemd/mon_fsstatd.service.in
|
||||||
|
@@ -30,10 +30,11 @@ EnvironmentFile=/etc/sysconfig/mon_fssta
|
||||||
|
|
||||||
|
ExecStartPre=-/sbin/modprobe monwriter
|
||||||
|
ExecStartPre=/sbin/udevadm settle --timeout=10
|
||||||
|
-ExecStart=@usrsbin_path@/mon_fsstatd -a -i $FSSTAT_INTERVAL
|
||||||
|
+ExecStart=@usrsbin_path@/mon_fsstatd -i $FSSTAT_INTERVAL
|
||||||
|
ExecReload=/bin/kill -HUP $MAINPID
|
||||||
|
KillMode=process
|
||||||
|
-Type=simple
|
||||||
|
+Type=forking
|
||||||
|
+PIDFile=/var/run/mon_fsstatd.pid
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
--- a/systemd/mon_procd.service.in
|
||||||
|
+++ b/systemd/mon_procd.service.in
|
||||||
|
@@ -30,10 +30,11 @@ EnvironmentFile=/etc/sysconfig/mon_procd
|
||||||
|
|
||||||
|
ExecStartPre=-/sbin/modprobe monwriter
|
||||||
|
ExecStartPre=/sbin/udevadm settle --timeout=10
|
||||||
|
-ExecStart=@usrsbin_path@/mon_procd -a -i $PROC_INTERVAL
|
||||||
|
+ExecStart=@usrsbin_path@/mon_procd -i $PROC_INTERVAL
|
||||||
|
ExecReload=/bin/kill -HUP $MAINPID
|
||||||
|
KillMode=process
|
||||||
|
-Type=simple
|
||||||
|
+Type=forking
|
||||||
|
+PIDFile=/var/run/mon_procd.pid
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
@ -0,0 +1,53 @@
|
|||||||
|
From 2a6a28023bdfe127be68ac605f9a026a82884c80 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Peter Oberparleiter <oberpar@linux.vnet.ibm.com>
|
||||||
|
Date: Tue, 5 Dec 2017 15:40:23 +0100
|
||||||
|
Subject: [PATCH 1/4] zdev: Enable running chzdev from unknown root devices
|
||||||
|
|
||||||
|
When a persistent device configuration is changed, chzdev tries to
|
||||||
|
find out if it needs to perform additional steps to make this change
|
||||||
|
persistent. If this check fails, for example because the root device
|
||||||
|
is located on a RAM-disk, or on a device type not managed by chzdev,
|
||||||
|
the tool reports an error and exits with non-zero exit code:
|
||||||
|
|
||||||
|
chzdev: Could not determine device that provides /
|
||||||
|
|
||||||
|
or
|
||||||
|
|
||||||
|
chzdev: Could not determine device that provides loop0
|
||||||
|
|
||||||
|
This behavior unnecessarily restricts chzdev from being used in
|
||||||
|
scripted environments like an installation initial RAM-disk.
|
||||||
|
|
||||||
|
Fix this by removing the non-zero exit code and moving the message to
|
||||||
|
verbose output mode only.
|
||||||
|
|
||||||
|
Signed-off-by: Peter Oberparleiter <oberpar@linux.vnet.ibm.com>
|
||||||
|
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
---
|
||||||
|
zdev/src/root.c | 9 +++++++--
|
||||||
|
1 file changed, 7 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/zdev/src/root.c b/zdev/src/root.c
|
||||||
|
index 7f0d39f..668bdbd 100644
|
||||||
|
--- a/zdev/src/root.c
|
||||||
|
+++ b/zdev/src/root.c
|
||||||
|
@@ -35,9 +35,14 @@ exit_code_t root_check(void)
|
||||||
|
/* Get list of devices that provide the root device. */
|
||||||
|
selected = selected_dev_list_new();
|
||||||
|
rc = select_by_path(NULL, selected, config_active, scope_mandatory,
|
||||||
|
- NULL, NULL, PATH_ROOT, err_print);
|
||||||
|
- if (rc)
|
||||||
|
+ NULL, NULL, PATH_ROOT, err_ignore);
|
||||||
|
+ if (rc) {
|
||||||
|
+ /* Running from an unknown root device is not an error. */
|
||||||
|
+ verb("Note: Could not determine if root device configuration "
|
||||||
|
+ "needs to be updated\n");
|
||||||
|
+ rc = 0;
|
||||||
|
goto out;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
/* Determine if any of the devices or device types has been modified. */
|
||||||
|
mod = strlist_new();
|
||||||
|
--
|
||||||
|
2.13.6
|
||||||
|
|
@ -0,0 +1,54 @@
|
|||||||
|
From 0348a8443e5f15636f86ef2533a7d6e8fa5d936d Mon Sep 17 00:00:00 2001
|
||||||
|
From: Peter Oberparleiter <oberpar@linux.vnet.ibm.com>
|
||||||
|
Date: Thu, 7 Dec 2017 17:21:11 +0100
|
||||||
|
Subject: [PATCH 4/4] zdev: Fix zdev dracut module aborting on unknown root
|
||||||
|
device
|
||||||
|
|
||||||
|
Running dracut when the root device is not known to zdev (for example
|
||||||
|
because it is located on a virtio block device) will cause the zdev
|
||||||
|
dracut module to incorrectly return an error in the installkernel()
|
||||||
|
function. As a result dracut aborts with an error.
|
||||||
|
|
||||||
|
Fix this by ensuring that the non-zero exit code resulting from lszdev
|
||||||
|
not being able to determine the root device is not passed on to the
|
||||||
|
calling function. Also remove unnecessary error output in this case
|
||||||
|
by leaving the install() function early when the root device is not
|
||||||
|
known to zdev.
|
||||||
|
|
||||||
|
Signed-off-by: Peter Oberparleiter <oberpar@linux.vnet.ibm.com>
|
||||||
|
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
---
|
||||||
|
zdev/dracut/95zdev/module-setup.sh | 12 ++++++++++--
|
||||||
|
1 file changed, 10 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/zdev/dracut/95zdev/module-setup.sh b/zdev/dracut/95zdev/module-setup.sh
|
||||||
|
index 7c67cd7..4c13a65 100644
|
||||||
|
--- a/zdev/dracut/95zdev/module-setup.sh
|
||||||
|
+++ b/zdev/dracut/95zdev/module-setup.sh
|
||||||
|
@@ -29,13 +29,21 @@ depends() {
|
||||||
|
}
|
||||||
|
|
||||||
|
installkernel() {
|
||||||
|
- local _modules=$(lszdev --by-path / --columns MODULES --no-headings)
|
||||||
|
+ local _modules=$(lszdev --by-path / --columns MODULES --no-headings 2>/dev/null)
|
||||||
|
|
||||||
|
+ [ -z "$_modules" ] && return 0
|
||||||
|
[ ! -z "$_modules" ] && instmods $_modules
|
||||||
|
}
|
||||||
|
|
||||||
|
install() {
|
||||||
|
- local _tempfile=$(mktemp --tmpdir dracut-zdev.XXXXXX)
|
||||||
|
+ local _tempfile
|
||||||
|
+
|
||||||
|
+ # Exit early if root device type is unknown
|
||||||
|
+ if ! lszdev --by-path / >/dev/null 2>&1 ; then
|
||||||
|
+ return 0
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ _tempfile=$(mktemp --tmpdir dracut-zdev.XXXXXX)
|
||||||
|
|
||||||
|
if chzdev --export - --persistent --by-path / >/dev/null 2>&1 ; then
|
||||||
|
# Use persistent configuration
|
||||||
|
--
|
||||||
|
2.13.6
|
||||||
|
|
@ -22,7 +22,7 @@ diff --git a/common.mak b/common.mak
|
|||||||
index b9a9f54..bb6cdf0 100644
|
index b9a9f54..bb6cdf0 100644
|
||||||
--- a/common.mak
|
--- a/common.mak
|
||||||
+++ b/common.mak
|
+++ b/common.mak
|
||||||
@@ -194,12 +194,14 @@ ALL_CFLAGS = -DS390_TOOLS_RELEASE=$(S390_TOOLS_RELEASE) \
|
@@ -193,12 +193,14 @@ ALL_CFLAGS = -DS390_TOOLS_RELEASE=$(S390_TOOLS_RELEASE) \
|
||||||
-DS390_TOOLS_LIBDIR=$(TOOLS_LIBDIR) \
|
-DS390_TOOLS_LIBDIR=$(TOOLS_LIBDIR) \
|
||||||
-DS390_TOOLS_DATADIR=$(TOOLS_DATADIR) \
|
-DS390_TOOLS_DATADIR=$(TOOLS_DATADIR) \
|
||||||
-DS390_TOOLS_SYSCONFDIR=$(SYSCONFDIR) \
|
-DS390_TOOLS_SYSCONFDIR=$(SYSCONFDIR) \
|
||||||
|
28
s390-tools-sles15-ziomon-re-add-missing-line.patch
Normal file
28
s390-tools-sles15-ziomon-re-add-missing-line.patch
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
Subject: [PATCH] [BZ 161467] ziomon: Re-add missing line in ziomon_fcpconf
|
||||||
|
From: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
Description: ziomon: Re-add missing line in ziomon_fcpconf
|
||||||
|
Symptom: ziomon_fcpconf fails on startup with:
|
||||||
|
Global symbol "$map_dev" requires explicit package name ...
|
||||||
|
Problem: During the GPL to MIT conversion process from v1.39.0 to
|
||||||
|
v2.0.0 one line has been lost by accident.
|
||||||
|
Solution: Re-add that line again.
|
||||||
|
Reproduction: Call the ziomon_fcpconf tool.
|
||||||
|
Upstream-ID: 523d833eb31633673847b6da0edbd35903f14dc4
|
||||||
|
Problem-ID: 161467
|
||||||
|
|
||||||
|
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
||||||
|
---
|
||||||
|
ziomon/ziomon_fcpconf | 1 +
|
||||||
|
1 file changed, 1 insertion(+)
|
||||||
|
|
||||||
|
--- a/ziomon/ziomon_fcpconf
|
||||||
|
+++ b/ziomon/ziomon_fcpconf
|
||||||
|
@@ -58,6 +58,7 @@ sub store_mapper_devices
|
||||||
|
my $src_dir = shift();
|
||||||
|
my @entries = grep { ! /^\./ } dir_content($src_dir);
|
||||||
|
|
||||||
|
+ foreach my $map_dev (@entries) {
|
||||||
|
my $tf = catfile($src_dir, "$map_dev");
|
||||||
|
my $mm = `stat -L -c%t:%T $tf`;
|
||||||
|
chomp($mm);
|
@ -0,0 +1,29 @@
|
|||||||
|
Subject: [PATCH] [BZ 161183] zipl: remove invalid dasdview command line option
|
||||||
|
From: Stefan Haberland <sth@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
Description: zipl: remove invalid dasdview command line option
|
||||||
|
Symptom: zipl does not work when used with a lvm or device mapper
|
||||||
|
target.
|
||||||
|
Problem: The zipl_helper.device-mapper script uses dasdview with
|
||||||
|
an option "-f" that has been removed recently.
|
||||||
|
Solution: Remove "-f" from the dasdview call.
|
||||||
|
Reproduction: Run zipl on a lvm target.
|
||||||
|
Upstream-ID: -
|
||||||
|
Problem-ID: 161183
|
||||||
|
|
||||||
|
Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com>
|
||||||
|
---
|
||||||
|
zipl/src/zipl_helper.device-mapper | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
--- a/zipl/src/zipl_helper.device-mapper
|
||||||
|
+++ b/zipl/src/zipl_helper.device-mapper
|
||||||
|
@@ -623,7 +623,7 @@ sub get_dasd_info($)
|
||||||
|
my $type;
|
||||||
|
local *HANDLE;
|
||||||
|
|
||||||
|
- open(HANDLE, "$dasdview -x -f $dev 2>/dev/null|") or
|
||||||
|
+ open(HANDLE, "$dasdview -x $dev 2>/dev/null|") or
|
||||||
|
# dasdview returned with an error
|
||||||
|
return undef;
|
||||||
|
while (<HANDLE>) {
|
@ -1,3 +1,46 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Thu Dec 7 23:08:31 UTC 2017 - mpost@suse.com
|
||||||
|
|
||||||
|
- Added the following two patches (bsc#1071166):
|
||||||
|
s390-tools-sles15-zdev-Enable-running-chzdev-from-unknown-root-devices.patch
|
||||||
|
s390-tools-sles15-zdev-Fix-zdev-dracut-module-aborting-on-unknown-root.patch
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Dec 5 17:49:35 UTC 2017 - mpost@suse.com
|
||||||
|
|
||||||
|
- Added the following patches (bsc#1070836):
|
||||||
|
s390-tools-sles15-cpuplugd-Improve-systemctl-start-error-handling.patch
|
||||||
|
s390-tools-sles15-mon_tools-Improve-systemctl-start-error-handling.patch
|
||||||
|
s390-tools-sles15-lsluns-do-not-scan-all-if-filters-match-nothing.patch
|
||||||
|
s390-tools-sles15-lsluns-do-not-print-confusing-messages-when-a-filter.patch
|
||||||
|
s390-tools-sles15-lsluns-fix-flawed-formatting-of-man-page.patch
|
||||||
|
s390-tools-sles15-lsluns-enhance-usage-statement-and-man-page.patch
|
||||||
|
s390-tools-sles15-lsluns-clarify-discovery-use-case-relation-to-NPIV-a.patch
|
||||||
|
s390-tools-sles15-lsluns-point-out-IBM-Storwize-configuration-requirem.patch
|
||||||
|
s390-tools-sles15-lsluns-document-restriction-to-zfcp-only-systems.patch
|
||||||
|
s390-tools-sles15-lsluns-complement-alternative-tools-with-lszdev.patch
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Dec 5 15:46:44 UTC 2017 - mpost@suse.com
|
||||||
|
|
||||||
|
- Added "--no-root-update" to all the chzdev calls in the following
|
||||||
|
scripts for bsc#1071165:
|
||||||
|
ctc_configure
|
||||||
|
dasd_configure
|
||||||
|
qeth_configure
|
||||||
|
zfcp_disk_configure
|
||||||
|
zfcp_host_configure
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Thu Nov 30 20:22:09 UTC 2017 - mpost@suse.com
|
||||||
|
|
||||||
|
- Added the following patches (bsc#1068538)
|
||||||
|
* s390-tools-sles15-cpi-add-unit-install-section.patch
|
||||||
|
* s390-tools-sles15-zipl-remove-invalid-dasdview-command-line-option.patch
|
||||||
|
* s390-tools-sles15-ziomon-re-add-missing-line.patch
|
||||||
|
- Modified s390-tools-sles15-zdev-Use-correct-path-to-vmcp-binary.patch to
|
||||||
|
point to the correct line in the common.mk file.
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Thu Nov 23 13:41:27 UTC 2017 - rbrown@suse.com
|
Thu Nov 23 13:41:27 UTC 2017 - rbrown@suse.com
|
||||||
|
|
||||||
|
@ -122,6 +122,21 @@ Patch14: s390-tools-sles12-fdasd-skip-partition-check-and-BLKRRPART-ioctl
|
|||||||
Patch15: s390-tools-sles15-Fix-truncation-warning.patch
|
Patch15: s390-tools-sles15-Fix-truncation-warning.patch
|
||||||
Patch16: s390-tools-sles15-iucvterm-include-ctype-for-toupper.patch
|
Patch16: s390-tools-sles15-iucvterm-include-ctype-for-toupper.patch
|
||||||
Patch17: s390-tools-sles15-zdev-Use-correct-path-to-vmcp-binary.patch
|
Patch17: s390-tools-sles15-zdev-Use-correct-path-to-vmcp-binary.patch
|
||||||
|
Patch18: s390-tools-sles15-cpi-add-unit-install-section.patch
|
||||||
|
Patch19: s390-tools-sles15-zipl-remove-invalid-dasdview-command-line-option.patch
|
||||||
|
Patch20: s390-tools-sles15-ziomon-re-add-missing-line.patch
|
||||||
|
Patch21: s390-tools-sles15-cpuplugd-Improve-systemctl-start-error-handling.patch
|
||||||
|
Patch22: s390-tools-sles15-mon_tools-Improve-systemctl-start-error-handling.patch
|
||||||
|
Patch23: s390-tools-sles15-lsluns-do-not-scan-all-if-filters-match-nothing.patch
|
||||||
|
Patch24: s390-tools-sles15-lsluns-do-not-print-confusing-messages-when-a-filter.patch
|
||||||
|
Patch25: s390-tools-sles15-lsluns-fix-flawed-formatting-of-man-page.patch
|
||||||
|
Patch26: s390-tools-sles15-lsluns-enhance-usage-statement-and-man-page.patch
|
||||||
|
Patch27: s390-tools-sles15-lsluns-clarify-discovery-use-case-relation-to-NPIV-a.patch
|
||||||
|
Patch28: s390-tools-sles15-lsluns-point-out-IBM-Storwize-configuration-requirem.patch
|
||||||
|
Patch29: s390-tools-sles15-lsluns-document-restriction-to-zfcp-only-systems.patch
|
||||||
|
Patch30: s390-tools-sles15-lsluns-complement-alternative-tools-with-lszdev.patch
|
||||||
|
Patch31: s390-tools-sles15-zdev-Enable-running-chzdev-from-unknown-root-devices.patch
|
||||||
|
Patch32: s390-tools-sles15-zdev-Fix-zdev-dracut-module-aborting-on-unknown-root.patch
|
||||||
|
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
||||||
ExclusiveArch: s390 s390x
|
ExclusiveArch: s390 s390x
|
||||||
@ -195,6 +210,21 @@ to list files and directories.
|
|||||||
%patch15 -p1
|
%patch15 -p1
|
||||||
%patch16 -p1
|
%patch16 -p1
|
||||||
%patch17 -p1
|
%patch17 -p1
|
||||||
|
%patch18 -p1
|
||||||
|
%patch19 -p1
|
||||||
|
%patch20 -p1
|
||||||
|
%patch21 -p1
|
||||||
|
%patch22 -p1
|
||||||
|
%patch23 -p1
|
||||||
|
%patch24 -p1
|
||||||
|
%patch25 -p1
|
||||||
|
%patch26 -p1
|
||||||
|
%patch27 -p1
|
||||||
|
%patch28 -p1
|
||||||
|
%patch29 -p1
|
||||||
|
%patch30 -p1
|
||||||
|
%patch31 -p1
|
||||||
|
%patch32 -p1
|
||||||
|
|
||||||
cp -vi %{S:22} CAUTION
|
cp -vi %{S:22} CAUTION
|
||||||
|
|
||||||
|
@ -62,11 +62,11 @@ FCP_WWPN=$(echo ${FCP_WWPN} | tr "A-Z" "a-z")
|
|||||||
FCP_LUN=$(echo ${FCP_LUN} | tr "A-Z" "a-z")
|
FCP_LUN=$(echo ${FCP_LUN} | tr "A-Z" "a-z")
|
||||||
|
|
||||||
if [ "${ON_OFF}" == 0 ]; then
|
if [ "${ON_OFF}" == 0 ]; then
|
||||||
debug_mesg "chzdev -d zfcp-lun ${CCW_CHAN_ID}:${FCP_WWPN}:${FCP_LUN}"
|
debug_mesg "chzdev -d zfcp-lun --no-root-update ${CCW_CHAN_ID}:${FCP_WWPN}:${FCP_LUN}"
|
||||||
chzdev -d zfcp-lun ${CCW_CHAN_ID}:${FCP_WWPN}:${FCP_LUN}
|
chzdev -d zfcp-lun --no-root-update ${CCW_CHAN_ID}:${FCP_WWPN}:${FCP_LUN}
|
||||||
elif [ "${ON_OFF}" == 1 ]; then
|
elif [ "${ON_OFF}" == 1 ]; then
|
||||||
debug_mesg "chzdev -e zfcp-lun ${CCW_CHAN_ID}:${FCP_WWPN}:${FCP_LUN}"
|
debug_mesg "chzdev -e zfcp-lun --no-root-update ${CCW_CHAN_ID}:${FCP_WWPN}:${FCP_LUN}"
|
||||||
chzdev -e zfcp-lun ${CCW_CHAN_ID}:${FCP_WWPN}:${FCP_LUN}
|
chzdev -e zfcp-lun --no-root-update ${CCW_CHAN_ID}:${FCP_WWPN}:${FCP_LUN}
|
||||||
else mesg "You must specify a 0 or a 1 for the online/offline attribute."
|
else mesg "You must specify a 0 or a 1 for the online/offline attribute."
|
||||||
usage
|
usage
|
||||||
exit 1
|
exit 1
|
||||||
|
@ -74,11 +74,11 @@ if [ -z "${CCW_CHAN_ID}" ] || [ -z "${ON_OFF}" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "${ON_OFF}" == 0 ]; then
|
if [ "${ON_OFF}" == 0 ]; then
|
||||||
debug_mesg "chzdev -d zfcp-host ${CCW_CHAN_ID}"
|
debug_mesg "chzdev -d zfcp-host --no-root-update ${CCW_CHAN_ID}"
|
||||||
chzdev -d zfcp-host ${CCW_CHAN_ID}
|
chzdev -d zfcp-host --no-root-update ${CCW_CHAN_ID}
|
||||||
elif [ "${ON_OFF}" == 1 ]; then
|
elif [ "${ON_OFF}" == 1 ]; then
|
||||||
debug_mesg "chzdev -e zfcp-host ${CCW_CHAN_ID}"
|
debug_mesg "chzdev -e zfcp-host --no-root-update ${CCW_CHAN_ID}"
|
||||||
chzdev -e zfcp-host ${CCW_CHAN_ID}
|
chzdev -e zfcp-host --no-root-update ${CCW_CHAN_ID}
|
||||||
else mesg "You must specify a 0 or a 1 for the online/offline attribute."
|
else mesg "You must specify a 0 or a 1 for the online/offline attribute."
|
||||||
usage
|
usage
|
||||||
exit 1
|
exit 1
|
||||||
|
Loading…
Reference in New Issue
Block a user