From 39e52c4b0a7d9a755f47e06205c8e9fd5fae5ba4 Mon Sep 17 00:00:00 2001 From: Jordan Whited Date: Mon, 30 Jan 2023 22:38:20 -0800 Subject: [PATCH] wgengine/magicsock: fix de-dup disco ping handling for netmap endpoints (#7118) Fixes #7116 Signed-off-by: Jordan Whited --- wgengine/magicsock/magicsock.go | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/wgengine/magicsock/magicsock.go b/wgengine/magicsock/magicsock.go index 74c28853e..dda3b5df9 100644 --- a/wgengine/magicsock/magicsock.go +++ b/wgengine/magicsock/magicsock.go @@ -3747,10 +3747,10 @@ type endpointState struct { // updated and use it to discard old candidates. lastGotPing time.Time - // lastGotPingTxID, if lastGotPing is non-zero, contains the TxID for the - // last incoming ping. This is used to de-dup incoming pings that we may - // see on both the raw disco socket on Linux, and UDP socket. We cannot rely - // solely on the raw socket disco handling due to https://github.com/tailscale/tailscale/issues/7078. + // lastGotPingTxID contains the TxID for the last incoming ping. This is + // used to de-dup incoming pings that we may see on both the raw disco + // socket on Linux, and UDP socket. We cannot rely solely on the raw socket + // disco handling due to https://github.com/tailscale/tailscale/issues/7078. lastGotPingTxID stun.TxID // callMeMaybeTime, if non-zero, is the time this endpoint @@ -4219,16 +4219,16 @@ func (de *endpoint) addCandidateEndpoint(ep netip.AddrPort, forRxPingTxID stun.T defer de.mu.Unlock() if st, ok := de.endpointState[ep]; ok { + duplicatePing = forRxPingTxID == st.lastGotPingTxID + if !duplicatePing { + st.lastGotPingTxID = forRxPingTxID + } if st.lastGotPing.IsZero() { // Already-known endpoint from the network map. - return false - } - if forRxPingTxID == st.lastGotPingTxID { - return true + return duplicatePing } st.lastGotPing = time.Now() - st.lastGotPingTxID = forRxPingTxID - return false + return duplicatePing } // Newly discovered endpoint. Exciting!