summaryrefslogtreecommitdiffstats
path: root/src/lib
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/connections/bridge19
1 files changed, 9 insertions, 10 deletions
diff --git a/src/lib/connections/bridge b/src/lib/connections/bridge
index 94a9b64..3b0a94b 100644
--- a/src/lib/connections/bridge
+++ b/src/lib/connections/bridge
@@ -2,7 +2,6 @@
. "$SUBR_DIR/ip"
-: ${BRCTL:=brctl}
declare -ag BindsToInterfaces
bridge_up() {
@@ -12,17 +11,17 @@ bridge_up() {
return 1
fi
else
- $BRCTL addbr "$Interface"
+ ip link add name "$Interface" type bridge
fi
for member in "${BindsToInterfaces[@]}"; do
- ip link set "$member" promisc on up
- ip addr flush dev "$member"
- $BRCTL addif "$Interface" "$member"
+ ip link set dev "$member" promisc on up
+ ip addr flush dev "$member" scope host &>/dev/null
+ ip addr flush dev "$member" scope site &>/dev/null
+ ip addr flush dev "$member" scope global &>/dev/null
+ ip link set dev "member" master "$Interface"
+ is_yes "${SkipForwardingDelay:-no}" && bridge link set dev "$member" state 3
done
- # Set options
- [[ "$FwdDelay" ]] && $BRCTL setfd "$Interface" "$FwdDelay"
- [[ "$MaxAge" ]] && $BRCTL setmaxage "$Interface" "$MaxAge"
bring_interface_up "$Interface"
ip_set
@@ -31,12 +30,12 @@ bridge_up() {
bridge_down() {
for member in "${BindsToInterfaces[@]}"; do
ip link set "$member" promisc off down
- $BRCTL delif "$Interface" "$member"
+ ip link set dev "$member" nomaster
done
ip_unset
bring_interface_down "$Interface"
- $BRCTL delbr "$Interface"
+ ip link delete "$Interface" type bridge
}