wgengine/magicsock: shortcircuit discoEndpoint.heartbeat when its connection is closed

This prevents us from continuing to do unnecessary work
(including logging) after the connection has closed.

Signed-off-by: Josh Bleecher Snyder <josh@tailscale.com>
This commit is contained in:
Josh Bleecher Snyder 2021-01-14 16:52:50 -08:00 committed by Josh Bleecher Snyder
parent 7c76435bf7
commit 08baa17d9a

View File

@ -2280,6 +2280,13 @@ func (c *Conn) Close() error {
return err return err
} }
// isClosed reports whether c is closed.
func (c *Conn) isClosed() bool {
c.mu.Lock()
defer c.mu.Unlock()
return c.closed
}
func (c *Conn) goroutinesRunningLocked() bool { func (c *Conn) goroutinesRunningLocked() bool {
if c.endpointsUpdateActive { if c.endpointsUpdateActive {
return true return true
@ -3017,6 +3024,10 @@ func (de *discoEndpoint) heartbeat() {
de.heartBeatTimer = nil de.heartBeatTimer = nil
if de.c.isClosed() {
return
}
if de.lastSend.IsZero() { if de.lastSend.IsZero() {
// Shouldn't happen. // Shouldn't happen.
return return