summaryrefslogtreecommitdiffstats
path: root/src/lib
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/connections/bridge19
-rw-r--r--src/lib/connections/wireless2
-rw-r--r--src/lib/wpa3
3 files changed, 11 insertions, 13 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
}
diff --git a/src/lib/connections/wireless b/src/lib/connections/wireless
index fe01b90..870af51 100644
--- a/src/lib/connections/wireless
+++ b/src/lib/connections/wireless
@@ -17,7 +17,7 @@ wireless_up() {
: ${Security:=none}
: ${WPADriver:=nl80211,wext}
: ${TimeoutWPA:=15}
-
+
if [[ $RFKill ]]; then
enable_rf "$Interface" "$RFKill" || return 1
fi
diff --git a/src/lib/wpa b/src/lib/wpa
index ca9b83e..d79fdbe 100644
--- a/src/lib/wpa
+++ b/src/lib/wpa
@@ -12,8 +12,7 @@ wpa_call() {
if [[ $WPA_CTRL_DIR ]]; then
args+=("-p" "$WPA_CTRL_DIR")
elif [[ $WPAConfigFile ]] && grep -q "^[[:space:]]*ctrl_interface=" "$WPAConfigFile"; then
- WPA_CTRL_DIR=$(grep -m1 "^[[:space:]]*ctrl_interface=" "$WPAConfigFile")
- WPA_CTRL_DIR=${WPA_CTRL_DIR#*ctrl_interface=}
+ WPA_CTRL_DIR=$(sed -n "0,/^[[:space:]]*ctrl_interface=/s///p" "$WPAConfigFile")
if [[ $WPA_CTRL_DIR == DIR=* ]]; then
WPA_CTRL_DIR=${WPA_CTRL_DIR:4}
WPA_CTRL_DIR=${WPA_CTRL_DIR%% GROUP=*}