Prevent tinc from forgeting e->local_address
If ADD_EDGE came from tinc version 1.0.x local_address.sa.sa_family is set to 0. If it came from tinc version 1.1.x forwarded for older verion it will be 255 - AF_UNKNOWN.
This commit is contained in:
		
							parent
							
								
									5ae403f9e6
								
							
						
					
					
						commit
						06d4eac9ac
					
				
					 1 changed files with 4 additions and 1 deletions
				
			
		| 
						 | 
				
			
			@ -158,8 +158,11 @@ bool add_edge_h(connection_t *c, const char *request) {
 | 
			
		|||
				// Otherwise, just ignore it.
 | 
			
		||||
				sockaddrfree(&local_address);
 | 
			
		||||
				return true;
 | 
			
		||||
			} else if(local_address.sa.sa_family) {
 | 
			
		||||
			} else if(local_address.sa.sa_family && local_address.sa.sa_family != AF_UNKNOWN) {
 | 
			
		||||
				// We learned a new local address for this edge.
 | 
			
		||||
				// local_address.sa.sa_family will be 0 if we got it from older tinc versions
 | 
			
		||||
				// local_address.sa.sa_family will be 255 (AF_UNKNOWN) if we got it from newer versions
 | 
			
		||||
				// but for edge which does not have local_address
 | 
			
		||||
				sockaddrfree(&e->local_address);
 | 
			
		||||
				e->local_address = local_address;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue