mirror of
				https://github.com/tailscale/tailscale.git
				synced 2025-10-25 18:20:07 +00:00 
			
		
		
		
	wgengine/magicsock: check all 3 fast paths independently.
The previous code would skip the DERP short-circuit if roamAddr was set, which is not what we wanted. More generally, hitting any of the fast path conditions is a direct return, so we can just have 3 standalone branches rather than 'else if' stuff. Signed-Off-By: David Anderson <danderson@tailscale.com>
This commit is contained in:
		 David Anderson
					David Anderson
				
			
				
					committed by
					
						 Dave Anderson
						Dave Anderson
					
				
			
			
				
	
			
			
			 Dave Anderson
						Dave Anderson
					
				
			
						parent
						
							05a52746a4
						
					
				
				
					commit
					ef31dd7bb5
				
			| @@ -1124,16 +1124,23 @@ func (a *AddrSet) SrcToString() string { return "" } | |||||||
| func (a *AddrSet) ClearSrc()           {} | func (a *AddrSet) ClearSrc()           {} | ||||||
|  |  | ||||||
| func (a *AddrSet) UpdateDst(new *net.UDPAddr) error { | func (a *AddrSet) UpdateDst(new *net.UDPAddr) error { | ||||||
|  | 	if new.IP.Equal(derpMagicIP) { | ||||||
|  | 		// Never consider DERP addresses as a viable candidate for | ||||||
|  | 		// either curAddr or roamAddr. It's only ever a last resort | ||||||
|  | 		// choice, never a preferred choice. | ||||||
|  | 		// This is a hot path for established connections. | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	a.mu.Lock() | 	a.mu.Lock() | ||||||
| 	defer a.mu.Unlock() | 	defer a.mu.Unlock() | ||||||
|  |  | ||||||
| 	if a.roamAddr != nil { | 	if a.roamAddr != nil && equalUDPAddr(new, a.roamAddr) { | ||||||
| 		if equalUDPAddr(a.roamAddr, new) { |  | ||||||
| 		// Packet from the current roaming address, no logging. | 		// Packet from the current roaming address, no logging. | ||||||
| 		// This is a hot path for established connections. | 		// This is a hot path for established connections. | ||||||
| 		return nil | 		return nil | ||||||
| 	} | 	} | ||||||
| 	} else if a.curAddr >= 0 && equalUDPAddr(new, &a.addrs[a.curAddr]) { | 	if a.curAddr >= 0 && equalUDPAddr(new, &a.addrs[a.curAddr]) { | ||||||
| 		// Packet from current-priority address, no logging. | 		// Packet from current-priority address, no logging. | ||||||
| 		// This is a hot path for established connections. | 		// This is a hot path for established connections. | ||||||
| 		return nil | 		return nil | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user