* Changes of existing tools: dbginfo.sh: Add details on CPU-measurement dbginfo.sh: Add new crypto command dbginfo.sh: Add overview commands and crypto update dbginfo.sh: Adding kdump info dbginfo.sh: Removing outdated email references dbginfo.sh: Rework network section dbginfo.sh: Update copyright 2nd year pvimg: Add '--(enable|disable)-image-encryption' flags to 'pvimg create' pvimg: Add '--cck ' command line option and make '--comm-key' an alias pvimg: Add '--hdr-key' command line option to 'pvimg create' pvimg: Rename '--key' into '--hdr-key' and use '--key' as an alias (for 'pvimg info') pvsecret: Add support for retrievable secrets ziorep_config: Add PCHID field to adapter report ziorep_traffic: Add DEVBUSID column to traffic report ziorep_utilization: Add --fcp-device parameter to print virtual adapter report ziorep_utilization: Add PCHID column to physical adapter report ziorep_utilization: Now prints only physical adapter report by default ziorep_utilization: Swap Bus-ID and CHPID columns in virtual adapter report zipl/boot: Increase section size for eckd_mv dumper zkey: Add support for listing and importing protected virtualization secrets * Bug Fixes: chpstat: Fix invalid utilization data on older kernels opticsmon: Fix runaway loop in on_link_change() zipl: Update inline assembly for GCC 15 zipl_helper.device-mapper: Add missed step in logical device resolution - Revendored vendor.tar.gz - Removed obsolete patches: * s390-tools-01-zipl_helper.device-mapper-add-missed-step-in-logical.patch * s390-tools-02-zipl-src-fix-imprecise-check-that-file-is-on-specifi.patch * s390-tools-General-update-01.patch * s390-tools-General-update-02.patch * s390-tools-General-update-03.patch * s390-tools-General-update-04.patch * s390-tools-General-update-05.patch * s390-tools-General-update-06.patch * s390-tools-General-update-07.patch * s390-tools-General-update-08.patch * s390-tools-General-update-09.patch * s390-tools-General-update-10.patch * s390-tools-General-update-11.patch * s390-tools-General-update-12.patch * s390-tools-Additional-update-01.patch * s390-tools-Additional-update-02.patch * s390-tools-pvimg-info-command-01.patch * s390-tools-pvimg-info-command-02.patch * s390-tools-pvimg-info-command-03.patch * s390-tools-Support-unencrypted-SE-images-01.patch * s390-tools-pvimg-info-command-04.patch * s390-tools-pvimg-additional-01.patch * s390-tools-01-zkey-Add-support-for-retrieving-a-list-of-ultravisor-secrets.patch * s390-tools-02-zkey-Add-the--pvsecrets-list-command.patch * s390-tools-03-zkey-Add-PVSECRETS-AES-key-type.patch * s390-tools-04-zkey-Add-the-pvsecrets-import-command.patch * s390-tools-05-zkey-Reject-key-generation-and-APQN-association-for-PVSECRET-AES-keys.patch * s390-tools-06-zkey-Reject-re-enciphering-of-PVSECRET-AES-keys.patch * s390-tools-07-zkey-Support-validation-of-key-of-type-PVSECRET-AES.patch * s390-tools-08-rust-pvimg-Fix-flag-parsing-for-allowing-dump.patch * s390-tools-09-rust-pvimg-Document-the-change-from--comm-key-to--cck.patch OBS-URL: https://build.opensuse.org/package/show/Base:System/s390-tools?expand=0&rev=249
134 lines
2.8 KiB
Bash
134 lines
2.8 KiB
Bash
#! /bin/sh
|
|
#
|
|
# iucv_configure
|
|
#
|
|
# Configures a z/VM IUCV network adapter
|
|
#
|
|
# Usage:
|
|
# iucv_configure <peer_userid> <online>
|
|
#
|
|
# peer_userid = z/VM userid of the IUCV peer
|
|
# online = 0 to take the device offline
|
|
# 1 to bring the device online
|
|
#
|
|
# Return values:
|
|
# 1 sysfs not mounted
|
|
# 2 Invalid status for <online>
|
|
# 3 Could not create iucv device
|
|
# 4 Could not remove iucv device
|
|
#
|
|
|
|
if [ "${DEBUG}" != "yes" ]; then
|
|
DEBUG="no"
|
|
fi
|
|
|
|
mesg () {
|
|
echo "$@"
|
|
}
|
|
|
|
debug_mesg () {
|
|
case "$DEBUG" in
|
|
yes) mesg "$@" ;;
|
|
*) ;;
|
|
esac
|
|
}
|
|
|
|
if [ $# -ne 2 ] ; then
|
|
echo "Usage: $0 <peer_userid> <online>"
|
|
echo " peer_userid = z/VM userid of the IUCV peer"
|
|
echo " online = 0 to take the device offline"
|
|
echo " 1 to bring the device online"
|
|
exit 1
|
|
fi
|
|
|
|
# Get the mount point for sysfs
|
|
while read MNTPT MNTDIR MNTSYS MNTTYPE; do
|
|
if test "$MNTSYS" = "sysfs"; then
|
|
SYSFS="$MNTDIR"
|
|
break;
|
|
fi
|
|
done </proc/mounts
|
|
|
|
if [ -z "$SYSFS" ]; then
|
|
mesg "/sysfs not present"
|
|
exit 1
|
|
fi
|
|
|
|
PEER_USERID_LOWER=$1
|
|
PEER_USERID=$(echo $1 | tr "a-z" "A-Z")
|
|
ONLINE=$2
|
|
|
|
if [ -z "$PEER_USERID" ] ; then
|
|
mesg "No IUCV user name given"
|
|
exit 2
|
|
fi
|
|
|
|
if [ -z "$ONLINE" ] ; then
|
|
ONLINE=1
|
|
fi
|
|
|
|
_iucv_dir=${SYSFS}/bus/iucv/devices
|
|
|
|
_iucv_drv=${SYSFS}/bus/iucv/drivers/netiucv
|
|
if [ ! -d "$_iucv_drv" ] ; then
|
|
modprobe -q netiucv
|
|
fi
|
|
|
|
debug_mesg "Configuring IUCV device ${PEER_USERID}"
|
|
|
|
for _iucv_dev in $_iucv_dir/netiucv?* ; do
|
|
[ -d $_iucv_dev ] || continue
|
|
read user < $_iucv_dev/user
|
|
if [ "$user" = "$PEER_USERID" ] ; then
|
|
# Already configured, ok
|
|
iucvdev=${_iucv_dev##*/}
|
|
break;
|
|
fi
|
|
done
|
|
|
|
if [ -z "$iucvdev" -a $ONLINE -eq 1 ] ; then
|
|
echo $PEER_USERID > $_iucv_drv/connection
|
|
if [ $? -ne 0 ] ; then
|
|
mesg "Unable to connect to $PEER_USERID"
|
|
exit 3
|
|
fi
|
|
for _iucv_dev in $_iucv_dir/netiucv?* ; do
|
|
[ -d $_iucv_dev ] || continue
|
|
read user < $_iucv_dev/user
|
|
if [ "$user" = "$PEER_USERID" ] ; then
|
|
iucvdev=${_iucv_dev##*/}
|
|
break;
|
|
fi
|
|
done
|
|
if [ "$iucvdev" ] ; then
|
|
debug_mesg "Configured device $iucvdev"
|
|
fi
|
|
elif [ "$iucvdev" -a $ONLINE -eq 0 ] ; then
|
|
for _net_dev in $_iucv_dir/$iucvdev/net/* ; do
|
|
[ -d $_net_dev ] || continue
|
|
netdev=${_net_dev##*/}
|
|
break;
|
|
done
|
|
if [ "$netdev" ] ; then
|
|
echo $netdev > $_iucv_drv/remove
|
|
if [ $? -ne 0 ] ; then
|
|
mesg "Unable to remove device $netdev"
|
|
exit 4
|
|
else
|
|
debug_mesg "Removed device $iucvdev"
|
|
rm -f /etc/udev/rules.d/51-iucv-$PEER_USERID.rules /etc/udev/rules.d/51-iucv-$PEER_USERID_LOWER.rules
|
|
iucvdev=
|
|
fi
|
|
fi
|
|
|
|
fi
|
|
|
|
if [ "$iucvdev" ] ; then
|
|
cat > /etc/udev/rules.d/51-iucv-$PEER_USERID.rules <<EOF
|
|
ACTION=="add", SUBSYSTEM=="subsystem", KERNEL=="iucv", RUN+="/usr/sbin/modprobe netiucv"
|
|
ACTION=="add", SUBSYSTEM=="drivers", KERNEL=="netiucv", ATTR{connection}="$PEER_USERID"
|
|
EOF
|
|
fi
|
|
|
|
exit
|