2007-06-19 12:12:02 +02:00
|
|
|
/** @file
|
2007-06-28 00:53:31 +02:00
|
|
|
EFI Network Interface Identifier Protocol
|
2007-06-19 12:12:02 +02:00
|
|
|
|
2008-07-25 12:37:15 +02:00
|
|
|
Copyright (c) 2006 - 2008, Intel Corporation
|
2007-06-19 12:12:02 +02:00
|
|
|
All rights reserved. This program and the accompanying materials
|
|
|
|
are licensed and made available under the terms and conditions of the BSD License
|
|
|
|
which accompanies this distribution. The full text of the license may be found at
|
|
|
|
http://opensource.org/licenses/bsd-license.php
|
|
|
|
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __EFI_NETWORK_INTERFACE_IDENTIFER_H__
|
|
|
|
#define __EFI_NETWORK_INTERFACE_IDENTIFER_H__
|
|
|
|
|
|
|
|
|
|
|
|
#define EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL_GUID \
|
|
|
|
{ \
|
|
|
|
0xE18541CD, 0xF755, 0x4f73, {0x92, 0x8D, 0x64, 0x3C, 0x8A, 0x79, 0xB2, 0x29 } \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL_REVISION 0x00010000
|
|
|
|
|
2008-08-14 06:29:48 +02:00
|
|
|
///
|
|
|
|
/// Revision defined in EFI1.1.
|
|
|
|
///
|
2007-06-21 09:16:27 +02:00
|
|
|
#define EFI_NETWORK_INTERFACE_IDENTIFIER_INTERFACE_REVISION EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL_REVISION
|
|
|
|
|
2008-08-14 06:29:48 +02:00
|
|
|
///
|
|
|
|
/// Forward reference for pure ANSI compatability
|
|
|
|
///
|
2007-06-19 12:12:02 +02:00
|
|
|
typedef struct _EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL;
|
|
|
|
|
2008-08-14 06:29:48 +02:00
|
|
|
///
|
|
|
|
/// Protocol defined in EFI1.1.
|
|
|
|
///
|
2007-06-21 09:16:27 +02:00
|
|
|
typedef EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL EFI_NETWORK_INTERFACE_IDENTIFIER_INTERFACE;
|
|
|
|
|
2007-06-19 12:12:02 +02:00
|
|
|
typedef enum {
|
|
|
|
EfiNetworkInterfaceUndi = 1
|
|
|
|
} EFI_NETWORK_PROTOCOL_TYPE;
|
|
|
|
|
2008-10-13 04:54:29 +02:00
|
|
|
///
|
|
|
|
/// An optional protocol that is used to describe details about the software
|
|
|
|
/// layer that is used to produce the Simple Network Protocol.
|
|
|
|
///
|
2007-06-19 12:12:02 +02:00
|
|
|
struct _EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL {
|
2008-10-09 21:05:11 +02:00
|
|
|
///
|
|
|
|
/// The revision of the EFI_NETWORK_INTERFACE_IDENTIFIER protocol.
|
|
|
|
///
|
2007-06-19 12:12:02 +02:00
|
|
|
UINT64 Revision;
|
2008-10-09 21:05:11 +02:00
|
|
|
|
|
|
|
///
|
|
|
|
/// Address of the first byte of the identifying structure for this network
|
|
|
|
/// interface. This is only valid when the network interface is started
|
|
|
|
/// (see Start()). When the network interface is not started, this field is set to zero.
|
|
|
|
///
|
2007-06-19 12:12:02 +02:00
|
|
|
UINT64 ID;
|
2008-10-09 21:05:11 +02:00
|
|
|
|
|
|
|
///
|
|
|
|
/// Address of the first byte of the identifying structure for this
|
|
|
|
/// network interface. This is set to zero if there is no structure.
|
|
|
|
///
|
|
|
|
/// For PXE/UNDI this is the first byte of the !PXE structure.
|
|
|
|
///
|
2007-06-19 12:12:02 +02:00
|
|
|
UINT64 ImageAddr;
|
2008-10-09 21:05:11 +02:00
|
|
|
|
|
|
|
///
|
|
|
|
/// Size of unrelocated network interface image.
|
|
|
|
///
|
2007-06-19 12:12:02 +02:00
|
|
|
UINT32 ImageSize;
|
2008-10-09 21:05:11 +02:00
|
|
|
|
|
|
|
///
|
|
|
|
/// A four-character ASCII string that is sent in the class identifier field of
|
|
|
|
/// option 60 in DHCP. For a Type of EfiNetworkInterfaceUndi, this field is UNDI.
|
|
|
|
///
|
2007-06-19 12:12:02 +02:00
|
|
|
CHAR8 StringId[4];
|
2008-10-09 21:05:11 +02:00
|
|
|
|
|
|
|
///
|
|
|
|
/// Network interface type. This will be set to one of the values
|
|
|
|
/// in EFI_NETWORK_INTERFACE_TYPE.
|
|
|
|
///
|
2007-06-19 12:12:02 +02:00
|
|
|
UINT8 Type;
|
2008-10-09 21:05:11 +02:00
|
|
|
|
|
|
|
UINT8 MajorVer; ///< Major version number.
|
|
|
|
UINT8 MinorVer; ///< Minor version number.
|
|
|
|
|
|
|
|
///
|
|
|
|
/// TRUE if the network interface supports IPv6; otherwise FALSE.\
|
|
|
|
///
|
2007-06-19 12:12:02 +02:00
|
|
|
BOOLEAN Ipv6Supported;
|
2008-10-09 21:05:11 +02:00
|
|
|
|
|
|
|
///
|
|
|
|
/// The network interface number that is being identified by this Network
|
|
|
|
/// Interface Identifier Protocol. This field must be less than or equal
|
|
|
|
/// to the IFcnt field in the !PXE structure.
|
|
|
|
///
|
|
|
|
UINT8 IfNum;
|
2007-06-19 12:12:02 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
extern EFI_GUID gEfiNetworkInterfaceIdentifierProtocolGuid;
|
|
|
|
extern EFI_GUID gEfiNetworkInterfaceIdentifierProtocolGuid_31;
|
|
|
|
|
|
|
|
#endif // _EFI_NII_H
|