ibmvnic: Properly dispose of all skbs during a failover.
[ Upstream commit 1b18f09d31cfa7148df15a7d5c5e0e86f105f7d1 ]
During a reset, there may have been transmits in flight that are no
longer valid and cannot be fulfilled.  Resetting and clearing the
queues is insufficient; each skb also needs to be explicitly freed
so that upper levels are not left waiting for confirmation of a
transmit that will never happen.  If this happens frequently enough,
the apparent backlog will cause TCP to begin "congestion control"
unnecessarily, culminating in permanently decreased throughput.
Fixes: d7c0ef36bd ("ibmvnic: Free and re-allocate scrqs when tx/rx scrqs change")
Tested-by: Nick Child <nnac123@linux.ibm.com>
Reviewed-by: Brian King <brking@linux.vnet.ibm.com>
Signed-off-by: Rick Lindsley <ricklind@us.ibm.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
			
			
This commit is contained in:
		 Rick Lindsley
					Rick Lindsley
				
			
				
					committed by
					
						 Greg Kroah-Hartman
						Greg Kroah-Hartman
					
				
			
			
				
	
			
			
			 Greg Kroah-Hartman
						Greg Kroah-Hartman
					
				
			
						parent
						
							2b4659c145
						
					
				
				
					commit
					23cdc57d88
				
			| @@ -5228,6 +5228,15 @@ static int ibmvnic_reset_init(struct ibmvnic_adapter *adapter, bool reset) | ||||
| 			release_sub_crqs(adapter, 0); | ||||
| 			rc = init_sub_crqs(adapter); | ||||
| 		} else { | ||||
| 			/* no need to reinitialize completely, but we do
 | ||||
| 			 * need to clean up transmits that were in flight | ||||
| 			 * when we processed the reset.  Failure to do so | ||||
| 			 * will confound the upper layer, usually TCP, by | ||||
| 			 * creating the illusion of transmits that are | ||||
| 			 * awaiting completion. | ||||
| 			 */ | ||||
| 			clean_tx_pools(adapter); | ||||
| 
 | ||||
| 			rc = reset_sub_crq_queues(adapter); | ||||
| 		} | ||||
| 	} else { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user