|
|
@ -1,10 +1,22 @@
|
|
|
|
#!/bin/bash
|
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_DRACUT_KDUMP_NM_TMP_DIR="$DRACUT_TMPDIR/$$-DRACUT_KDUMP_NM"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_save_kdump_netifs() {
|
|
|
|
|
|
|
|
unique_netifs[$1]=1
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_get_kdump_netifs() {
|
|
|
|
|
|
|
|
echo -n "${!unique_netifs[@]}"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
kdump_module_init() {
|
|
|
|
kdump_module_init() {
|
|
|
|
if ! [[ -d "${initdir}/tmp" ]]; then
|
|
|
|
if ! [[ -d "${initdir}/tmp" ]]; then
|
|
|
|
mkdir -p "${initdir}/tmp"
|
|
|
|
mkdir -p "${initdir}/tmp"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
mkdir -p "$_DRACUT_KDUMP_NM_TMP_DIR"
|
|
|
|
|
|
|
|
|
|
|
|
. /lib/kdump/kdump-lib.sh
|
|
|
|
. /lib/kdump/kdump-lib.sh
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -40,6 +52,14 @@ depends() {
|
|
|
|
_dep="$_dep ssh-client"
|
|
|
|
_dep="$_dep ssh-client"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if is_lvm2_thinp_dump_target; then
|
|
|
|
|
|
|
|
if grep -q lvmthinpool-monitor <<< $(dracut --list-modules); then
|
|
|
|
|
|
|
|
add_opt_module lvmthinpool-monitor
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
dwarning "Required lvmthinpool-monitor modules is missing! Please upgrade dracut >= 057."
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
if [[ "$(uname -m)" == "s390x" ]]; then
|
|
|
|
if [[ "$(uname -m)" == "s390x" ]]; then
|
|
|
|
_dep="$_dep znet"
|
|
|
|
_dep="$_dep znet"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
@ -84,39 +104,6 @@ source_ifcfg_file() {
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
kdump_setup_dns() {
|
|
|
|
|
|
|
|
local _netdev="$1"
|
|
|
|
|
|
|
|
local _conpath="$2"
|
|
|
|
|
|
|
|
local _nameserver _dns _tmp array
|
|
|
|
|
|
|
|
local _dnsfile=${initdir}/etc/cmdline.d/42dns.conf
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_tmp=$(get_nmcli_field_by_conpath "IP4.DNS" "$_conpath")
|
|
|
|
|
|
|
|
# shellcheck disable=SC2206
|
|
|
|
|
|
|
|
array=(${_tmp//|/ })
|
|
|
|
|
|
|
|
if [[ ${array[*]} ]]; then
|
|
|
|
|
|
|
|
for _dns in "${array[@]}"; do
|
|
|
|
|
|
|
|
echo "nameserver=$_dns" >> "$_dnsfile"
|
|
|
|
|
|
|
|
done
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
dwarning "Failed to get DNS info via nmcli output. Now try sourcing ifcfg script"
|
|
|
|
|
|
|
|
source_ifcfg_file "$_netdev"
|
|
|
|
|
|
|
|
[[ -n $DNS1 ]] && echo "nameserver=$DNS1" > "$_dnsfile"
|
|
|
|
|
|
|
|
[[ -n $DNS2 ]] && echo "nameserver=$DNS2" >> "$_dnsfile"
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
while read -r content; do
|
|
|
|
|
|
|
|
_nameserver=$(echo "$content" | grep ^nameserver)
|
|
|
|
|
|
|
|
[[ -z $_nameserver ]] && continue
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_dns=$(echo "$_nameserver" | awk '{print $2}')
|
|
|
|
|
|
|
|
[[ -z $_dns ]] && continue
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [[ ! -f $_dnsfile ]] || ! grep -q "$_dns" "$_dnsfile"; then
|
|
|
|
|
|
|
|
echo "nameserver=$_dns" >> "$_dnsfile"
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
done < "/etc/resolv.conf"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# $1: repeat times
|
|
|
|
# $1: repeat times
|
|
|
|
# $2: string to be repeated
|
|
|
|
# $2: string to be repeated
|
|
|
|
# $3: separator
|
|
|
|
# $3: separator
|
|
|
@ -227,291 +214,309 @@ cal_netmask_by_prefix() {
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#$1: netdev name
|
|
|
|
kdump_get_mac_addr() {
|
|
|
|
#$2: srcaddr
|
|
|
|
cat "/sys/class/net/$1/address"
|
|
|
|
#if it use static ip echo it, or echo null
|
|
|
|
}
|
|
|
|
kdump_static_ip() {
|
|
|
|
|
|
|
|
local _netdev="$1" _srcaddr="$2" kdumpnic="$3" _ipv6_flag
|
|
|
|
|
|
|
|
local _netmask _gateway _ipaddr _target _nexthop _prefix
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_ipaddr=$(ip addr show dev "$_netdev" permanent | awk "/ $_srcaddr\/.* /{print \$2}")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if is_ipv6_address "$_srcaddr"; then
|
|
|
|
#Bonding or team master modifies the mac address
|
|
|
|
_ipv6_flag="-6"
|
|
|
|
#of its slaves, we should use perm address
|
|
|
|
|
|
|
|
kdump_get_perm_addr() {
|
|
|
|
|
|
|
|
local addr
|
|
|
|
|
|
|
|
addr=$(ethtool -P "$1" | sed -e 's/Permanent address: //')
|
|
|
|
|
|
|
|
if [[ -z $addr ]] || [[ $addr == "00:00:00:00:00:00" ]]; then
|
|
|
|
|
|
|
|
derror "Can't get the permanent address of $1"
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
echo "$addr"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if [[ -n $_ipaddr ]]; then
|
|
|
|
apply_nm_initrd_generator_timeouts() {
|
|
|
|
_gateway=$(ip $_ipv6_flag route list dev "$_netdev" \
|
|
|
|
local _timeout_conf
|
|
|
|
| awk '/^default /{print $3}' | head -n 1)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [[ "x" != "x"$_ipv6_flag ]]; then
|
|
|
|
_timeout_conf=$_DRACUT_KDUMP_NM_TMP_DIR/timeout_conf
|
|
|
|
# _ipaddr="2002::56ff:feb6:56d5/64", _netmask is the number after "/"
|
|
|
|
cat << EOF > "$_timeout_conf"
|
|
|
|
_netmask=${_ipaddr#*\/}
|
|
|
|
[device-95-kdump]
|
|
|
|
_srcaddr="[$_srcaddr]"
|
|
|
|
carrier-wait-timeout=30000
|
|
|
|
_gateway="[$_gateway]"
|
|
|
|
|
|
|
|
else
|
|
|
|
[connection-95-kdump]
|
|
|
|
_prefix=$(cut -d'/' -f2 <<< "$_ipaddr")
|
|
|
|
ipv4.dhcp-timeout=90
|
|
|
|
if ! _netmask=$(cal_netmask_by_prefix "$_prefix" "$_ipv6_flag"); then
|
|
|
|
ipv6.dhcp-timeout=90
|
|
|
|
derror "Failed to calculate netmask for $_ipaddr"
|
|
|
|
EOF
|
|
|
|
exit 1
|
|
|
|
|
|
|
|
|
|
|
|
inst "$_timeout_conf" "/etc/NetworkManager/conf.d/95-kdump-timeouts.conf"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
use_ipv4_or_ipv6() {
|
|
|
|
|
|
|
|
local _netif=$1 _uuid=$2
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [[ -v "ipv4_usage[$_netif]" ]]; then
|
|
|
|
|
|
|
|
nmcli connection modify --temporary "$_uuid" ipv4.may-fail no &> >(ddebug)
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [[ -v "ipv6_usage[$_netif]" ]]; then
|
|
|
|
|
|
|
|
nmcli connection modify --temporary "$_uuid" ipv6.may-fail no &> >(ddebug)
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
echo -n "${_srcaddr}::${_gateway}:${_netmask}::"
|
|
|
|
|
|
|
|
|
|
|
|
if [[ -v "ipv4_usage[$_netif]" ]] && [[ ! -v "ipv6_usage[$_netif]" ]]; then
|
|
|
|
|
|
|
|
nmcli connection modify --temporary "$_uuid" ipv6.method disabled &> >(ddebug)
|
|
|
|
|
|
|
|
elif [[ ! -v "ipv4_usage[$_netif]" ]] && [[ -v "ipv6_usage[$_netif]" ]]; then
|
|
|
|
|
|
|
|
nmcli connection modify --temporary "$_uuid" ipv4.method disabled &> >(ddebug)
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/sbin/ip $_ipv6_flag route show | grep -v default \
|
|
|
|
_clone_nmconnection() {
|
|
|
|
| grep ".*via.* $_netdev " | grep -v "^[[:space:]]*nexthop" \
|
|
|
|
local _clone_output _name _unique_id
|
|
|
|
| while read -r _route; do
|
|
|
|
|
|
|
|
_target=$(echo "$_route" | awk '{print $1}')
|
|
|
|
_unique_id=$1
|
|
|
|
_nexthop=$(echo "$_route" | awk '{print $3}')
|
|
|
|
_name=$(nmcli --get-values connection.id connection show "$_unique_id")
|
|
|
|
if [[ "x" != "x"$_ipv6_flag ]]; then
|
|
|
|
if _clone_output=$(nmcli connection clone --temporary uuid "$_unique_id" "$_name"); then
|
|
|
|
_target="[$_target]"
|
|
|
|
sed -E -n "s/.* \(.*\) cloned as.*\((.*)\)\.$/\1/p" <<< "$_clone_output"
|
|
|
|
_nexthop="[$_nexthop]"
|
|
|
|
return 0
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
echo "rd.route=$_target:$_nexthop:$kdumpnic"
|
|
|
|
|
|
|
|
done >> "${initdir}/etc/cmdline.d/45route-static.conf"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
kdump_handle_mulitpath_route "$_netdev" "$_srcaddr" "$kdumpnic"
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
kdump_handle_mulitpath_route() {
|
|
|
|
_match_nmconnection_by_mac() {
|
|
|
|
local _netdev="$1" _srcaddr="$2" kdumpnic="$3" _ipv6_flag
|
|
|
|
local _unique_id _dev _mac _mac_field
|
|
|
|
local _target _nexthop _route _weight _max_weight _rule
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if is_ipv6_address "$_srcaddr"; then
|
|
|
|
_unique_id=$1
|
|
|
|
_ipv6_flag="-6"
|
|
|
|
_dev=$2
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
_mac=$(kdump_get_perm_addr "$_dev")
|
|
|
|
while IFS="" read -r _route; do
|
|
|
|
[[ $_mac != 'not set' ]] || return
|
|
|
|
if [[ $_route =~ [[:space:]]+nexthop ]]; then
|
|
|
|
_mac_field=$(nmcli --get-values connection.type connection show "$_unique_id").mac-address
|
|
|
|
_route=${_route##[[:space:]]}
|
|
|
|
nmcli connection modify --temporary "$_unique_id" "$_mac_field" "$_mac" &> >(ddebug)
|
|
|
|
# Parse multipath route, using previous _target
|
|
|
|
nmcli connection modify --temporary "$_unique_id" "connection.interface-name" "" &> >(ddebug)
|
|
|
|
[[ $_target == 'default' ]] && continue
|
|
|
|
}
|
|
|
|
[[ $_route =~ .*via.*\ $_netdev ]] || continue
|
|
|
|
|
|
|
|
|
|
|
|
# Clone and modify NM connection profiles
|
|
|
|
_weight=$(echo "$_route" | cut -d ' ' -f7)
|
|
|
|
#
|
|
|
|
if [[ $_weight -gt $_max_weight ]]; then
|
|
|
|
# This function makes use of "nmcli clone" to automatically convert ifcfg-*
|
|
|
|
_nexthop=$(echo "$_route" | cut -d ' ' -f3)
|
|
|
|
# files to Networkmanager .nmconnection connection profiles and also modify the
|
|
|
|
_max_weight=$_weight
|
|
|
|
# properties of .nmconnection if necessary.
|
|
|
|
if [[ "x" != "x"$_ipv6_flag ]]; then
|
|
|
|
clone_and_modify_nmconnection() {
|
|
|
|
_rule="rd.route=[$_target]:[$_nexthop]:$kdumpnic"
|
|
|
|
local _dev _cloned_nmconnection_file_path _tmp_nmconnection_file_path _old_uuid _uuid
|
|
|
|
else
|
|
|
|
|
|
|
|
_rule="rd.route=$_target:$_nexthop:$kdumpnic"
|
|
|
|
_dev=$1
|
|
|
|
fi
|
|
|
|
_nmconnection_file_path=$2
|
|
|
|
fi
|
|
|
|
|
|
|
|
else
|
|
|
|
_old_uuid=$(nmcli --get-values connection.uuid connection show filename "$_nmconnection_file_path")
|
|
|
|
[[ -n $_rule ]] && echo "$_rule"
|
|
|
|
|
|
|
|
_target=$(echo "$_route" | cut -d ' ' -f1)
|
|
|
|
if ! _uuid=$(_clone_nmconnection "$_old_uuid"); then
|
|
|
|
_rule="" _max_weight=0 _weight=0
|
|
|
|
derror "Failed to clone $_old_uuid"
|
|
|
|
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
done >> "${initdir}/etc/cmdline.d/45route-static.conf" \
|
|
|
|
|
|
|
|
<<< "$(/sbin/ip $_ipv6_flag route show)"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
[[ -n $_rule ]] && echo "$_rule" >> "${initdir}/etc/cmdline.d/45route-static.conf"
|
|
|
|
use_ipv4_or_ipv6 "$_dev" "$_uuid"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
nmcli connection modify --temporary uuid "$_uuid" connection.wait-device-timeout 60000 &> >(ddebug)
|
|
|
|
|
|
|
|
# For physical NIC i.e. non-user created NIC, ask NM to match a
|
|
|
|
|
|
|
|
# connection profile based on MAC address
|
|
|
|
|
|
|
|
_match_nmconnection_by_mac "$_uuid" "$_dev"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_cloned_nmconnection_file_path=$(nmcli --get-values UUID,FILENAME connection show | sed -n "s/^${_uuid}://p")
|
|
|
|
|
|
|
|
_tmp_nmconnection_file_path=$_DRACUT_KDUMP_NM_TMP_DIR/$(basename "$_nmconnection_file_path")
|
|
|
|
|
|
|
|
cp "$_cloned_nmconnection_file_path" "$_tmp_nmconnection_file_path"
|
|
|
|
|
|
|
|
# change uuid back to old value in case it's refered by other connection
|
|
|
|
|
|
|
|
# profile e.g. connection.master could be interface name of the master
|
|
|
|
|
|
|
|
# device or UUID of the master connection.
|
|
|
|
|
|
|
|
sed -i -E "s/(^uuid=).*$/\1${_old_uuid}/g" "$_tmp_nmconnection_file_path"
|
|
|
|
|
|
|
|
nmcli connection del "$_uuid" &> >(ddebug)
|
|
|
|
|
|
|
|
echo -n "$_tmp_nmconnection_file_path"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
kdump_get_mac_addr() {
|
|
|
|
_install_nmconnection() {
|
|
|
|
cat "/sys/class/net/$1/address"
|
|
|
|
local _src _nmconnection_name _dst
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_src=$1
|
|
|
|
|
|
|
|
_nmconnection_name=$(basename "$_src")
|
|
|
|
|
|
|
|
_dst="/etc/NetworkManager/system-connections/$_nmconnection_name"
|
|
|
|
|
|
|
|
inst "$_src" "$_dst"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#Bonding or team master modifies the mac address
|
|
|
|
kdump_install_nmconnections() {
|
|
|
|
#of its slaves, we should use perm address
|
|
|
|
local _netif _nm_conn_path _cloned_nm_path
|
|
|
|
kdump_get_perm_addr() {
|
|
|
|
|
|
|
|
local addr
|
|
|
|
while IFS=: read -r _netif _nm_conn_path; do
|
|
|
|
addr=$(ethtool -P "$1" | sed -e 's/Permanent address: //')
|
|
|
|
[[ -v "unique_netifs[$_netif]" ]] || continue
|
|
|
|
if [[ -z $addr ]] || [[ $addr == "00:00:00:00:00:00" ]]; then
|
|
|
|
if _cloned_nm_path=$(clone_and_modify_nmconnection "$_netif" "$_nm_conn_path"); then
|
|
|
|
derror "Can't get the permanent address of $1"
|
|
|
|
_install_nmconnection "$_cloned_nm_path"
|
|
|
|
else
|
|
|
|
else
|
|
|
|
echo "$addr"
|
|
|
|
derror "Failed to install the .nmconnection for $_netif"
|
|
|
|
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
done <<< "$(nmcli -t -f device,filename connection show --active)"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Stop dracut 35network-manger to calling nm-initrd-generator.
|
|
|
|
|
|
|
|
# Note this line of code can be removed after NetworkManager >= 1.35.2
|
|
|
|
|
|
|
|
# gets released.
|
|
|
|
|
|
|
|
echo > "${initdir}/usr/libexec/nm-initrd-generator"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# Prefix kernel assigned names with "kdump-". EX: eth0 -> kdump-eth0
|
|
|
|
kdump_install_nm_netif_allowlist() {
|
|
|
|
# Because kernel assigned names are not persistent between 1st and 2nd
|
|
|
|
local _netif _except_netif _netif_allowlist _netif_allowlist_nm_conf
|
|
|
|
# kernel. We could probably end up with eth0 being eth1, eth0 being
|
|
|
|
|
|
|
|
# eth1, and naming conflict happens.
|
|
|
|
for _netif in $1; do
|
|
|
|
kdump_setup_ifname() {
|
|
|
|
_per_mac=$(kdump_get_perm_addr "$_netif")
|
|
|
|
local _ifname
|
|
|
|
if [[ "$_per_mac" != 'not set' ]]; then
|
|
|
|
|
|
|
|
_except_netif="mac:$_per_mac"
|
|
|
|
# If ifname already has 'kdump-' prefix, we must be switching from
|
|
|
|
|
|
|
|
# fadump to kdump. Skip prefixing 'kdump-' in this case as adding
|
|
|
|
|
|
|
|
# another prefix may truncate the ifname. Since an ifname with
|
|
|
|
|
|
|
|
# 'kdump-' is already persistent, this should be fine.
|
|
|
|
|
|
|
|
if [[ $1 =~ eth* ]] && [[ ! $1 =~ ^kdump-* ]]; then
|
|
|
|
|
|
|
|
_ifname="kdump-$1"
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
_ifname="$1"
|
|
|
|
_except_netif="interface-name:$_netif"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
_netif_allowlist="${_netif_allowlist}except:${_except_netif};"
|
|
|
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_netif_allowlist_nm_conf=$_DRACUT_KDUMP_NM_TMP_DIR/netif_allowlist_nm_conf
|
|
|
|
|
|
|
|
cat << EOF > "$_netif_allowlist_nm_conf"
|
|
|
|
|
|
|
|
[device-others]
|
|
|
|
|
|
|
|
match-device=${_netif_allowlist}
|
|
|
|
|
|
|
|
managed=false
|
|
|
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
inst "$_netif_allowlist_nm_conf" "/etc/NetworkManager/conf.d/10-kdump-netif_allowlist.conf"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_get_nic_driver() {
|
|
|
|
|
|
|
|
ethtool -i "$1" | sed -n -E "s/driver: (.*)/\1/p"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_get_hpyerv_physical_driver() {
|
|
|
|
|
|
|
|
local _physical_nic
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_physical_nic=$(find /sys/class/net/"$1"/ -name 'lower_*' | sed -En "s/\/.*lower_(.*)/\1/p")
|
|
|
|
|
|
|
|
[[ -n $_physical_nic ]] || return
|
|
|
|
|
|
|
|
_get_nic_driver "$_physical_nic"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
kdump_install_nic_driver() {
|
|
|
|
|
|
|
|
local _netif _driver _drivers
|
|
|
|
|
|
|
|
|
|
|
|
echo "$_ifname"
|
|
|
|
_drivers=()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for _netif in $1; do
|
|
|
|
|
|
|
|
[[ $_netif == lo ]] && continue
|
|
|
|
|
|
|
|
_driver=$(_get_nic_driver "$_netif")
|
|
|
|
|
|
|
|
if [[ -z $_driver ]]; then
|
|
|
|
|
|
|
|
derror "Failed to get the driver of $_netif"
|
|
|
|
|
|
|
|
exit 1
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [[ $_driver == "802.1Q VLAN Support" ]]; then
|
|
|
|
|
|
|
|
# ethtool somehow doesn't return the driver name for a VLAN NIC
|
|
|
|
|
|
|
|
_driver=8021q
|
|
|
|
|
|
|
|
elif [[ $_driver == "team" ]]; then
|
|
|
|
|
|
|
|
# install the team mode drivers like team_mode_roundrobin.ko as well
|
|
|
|
|
|
|
|
_driver='=drivers/net/team'
|
|
|
|
|
|
|
|
elif [[ $_driver == "hv_netvsc" ]]; then
|
|
|
|
|
|
|
|
# A Hyper-V VM may have accelerated networking
|
|
|
|
|
|
|
|
# https://learn.microsoft.com/en-us/azure/virtual-network/accelerated-networking-overview
|
|
|
|
|
|
|
|
# Install the driver of physical NIC as well
|
|
|
|
|
|
|
|
_drivers+=("$(_get_hpyerv_physical_driver "$_netif")")
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_drivers+=("$_driver")
|
|
|
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
[[ -n ${_drivers[*]} ]] || return
|
|
|
|
|
|
|
|
instmods "${_drivers[@]}"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
kdump_setup_bridge() {
|
|
|
|
kdump_setup_bridge() {
|
|
|
|
local _netdev=$1
|
|
|
|
local _netdev=$1
|
|
|
|
local _brif _dev _mac _kdumpdev
|
|
|
|
local _dev
|
|
|
|
for _dev in "/sys/class/net/$_netdev/brif/"*; do
|
|
|
|
for _dev in "/sys/class/net/$_netdev/brif/"*; do
|
|
|
|
[[ -e $_dev ]] || continue
|
|
|
|
[[ -e $_dev ]] || continue
|
|
|
|
_dev=${_dev##*/}
|
|
|
|
_dev=${_dev##*/}
|
|
|
|
_kdumpdev=$_dev
|
|
|
|
|
|
|
|
if kdump_is_bond "$_dev"; then
|
|
|
|
if kdump_is_bond "$_dev"; then
|
|
|
|
(kdump_setup_bond "$_dev" "$(get_nmcli_connection_apath_by_ifname "$_dev")") || exit 1
|
|
|
|
kdump_setup_bond "$_dev" || return 1
|
|
|
|
elif kdump_is_team "$_dev"; then
|
|
|
|
elif kdump_is_team "$_dev"; then
|
|
|
|
kdump_setup_team "$_dev"
|
|
|
|
kdump_setup_team "$_dev"
|
|
|
|
elif kdump_is_vlan "$_dev"; then
|
|
|
|
elif kdump_is_vlan "$_dev"; then
|
|
|
|
kdump_setup_vlan "$_dev"
|
|
|
|
kdump_setup_vlan "$_dev"
|
|
|
|
else
|
|
|
|
|
|
|
|
_mac=$(kdump_get_mac_addr "$_dev")
|
|
|
|
|
|
|
|
_kdumpdev=$(kdump_setup_ifname "$_dev")
|
|
|
|
|
|
|
|
echo -n " ifname=$_kdumpdev:$_mac" >> "${initdir}/etc/cmdline.d/41bridge.conf"
|
|
|
|
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
_brif+="$_kdumpdev,"
|
|
|
|
_save_kdump_netifs "$_dev"
|
|
|
|
done
|
|
|
|
done
|
|
|
|
echo " bridge=$_netdev:${_brif%,}" >> "${initdir}/etc/cmdline.d/41bridge.conf"
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# drauct takes bond=<bondname>[:<bondslaves>:[:<options>]] syntax to parse
|
|
|
|
|
|
|
|
# bond. For example:
|
|
|
|
|
|
|
|
# bond=bond0:eth0,eth1:mode=balance-rr
|
|
|
|
|
|
|
|
kdump_setup_bond() {
|
|
|
|
kdump_setup_bond() {
|
|
|
|
local _netdev="$1"
|
|
|
|
local _netdev="$1"
|
|
|
|
local _conpath="$2"
|
|
|
|
local _dev
|
|
|
|
local _dev _mac _slaves _kdumpdev _bondoptions
|
|
|
|
|
|
|
|
for _dev in $(cat "/sys/class/net/$_netdev/bonding/slaves"); do
|
|
|
|
|
|
|
|
_mac=$(kdump_get_perm_addr "$_dev")
|
|
|
|
|
|
|
|
_kdumpdev=$(kdump_setup_ifname "$_dev")
|
|
|
|
|
|
|
|
echo -n " ifname=$_kdumpdev:$_mac" >> "${initdir}/etc/cmdline.d/42bond.conf"
|
|
|
|
|
|
|
|
_slaves+="$_kdumpdev,"
|
|
|
|
|
|
|
|
done
|
|
|
|
|
|
|
|
echo -n " bond=$_netdev:${_slaves%,}" >> "${initdir}/etc/cmdline.d/42bond.conf"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_bondoptions=$(get_nmcli_field_by_conpath "bond.options" "$_conpath")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [[ -z $_bondoptions ]]; then
|
|
|
|
|
|
|
|
dwarning "Failed to get bond configuration via nmlci output. Now try sourcing ifcfg script."
|
|
|
|
|
|
|
|
source_ifcfg_file "$_netdev"
|
|
|
|
|
|
|
|
_bondoptions="$(echo "$BONDING_OPTS" | xargs echo | tr " " ",")"
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [[ -z $_bondoptions ]]; then
|
|
|
|
|
|
|
|
derror "Get empty bond options"
|
|
|
|
|
|
|
|
exit 1
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
echo ":$_bondoptions" >> "${initdir}/etc/cmdline.d/42bond.conf"
|
|
|
|
for _dev in $(< "/sys/class/net/$_netdev/bonding/slaves"); do
|
|
|
|
|
|
|
|
_save_kdump_netifs "$_dev"
|
|
|
|
|
|
|
|
done
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
kdump_setup_team() {
|
|
|
|
kdump_setup_team() {
|
|
|
|
local _netdev=$1
|
|
|
|
local _netdev=$1
|
|
|
|
local _dev _mac _slaves _kdumpdev
|
|
|
|
local _dev
|
|
|
|
for _dev in $(teamnl "$_netdev" ports | awk -F':' '{print $2}'); do
|
|
|
|
for _dev in $(teamnl "$_netdev" ports | awk -F':' '{print $2}'); do
|
|
|
|
_mac=$(kdump_get_perm_addr "$_dev")
|
|
|
|
_save_kdump_netifs "$_dev"
|
|
|
|
_kdumpdev=$(kdump_setup_ifname "$_dev")
|
|
|
|
|
|
|
|
echo -n " ifname=$_kdumpdev:$_mac" >> "${initdir}/etc/cmdline.d/44team.conf"
|
|
|
|
|
|
|
|
_slaves+="$_kdumpdev,"
|
|
|
|
|
|
|
|
done
|
|
|
|
done
|
|
|
|
echo " team=$_netdev:${_slaves%,}" >> "${initdir}/etc/cmdline.d/44team.conf"
|
|
|
|
|
|
|
|
#Buggy version teamdctl outputs to stderr!
|
|
|
|
|
|
|
|
#Try to use the latest version of teamd.
|
|
|
|
|
|
|
|
if ! teamdctl "$_netdev" config dump > "${initdir}/tmp/$$-$_netdev.conf"; then
|
|
|
|
|
|
|
|
derror "teamdctl failed."
|
|
|
|
|
|
|
|
exit 1
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
inst_dir /etc/teamd
|
|
|
|
|
|
|
|
inst_simple "${initdir}/tmp/$$-$_netdev.conf" "/etc/teamd/$_netdev.conf"
|
|
|
|
|
|
|
|
rm -f "${initdir}/tmp/$$-$_netdev.conf"
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
kdump_setup_vlan() {
|
|
|
|
kdump_setup_vlan() {
|
|
|
|
local _netdev=$1
|
|
|
|
local _netdev=$1
|
|
|
|
local _phydev
|
|
|
|
local _parent_netif
|
|
|
|
local _netmac
|
|
|
|
|
|
|
|
local _kdumpdev
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_phydev="$(awk '/^Device:/{print $2}' /proc/net/vlan/"$_netdev")"
|
|
|
|
_parent_netif="$(awk '/^Device:/{print $2}' /proc/net/vlan/"$_netdev")"
|
|
|
|
_netmac="$(kdump_get_mac_addr "$_phydev")"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#Just support vlan over bond and team
|
|
|
|
#Just support vlan over bond and team
|
|
|
|
if kdump_is_bridge "$_phydev"; then
|
|
|
|
if kdump_is_bridge "$_parent_netif"; then
|
|
|
|
derror "Vlan over bridge is not supported!"
|
|
|
|
derror "Vlan over bridge is not supported!"
|
|
|
|
exit 1
|
|
|
|
exit 1
|
|
|
|
elif kdump_is_bond "$_phydev"; then
|
|
|
|
elif kdump_is_bond "$_parent_netif"; then
|
|
|
|
(kdump_setup_bond "$_phydev" "$(get_nmcli_connection_apath_by_ifname "$_phydev")") || exit 1
|
|
|
|
kdump_setup_bond "$_parent_netif" || return 1
|
|
|
|
echo " vlan=$(kdump_setup_ifname "$_netdev"):$_phydev" > "${initdir}/etc/cmdline.d/43vlan.conf"
|
|
|
|
elif kdump_is_team "$_parent_netif"; then
|
|
|
|
else
|
|
|
|
kdump_setup_team "$_parent_netif" || return 1
|
|
|
|
_kdumpdev="$(kdump_setup_ifname "$_phydev")"
|
|
|
|
|
|
|
|
echo " vlan=$(kdump_setup_ifname "$_netdev"):$_kdumpdev ifname=$_kdumpdev:$_netmac" > "${initdir}/etc/cmdline.d/43vlan.conf"
|
|
|
|
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_save_kdump_netifs "$_parent_netif"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# find online znet device
|
|
|
|
_find_znet_nmconnection() {
|
|
|
|
# return ifname (_netdev)
|
|
|
|
LANG=C grep -s -E -i -l \
|
|
|
|
# code reaped from the list_configured function of
|
|
|
|
"^s390-subchannels=([0-9]\.[0-9]\.[a-f0-9]+;){0,2}" \
|
|
|
|
# https://github.com/hreinecke/s390-tools/blob/master/zconf/znetconf
|
|
|
|
"$1"/*.nmconnection | LC_ALL=C sed -e "$2"
|
|
|
|
find_online_znet_device() {
|
|
|
|
|
|
|
|
local CCWGROUPBUS_DEVICEDIR="/sys/bus/ccwgroup/devices"
|
|
|
|
|
|
|
|
local NETWORK_DEVICES d ifname ONLINE
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
[[ ! -d $CCWGROUPBUS_DEVICEDIR ]] && return
|
|
|
|
|
|
|
|
NETWORK_DEVICES=$(find $CCWGROUPBUS_DEVICEDIR)
|
|
|
|
|
|
|
|
for d in $NETWORK_DEVICES; do
|
|
|
|
|
|
|
|
[[ ! -f "$d/online" ]] && continue
|
|
|
|
|
|
|
|
read -r ONLINE < "$d/online"
|
|
|
|
|
|
|
|
if [[ $ONLINE -ne 1 ]]; then
|
|
|
|
|
|
|
|
continue
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
# determine interface name, if there (only for qeth and if
|
|
|
|
|
|
|
|
# device is online)
|
|
|
|
|
|
|
|
if [[ -f $d/if_name ]]; then
|
|
|
|
|
|
|
|
read -r ifname < "$d/if_name"
|
|
|
|
|
|
|
|
elif [[ -d $d/net ]]; then
|
|
|
|
|
|
|
|
ifname=$(ls "$d/net/")
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
[[ -n $ifname ]] && break
|
|
|
|
|
|
|
|
done
|
|
|
|
|
|
|
|
echo -n "$ifname"
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# setup s390 znet cmdline
|
|
|
|
# setup s390 znet
|
|
|
|
# $1: netdev (ifname)
|
|
|
|
#
|
|
|
|
# $2: nmcli connection path
|
|
|
|
# Note part of code is extracted from ccw_init provided by s390utils
|
|
|
|
kdump_setup_znet() {
|
|
|
|
kdump_setup_znet() {
|
|
|
|
local _netdev="$1"
|
|
|
|
local _config_file _unique_name _NM_conf_dir
|
|
|
|
local _conpath="$2"
|
|
|
|
local __sed_discard_ignored_files='/\(~\|\.bak\|\.old\|\.orig\|\.rpmnew\|\.rpmorig\|\.rpmsave\)$/d'
|
|
|
|
local s390_prefix="802-3-ethernet.s390-"
|
|
|
|
|
|
|
|
local _options=""
|
|
|
|
if [[ "$(uname -m)" != "s390x" ]]; then
|
|
|
|
local NETTYPE
|
|
|
|
return
|
|
|
|
local SUBCHANNELS
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
NETTYPE=$(get_nmcli_field_by_conpath "${s390_prefix}nettype" "$_conpath")
|
|
|
|
|
|
|
|
SUBCHANNELS=$(get_nmcli_field_by_conpath "${s390_prefix}subchannels" "$_conpath")
|
|
|
|
|
|
|
|
_options=$(get_nmcli_field_by_conpath "${s390_prefix}options" "$_conpath")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [[ -z $NETTYPE || -z $SUBCHANNELS || -z $_options ]]; then
|
|
|
|
|
|
|
|
dwarning "Failed to get znet configuration via nmlci output. Now try sourcing ifcfg script."
|
|
|
|
|
|
|
|
source_ifcfg_file "$_netdev"
|
|
|
|
|
|
|
|
for i in $OPTIONS; do
|
|
|
|
|
|
|
|
_options=${_options},$i
|
|
|
|
|
|
|
|
done
|
|
|
|
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
if [[ -z $NETTYPE || -z $SUBCHANNELS || -z $_options ]]; then
|
|
|
|
_NM_conf_dir="/etc/NetworkManager/system-connections"
|
|
|
|
exit 1
|
|
|
|
|
|
|
|
|
|
|
|
_config_file=$(_find_znet_nmconnection "$initdir/$_NM_conf_dir" "$__sed_discard_ignored_files")
|
|
|
|
|
|
|
|
if [[ -n "$_config_file" ]]; then
|
|
|
|
|
|
|
|
ddebug "$_config_file has already contained the znet config"
|
|
|
|
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
echo "rd.znet=${NETTYPE},${SUBCHANNELS},${_options} rd.znet_ifname=$_netdev:${SUBCHANNELS}" > "${initdir}/etc/cmdline.d/30znet.conf"
|
|
|
|
_config_file=$(LANG=C grep -s -E -i -l \
|
|
|
|
}
|
|
|
|
"^[[:space:]]*SUBCHANNELS=['\"]?([0-9]\.[0-9]\.[a-f0-9]+,){0,2}" \
|
|
|
|
|
|
|
|
/etc/sysconfig/network-scripts/ifcfg-* \
|
|
|
|
|
|
|
|
| LC_ALL=C sed -e "$__sed_discard_ignored_files")
|
|
|
|
|
|
|
|
|
|
|
|
kdump_get_ip_route() {
|
|
|
|
if [[ -z "$_config_file" ]]; then
|
|
|
|
local _route
|
|
|
|
_config_file=$(_find_znet_nmconnection "$_NM_conf_dir" "$__sed_discard_ignored_files")
|
|
|
|
if ! _route=$(/sbin/ip -o route get to "$1" 2>&1); then
|
|
|
|
fi
|
|
|
|
derror "Bad kdump network destination: $1"
|
|
|
|
|
|
|
|
exit 1
|
|
|
|
if [[ -n "$_config_file" ]]; then
|
|
|
|
|
|
|
|
_unique_name=$(cat /proc/sys/kernel/random/uuid)
|
|
|
|
|
|
|
|
nmcli connection clone --temporary "$_config_file" "$_unique_name" &> >(ddebug)
|
|
|
|
|
|
|
|
nmcli connection modify --temporary "$_unique_name" connection.autoconnect false
|
|
|
|
|
|
|
|
inst "/run/NetworkManager/system-connections/${_unique_name}.nmconnection" "${_NM_conf_dir}/${_unique_name}.nmconnection"
|
|
|
|
|
|
|
|
nmcli connection del "$_unique_name" &> >(ddebug)
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
echo "$_route"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
kdump_get_ip_route_field() {
|
|
|
|
|
|
|
|
echo "$1" | sed -n -e "s/^.*\<$2\>\s\+\(\S\+\).*$/\1/p"
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
kdump_get_remote_ip() {
|
|
|
|
kdump_get_remote_ip() {
|
|
|
@ -527,83 +532,55 @@ kdump_get_remote_ip() {
|
|
|
|
echo "$_remote"
|
|
|
|
echo "$_remote"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# Setup dracut to bring up network interface that enable
|
|
|
|
# Collect netifs needed by kdump
|
|
|
|
# initramfs accessing giving destination
|
|
|
|
|
|
|
|
# $1: destination host
|
|
|
|
# $1: destination host
|
|
|
|
kdump_install_net() {
|
|
|
|
kdump_collect_netif_usage() {
|
|
|
|
local _destaddr _srcaddr _route _netdev _conpath kdumpnic
|
|
|
|
local _destaddr _srcaddr _route _netdev
|
|
|
|
local _static _proto _ip_conf _ip_opts _ifname_opts
|
|
|
|
|
|
|
|
local _znet_netdev _znet_conpath
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_destaddr=$(kdump_get_remote_ip "$1")
|
|
|
|
_destaddr=$(kdump_get_remote_ip "$1")
|
|
|
|
_route=$(kdump_get_ip_route "$_destaddr")
|
|
|
|
_route=$(kdump_get_ip_route "$_destaddr")
|
|
|
|
_srcaddr=$(kdump_get_ip_route_field "$_route" "src")
|
|
|
|
_srcaddr=$(kdump_get_ip_route_field "$_route" "src")
|
|
|
|
_netdev=$(kdump_get_ip_route_field "$_route" "dev")
|
|
|
|
_netdev=$(kdump_get_ip_route_field "$_route" "dev")
|
|
|
|
_conpath=$(get_nmcli_connection_apath_by_ifname "$_netdev")
|
|
|
|
|
|
|
|
_netmac=$(kdump_get_mac_addr "$_netdev")
|
|
|
|
|
|
|
|
kdumpnic=$(kdump_setup_ifname "$_netdev")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_znet_netdev=$(find_online_znet_device)
|
|
|
|
|
|
|
|
if [[ -n $_znet_netdev ]]; then
|
|
|
|
|
|
|
|
_znet_conpath=$(get_nmcli_connection_apath_by_ifname "$_znet_netdev")
|
|
|
|
|
|
|
|
if ! (kdump_setup_znet "$_znet_netdev" "$_znet_conpath"); then
|
|
|
|
|
|
|
|
derror "Failed to set up znet"
|
|
|
|
|
|
|
|
exit 1
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_static=$(kdump_static_ip "$_netdev" "$_srcaddr" "$kdumpnic")
|
|
|
|
|
|
|
|
if [[ -n $_static ]]; then
|
|
|
|
|
|
|
|
_proto=none
|
|
|
|
|
|
|
|
elif is_ipv6_address "$_srcaddr"; then
|
|
|
|
|
|
|
|
_proto=auto6
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
_proto=dhcp
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_ip_conf="${initdir}/etc/cmdline.d/40ip.conf"
|
|
|
|
|
|
|
|
_ip_opts=" ip=${_static}$kdumpnic:${_proto}"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# dracut doesn't allow duplicated configuration for same NIC, even they're exactly the same.
|
|
|
|
|
|
|
|
# so we have to avoid adding duplicates
|
|
|
|
|
|
|
|
# We should also check /proc/cmdline for existing ip=xx arg.
|
|
|
|
|
|
|
|
# For example, iscsi boot will specify ip=xxx arg in cmdline.
|
|
|
|
|
|
|
|
if [[ ! -f $_ip_conf ]] || ! grep -q "$_ip_opts" "$_ip_conf" \
|
|
|
|
|
|
|
|
&& ! grep -q "ip=[^[:space:]]*$_netdev" /proc/cmdline; then
|
|
|
|
|
|
|
|
echo "$_ip_opts" >> "$_ip_conf"
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if kdump_is_bridge "$_netdev"; then
|
|
|
|
if kdump_is_bridge "$_netdev"; then
|
|
|
|
kdump_setup_bridge "$_netdev"
|
|
|
|
kdump_setup_bridge "$_netdev"
|
|
|
|
elif kdump_is_bond "$_netdev"; then
|
|
|
|
elif kdump_is_bond "$_netdev"; then
|
|
|
|
(kdump_setup_bond "$_netdev" "$_conpath") || exit 1
|
|
|
|
kdump_setup_bond "$_netdev" || return 1
|
|
|
|
elif kdump_is_team "$_netdev"; then
|
|
|
|
elif kdump_is_team "$_netdev"; then
|
|
|
|
kdump_setup_team "$_netdev"
|
|
|
|
kdump_setup_team "$_netdev"
|
|
|
|
elif kdump_is_vlan "$_netdev"; then
|
|
|
|
elif kdump_is_vlan "$_netdev"; then
|
|
|
|
kdump_setup_vlan "$_netdev"
|
|
|
|
kdump_setup_vlan "$_netdev"
|
|
|
|
else
|
|
|
|
|
|
|
|
_ifname_opts=" ifname=$kdumpnic:$_netmac"
|
|
|
|
|
|
|
|
echo "$_ifname_opts" >> "$_ip_conf"
|
|
|
|
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
_save_kdump_netifs "$_netdev"
|
|
|
|
kdump_setup_dns "$_netdev" "$_conpath"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [[ ! -f ${initdir}/etc/cmdline.d/50neednet.conf ]]; then
|
|
|
|
if [[ ! -f ${initdir}/etc/cmdline.d/50neednet.conf ]]; then
|
|
|
|
# network-manager module needs this parameter
|
|
|
|
# network-manager module needs this parameter
|
|
|
|
echo "rd.neednet" >> "${initdir}/etc/cmdline.d/50neednet.conf"
|
|
|
|
echo "rd.neednet" >> "${initdir}/etc/cmdline.d/50neednet.conf"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
# Save netdev used for kdump as cmdline
|
|
|
|
if [[ ! -f ${initdir}/etc/cmdline.d/60kdumpip.conf ]]; then
|
|
|
|
# Whoever calling kdump_install_net() is setting up the default gateway,
|
|
|
|
echo "kdump_remote_ip=$_destaddr" > "${initdir}/etc/cmdline.d/60kdumpip.conf"
|
|
|
|
# ie. bootdev/kdumpnic. So don't override the setting if calling
|
|
|
|
fi
|
|
|
|
# kdump_install_net() for another time. For example, after setting eth0 as
|
|
|
|
|
|
|
|
# the default gate way for network dump, eth1 in the fence kdump path will
|
|
|
|
if is_ipv6_address "$_srcaddr"; then
|
|
|
|
# call kdump_install_net again and we don't want eth1 to be the default
|
|
|
|
ipv6_usage[$_netdev]=1
|
|
|
|
# gateway.
|
|
|
|
else
|
|
|
|
if [[ ! -f ${initdir}/etc/cmdline.d/60kdumpnic.conf ]] \
|
|
|
|
ipv4_usage[$_netdev]=1
|
|
|
|
&& [[ ! -f ${initdir}/etc/cmdline.d/70bootdev.conf ]]; then
|
|
|
|
fi
|
|
|
|
echo "kdumpnic=$kdumpnic" > "${initdir}/etc/cmdline.d/60kdumpnic.conf"
|
|
|
|
}
|
|
|
|
echo "bootdev=$kdumpnic" > "${initdir}/etc/cmdline.d/70bootdev.conf"
|
|
|
|
|
|
|
|
|
|
|
|
# Setup dracut to bring up network interface that enable
|
|
|
|
|
|
|
|
# initramfs accessing giving destination
|
|
|
|
|
|
|
|
kdump_install_net() {
|
|
|
|
|
|
|
|
local _netifs
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_netifs=$(_get_kdump_netifs)
|
|
|
|
|
|
|
|
if [[ -n "$_netifs" ]]; then
|
|
|
|
|
|
|
|
kdump_install_nmconnections
|
|
|
|
|
|
|
|
apply_nm_initrd_generator_timeouts
|
|
|
|
|
|
|
|
kdump_setup_znet
|
|
|
|
|
|
|
|
kdump_install_nm_netif_allowlist "$_netifs"
|
|
|
|
|
|
|
|
kdump_install_nic_driver "$_netifs"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -642,7 +619,7 @@ default_dump_target_install_conf() {
|
|
|
|
|
|
|
|
|
|
|
|
_fstype=$(get_fs_type_from_target "$_target")
|
|
|
|
_fstype=$(get_fs_type_from_target "$_target")
|
|
|
|
if is_fs_type_nfs "$_fstype"; then
|
|
|
|
if is_fs_type_nfs "$_fstype"; then
|
|
|
|
kdump_install_net "$_target"
|
|
|
|
kdump_collect_netif_usage "$_target"
|
|
|
|
_fstype="nfs"
|
|
|
|
_fstype="nfs"
|
|
|
|
else
|
|
|
|
else
|
|
|
|
_target=$(kdump_get_persistent_dev "$_target")
|
|
|
|
_target=$(kdump_get_persistent_dev "$_target")
|
|
|
@ -673,16 +650,16 @@ kdump_install_conf() {
|
|
|
|
_pdev=$(persistent_policy="by-id" kdump_get_persistent_dev "$_val")
|
|
|
|
_pdev=$(persistent_policy="by-id" kdump_get_persistent_dev "$_val")
|
|
|
|
sed -i -e "s#^${_opt}[[:space:]]\+$_val#$_opt $_pdev#" "${initdir}/tmp/$$-kdump.conf"
|
|
|
|
sed -i -e "s#^${_opt}[[:space:]]\+$_val#$_opt $_pdev#" "${initdir}/tmp/$$-kdump.conf"
|
|
|
|
;;
|
|
|
|
;;
|
|
|
|
ext[234] | xfs | btrfs | minix)
|
|
|
|
ext[234] | xfs | btrfs | minix | virtiofs)
|
|
|
|
_pdev=$(kdump_get_persistent_dev "$_val")
|
|
|
|
_pdev=$(kdump_get_persistent_dev "$_val")
|
|
|
|
sed -i -e "s#^${_opt}[[:space:]]\+$_val#$_opt $_pdev#" "${initdir}/tmp/$$-kdump.conf"
|
|
|
|
sed -i -e "s#^${_opt}[[:space:]]\+$_val#$_opt $_pdev#" "${initdir}/tmp/$$-kdump.conf"
|
|
|
|
;;
|
|
|
|
;;
|
|
|
|
ssh | nfs)
|
|
|
|
ssh | nfs)
|
|
|
|
kdump_install_net "$_val"
|
|
|
|
kdump_collect_netif_usage "$_val"
|
|
|
|
;;
|
|
|
|
;;
|
|
|
|
dracut_args)
|
|
|
|
dracut_args)
|
|
|
|
if [[ $(get_dracut_args_fstype "$_val") == nfs* ]]; then
|
|
|
|
if [[ $(get_dracut_args_fstype "$_val") == nfs* ]]; then
|
|
|
|
kdump_install_net "$(get_dracut_args_target "$_val")"
|
|
|
|
kdump_collect_netif_usage "$(get_dracut_args_target "$_val")"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
;;
|
|
|
|
kdump_pre | kdump_post | extra_bins)
|
|
|
|
kdump_pre | kdump_post | extra_bins)
|
|
|
@ -804,7 +781,7 @@ kdump_setup_iscsi_device() {
|
|
|
|
|
|
|
|
|
|
|
|
[[ -n $username_in ]] && userpwd_in_str=":$username_in:$password_in"
|
|
|
|
[[ -n $username_in ]] && userpwd_in_str=":$username_in:$password_in"
|
|
|
|
|
|
|
|
|
|
|
|
kdump_install_net "$tgt_ipaddr"
|
|
|
|
kdump_collect_netif_usage "$tgt_ipaddr"
|
|
|
|
|
|
|
|
|
|
|
|
# prepare netroot= command line
|
|
|
|
# prepare netroot= command line
|
|
|
|
# FIXME: Do we need to parse and set other parameters like protocol, port
|
|
|
|
# FIXME: Do we need to parse and set other parameters like protocol, port
|
|
|
@ -840,7 +817,7 @@ kdump_check_iscsi_targets() {
|
|
|
|
# If our prerequisites are not met, fail anyways.
|
|
|
|
# If our prerequisites are not met, fail anyways.
|
|
|
|
type -P iscsistart > /dev/null || return 1
|
|
|
|
type -P iscsistart > /dev/null || return 1
|
|
|
|
|
|
|
|
|
|
|
|
kdump_check_setup_iscsi() (
|
|
|
|
kdump_check_setup_iscsi() {
|
|
|
|
local _dev
|
|
|
|
local _dev
|
|
|
|
_dev=$1
|
|
|
|
_dev=$1
|
|
|
|
|
|
|
|
|
|
|
@ -850,7 +827,7 @@ kdump_check_iscsi_targets() {
|
|
|
|
cd ..
|
|
|
|
cd ..
|
|
|
|
done
|
|
|
|
done
|
|
|
|
[[ -d iscsi_session ]] && kdump_setup_iscsi_device "$PWD"
|
|
|
|
[[ -d iscsi_session ]] && kdump_setup_iscsi_device "$PWD"
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
[[ $hostonly ]] || [[ $mount_needs ]] && {
|
|
|
|
[[ $hostonly ]] || [[ $mount_needs ]] && {
|
|
|
|
for_each_host_dev_and_slaves_all kdump_check_setup_iscsi
|
|
|
|
for_each_host_dev_and_slaves_all kdump_check_setup_iscsi
|
|
|
@ -968,7 +945,7 @@ kdump_configure_fence_kdump() {
|
|
|
|
|
|
|
|
|
|
|
|
# setup network for each node
|
|
|
|
# setup network for each node
|
|
|
|
for node in ${nodes}; do
|
|
|
|
for node in ${nodes}; do
|
|
|
|
kdump_install_net "$node"
|
|
|
|
kdump_collect_netif_usage "$node"
|
|
|
|
done
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
|
|
dracut_install /etc/hosts
|
|
|
|
dracut_install /etc/hosts
|
|
|
@ -1017,6 +994,7 @@ remove_cpu_online_rule() {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
install() {
|
|
|
|
install() {
|
|
|
|
|
|
|
|
declare -A unique_netifs ipv4_usage ipv6_usage
|
|
|
|
local arch
|
|
|
|
local arch
|
|
|
|
|
|
|
|
|
|
|
|
kdump_module_init
|
|
|
|
kdump_module_init
|
|
|
@ -1076,6 +1054,8 @@ install() {
|
|
|
|
inst "ip"
|
|
|
|
inst "ip"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
kdump_install_net
|
|
|
|
|
|
|
|
|
|
|
|
# For the lvm type target under kdump, in /etc/lvm/lvm.conf we can
|
|
|
|
# For the lvm type target under kdump, in /etc/lvm/lvm.conf we can
|
|
|
|
# safely replace "reserved_memory=XXXX"(default value is 8192) with
|
|
|
|
# safely replace "reserved_memory=XXXX"(default value is 8192) with
|
|
|
|
# "reserved_memory=1024" to lower memory pressure under kdump. We do
|
|
|
|
# "reserved_memory=1024" to lower memory pressure under kdump. We do
|
|
|
|