cd557016ed
- Added the following patches for bsc#1098069 * s390-tools-sles15-dbginfo-add-data-for-ps-cpprot.patch * s390-tools-sles15-mon_procd-fix-parsing-of-proc-pid-stat.patch * s390-tools-sles15-1-lstape-fix-output-with-SCSI-lin_tape-and-multiple-pa.patch * s390-tools-sles15-2-lstape-fix-to-prefer-sysfs-to-find-lin_tape-device-n.patch * s390-tools-sles15-3-lstape-fix-output-without-SCSI-generic-sg.patch * s390-tools-sles15-4-lsluns-fix-to-prevent-error-messages-if-there-are-no.patch * s390-tools-sles15-5-lstape-fix-to-prevent-error-messages-if-there-are-no.patch * s390-tools-sles15-6-lstape-fix-description-of-type-and-devbusid-filter-f.patch * s390-tools-sles15-7-lstape-fix-SCSI-output-description-in-man-page.patch * s390-tools-sles15-8-lstape-fix-SCSI-HBA-CCW-device-bus-ID-e.g.-for-virti.patch - dasd_reload: Fixed several syntax errors. Changed the script to ensure that the DASD volume are actually activated in device number order. If an old 51-dasd-<ccw>.rules file is found, rename it to obsolete-51-dasd-<ccw>.rules, and use chzdev to generate a new rules file. (bsc#1103407) - dasd_reload: Check for 41-dasd-<type>-<ccw>.rules in addition to the original 51-dasd-<ccw>.rules (bsc#1103407) - Removed s390 from the ExclusiveArch parameter (bsc#1102906) OBS-URL: https://build.opensuse.org/package/show/Base:System/s390-tools?expand=0&rev=54
174 lines
7.2 KiB
Diff
174 lines
7.2 KiB
Diff
Subject: lstape, lsluns: handle non-zfcp; lin_tape multiple paths
|
|
From: Steffen Maier <maier@linux.ibm.com>
|
|
|
|
Description: lstape, lsluns: handle non-zfcp; lin_tape multiple paths
|
|
|
|
Symptom: lstape shows unexpected additional Device suffix numbers in
|
|
excess output columns for each additional path of the same
|
|
tape/changer driven by the IBM lin_tape device driver
|
|
(independent of actual path failover enablement in lin_tape).
|
|
It also shows a wrong number of found devices in the header
|
|
(without --scsi-only).
|
|
|
|
lstape prints error about "Unexpected extra argument:" and the
|
|
usage for "sg_inq" along with wrong tabular output.
|
|
|
|
lsluns prints ENOENT error text for "cat" on SCSI device sysfs
|
|
attributes hba_id, wwpn, and fcp_lun.
|
|
|
|
lstape with --verbose option prints ENOENT error text for
|
|
"cat" on SCSI device sysfs attributes hba_id and wwpn.
|
|
|
|
lstape man page: Description of --type and <devbusid> filter
|
|
for channel tapes is incomplete. SCSI output description is
|
|
incomplete.
|
|
|
|
lstape shows "N/A" instead of the HBA device bus-ID with
|
|
virtio-scsi-ccw.
|
|
|
|
Problem: s390-tools-1.8.0 before the first upstream commit b627b8d8e1ab
|
|
("Initial s390-tools-2.0.0 import") introduced SCSI
|
|
tape/changer output for lstape. It used the SCSI device serial
|
|
number as lookup key to find a match in IBM lin_tape device
|
|
driver proc-fs output for a given SCSI device name. Multiple
|
|
paths to the same tape/changer have the same serial number.
|
|
Multiple matches cause excess arguments to printf. Explaining
|
|
the resulting output, the bash man page says: "The format is
|
|
reused as necessary to consume all of the arguments." This
|
|
also causes a wrong number of found devices.
|
|
|
|
The default bash settings have nullglob disabled so if
|
|
$SCSI_DEV/scsi_generic* aka
|
|
/sys/bus/scsi/devices/*:*:*:*/scsi_generic* does not match
|
|
anything, it leaves the glob pattern unmodified and
|
|
SG_DEV=$(basename $SG_DEV/*) results in the literal "*". If
|
|
$SG_INQ exists, it invoked sg_inq with more than the one
|
|
allowed positional argument for a SCSI generic device node
|
|
"sg_inq /dev/*". Causing error messages and the usage of
|
|
sg_inq to land in $TAPE_SERIAL.
|
|
|
|
lsluns iterates SCSI generic devices and unconditionally
|
|
reads zfcp-specific SCSI device sysfs attributes hba_id, wwpn,
|
|
and fcp_lun.
|
|
|
|
lstape --verbose unconditionally reads zfcp-specific SCSI
|
|
device sysfs attributes hba_id and wwpn.
|
|
|
|
<devbusid> filter missing from synopsis. <device-type> example
|
|
at wrong place with <devbusid> filter. <devbusid> filter
|
|
option description is a duplicate of <device-type> filter
|
|
option description. SCSI output description misses fields.
|
|
|
|
Lstape only used the zfcp-specific sysfs attribute hba_id.
|
|
|
|
Solution: Prefer sysfs to find lin_tape device name for SCSI device.
|
|
Fallback: The lin_tape proc-fs output format has changed over
|
|
the years. The HBA device driver string can contain whitespace
|
|
(e.g. "Virtio SCSI HBA") and breaks the field numbers with
|
|
tokenized parsing. Grep for the SCSI device name as word (to
|
|
skip names with same substring, such as 0:0:1:1 also matching
|
|
0:0:1:10) and cut the first field 'Number' (lin_tape device
|
|
name suffix). If there is no SCSI column at all [lin_tape
|
|
before v2.2.0] (and no SCSI LLDD or other column with a name
|
|
accidentally matching an existing SCSI device name), we get no
|
|
match and better bail out with the initialized "N/A" for the
|
|
lstape column "Device".
|
|
|
|
To not have to rely on the nullglob setting, explicitly check
|
|
for the existence of $SCSI_DEV/scsi_generic before evaluating
|
|
SG_DEV=$(basename $SG_DEV/*). Also handle availability of
|
|
sg_inq but absence of scsi_generic individually to provide the
|
|
user with a hint if only sg is missing.
|
|
|
|
Simply skip non-zfcp SCSI devices, such as iSCSI or
|
|
virtio-scsi-ccw, to not erroneously access absent attributes.
|
|
|
|
Assume "N/A" for HBA and WWPN of non-zfcp SCSI devices, such
|
|
as iSCSI or virtio-scsi-ccw, to not erroneously access absent
|
|
zfcp-specific sysfs attributes.
|
|
|
|
Add <devbusid> filter to synopsis. Move <device-type> example
|
|
to <device-type> option. Replace <devbusid> filter option
|
|
description. Move existing SCSI output description to a new
|
|
subsection and add description of missing fields.
|
|
|
|
Also search sysfs for an ancestor with subsystem ccw.
|
|
|
|
Reproduction: Attach more than one path to the same SCSI tape or changer and
|
|
load the IBM lin_tape device driver.
|
|
|
|
Unload sg kernel module.
|
|
|
|
Attach non-zfcp SCSI devices such as iSCSI or virtio-scsi-ccw.
|
|
|
|
Attach non-zfcp SCSI devices such as iSCSI or virtio-scsi-ccw.
|
|
|
|
man lstape
|
|
|
|
Attach SCSI tape or changer with virtio-scsi-ccw to a KVM
|
|
guest and run "lstape --verbose".
|
|
|
|
Upstream-ID: -
|
|
Problem-ID: 170633
|
|
|
|
Signed-off-by: Steffen Maier <maier@linux.ibm.com>
|
|
---
|
|
zconf/lstape | 25 +++++++++++++++++++++++--
|
|
zconf/lstape.8 | 3 ++-
|
|
2 files changed, 25 insertions(+), 3 deletions(-)
|
|
|
|
--- a/zconf/lstape
|
|
+++ b/zconf/lstape
|
|
@@ -223,6 +223,24 @@ function SysfsCreateListCCW() {
|
|
' | sort
|
|
}
|
|
|
|
+# handle SCSI device not necessarily zfcp-attached, e.g. virtio-scsi-ccw
|
|
+function SCSISearchCCWBusid()
|
|
+{
|
|
+ local SCSI_DEV=$1
|
|
+ local SDEVCAN=$(readlink -e $SCSI_DEV)
|
|
+ while [ -n "$SDEVCAN" ]; do
|
|
+ # ascend to parent: strip last path part
|
|
+ SDEVCAN=${SDEVCAN%/*}
|
|
+ [ -h $SDEVCAN/subsystem ] || continue
|
|
+ local SUBSYSTEM=$(readlink -e $SDEVCAN/subsystem)
|
|
+ if [ "${SUBSYSTEM##*/}" = "ccw" ]; then
|
|
+ echo ${SDEVCAN##*/}
|
|
+ return
|
|
+ fi
|
|
+ done
|
|
+ echo "N/A"
|
|
+}
|
|
+
|
|
function SysfsCreateListSCSI()
|
|
{
|
|
for SCSI_DEV in $1/bus/scsi/devices/*:*:*:*; do
|
|
@@ -335,8 +353,11 @@ function SysfsCreateListSCSI()
|
|
$STATE
|
|
|
|
if $VERBOSE; then
|
|
- HBA_ID="N/A"
|
|
- [ -r $SCSI_DEV/hba_id ] && HBA_ID=$(cat $SCSI_DEV/hba_id)
|
|
+ if [ -r $SCSI_DEV/hba_id ]; then
|
|
+ HBA_ID=$(cat $SCSI_DEV/hba_id)
|
|
+ else
|
|
+ HBA_ID=$(SCSISearchCCWBusid $SCSI_DEV)
|
|
+ fi
|
|
WWPN="N/A"
|
|
[ -r $SCSI_DEV/wwpn ] && WWPN=$(cat $SCSI_DEV/wwpn)
|
|
printf "$SCSIVFORMAT" \
|
|
--- a/zconf/lstape.8
|
|
+++ b/zconf/lstape.8
|
|
@@ -112,8 +112,9 @@ For SCSI devices, the --verbose option a
|
|
.TP
|
|
.B HBA
|
|
The device bus-ID of the FCP device
|
|
+or of the virtio-scsi-ccw virtual HBA
|
|
through which the tape drive is attached.
|
|
-"N/A" if device is not attached through zfcp.
|
|
+"N/A" if the device does not have a sysfs ancestor with subsystem ccw.
|
|
.TP
|
|
.B WWPN
|
|
The WWPN (worldwide port name) of the tape drive in the SAN.
|