diff options
author | Thomas Bächler <thomas@archlinux.org> | 2013-05-16 23:19:25 +0200 |
---|---|---|
committer | Jouke Witteveen <j.witteveen@gmail.com> | 2013-05-17 10:52:51 +0200 |
commit | 032dfba32c67ba59161a0856e8bc819fceefd1e0 (patch) | |
tree | c9a0e7327d68d1911b339ed84bd2a71114522729 | |
parent | 55adbd5a83f245af22896adb13fd120b6df0253d (diff) | |
download | netctl-032dfba32c67ba59161a0856e8bc819fceefd1e0.tar.gz netctl-032dfba32c67ba59161a0856e8bc819fceefd1e0.tar.xz |
Flush the interface configuration in ip_unset instead of bring_interface_down.
When switching networks in auto.action, the addresses are not flushed. This
is especially problematic with stateless ipv6 autoconfigutation, as invalid
IPs may stay around until their (potentially very long) lifetime has expired.
bring_interface_down is always called after ip_unset everywhere else, so
this change does not affect anything else.
V2: Make sure not to flush the link local address.
-rw-r--r-- | src/lib/ip | 5 | ||||
-rwxr-xr-x | src/lib/network | 1 |
2 files changed, 4 insertions, 2 deletions
@@ -175,7 +175,7 @@ ip_set() { } -## Clean up the dynamic part of an IP configuration +## Clean up the IP configuration # $Interface: interface name # $IP: type of IPv4 configuration # $IP6: type of IPv6 configuration @@ -202,6 +202,9 @@ ip_unset() { fi [[ $DNS ]] && resolvconf -d "$Interface" + ip addr flush dev "$Interface" scope host &>/dev/null + ip addr flush dev "$Interface" scope site &>/dev/null + ip addr flush dev "$Interface" scope global &>/dev/null } diff --git a/src/lib/network b/src/lib/network index 6ac9d75..7dfe0b5 100755 --- a/src/lib/network +++ b/src/lib/network @@ -31,7 +31,6 @@ bring_interface_up() { # $1: interface name bring_interface_down() { local interface=$1 - ip addr flush dev "$interface" &>/dev/null ip link set dev "$interface" down &>/dev/null # We reuse the up timeout (down normally is faster) timeout_wait "${TimeoutUp:-5}" '! interface_is_up "$interface"' |