* 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
157 lines
4.0 KiB
Bash
157 lines
4.0 KiB
Bash
#!/bin/sh
|
|
#
|
|
# dasd_reload
|
|
# $Id: dasd_reload,v 1.2 2004/05/26 15:17:09 hare Exp $
|
|
#
|
|
# Deconfigures all active DASDs, unloads the modules
|
|
# and activates the configured DASDs again.
|
|
# Needed to establish an identical device mapping
|
|
# in the installation system and in the running system.
|
|
# All DASD access need to be cancelled prior to running
|
|
# this script.
|
|
#
|
|
# Usage:
|
|
# dasd_reload
|
|
#
|
|
# Return values:
|
|
# 1 Cannot read /proc/modules
|
|
# 2 Missing module programs
|
|
# 3 /sys not mounted
|
|
# 4 Failure on deactivate DASDs
|
|
#
|
|
|
|
if [ ! -r /proc/modules ]; then
|
|
echo "Cannot read /proc/modules"
|
|
exit 1
|
|
fi
|
|
|
|
if [ ! -x /usr/sbin/rmmod -o ! -x /usr/sbin/modprobe ]; then
|
|
echo "Missing module programs"
|
|
exit 2
|
|
fi
|
|
|
|
if [ ! -d /sys/bus ]; then
|
|
echo "sysfs not mounted"
|
|
exit 3
|
|
fi
|
|
|
|
let anymd=0
|
|
if [ -f /proc/mdstat ]; then
|
|
for mddevice in $(grep active /proc/mdstat | cut -f1 -d:); do
|
|
mdadm -S /dev/${mddevice}
|
|
let anymd=1
|
|
done
|
|
udevadm settle
|
|
fi
|
|
|
|
#
|
|
# Setting HyperPAV alias devices offline
|
|
#
|
|
dasd_alias=
|
|
let EXITRC=0
|
|
for dev in /sys/bus/ccw/devices/*; do
|
|
if [ -f ${dev}/use_diag ]; then
|
|
read _online < ${dev}/online
|
|
read _alias < ${dev}/alias
|
|
if [ "$_online" -eq 1 -a "$_alias" -eq 1 ]; then
|
|
echo "setting DASD HyperPAV alias $(basename ${dev}) offline"
|
|
echo "0" > ${dev}/online
|
|
read _online < ${dev}/online
|
|
dasd_alias="${dasd_alias} $(basename ${dev})"
|
|
if [ "$_online" -eq 1 ]; then
|
|
echo "failure on setting DASD HyperPAV alias $(basename ${dev}) offline !"
|
|
let EXITRC=4
|
|
fi
|
|
fi
|
|
fi
|
|
done
|
|
|
|
#
|
|
# Setting "normal" DASD and HyperPAV base devices offline
|
|
#
|
|
dasd_base=
|
|
for dev in /sys/bus/ccw/devices/*; do
|
|
if [ -f ${dev}/use_diag ]; then
|
|
read _online < ${dev}/online
|
|
read _alias < ${dev}/alias
|
|
if [ "$_online" -eq 1 -a "$_alias" -eq 0 ]; then
|
|
echo "setting DASD $(basename ${dev}) offline"
|
|
echo "0" > ${dev}/online
|
|
read _online < ${dev}/online
|
|
dasd_base="${dasd_base} $(basename ${dev})"
|
|
if [ "$_online" -eq 1 ]; then
|
|
echo "failure on setting DASD $(basename ${dev}) offline !"
|
|
let EXITRC=4
|
|
fi
|
|
fi
|
|
fi
|
|
done
|
|
|
|
udevadm settle
|
|
|
|
module_list=
|
|
module_test_list="dasd_diag_mod dasd_eckd_mod dasd_fba_mod dasd_mod"
|
|
for module in ${module_test_list}; do
|
|
if grep -q "${module}" /proc/modules; then
|
|
module_list="${module} ${module_list}"
|
|
: Unloading ${module}
|
|
/usr/sbin/rmmod ${module}
|
|
fi
|
|
done
|
|
|
|
udevadm settle
|
|
sleep 2
|
|
|
|
if [ -d /etc/udev/rules.d ]; then
|
|
cd /etc/udev/rules.d
|
|
#
|
|
# Re-activating "normal" DASD and HyperPAV base devices
|
|
#
|
|
# We need to move all the DASD udev rules out from /etc/udev/rules.d
|
|
# because if we don't, then when the first DASD volume gets brought
|
|
# back online, they are all brought back online, in a non-deterministic
|
|
# order, not the numeric order we expect.
|
|
#
|
|
mv -i 41-dasd-*.rules 51-dasd-*.rules /tmp
|
|
cd /tmp
|
|
for dasd in ${dasd_base}; do
|
|
for file in 41-dasd-*-${dasd}.rules 51-dasd-${dasd}.rules; do
|
|
[ -f "${file}" ] || continue
|
|
#
|
|
# Special handling is needed for old udev rules that start with 51-
|
|
# since the chzdev command won't look for that name
|
|
#
|
|
prefix="$(echo ${file} | cut -f1 -d-)"
|
|
if [ "${prefix}" == "51" ]; then
|
|
if [ -h /sys/bus/ccw/drivers/dasd-eckd/${dasd} ]; then
|
|
mv -i ${file} 41-dasd-eckd-${dasd}.rules
|
|
elif [ -h /sys/bus/ccw/drivers/dasd-fba/${dasd} ]; then
|
|
mv -i ${file} 41-dasd-fba-${dasd}.rules
|
|
else echo "DASD volume ${dasd} is neither an ECKD or FBA device."
|
|
let EXITRC=4
|
|
fi
|
|
fi
|
|
echo Activating ${dasd}
|
|
mv -i "${file}" /etc/udev/rules.d/
|
|
/usr/sbin/chzdev dasd --apply --configured -q --no-root-update ${dasd}
|
|
lsdasd
|
|
break
|
|
done
|
|
done
|
|
|
|
#
|
|
# Re-activating HyperPAV alias devices
|
|
#
|
|
for dasd in ${dasd_alias}; do
|
|
for file in 41-dasd-*-${dasd}.rules 51-dasd-${dasd}.rules; do
|
|
[ -f "${file}" ] || continue
|
|
echo Activating ${dasd}
|
|
mv -i "${file}" /etc/udev/rules.d/
|
|
/usr/sbin/chzdev dasd --apply --configured -q --no-root-update ${dasd}
|
|
break
|
|
done
|
|
done
|
|
fi
|
|
|
|
exit ${EXITRC}
|