de80c6
#!/bin/bash
de80c6
de80c6
. $dracutfunctions
de80c6
. /lib/kdump/kdump-lib.sh
de80c6
de80c6
check() {
de80c6
    [[ $debug ]] && set -x
de80c6
    #kdumpctl sets this explicitly
de80c6
    if [ -z "$IN_KDUMP" ] || [ ! -f /etc/kdump.conf ]
de80c6
    then
de80c6
        return 1
de80c6
    fi
de80c6
    return 0
de80c6
}
de80c6
de80c6
depends() {
de80c6
    local _dep="base shutdown"
de80c6
de80c6
    if [ -d /sys/module/drm/drivers ]; then
de80c6
        _dep="$_dep drm"
de80c6
    fi
de80c6
de80c6
    if [ is_generic_fence_kdump -o is_pcs_fence_kdump ]; then
de80c6
        _dep="$_dep network"
de80c6
    fi
de80c6
de80c6
    echo $_dep
de80c6
    return 0
de80c6
}
de80c6
de80c6
kdump_to_udev_name() {
de80c6
    local dev="${1//\"/}"
de80c6
de80c6
    case "$dev" in
de80c6
    UUID=*)
de80c6
        dev=`blkid -U "${dev#UUID=}"`
de80c6
        ;;
de80c6
    LABEL=*)
de80c6
        dev=`blkid -L "${dev#LABEL=}"`
de80c6
        ;;
de80c6
    esac
de80c6
    echo $(get_persistent_dev "$dev")
de80c6
}
de80c6
de80c6
kdump_is_bridge() {
de80c6
     [ -d /sys/class/net/"$1"/bridge ]
de80c6
}
de80c6
de80c6
kdump_is_bond() {
de80c6
     [ -d /sys/class/net/"$1"/bonding ]
de80c6
}
de80c6
de80c6
kdump_is_team() {
de80c6
     [ -f /usr/bin/teamnl ] && teamnl $1 ports &> /dev/null
de80c6
}
de80c6
de80c6
kdump_is_vlan() {
de80c6
     [ -f /proc/net/vlan/"$1" ]
de80c6
}
de80c6
de80c6
# $1: netdev name
de80c6
kdump_setup_dns() {
de80c6
    _dnsfile=${initdir}/etc/cmdline.d/42dns.conf
de80c6
    . /etc/sysconfig/network-scripts/ifcfg-$1
de80c6
    [ -n "$DNS1" ] && echo "nameserver=$DNS1" > "$_dnsfile"
de80c6
    [ -n "$DNS2" ] && echo "nameserver=$DNS2" >> "$_dnsfile"
de80c6
}
de80c6
de80c6
#$1: netdev name
de80c6
#$2: srcaddr
de80c6
#if it use static ip echo it, or echo null
de80c6
kdump_static_ip() {
de80c6
    local _netmask _gateway
de80c6
    local _netdev="$1" _srcaddr="$2"
de80c6
    local _ipaddr=$(ip addr show dev $_netdev permanent | \
de80c6
                    awk "/ $_srcaddr\/.* $_netdev\$/{print \$2}")
de80c6
    if [ -n "$_ipaddr" ]; then
de80c6
       _netmask=$(ipcalc -m $_ipaddr | cut -d'=' -f2)
de80c6
       _gateway=$(ip route list dev $_netdev | awk '/^default /{print $3}')
de80c6
       echo -n "${_srcaddr}::${_gateway}:${_netmask}::"
de80c6
    fi
de80c6
de80c6
    /sbin/ip route show | grep -v default | grep "^[[:digit:]].*via.* $_netdev " |\
de80c6
    while read line; do
de80c6
        echo $line | awk '{printf("rd.route=%s:%s:%s\n", $1, $3, $5)}'
de80c6
    done >> ${initdir}/etc/cmdline.d/45route-static.conf
de80c6
}
de80c6
de80c6
kdump_get_mac_addr() {
de80c6
    cat /sys/class/net/$1/address
de80c6
}
de80c6
de80c6
#Bonding or team master modifies the mac address
de80c6
#of its slaves, we should use perm address
de80c6
kdump_get_perm_addr() {
de80c6
    local addr=$(ethtool -P $1 | sed -e 's/Permanent address: //')
de80c6
    if [ -z "$addr" ] || [ "$addr" = "00:00:00:00:00:00" ]
de80c6
    then
de80c6
        derror "Can't get the permanent address of $1"
de80c6
    else
de80c6
        echo "$addr"
de80c6
    fi
de80c6
}
de80c6
de80c6
# Prefix kernel assigned names with "kdump-". EX: eth0 -> kdump-eth0
de80c6
# Because kernel assigned names are not persistent between 1st and 2nd
de80c6
# kernel. We could probably end up with eth0 being eth1, eth0 being
de80c6
# eth1, and naming conflict happens.
de80c6
kdump_setup_ifname() {
de80c6
    local _ifname
de80c6
de80c6
    if [[ $1 =~ eth* ]]; then
de80c6
        _ifname="kdump-$1"
de80c6
    else
de80c6
        _ifname="$1"
de80c6
    fi
de80c6
de80c6
    echo "$_ifname"
de80c6
}
de80c6
de80c6
kdump_setup_bridge() {
de80c6
    local _netdev=$1
de80c6
    local _brif _dev _mac _kdumpdev
de80c6
    for _dev in `ls /sys/class/net/$_netdev/brif/`; do
de80c6
        _kdumpdev=$_dev
de80c6
        if kdump_is_bond "$_dev"; then
de80c6
            kdump_setup_bond "$_dev"
de80c6
        elif kdump_is_team "$_dev"; then
de80c6
            kdump_setup_team "$_dev"
de80c6
        elif kdump_is_vlan "$_dev"; then
de80c6
            kdump_setup_vlan "$_dev"
de80c6
        else
de80c6
            _mac=$(kdump_get_mac_addr $_dev)
de80c6
            _kdumpdev=$(kdump_setup_ifname $_dev)
de80c6
            echo -n " ifname=$_kdumpdev:$_mac" >> ${initdir}/etc/cmdline.d/41bridge.conf
de80c6
        fi
de80c6
        _brif+="$_kdumpdev,"
de80c6
    done
de80c6
    echo " bridge=$_netdev:$(echo $_brif | sed -e 's/,$//')" >> ${initdir}/etc/cmdline.d/41bridge.conf
de80c6
}
de80c6
de80c6
kdump_setup_bond() {
de80c6
    local _netdev=$1
de80c6
    local _dev _mac _slaves _kdumpdev
de80c6
    for _dev in `cat /sys/class/net/$_netdev/bonding/slaves`; do
de80c6
        _mac=$(kdump_get_perm_addr $_dev)
de80c6
        _kdumpdev=$(kdump_setup_ifname $_dev)
de80c6
        echo -n " ifname=$_kdumpdev:$_mac" >> ${initdir}/etc/cmdline.d/42bond.conf
de80c6
        _slaves+="$_kdumpdev,"
de80c6
    done
de80c6
    echo -n " bond=$_netdev:$(echo $_slaves | sed 's/,$//')" >> ${initdir}/etc/cmdline.d/42bond.conf
de80c6
    # Get bond options specified in ifcfg
de80c6
    . /etc/sysconfig/network-scripts/ifcfg-$_netdev
de80c6
    bondoptions="$(echo :$BONDING_OPTS | sed 's/\s\+/,/')"
de80c6
    echo "$bondoptions" >> ${initdir}/etc/cmdline.d/42bond.conf
de80c6
}
de80c6
de80c6
kdump_setup_team() {
de80c6
    local _netdev=$1
de80c6
    local _dev _mac _slaves _kdumpdev
de80c6
    for _dev in `teamnl $_netdev ports | awk -F':' '{print $2}'`; do
de80c6
        _mac=$(kdump_get_perm_addr $_dev)
de80c6
        _kdumpdev=$(kdump_setup_ifname $_dev)
de80c6
        echo -n " ifname=$_kdumpdev:$_mac" >> ${initdir}/etc/cmdline.d/44team.conf
de80c6
        _slaves+="$_kdumpdev,"
de80c6
    done
de80c6
    echo " team=$_netdev:$(echo $_slaves | sed -e 's/,$//')" >> ${initdir}/etc/cmdline.d/44team.conf
de80c6
    #Buggy version teamdctl outputs to stderr!
de80c6
    #Try to use the latest version of teamd.
de80c6
    teamdctl "$_netdev" config dump > /tmp/$$-$_netdev.conf
de80c6
    if [ $? -ne 0 ]
de80c6
    then
de80c6
        derror "teamdctl failed."
de80c6
        exit 1
de80c6
    fi
de80c6
    inst_dir /etc/teamd
de80c6
    inst_simple /tmp/$$-$_netdev.conf "/etc/teamd/$_netdev.conf"
de80c6
    rm -f /tmp/$$-$_netdev.conf
de80c6
}
de80c6
de80c6
kdump_setup_vlan() {
de80c6
    local _netdev=$1
de80c6
    local _phydev="$(awk '/^Device:/{print $2}' /proc/net/vlan/"$_netdev")"
de80c6
    local _netmac="$(kdump_get_mac_addr $_phydev)"
de80c6
    local _kdumpdev
de80c6
de80c6
    #Just support vlan over bond, it is not easy
de80c6
    #to support all other complex setup
de80c6
    if kdump_is_bridge "$_phydev"; then
de80c6
        derror "Vlan over bridge is not supported!"
de80c6
        exit 1
de80c6
    elif kdump_is_team "$_phydev"; then
de80c6
        derror "Vlan over team is not supported!"
de80c6
        exit 1
de80c6
    elif kdump_is_bond "$_phydev"; then
de80c6
        kdump_setup_bond "$_phydev"
de80c6
        echo " vlan=$_netdev:$_phydev" > ${initdir}/etc/cmdline.d/43vlan.conf
de80c6
    else
de80c6
        _kdumpdev="$(kdump_setup_ifname $_phydev)"
de80c6
        echo " vlan=$_netdev:$_kdumpdev ifname=$_kdumpdev:$_netmac" > ${initdir}/etc/cmdline.d/43vlan.conf
de80c6
    fi
de80c6
}
de80c6
de80c6
# setup s390 znet cmdline
de80c6
# $1: netdev name
de80c6
kdump_setup_znet() {
de80c6
    local _options=""
de80c6
    . /etc/sysconfig/network-scripts/ifcfg-$1
de80c6
    for i in $OPTIONS; do
de80c6
        _options=${_options},$i
de80c6
    done
de80c6
    echo rd.znet=${NETTYPE},${SUBCHANNELS}${_options} > ${initdir}/etc/cmdline.d/30znet.conf
de80c6
}
de80c6
de80c6
# Setup dracut to bringup a given network interface
de80c6
kdump_setup_netdev() {
de80c6
    local _netdev=$1 _srcaddr=$2
de80c6
    local _static _proto _ip_conf _ip_opts _ifname_opts
de80c6
de80c6
    if [ "$(uname -m)" = "s390x" ]; then
de80c6
        kdump_setup_znet $_netdev
de80c6
    fi
de80c6
de80c6
    _netmac=$(kdump_get_mac_addr $_netdev)
de80c6
    _static=$(kdump_static_ip $_netdev $_srcaddr)
de80c6
    if [ -n "$_static" ]; then
de80c6
        _proto=none
de80c6
    else
de80c6
        _proto=dhcp
de80c6
    fi
de80c6
de80c6
    _ip_conf="${initdir}/etc/cmdline.d/40ip.conf"
de80c6
    _ip_opts=" ip=${_static}$(kdump_setup_ifname $_netdev):${_proto}"
de80c6
de80c6
    # dracut doesn't allow duplicated configuration for same NIC, even they're exactly the same.
de80c6
    # so we have to avoid adding duplicates
de80c6
    # We should also check /proc/cmdline for existing ip=xx arg.
de80c6
    # For example, iscsi boot will specify ip=xxx arg in cmdline.
de80c6
    if [ ! -f $_ip_conf ] || ! grep -q $_ip_opts $_ip_conf &&\
de80c6
        ! grep -q "ip=[^[:space:]]*$_netdev" /proc/cmdline; then
de80c6
        echo "$_ip_opts" >> $_ip_conf
de80c6
    fi
de80c6
de80c6
    if kdump_is_bridge "$_netdev"; then
de80c6
        kdump_setup_bridge "$_netdev"
de80c6
    elif kdump_is_bond "$_netdev"; then
de80c6
        kdump_setup_bond "$_netdev"
de80c6
    elif kdump_is_team "$_netdev"; then
de80c6
        kdump_setup_team "$_netdev"
de80c6
    elif kdump_is_vlan "$_netdev"; then
de80c6
        kdump_setup_vlan "$_netdev"
de80c6
    else
de80c6
        _ifname_opts=" ifname=$(kdump_setup_ifname $_netdev):$(kdump_get_mac_addr $_netdev)"
de80c6
        echo "$_ifname_opts" >> $_ip_conf
de80c6
    fi
de80c6
de80c6
    kdump_setup_dns "$_netdev"
de80c6
}
de80c6
de80c6
#Function:kdump_install_net
de80c6
#$1: config values of net line in kdump.conf
de80c6
#$2: srcaddr of network device
de80c6
kdump_install_net() {
de80c6
    local _server _netdev _srcaddr
de80c6
    local config_val="$1"
de80c6
de80c6
    _server=`echo $config_val | sed 's/.*@//' | cut -d':' -f1`
de80c6
de80c6
    _need_dns=`echo $_server|grep "[a-zA-Z]"`
de80c6
    [ -n "$_need_dns" ] && _server=`getent hosts $_server|cut -d' ' -f1`
de80c6
de80c6
    _netdev=`/sbin/ip route get to $_server 2>&1`
de80c6
    [ $? != 0 ] && echo "Bad kdump location: $config_val" && exit 1
de80c6
de80c6
    #the field in the ip output changes if we go to another subnet
de80c6
    if [ -n "`echo $_netdev | grep via`" ]
de80c6
    then
de80c6
        # we are going to a different subnet
de80c6
        _srcaddr=`echo $_netdev|awk '{print $7}'|head -n 1`
de80c6
        _netdev=`echo $_netdev|awk '{print $5;}'|head -n 1`
de80c6
    else
de80c6
        # we are on the same subnet
de80c6
        _srcaddr=`echo $_netdev|awk '{print $5}'|head -n 1`
de80c6
        _netdev=`echo $_netdev|awk '{print $3}'|head -n 1`
de80c6
    fi
de80c6
de80c6
    kdump_setup_netdev "${_netdev}" "${_srcaddr}"
de80c6
de80c6
    #save netdev used for kdump as cmdline
de80c6
    # Whoever calling kdump_install_net() is setting up the default gateway,
de80c6
    # ie. bootdev/kdumpnic. So don't override the setting if calling
de80c6
    # kdump_install_net() for another time. For example, after setting eth0 as
de80c6
    # the default gate way for network dump, eth1 in the fence kdump path will
de80c6
    # call kdump_install_net again and we don't want eth1 to be the default
de80c6
    # gateway.
de80c6
    if [ ! -f ${initdir}${initdir}/etc/cmdline.d/60kdumpnic.conf ] &&
de80c6
       [ ! -f ${initdir}/etc/cmdline.d/70bootdev.conf ]; then
de80c6
        echo "kdumpnic=$(kdump_setup_ifname $_netdev)" > ${initdir}/etc/cmdline.d/60kdumpnic.conf
de80c6
        echo "bootdev=$(kdump_setup_ifname $_netdev)" > ${initdir}/etc/cmdline.d/70bootdev.conf
de80c6
    fi
de80c6
}
de80c6
de80c6
default_dump_target_install_conf()
de80c6
{
de80c6
    local _target _fstype
de80c6
    local _s  _t
de80c6
    local _mntpoint
de80c6
    local _path _save_path
de80c6
de80c6
    is_user_configured_dump_target && return
de80c6
de80c6
    _save_path=$(get_option_value "path")
de80c6
    [ -z "$_save_path" ] && _save_path=$DEFAULT_PATH
de80c6
de80c6
    _mntpoint=$(get_mntpoint_from_path $_save_path)
de80c6
    _target=$(get_target_from_path $_save_path)
de80c6
    if [ "$_mntpoint" != "/" ]; then
de80c6
        _fstype=$(get_fs_type_from_target $_target)
de80c6
de80c6
        if $(is_fs_type_nfs $_fstype); then
de80c6
            kdump_install_net "$_target"
de80c6
            _fstype="nfs"
de80c6
        else
de80c6
            _target=$(kdump_to_udev_name $_target)
de80c6
        fi
de80c6
de80c6
        echo "$_fstype $_target" >> /tmp/$$-kdump.conf
de80c6
de80c6
        _path=${_save_path##"$_mntpoint"}
de80c6
de80c6
        #erase the old path line, then insert the parsed path
de80c6
        sed -i "/^path/d" /tmp/$$-kdump.conf
de80c6
        echo "path $_path" >> /tmp/$$-kdump.conf
de80c6
    fi
de80c6
de80c6
}
de80c6
de80c6
#install kdump.conf and what user specifies in kdump.conf
de80c6
kdump_install_conf() {
de80c6
    sed -ne '/^#/!p' /etc/kdump.conf > /tmp/$$-kdump.conf
de80c6
de80c6
    while read config_opt config_val;
de80c6
    do
de80c6
        # remove inline comments after the end of a directive.
de80c6
        config_val=$(strip_comments $config_val)
de80c6
        case "$config_opt" in
de80c6
        ext[234]|xfs|btrfs|minix|raw)
de80c6
            sed -i -e "s#^$config_opt[[:space:]]\+$config_val#$config_opt $(kdump_to_udev_name $config_val)#" /tmp/$$-kdump.conf
de80c6
            ;;
de80c6
        ssh|nfs)
de80c6
            kdump_install_net "$config_val"
de80c6
            ;;
de80c6
        kdump_pre|kdump_post|extra_bins)
de80c6
            dracut_install $config_val
de80c6
            ;;
de80c6
        core_collector)
de80c6
            dracut_install "${config_val%%[[:blank:]]*}"
de80c6
            ;;
de80c6
        esac
de80c6
    done < /etc/kdump.conf
de80c6
de80c6
    default_dump_target_install_conf
de80c6
de80c6
    kdump_configure_fence_kdump  "/tmp/$$-kdump.conf"
de80c6
    inst "/tmp/$$-kdump.conf" "/etc/kdump.conf"
de80c6
    rm -f /tmp/$$-kdump.conf
de80c6
}
de80c6
de80c6
# Default sysctl parameters should suffice for kdump kernel.
de80c6
# Remove custom configurations sysctl.conf & sysctl.d/*
de80c6
remove_sysctl_conf() {
de80c6
de80c6
    # As custom configurations like vm.min_free_kbytes can lead
de80c6
    # to OOM issues in kdump kernel, avoid them
de80c6
    rm -f "${initdir}/etc/sysctl.conf"
de80c6
    rm -rf "${initdir}/etc/sysctl.d"
de80c6
    rm -rf "${initdir}/run/sysctl.d"
de80c6
    rm -rf "${initdir}/usr/lib/sysctl.d"
de80c6
}
de80c6
de80c6
kdump_iscsi_get_rec_val() {
de80c6
de80c6
    local result
de80c6
de80c6
    # The open-iscsi 742 release changed to using flat files in
de80c6
    # /var/lib/iscsi.
de80c6
de80c6
    result=$(/sbin/iscsiadm --show -m session -r ${1} | grep "^${2} = ")
de80c6
    result=${result##* = }
de80c6
    echo $result
de80c6
}
de80c6
de80c6
kdump_get_iscsi_initiator() {
de80c6
    local _initiator
de80c6
    local initiator_conf="/etc/iscsi/initiatorname.iscsi"
de80c6
de80c6
    [ -f "$initiator_conf" ] || return 1
de80c6
de80c6
    while read _initiator; do
de80c6
        [ -z "${_initiator%%#*}" ] && continue # Skip comment lines
de80c6
de80c6
        case $_initiator in
de80c6
            InitiatorName=*)
de80c6
                initiator=${_initiator#InitiatorName=}
de80c6
                echo "rd.iscsi.initiator=${initiator}"
de80c6
                return 0;;
de80c6
            *) ;;
de80c6
        esac
de80c6
    done < ${initiator_conf}
de80c6
de80c6
    return 1
de80c6
}
de80c6
de80c6
# No ibft handling yet.
de80c6
kdump_setup_iscsi_device() {
de80c6
    local path=$1
de80c6
    local tgt_name; local tgt_ipaddr;
de80c6
    local username; local password; local userpwd_str;
de80c6
    local username_in; local password_in; local userpwd_in_str;
de80c6
    local netdev
de80c6
    local srcaddr
de80c6
    local idev
de80c6
    local netroot_str ; local initiator_str;
de80c6
    local netroot_conf="${initdir}/etc/cmdline.d/50iscsi.conf"
de80c6
    local initiator_conf="/etc/iscsi/initiatorname.iscsi"
de80c6
de80c6
    dinfo "Found iscsi component $1"
de80c6
de80c6
    # Check once before getting explicit values, so we can output a decent
de80c6
    # error message.
de80c6
de80c6
    if ! /sbin/iscsiadm -m session -r ${path} >/dev/null ; then
de80c6
        derror "Unable to find iscsi record for $path"
de80c6
        return 1
de80c6
    fi
de80c6
de80c6
    tgt_name=$(kdump_iscsi_get_rec_val ${path} "node.name")
de80c6
    tgt_ipaddr=$(kdump_iscsi_get_rec_val ${path} "node.conn\[0\].address")
de80c6
de80c6
    # get and set username and password details
de80c6
    username=$(kdump_iscsi_get_rec_val ${path} "node.session.auth.username")
de80c6
    [ "$username" == "<empty>" ] && username=""
de80c6
    password=$(kdump_iscsi_get_rec_val ${path} "node.session.auth.password")
de80c6
    [ "$password" == "<empty>" ] && password=""
de80c6
    username_in=$(kdump_iscsi_get_rec_val ${path} "node.session.auth.username_in")
de80c6
    [ -n "$username" ] && userpwd_str="$username:$password"
de80c6
de80c6
    # get and set incoming username and password details
de80c6
    [ "$username_in" == "<empty>" ] && username_in=""
de80c6
    password_in=$(kdump_iscsi_get_rec_val ${path} "node.session.auth.password_in")
de80c6
    [ "$password_in" == "<empty>" ] && password_in=""
de80c6
de80c6
    [ -n "$username_in" ] && userpwd_in_str=":$username_in:$password_in"
de80c6
de80c6
    netdev=$(/sbin/ip route get to ${tgt_ipaddr} | \
de80c6
        sed 's|.*dev \(.*\).*|\1|g')
de80c6
    srcaddr=$(echo $netdev | awk '{ print $3; exit }')
de80c6
    netdev=$(echo $netdev | awk '{ print $1; exit }')
de80c6
de80c6
    kdump_setup_netdev $netdev $srcaddr
de80c6
de80c6
    # prepare netroot= command line
de80c6
    # FIXME: IPV6 addresses require explicit [] around $tgt_ipaddr
de80c6
    # FIXME: Do we need to parse and set other parameters like protocol, port
de80c6
    #        iscsi_iface_name, netdev_name, LUN etc.
de80c6
de80c6
    netroot_str="netroot=iscsi:${userpwd_str}${userpwd_in_str}@$tgt_ipaddr::::$tgt_name"
de80c6
de80c6
    [[ -f $netroot_conf ]] || touch $netroot_conf
de80c6
de80c6
    # If netroot target does not exist already, append.
de80c6
    if ! grep -q $netroot_str $netroot_conf; then
de80c6
         echo $netroot_str >> $netroot_conf
de80c6
         dinfo "Appended $netroot_str to $netroot_conf"
de80c6
    fi
de80c6
de80c6
    # Setup initator
de80c6
    initiator_str=$(kdump_get_iscsi_initiator)
de80c6
    [ $? -ne "0" ] && derror "Failed to get initiator name" && return 1
de80c6
de80c6
    # If initiator details do not exist already, append.
de80c6
    if ! grep -q "$initiator_str" $netroot_conf; then
de80c6
         echo "$initiator_str" >> $netroot_conf
de80c6
         dinfo "Appended "$initiator_str" to $netroot_conf"
de80c6
    fi
de80c6
}
de80c6
de80c6
kdump_check_iscsi_targets () {
de80c6
    # If our prerequisites are not met, fail anyways.
de80c6
    type -P iscsistart >/dev/null || return 1
de80c6
de80c6
    kdump_check_setup_iscsi() (
de80c6
        local _dev
de80c6
        _dev=$1
de80c6
de80c6
        [[ -L /sys/dev/block/$_dev ]] || return
de80c6
        cd "$(readlink -f /sys/dev/block/$_dev)"
de80c6
        until [[ -d sys || -d iscsi_session ]]; do
de80c6
            cd ..
de80c6
        done
de80c6
        [[ -d iscsi_session ]] && kdump_setup_iscsi_device "$PWD"
de80c6
    )
de80c6
de80c6
    [[ $hostonly ]] || [[ $mount_needs ]] && {
de80c6
        for_each_host_dev_and_slaves_all kdump_check_setup_iscsi
de80c6
    }
de80c6
}
de80c6
de80c6
# retrieves fence_kdump nodes from Pacemaker cluster configuration
de80c6
get_pcs_fence_kdump_nodes() {
de80c6
    local nodes
de80c6
de80c6
    # get cluster nodes from cluster cib, get interface and ip address
de80c6
    nodelist=`pcs cluster cib | xmllint --xpath "/cib/status/node_state/@uname" -`
de80c6
de80c6
    # nodelist is formed as 'uname="node1" uname="node2" ... uname="nodeX"'
de80c6
    # we need to convert each to node1, node2 ... nodeX in each iteration
de80c6
    for node in ${nodelist}; do
de80c6
        # convert $node from 'uname="nodeX"' to 'nodeX'
de80c6
        eval $node
de80c6
        nodename=$uname
de80c6
        # Skip its own node name
de80c6
        if [ "$nodename" = `hostname` -o "$nodename" = `hostname -s` ]; then
de80c6
            continue
de80c6
        fi
de80c6
        nodes="$nodes $nodename"
de80c6
    done
de80c6
de80c6
    echo $nodes
de80c6
}
de80c6
de80c6
# retrieves fence_kdump args from config file
de80c6
get_pcs_fence_kdump_args() {
de80c6
    if [ -f $FENCE_KDUMP_CONFIG_FILE ]; then
de80c6
        . $FENCE_KDUMP_CONFIG_FILE
de80c6
        echo $FENCE_KDUMP_OPTS
de80c6
    fi
de80c6
}
de80c6
de80c6
# setup fence_kdump in cluster
de80c6
# setup proper network and install needed files
de80c6
kdump_configure_fence_kdump () {
de80c6
    local kdump_cfg_file=$1
de80c6
    local nodes
de80c6
    local args
de80c6
de80c6
    if is_generic_fence_kdump; then
de80c6
        nodes=$(get_option_value "fence_kdump_nodes")
de80c6
de80c6
    elif is_pcs_fence_kdump; then
de80c6
        nodes=$(get_pcs_fence_kdump_nodes)
de80c6
de80c6
        # set appropriate options in kdump.conf
de80c6
        echo "fence_kdump_nodes $nodes" >> ${kdump_cfg_file}
de80c6
de80c6
        args=$(get_pcs_fence_kdump_args)
de80c6
        if [ -n "$args" ]; then
de80c6
            echo "fence_kdump_args $args" >> ${kdump_cfg_file}
de80c6
        fi
de80c6
de80c6
    else
de80c6
        # fence_kdump not configured
de80c6
        return 1
de80c6
    fi
de80c6
de80c6
    # setup network for each node
de80c6
    for node in ${nodes}; do
de80c6
        kdump_install_net $node
de80c6
    done
de80c6
de80c6
    dracut_install $FENCE_KDUMP_SEND
de80c6
}
de80c6
de80c6
# Install a random seed used to feed /dev/urandom
de80c6
# By the time kdump service starts, /dev/uramdom is already fed by systemd
de80c6
kdump_install_random_seed() {
de80c6
    local poolsize=`cat /proc/sys/kernel/random/poolsize`
de80c6
de80c6
    if [ ! -d ${initdir}/var/lib/ ]; then
de80c6
        mkdir -p ${initdir}/var/lib/
de80c6
    fi
de80c6
de80c6
    dd if=/dev/urandom of=${initdir}/var/lib/random-seed \
de80c6
       bs=$poolsize count=1 2> /dev/null
de80c6
}
de80c6
de80c6
install() {
de80c6
    kdump_install_conf
de80c6
    remove_sysctl_conf
de80c6
de80c6
    if is_ssh_dump_target; then
de80c6
        kdump_install_random_seed
de80c6
    fi
de80c6
    dracut_install -o /etc/adjtime /etc/localtime
de80c6
    inst "$moddir/monitor_dd_progress" "/kdumpscripts/monitor_dd_progress"
de80c6
    chmod +x ${initdir}/kdumpscripts/monitor_dd_progress
de80c6
    inst "/bin/dd" "/bin/dd"
de80c6
    inst "/bin/tail" "/bin/tail"
de80c6
    inst "/bin/date" "/bin/date"
de80c6
    inst "/bin/sync" "/bin/sync"
de80c6
    inst "/bin/cut" "/bin/cut"
de80c6
    inst "/sbin/makedumpfile" "/sbin/makedumpfile"
de80c6
    inst "/sbin/vmcore-dmesg" "/sbin/vmcore-dmesg"
de80c6
    inst "/lib/kdump/kdump-lib.sh" "/lib/kdump-lib.sh"
de80c6
    inst "/lib/kdump/kdump-lib-initramfs.sh" "/lib/kdump-lib-initramfs.sh"
de80c6
    inst "$moddir/kdump.sh" "/usr/bin/kdump.sh"
de80c6
    inst "$moddir/kdump-capture.service" "$systemdsystemunitdir/kdump-capture.service"
de80c6
    ln_r "$systemdsystemunitdir/kdump-capture.service" "$systemdsystemunitdir/initrd.target.wants/kdump-capture.service"
de80c6
    inst "$moddir/kdump-error-handler.sh" "/usr/bin/kdump-error-handler.sh"
de80c6
    inst "$moddir/kdump-error-handler.service" "$systemdsystemunitdir/kdump-error-handler.service"
de80c6
    # Replace existing emergency service
de80c6
    cp "$moddir/kdump-emergency.service" "$initdir/$systemdsystemunitdir/emergency.service"
de80c6
    # Also redirect dracut-emergency to kdump error handler
de80c6
    ln_r "$systemdsystemunitdir/emergency.service" "$systemdsystemunitdir/dracut-emergency.service"
de80c6
de80c6
    # Check for all the devices and if any device is iscsi, bring up iscsi
de80c6
    # target. Ideally all this should be pushed into dracut iscsi module
de80c6
    # at some point of time.
de80c6
    kdump_check_iscsi_targets
de80c6
}
de80c6
de80c6
installkernel() {
de80c6
    wdt=$(lsmod|cut -f1 -d' '|grep "wdt$")
de80c6
    if [ -n "$wdt" ]; then
de80c6
        [ "$wdt" = "iTCO_wdt" ] && instmods lpc_ich
de80c6
        instmods $wdt
de80c6
    fi
de80c6
}