2017-02-21 12:14:26 +01:00
|
|
|
#! /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
|
2019-04-18 08:18:45 +02:00
|
|
|
#
|
2017-02-21 12:14:26 +01:00
|
|
|
# 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() {
|
2019-04-18 08:18:45 +02:00
|
|
|
if [ "$1" = "cleanup" ]; then
|
2017-02-21 12:14:26 +01:00
|
|
|
file=$HSNC_CLEANUP_FILE
|
|
|
|
else
|
|
|
|
file=$HSNC_CONFIG_FILE
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -s $file ]; then
|
2019-04-18 08:18:45 +02:00
|
|
|
. $file
|
2017-02-21 12:14:26 +01:00
|
|
|
else
|
|
|
|
echo -ne "\nCannot read $file: empty or nonexistant! "
|
|
|
|
# Means not configured:
|
2018-01-11 01:30:11 +01:00
|
|
|
exit 3
|
2017-02-21 12:14:26 +01:00
|
|
|
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.
|
2019-04-18 08:18:45 +02:00
|
|
|
if [ "$operating_mode" = "full" ]; then
|
|
|
|
if [ "$1" = "cleanup" ]; then
|
2017-02-21 12:14:26 +01:00
|
|
|
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
|
2019-04-18 08:18:45 +02:00
|
|
|
if [ "$1" = "cleanup" ]; then
|
2017-02-21 12:14:26 +01:00
|
|
|
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
|
2019-04-18 08:18:45 +02:00
|
|
|
if [ "$operating_mode" = "full" ]; then
|
2017-02-21 12:14:26 +01:00
|
|
|
$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.
|
|
|
|
#
|
2019-04-18 08:18:45 +02:00
|
|
|
if [ "$operating_mode" = "full" ]; then
|
2017-02-21 12:14:26 +01:00
|
|
|
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
|
2018-01-11 01:30:11 +01:00
|
|
|
RETVAL=$?
|
|
|
|
exit $RETVAL
|
2017-02-21 12:14:26 +01:00
|
|
|
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
|
2018-01-11 01:30:11 +01:00
|
|
|
|