mirror of
				https://git.proxmox.com/git/mirror_edk2
				synced 2025-10-25 07:30:52 +00:00 
			
		
		
		
	 4542f8b813
			
		
	
	
		4542f8b813
		
	
	
	
	
		
			
			Signed-off-by: Liming Gao <liming.gao@intel.com> Cc: Siyuan Fu <siyuan.fu@intel.com> Cc: Jiaxin Wu <jiaxin.wu@intel.com> Reviewed-by: Jiaxin Wu <jiaxin.wu@intel.com> Reviewed-by: Siyuan Fu <siyuan.fu@intel.com>
		
			
				
	
	
		
			87 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
|     Event handler to check for available packet.
 | |
| 
 | |
| Copyright (c) 2004 - 2018, Intel Corporation. All rights reserved.<BR>
 | |
| SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| 
 | |
| **/
 | |
| 
 | |
| #include "Snp.h"
 | |
| 
 | |
| 
 | |
| /**
 | |
|   Nofication call back function for WaitForPacket event.
 | |
| 
 | |
|   @param  Event       EFI Event.
 | |
|   @param  SnpPtr      Pointer to SNP_DRIVER structure.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| EFIAPI
 | |
| SnpWaitForPacketNotify (
 | |
|   EFI_EVENT     Event,
 | |
|   VOID          *SnpPtr
 | |
|   )
 | |
| {
 | |
|   PXE_DB_GET_STATUS PxeDbGetStatus;
 | |
| 
 | |
|   //
 | |
|   // Do nothing if either parameter is a NULL pointer.
 | |
|   //
 | |
|   if (Event == NULL || SnpPtr == NULL) {
 | |
|     return ;
 | |
|   }
 | |
|   //
 | |
|   // Do nothing if the SNP interface is not initialized.
 | |
|   //
 | |
|   switch (((SNP_DRIVER *) SnpPtr)->Mode.State) {
 | |
|   case EfiSimpleNetworkInitialized:
 | |
|     break;
 | |
| 
 | |
|   case EfiSimpleNetworkStopped:
 | |
|   case EfiSimpleNetworkStarted:
 | |
|   default:
 | |
|     return ;
 | |
|   }
 | |
|   //
 | |
|   // Fill in CDB for UNDI GetStatus().
 | |
|   //
 | |
|   ((SNP_DRIVER *) SnpPtr)->Cdb.OpCode     = PXE_OPCODE_GET_STATUS;
 | |
|   ((SNP_DRIVER *) SnpPtr)->Cdb.OpFlags    = 0;
 | |
|   ((SNP_DRIVER *) SnpPtr)->Cdb.CPBsize    = PXE_CPBSIZE_NOT_USED;
 | |
|   ((SNP_DRIVER *) SnpPtr)->Cdb.CPBaddr    = PXE_CPBADDR_NOT_USED;
 | |
|   ((SNP_DRIVER *) SnpPtr)->Cdb.DBsize     = (UINT16) (sizeof (UINT32) * 2);
 | |
|   ((SNP_DRIVER *) SnpPtr)->Cdb.DBaddr     = (UINT64)(UINTN) (((SNP_DRIVER *) SnpPtr)->Db);
 | |
|   ((SNP_DRIVER *) SnpPtr)->Cdb.StatCode   = PXE_STATCODE_INITIALIZE;
 | |
|   ((SNP_DRIVER *) SnpPtr)->Cdb.StatFlags  = PXE_STATFLAGS_INITIALIZE;
 | |
|   ((SNP_DRIVER *) SnpPtr)->Cdb.IFnum      = ((SNP_DRIVER *) SnpPtr)->IfNum;
 | |
|   ((SNP_DRIVER *) SnpPtr)->Cdb.Control    = PXE_CONTROL_LAST_CDB_IN_LIST;
 | |
| 
 | |
|   //
 | |
|   // Clear contents of DB buffer.
 | |
|   //
 | |
|   ZeroMem (((SNP_DRIVER *) SnpPtr)->Db, sizeof (UINT32) * 2);
 | |
| 
 | |
|   //
 | |
|   // Issue UNDI command and check result.
 | |
|   //
 | |
|   (*((SNP_DRIVER *) SnpPtr)->IssueUndi32Command) ((UINT64)(UINTN) &((SNP_DRIVER *) SnpPtr)->Cdb);
 | |
| 
 | |
|   if (((SNP_DRIVER *) SnpPtr)->Cdb.StatCode != EFI_SUCCESS) {
 | |
|     return ;
 | |
|   }
 | |
|   //
 | |
|   // We might have a packet.  Check the receive length and signal
 | |
|   // the event if the length is not zero.
 | |
|   //
 | |
|   CopyMem (
 | |
|     &PxeDbGetStatus,
 | |
|     ((SNP_DRIVER *) SnpPtr)->Db,
 | |
|     sizeof (UINT32) * 2
 | |
|     );
 | |
| 
 | |
|   if (PxeDbGetStatus.RxFrameLen != 0) {
 | |
|     gBS->SignalEvent (Event);
 | |
|   }
 | |
| }
 |