* 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
182 lines
4.3 KiB
Bash
182 lines
4.3 KiB
Bash
#! /bin/sh
|
|
# Copyright (c) 2003 SUSE LINUX AG Nuernberg, Germany.
|
|
#
|
|
# Please send feedback to http://www.suse.de/feedback/
|
|
#
|
|
# /etc/init.d/hsnc
|
|
#
|
|
# and symbolic its link
|
|
#
|
|
# /usr/sbin/ip_watcher.pl
|
|
# /usr/sbin/xcec-bridge
|
|
# /usr/sbin/start_hsnc.sh
|
|
# /use/sbin/rchsnc
|
|
#
|
|
# System startup script for the HiperSockets Network Concentrator
|
|
#
|
|
# /etc/hsnc.conf should contain the following lines:
|
|
#
|
|
# operating_mode=[unicast|full|no]
|
|
# unicast means, only unicast forwarded between the hsint's and osaint's.
|
|
# this is the default mode
|
|
# full means, unicast, multicast and broadcast are forwarded, if supported
|
|
# by the hardware
|
|
#
|
|
# hsi_int="<interface> [<interface> [...]]"
|
|
# described all the HiperSockets interfaces involved in the HSN
|
|
#
|
|
# osa_int="<interface>"
|
|
# describes the OSA interface connecting to other LANs
|
|
#
|
|
|
|
|
|
START_HSNC_BIN=/usr/sbin/start_hsnc.sh
|
|
IP_WATCHER_BIN=/usr/sbin/ip_watcher.pl
|
|
XCEC_BRIDGE_BIN=/usr/sbin/xcec-bridge
|
|
|
|
HSNC_CONFIG_FILE=/etc/sysconfig/hsnc
|
|
HSNC_CLEANUP_FILE=/var/run/hsnc.cleanup
|
|
|
|
test -x $START_HSNC_BIN || exit 5
|
|
test -x $IP_WATCHER_BIN || exit 5
|
|
test -x $XCEC_BRIDGE_BIN || exit 5
|
|
|
|
# Return values acc. to LSB for all commands but status:
|
|
# 0 - success
|
|
# 1 - generic or unspecified error
|
|
# 2 - invalid or excess argument(s)
|
|
# 3 - unimplemented feature (e.g. "reload")
|
|
# 4 - insufficient privilege
|
|
# 5 - program is not installed
|
|
# 6 - program is not configured
|
|
# 7 - program is not running
|
|
#
|
|
# Note that starting an already running service, stopping
|
|
# or restarting a not-running service as well as the restart
|
|
# with force-reload (in case signalling is not supported) are
|
|
# considered a success.
|
|
|
|
#call with cleanup or not
|
|
read_config_file() {
|
|
if [ "$1" == "cleanup" ]; then
|
|
file=$HSNC_CLEANUP_FILE
|
|
else
|
|
file=$HSNC_CONFIG_FILE
|
|
fi
|
|
|
|
if [ -s $file ]; then
|
|
source $file
|
|
else
|
|
echo -ne "\nCannot read $file: empty or nonexistant! "
|
|
# Means not configured:
|
|
exit 3
|
|
fi
|
|
}
|
|
|
|
#call with cleanup or not
|
|
set_osa_mode() {
|
|
# for full mode, we set up the osa as multicast router. otherwise, no
|
|
# special setup is required for the osa.
|
|
if [ "$operating_mode" == "full" ]; then
|
|
if [ "$1" == "cleanup" ]; then
|
|
echo no_router > /sys/class/net/$osa_int/device/route4
|
|
else
|
|
echo multicast_router > /sys/class/net/$osa_int/device/route4
|
|
fi
|
|
fi
|
|
}
|
|
|
|
#call with cleanup or not
|
|
set_hsi_mode() {
|
|
# set all the involved HiperSockets interfaces as primary_connector. For
|
|
# special HA setups, some more tweaking is needed, but then a handcarved
|
|
# solution should be used anyway.
|
|
for i in $hsi_int ; do
|
|
if [ "$1" == "cleanup" ]; then
|
|
echo no_router > /sys/class/net/$i/device/route4
|
|
else
|
|
echo primary_connector > /sys/class/net/$i/device/route4
|
|
fi
|
|
done
|
|
}
|
|
|
|
do_start_hsnc() {
|
|
set_osa_mode
|
|
set_hsi_mode
|
|
if [ "$operating_mode" == "full" ]; then
|
|
$IP_WATCHER_BIN --check
|
|
else
|
|
$IP_WATCHER_BIN --check $osa_int
|
|
fi
|
|
CODE=$?
|
|
if [ $CODE != 0 ]; then
|
|
return $CODE
|
|
else
|
|
cp $HSNC_CONFIG_FILE $HSNC_CLEANUP_FILE
|
|
#
|
|
# To match the LSB spec, startproc returns 0,
|
|
# even if the program it already running.
|
|
#
|
|
if [ "$operating_mode" == "full" ]; then
|
|
startproc $START_HSNC_BIN
|
|
else
|
|
startproc $START_HSNC_BIN $osa_int
|
|
fi
|
|
return $?
|
|
fi
|
|
}
|
|
|
|
service="HiperSockets Network concentrator"
|
|
case "$1" in
|
|
start)
|
|
if checkproc $START_HSNC_BIN; then
|
|
# Starting an already running service is success:
|
|
echo -n "(already running)"
|
|
else
|
|
if read_config_file; then
|
|
do_start_hsnc
|
|
RETVAL=$?
|
|
exit $RETVAL
|
|
fi
|
|
fi
|
|
|
|
;;
|
|
stop)
|
|
echo -n "Shutting down $service "
|
|
|
|
# kill ip_watcher, start_hsnc, which started it needs cleans up
|
|
# then:
|
|
killproc -TERM $IP_WATCHER_BIN
|
|
if [ -f $HSNC_CLEANUP_FILE ]; then
|
|
read_config_file cleanup
|
|
# remove all connector settings(not yet implemented):
|
|
set_osa_mode cleanup
|
|
set_hsi_mode cleanup
|
|
|
|
# remove the file in /var/run
|
|
rm -f $HSNC_CLEANUP_FILE
|
|
else
|
|
echo -n "- no cleanup file found "
|
|
fi
|
|
|
|
;;
|
|
status)
|
|
echo -n "Checking $service "
|
|
## Check status with checkproc(8), if process is running
|
|
## checkproc will return with exit status 0.
|
|
|
|
# Status has a slightly different for the status command:
|
|
# 0 - service running
|
|
# 1 - service dead, but /var/run/ pid file exists
|
|
# 2 - service dead, but /var/lock/ lock file exists
|
|
# 3 - service not running
|
|
|
|
# NOTE: checkproc returns LSB compliant status values.
|
|
checkproc $START_HSNC_BIN
|
|
;;
|
|
*)
|
|
exit 1
|
|
;;
|
|
esac
|
|
|