REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3737 Apply uncrustify changes to .c/.h files in the MdePkg package Cc: Andrew Fish <afish@apple.com> Cc: Leif Lindholm <leif@nuviainc.com> Cc: Michael D Kinney <michael.d.kinney@intel.com> Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com> Reviewed-by: Liming Gao <gaoliming@byosoft.com.cn>
		
			
				
	
	
		
			124 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/** @file
 | 
						|
  It is invoked when the PXE Base Code Protocol is about to transmit, has received,
 | 
						|
  or is waiting to receive a packet.
 | 
						|
 | 
						|
Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>
 | 
						|
SPDX-License-Identifier: BSD-2-Clause-Patent
 | 
						|
 | 
						|
  @par Revision Reference:
 | 
						|
  This Protocol is introduced in EFI Specification 1.10
 | 
						|
 | 
						|
**/
 | 
						|
 | 
						|
#ifndef _PXE_BASE_CODE_CALLBACK_H_
 | 
						|
#define _PXE_BASE_CODE_CALLBACK_H_
 | 
						|
 | 
						|
///
 | 
						|
/// Call Back Definitions.
 | 
						|
///
 | 
						|
#define EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL_GUID \
 | 
						|
  { \
 | 
						|
    0x245dca21, 0xfb7b, 0x11d3, {0x8f, 0x01, 0x00, 0xa0, 0xc9, 0x69, 0x72, 0x3b } \
 | 
						|
  }
 | 
						|
 | 
						|
///
 | 
						|
/// UEFI Revision Number Definition.
 | 
						|
///
 | 
						|
#define EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL_REVISION  0x00010000
 | 
						|
 | 
						|
///
 | 
						|
/// EFI 1.1 Revision Number defintion.
 | 
						|
///
 | 
						|
#define EFI_PXE_BASE_CODE_CALLBACK_INTERFACE_REVISION  \
 | 
						|
        EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL_REVISION
 | 
						|
 | 
						|
///
 | 
						|
/// UEFI Protocol name.
 | 
						|
///
 | 
						|
typedef struct _EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL;
 | 
						|
 | 
						|
///
 | 
						|
/// EFI1.1 Protocol name.
 | 
						|
///
 | 
						|
typedef EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL EFI_PXE_BASE_CODE_CALLBACK;
 | 
						|
 | 
						|
///
 | 
						|
/// Event type list for PXE Base Code Protocol function.
 | 
						|
///
 | 
						|
typedef enum {
 | 
						|
  EFI_PXE_BASE_CODE_FUNCTION_FIRST,
 | 
						|
  EFI_PXE_BASE_CODE_FUNCTION_DHCP,
 | 
						|
  EFI_PXE_BASE_CODE_FUNCTION_DISCOVER,
 | 
						|
  EFI_PXE_BASE_CODE_FUNCTION_MTFTP,
 | 
						|
  EFI_PXE_BASE_CODE_FUNCTION_UDP_WRITE,
 | 
						|
  EFI_PXE_BASE_CODE_FUNCTION_UDP_READ,
 | 
						|
  EFI_PXE_BASE_CODE_FUNCTION_ARP,
 | 
						|
  EFI_PXE_BASE_CODE_FUNCTION_IGMP,
 | 
						|
  EFI_PXE_BASE_CODE_PXE_FUNCTION_LAST
 | 
						|
} EFI_PXE_BASE_CODE_FUNCTION;
 | 
						|
 | 
						|
///
 | 
						|
/// Callback status type.
 | 
						|
///
 | 
						|
typedef enum {
 | 
						|
  EFI_PXE_BASE_CODE_CALLBACK_STATUS_FIRST,
 | 
						|
  EFI_PXE_BASE_CODE_CALLBACK_STATUS_CONTINUE,
 | 
						|
  EFI_PXE_BASE_CODE_CALLBACK_STATUS_ABORT,
 | 
						|
  EFI_PXE_BASE_CODE_CALLBACK_STATUS_LAST
 | 
						|
} EFI_PXE_BASE_CODE_CALLBACK_STATUS;
 | 
						|
 | 
						|
/**
 | 
						|
  Callback function that is invoked when the PXE Base Code Protocol is about to transmit, has
 | 
						|
  received, or is waiting to receive a packet.
 | 
						|
 | 
						|
  This function is invoked when the PXE Base Code Protocol is about to transmit, has received,
 | 
						|
  or is waiting to receive a packet. Parameters Function and Received specify the type of event.
 | 
						|
  Parameters PacketLen and Packet specify the packet that generated the event. If these fields
 | 
						|
  are zero and NULL respectively, then this is a status update callback. If the operation specified
 | 
						|
  by Function is to continue, then CALLBACK_STATUS_CONTINUE should be returned. If the operation
 | 
						|
  specified by Function should be aborted, then CALLBACK_STATUS_ABORT should be returned. Due to
 | 
						|
  the polling nature of UEFI device drivers, a callback function should not execute for more than 5 ms.
 | 
						|
  The SetParameters() function must be called after a Callback Protocol is installed to enable the
 | 
						|
  use of callbacks.
 | 
						|
 | 
						|
  @param  This                  The pointer to the EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL instance.
 | 
						|
  @param  Function              The PXE Base Code Protocol function that is waiting for an event.
 | 
						|
  @param  Received              TRUE if the callback is being invoked due to a receive event. FALSE if
 | 
						|
                                the callback is being invoked due to a transmit event.
 | 
						|
  @param  PacketLen             The length, in bytes, of Packet. This field will have a value of zero if
 | 
						|
                                this is a wait for receive event.
 | 
						|
  @param  Packet                If Received is TRUE, a pointer to the packet that was just received;
 | 
						|
                                otherwise a pointer to the packet that is about to be transmitted.
 | 
						|
 | 
						|
  @retval EFI_PXE_BASE_CODE_CALLBACK_STATUS_CONTINUE if Function specifies a continue operation
 | 
						|
  @retval EFI_PXE_BASE_CODE_CALLBACK_STATUS_ABORT    if Function specifies an abort operation
 | 
						|
 | 
						|
**/
 | 
						|
typedef
 | 
						|
EFI_PXE_BASE_CODE_CALLBACK_STATUS
 | 
						|
(EFIAPI *EFI_PXE_CALLBACK)(
 | 
						|
  IN EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL  *This,
 | 
						|
  IN EFI_PXE_BASE_CODE_FUNCTION           Function,
 | 
						|
  IN BOOLEAN                              Received,
 | 
						|
  IN UINT32                               PacketLen,
 | 
						|
  IN EFI_PXE_BASE_CODE_PACKET             *Packet     OPTIONAL
 | 
						|
  );
 | 
						|
 | 
						|
///
 | 
						|
/// Protocol that is invoked when the PXE Base Code Protocol is about
 | 
						|
/// to transmit, has received, or is waiting to receive a packet.
 | 
						|
///
 | 
						|
struct _EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL {
 | 
						|
  ///
 | 
						|
  ///  The revision of the EFI_PXE_BASE_CODE_PROTOCOL. All future revisions must
 | 
						|
  ///  be backwards compatible. If a future version is not backwards compatible
 | 
						|
  ///  it is not the same GUID.
 | 
						|
  ///
 | 
						|
  UINT64              Revision;
 | 
						|
  EFI_PXE_CALLBACK    Callback;
 | 
						|
};
 | 
						|
 | 
						|
extern EFI_GUID  gEfiPxeBaseCodeCallbackProtocolGuid;
 | 
						|
 | 
						|
#endif
 |