ShellPkg/Ping: fix loss of first packet
Issue:
Reply for first ping packet was getting dropped.
Cause:
Sometimes reply message comes even before trasmit
function returns, hence missing 1st reply
Fix:
Prepare the TxList before calling Transmit function.
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Meenakshi Aggarwal <meenakshi.aggarwal@nxp.com>
Reviewed-by: Jaben Carsey <jaben.carsey@intel.com>
Reviewed-by: Ruiyu Ni <ruiyu.ni@intel.com>
(cherry picked from commit d624deb7ab)
			
			
This commit is contained in:
		
				
					committed by
					
						 Ruiyu Ni
						Ruiyu Ni
					
				
			
			
				
	
			
			
			
						parent
						
							a763560aa6
						
					
				
				
					commit
					3fca88b2b9
				
			| @@ -784,14 +784,17 @@ PingSendEchoRequest ( | ||||
|   } | ||||
|  | ||||
|   ASSERT(Private->ProtocolPointers.Transmit != NULL); | ||||
|  | ||||
|   InsertTailList (&Private->TxList, &TxInfo->Link); | ||||
|  | ||||
|   Status = Private->ProtocolPointers.Transmit (Private->IpProtocol, TxInfo->Token); | ||||
|  | ||||
|   if (EFI_ERROR (Status)) { | ||||
|     RemoveEntryList (&TxInfo->Link); | ||||
|     PingDestroyTxInfo (TxInfo, Private->IpChoice); | ||||
|     return Status; | ||||
|   } | ||||
|  | ||||
|   InsertTailList (&Private->TxList, &TxInfo->Link); | ||||
|   Private->TxCount++; | ||||
|  | ||||
|   return EFI_SUCCESS; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user