diff options
author | Natanael Copa <ncopa@alpinelinux.org> | 2012-03-22 22:35:49 +0100 |
---|---|---|
committer | Natanael Copa <ncopa@alpinelinux.org> | 2012-03-22 22:35:49 +0100 |
commit | 3b0ca46fbbcf5bbbb79abbc16856dfc7bd12dc76 (patch) | |
tree | c12c54726e0e3e6a920e01aa50a46a7c268928f9 | |
parent | 3638145ad0c6ac3c1eff011e58b233cc5c0a7ce1 (diff) | |
download | alpine-conf-3b0ca46fbbcf5bbbb79abbc16856dfc7bd12dc76.zip |
setup-interfaces: initial bonding support
-rwxr-xr-x | setup-interfaces.in | 64 |
1 files changed, 60 insertions, 4 deletions
diff --git a/setup-interfaces.in b/setup-interfaces.in index fc86223..042475e 100755 --- a/setup-interfaces.in +++ b/setup-interfaces.in @@ -131,6 +131,10 @@ config_iface() { bridge_ports=$(echo $(cat $iface.bridge_ports)) echo "bridge_ports=\"$bridge_ports\"" >> $conf fi + if [ -r "$iface.bond_slaves" ]; then + bond_slaves=$(echo $(cat $iface.bond_slaves)) + echo "bond_slaves=\"$bond_slaves\"" >> $conf + fi # use ipcalc to validate the address. we do accept /mask # we are no interested in the result, only error code, so # we send result to /dev/null @@ -200,13 +204,17 @@ config_iface() { } is_bridge() { - [ -e /sys/class/net/$1/bridge ] || [ -e $i.bridge_ports ] + [ -e /sys/class/net/$1/bridge ] || [ -e $1.bridge_ports ] +} + +is_bond_master() { + [ -e $1.bond_slaves ] } -unconfigured_non_bridges() { +unconfigured_available() { local local i= iflist= for i in $(unconfigured_list); do - if ! is_bridge $i; then + if ! is_bridge $i && ! is_bond_master $i; then iflist="${iflist}${iflist:+ }$i" fi done @@ -224,7 +232,7 @@ unconfigured_all_are() { config_bridge() { local bridge=$1 iflist= i= ports= while ! unconfigured_all_done; do - set -- $(unconfigured_non_bridges) + set -- $(unconfigured_available) [ $# -eq 0 ] && return 0; ports=$(bridge_list_ports $bridge) if [ -n "$ports" ]; then @@ -246,6 +254,47 @@ config_bridge() { done } +bond_add_slave() { + local master=$1 slave= + shift + for slave; do + echo $slave >> $master.bond_slaves + unconfigured_add $master + unconfigured_del $slave + done +} + +bond_list_slaves() { + if [ -r $1.bond_slaves ]; then + echo $(cat $1.bond_slaves) + fi +} + +config_bond() { + local master=$1 slaves= + while ! unconfigured_all_done; do + set -- $(unconfigured_available) + [ $# -eq 0 ] && return 0; + slaves=$(bond_list_slaves $master) + if [ -n "$slaves" ]; then + echo "Bond slaves in $master are: $slaves" + fi + echo "Available bond slaves are: $@" + ask "Which slave(s) do you want add to $master? (or 'done')" $1 + case $resp in + 'abort') return 1;; + 'done') return 0;; + esac + for i in $resp; do + if unconfigured_isin $i; then + bond_add_slave $master $i + else + echo "$i is not valid" + fi + done + done +} + usage() { cat <<__EOF__ usage: setup-interfaces [-bhi] [-p ROOT] @@ -278,6 +327,8 @@ prompt_for_interfaces() { "done") break;; br[0-9]*|bridge[0-9]*|virbr[0-9]*) config_bridge $iface || continue;; + bond[0-9]*) + config_bond $iface || continue;; *) unconfigured_isin $iface || continue;; esac config_iface $iface $(printf "%.3d~" $index) @@ -292,6 +343,7 @@ prompt_for_interfaces() { iface=`basename $i .conf` iface=${iface#[0-9]*~} bridge_ports= + bond_slaves= address= type= gateway= @@ -301,6 +353,9 @@ prompt_for_interfaces() { if [ -n "$bridge_ports" ]; then echo -e "\tbridge-ports $bridge_ports" >> interfaces fi + if [ -n "$bond_slaves" ]; then + echo -e "\tbond-slaves $bond_slaves" >> interfaces + fi case $type in dhcp) [ -n "$hostname" ] \ @@ -313,6 +368,7 @@ prompt_for_interfaces() { && echo -e "\tgateway $gateway" >> interfaces ;; esac + echo "" >> interfaces done while [ "$answer" != "yes" ] && [ "$answer" != "no" ] ; do |