From bd59bba8e60112b283123d9cd107d3f5adbab5c4 Mon Sep 17 00:00:00 2001 From: Brad Fitzpatrick Date: Wed, 8 Jul 2020 16:50:31 -0700 Subject: [PATCH] wgengine/magicsock: stop discoEndpoint timers on Close And add some defensive early returns on c.closed. --- wgengine/magicsock/magicsock.go | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/wgengine/magicsock/magicsock.go b/wgengine/magicsock/magicsock.go index 83df340a9..22c49a7b1 100644 --- a/wgengine/magicsock/magicsock.go +++ b/wgengine/magicsock/magicsock.go @@ -1400,6 +1400,10 @@ func (c *Conn) ReceiveIPv6(b []byte) (int, conn.Endpoint, *net.UDPAddr, error) { func (c *Conn) sendDiscoMessage(dst netaddr.IPPort, dstKey key.Public, dstDisco tailcfg.DiscoKey, m disco.Message) (sent bool, err error) { c.mu.Lock() + if c.closed { + c.mu.Unlock() + return false, errClosed + } var nonce [disco.NonceLen]byte if _, err := crand.Read(nonce[:]); err != nil { panic(err) // worth dying for @@ -1446,6 +1450,9 @@ func (c *Conn) handleDiscoMessage(msg []byte, src netaddr.IPPort) bool { c.mu.Lock() defer c.mu.Unlock() + if c.closed { + return true + } if logDisco { c.logf("magicsock: disco: got disco-looking frame from %v", sender.ShortString()) } @@ -1860,6 +1867,10 @@ func (c *Conn) Close() error { } defer c.mu.Unlock() + for _, ep := range c.endpointOfDisco { + ep.cleanup() + } + c.closed = true c.connCtxCancel() c.closeAllDerpLocked("conn-close") @@ -3191,3 +3202,5 @@ type ippCacheKey struct { // derpStr replaces DERP IPs in s with "derp-". func derpStr(s string) string { return strings.ReplaceAll(s, "127.3.3.40:", "derp-") } + +var errClosed = errors.New("conn is closed")