Vishal Bhoj | 82c8071 | 2015-12-15 21:13:33 +0530 | [diff] [blame^] | 1 | /** @file
|
| 2 | It is invoked when the PXE Base Code Protocol is about to transmit, has received,
|
| 3 | or is waiting to receive a packet.
|
| 4 |
|
| 5 | Copyright (c) 2006 - 2010, Intel Corporation. All rights reserved.<BR>
|
| 6 | This program and the accompanying materials are licensed and made available under
|
| 7 | the terms and conditions of the BSD License that accompanies this distribution.
|
| 8 | The full text of the license may be found at
|
| 9 | http://opensource.org/licenses/bsd-license.php.
|
| 10 |
|
| 11 | THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
| 12 | WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
| 13 |
|
| 14 | @par Revision Reference:
|
| 15 | This Protocol is introduced in EFI Specification 1.10
|
| 16 |
|
| 17 | **/
|
| 18 |
|
| 19 | #ifndef _PXE_BASE_CODE_CALLBACK_H_
|
| 20 | #define _PXE_BASE_CODE_CALLBACK_H_
|
| 21 |
|
| 22 | ///
|
| 23 | /// Call Back Definitions.
|
| 24 | ///
|
| 25 | #define EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL_GUID \
|
| 26 | { \
|
| 27 | 0x245dca21, 0xfb7b, 0x11d3, {0x8f, 0x01, 0x00, 0xa0, 0xc9, 0x69, 0x72, 0x3b } \
|
| 28 | }
|
| 29 |
|
| 30 | ///
|
| 31 | /// UEFI Revision Number Definition.
|
| 32 | ///
|
| 33 | #define EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL_REVISION 0x00010000
|
| 34 |
|
| 35 | ///
|
| 36 | /// EFI 1.1 Revision Number defintion.
|
| 37 | ///
|
| 38 | #define EFI_PXE_BASE_CODE_CALLBACK_INTERFACE_REVISION \
|
| 39 | EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL_REVISION
|
| 40 |
|
| 41 | ///
|
| 42 | /// UEFI Protocol name.
|
| 43 | ///
|
| 44 | typedef struct _EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL;
|
| 45 |
|
| 46 | ///
|
| 47 | /// EFI1.1 Protocol name.
|
| 48 | ///
|
| 49 | typedef EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL EFI_PXE_BASE_CODE_CALLBACK;
|
| 50 |
|
| 51 | ///
|
| 52 | /// Event type list for PXE Base Code Protocol function.
|
| 53 | ///
|
| 54 | typedef enum {
|
| 55 | EFI_PXE_BASE_CODE_FUNCTION_FIRST,
|
| 56 | EFI_PXE_BASE_CODE_FUNCTION_DHCP,
|
| 57 | EFI_PXE_BASE_CODE_FUNCTION_DISCOVER,
|
| 58 | EFI_PXE_BASE_CODE_FUNCTION_MTFTP,
|
| 59 | EFI_PXE_BASE_CODE_FUNCTION_UDP_WRITE,
|
| 60 | EFI_PXE_BASE_CODE_FUNCTION_UDP_READ,
|
| 61 | EFI_PXE_BASE_CODE_FUNCTION_ARP,
|
| 62 | EFI_PXE_BASE_CODE_FUNCTION_IGMP,
|
| 63 | EFI_PXE_BASE_CODE_PXE_FUNCTION_LAST
|
| 64 | } EFI_PXE_BASE_CODE_FUNCTION;
|
| 65 |
|
| 66 | ///
|
| 67 | /// Callback status type.
|
| 68 | ///
|
| 69 | typedef enum {
|
| 70 | EFI_PXE_BASE_CODE_CALLBACK_STATUS_FIRST,
|
| 71 | EFI_PXE_BASE_CODE_CALLBACK_STATUS_CONTINUE,
|
| 72 | EFI_PXE_BASE_CODE_CALLBACK_STATUS_ABORT,
|
| 73 | EFI_PXE_BASE_CODE_CALLBACK_STATUS_LAST
|
| 74 | } EFI_PXE_BASE_CODE_CALLBACK_STATUS;
|
| 75 |
|
| 76 | /**
|
| 77 | Callback function that is invoked when the PXE Base Code Protocol is about to transmit, has
|
| 78 | received, or is waiting to receive a packet.
|
| 79 |
|
| 80 | This function is invoked when the PXE Base Code Protocol is about to transmit, has received,
|
| 81 | or is waiting to receive a packet. Parameters Function and Received specify the type of event.
|
| 82 | Parameters PacketLen and Packet specify the packet that generated the event. If these fields
|
| 83 | are zero and NULL respectively, then this is a status update callback. If the operation specified
|
| 84 | by Function is to continue, then CALLBACK_STATUS_CONTINUE should be returned. If the operation
|
| 85 | specified by Function should be aborted, then CALLBACK_STATUS_ABORT should be returned. Due to
|
| 86 | the polling nature of UEFI device drivers, a callback function should not execute for more than 5 ms.
|
| 87 | The SetParameters() function must be called after a Callback Protocol is installed to enable the
|
| 88 | use of callbacks.
|
| 89 |
|
| 90 | @param This The pointer to the EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL instance.
|
| 91 | @param Function The PXE Base Code Protocol function that is waiting for an event.
|
| 92 | @param Received TRUE if the callback is being invoked due to a receive event. FALSE if
|
| 93 | the callback is being invoked due to a transmit event.
|
| 94 | @param PacketLen The length, in bytes, of Packet. This field will have a value of zero if
|
| 95 | this is a wait for receive event.
|
| 96 | @param Packet If Received is TRUE, a pointer to the packet that was just received;
|
| 97 | otherwise a pointer to the packet that is about to be transmitted.
|
| 98 |
|
| 99 | @retval EFI_PXE_BASE_CODE_CALLBACK_STATUS_CONTINUE if Function specifies a continue operation
|
| 100 | @retval EFI_PXE_BASE_CODE_CALLBACK_STATUS_ABORT if Function specifies an abort operation
|
| 101 |
|
| 102 | **/
|
| 103 | typedef
|
| 104 | EFI_PXE_BASE_CODE_CALLBACK_STATUS
|
| 105 | (EFIAPI *EFI_PXE_CALLBACK)(
|
| 106 | IN EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL *This,
|
| 107 | IN EFI_PXE_BASE_CODE_FUNCTION Function,
|
| 108 | IN BOOLEAN Received,
|
| 109 | IN UINT32 PacketLen,
|
| 110 | IN EFI_PXE_BASE_CODE_PACKET *Packet OPTIONAL
|
| 111 | );
|
| 112 |
|
| 113 | ///
|
| 114 | /// Protocol that is invoked when the PXE Base Code Protocol is about
|
| 115 | /// to transmit, has received, or is waiting to receive a packet.
|
| 116 | ///
|
| 117 | struct _EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL {
|
| 118 | ///
|
| 119 | /// The revision of the EFI_PXE_BASE_CODE_PROTOCOL. All future revisions must
|
| 120 | /// be backwards compatible. If a future version is not backwards compatible
|
| 121 | /// it is not the same GUID.
|
| 122 | ///
|
| 123 | UINT64 Revision;
|
| 124 | EFI_PXE_CALLBACK Callback;
|
| 125 | };
|
| 126 |
|
| 127 | extern EFI_GUID gEfiPxeBaseCodeCallbackProtocolGuid;
|
| 128 |
|
| 129 | #endif
|
| 130 |
|