mirror of
				https://passt.top/passt
				synced 2025-10-26 00:59:13 +02:00 
			
		
		
		
	flow: Clarify and enforce flow state transitions
Flows move over several different states in their lifetime. The rules for these are documented in comments, but they're pretty complex and a number of the transitions are implicit, which makes this pretty fragile and error prone. Change the code to explicitly track the states in a field. Make all transitions explicit and logged. To the extent that it's practical in C, enforce what can and can't be done in various states with ASSERT()s. While we're at it, tweak the docs to clarify the restrictions on each state a bit. Signed-off-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
This commit is contained in:
		
					parent
					
						
							
								a63199832a
							
						
					
				
			
			
				commit
				
					
						0060acd11b
					
				
			
		
					 6 changed files with 183 additions and 69 deletions
				
			
		
							
								
								
									
										8
									
								
								tcp.c
									
										
									
									
									
								
							
							
						
						
									
										8
									
								
								tcp.c
									
										
									
									
									
								
							|  | @ -2004,7 +2004,7 @@ static void tcp_conn_from_tap(struct ctx *c, sa_family_t af, | |||
| 			goto cancel; | ||||
| 	} | ||||
| 
 | ||||
| 	conn = FLOW_START(flow, FLOW_TCP, tcp, TAPSIDE); | ||||
| 	conn = FLOW_SET_TYPE(flow, FLOW_TCP, tcp, TAPSIDE); | ||||
| 	conn->sock = s; | ||||
| 	conn->timer = -1; | ||||
| 	conn_event(c, conn, TAP_SYN_RCVD); | ||||
|  | @ -2075,6 +2075,7 @@ static void tcp_conn_from_tap(struct ctx *c, sa_family_t af, | |||
| 	} | ||||
| 
 | ||||
| 	tcp_epoll_ctl(c, conn); | ||||
| 	FLOW_ACTIVATE(conn); | ||||
| 	return; | ||||
| 
 | ||||
| cancel: | ||||
|  | @ -2715,7 +2716,8 @@ static void tcp_tap_conn_from_sock(struct ctx *c, in_port_t dstport, | |||
| 				   const union sockaddr_inany *sa, | ||||
| 				   const struct timespec *now) | ||||
| { | ||||
| 	struct tcp_tap_conn *conn = FLOW_START(flow, FLOW_TCP, tcp, SOCKSIDE); | ||||
| 	struct tcp_tap_conn *conn = FLOW_SET_TYPE(flow, FLOW_TCP, tcp, | ||||
| 						  SOCKSIDE); | ||||
| 
 | ||||
| 	conn->sock = s; | ||||
| 	conn->timer = -1; | ||||
|  | @ -2738,6 +2740,8 @@ static void tcp_tap_conn_from_sock(struct ctx *c, in_port_t dstport, | |||
| 	conn_flag(c, conn, ACK_FROM_TAP_DUE); | ||||
| 
 | ||||
| 	tcp_get_sndbuf(conn); | ||||
| 
 | ||||
| 	FLOW_ACTIVATE(conn); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 David Gibson
				David Gibson