wgengine/magicsock: reset AddrSet states on Rebind

Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>
This commit is contained in:
Brad Fitzpatrick 2020-04-09 22:25:31 -07:00 committed by Brad Fitzpatrick
parent c0697e1feb
commit 614261d00d

View File

@ -584,6 +584,8 @@ func shouldSprayPacket(b []byte) bool {
var logPacketDests, _ = strconv.ParseBool(os.Getenv("DEBUG_LOG_PACKET_DESTS")) var logPacketDests, _ = strconv.ParseBool(os.Getenv("DEBUG_LOG_PACKET_DESTS"))
const sprayPeriod = 3 * time.Second
// appendDests appends to dsts the destinations that b should be // appendDests appends to dsts the destinations that b should be
// written to in order to reach as. Some of the returned UDPAddrs may // written to in order to reach as. Some of the returned UDPAddrs may
// be fake addrs representing DERP servers. // be fake addrs representing DERP servers.
@ -606,7 +608,6 @@ func (as *AddrSet) appendDests(dsts []*net.UDPAddr, b []byte) (_ []*net.UDPAddr,
// Multiple packets are necessary because we have to both establish the // Multiple packets are necessary because we have to both establish the
// NAT mappings between two peers *and use* the mappings to switch away // NAT mappings between two peers *and use* the mappings to switch away
// from DERP to a higher-priority UDP endpoint. // from DERP to a higher-priority UDP endpoint.
const sprayPeriod = 3 * time.Second
const sprayFreq = 250 * time.Millisecond const sprayFreq = 250 * time.Millisecond
if spray { if spray {
as.lastSpray = now as.lastSpray = now
@ -1477,6 +1478,20 @@ func (c *Conn) Rebind() {
return return
} }
c.pconn4.Reset(packetConn.(*net.UDPConn)) c.pconn4.Reset(packetConn.(*net.UDPConn))
c.resetAddrSetStates()
}
// resetAddrSetStates resets the preferred address for all peers and
// re-enables spraying.
// This is called when connectivity changes enough that we no longer
// trust the old routes.
func (c *Conn) resetAddrSetStates() {
c.mu.Lock()
defer c.mu.Unlock()
for _, as := range c.addrsByKey {
as.curAddr = -1
as.stopSpray = as.timeNow().Add(sprayPeriod)
}
} }
// AddrSet is a set of UDP addresses that implements wireguard/conn.Endpoint. // AddrSet is a set of UDP addresses that implements wireguard/conn.Endpoint.