]> git.proxmox.com Git - mirror_edk2.git/blame_incremental - MdePkg/Include/Protocol/NetworkInterfaceIdentifier.h
MdePkg SmmSwDispatch2.h: comment cleanup.
[mirror_edk2.git] / MdePkg / Include / Protocol / NetworkInterfaceIdentifier.h
... / ...
CommitLineData
1/** @file\r
2 EFI Network Interface Identifier Protocol.\r
3\r
4Copyright (c) 2006 - 2011, Intel Corporation. All rights reserved.<BR>\r
5This program and the accompanying materials are licensed and made available under\r
6the terms and conditions of the BSD License that accompanies this distribution.\r
7The full text of the license may be found at\r
8http://opensource.org/licenses/bsd-license.php.\r
9\r
10THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
11WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
12\r
13 @par Revision Reference:\r
14 This Protocol is introduced in EFI Specification 1.10.\r
15\r
16**/\r
17\r
18#ifndef __EFI_NETWORK_INTERFACE_IDENTIFER_H__\r
19#define __EFI_NETWORK_INTERFACE_IDENTIFER_H__\r
20\r
21//\r
22// GUID retired from UEFI Specification 2.1b\r
23//\r
24#define EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL_GUID \\r
25 { \\r
26 0xE18541CD, 0xF755, 0x4f73, {0x92, 0x8D, 0x64, 0x3C, 0x8A, 0x79, 0xB2, 0x29 } \\r
27 }\r
28\r
29//\r
30// GUID intruduced in UEFI Specification 2.1b\r
31//\r
32#define EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL_GUID_31 \\r
33 { \\r
34 0x1ACED566, 0x76ED, 0x4218, {0xBC, 0x81, 0x76, 0x7F, 0x1F, 0x97, 0x7A, 0x89 } \\r
35 }\r
36\r
37#define EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL_REVISION 0x00010000\r
38\r
39///\r
40/// Revision defined in EFI1.1.\r
41///\r
42#define EFI_NETWORK_INTERFACE_IDENTIFIER_INTERFACE_REVISION EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL_REVISION\r
43\r
44///\r
45/// Forward reference for pure ANSI compatability.\r
46///\r
47typedef struct _EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL;\r
48\r
49///\r
50/// Protocol defined in EFI1.1.\r
51///\r
52typedef EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL EFI_NETWORK_INTERFACE_IDENTIFIER_INTERFACE;\r
53\r
54///\r
55/// An optional protocol that is used to describe details about the software\r
56/// layer that is used to produce the Simple Network Protocol.\r
57///\r
58struct _EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL {\r
59 UINT64 Revision; ///< The revision of the EFI_NETWORK_INTERFACE_IDENTIFIER protocol.\r
60 UINT64 Id; ///< The address of the first byte of the identifying structure for this network\r
61 ///< interface. This is only valid when the network interface is started\r
62 ///< (see Start()). When the network interface is not started, this field is set to zero.\r
63 UINT64 ImageAddr; ///< The address of the first byte of the identifying structure for this\r
64 ///< network interface. This is set to zero if there is no structure.\r
65 UINT32 ImageSize; ///< The size of unrelocated network interface image.\r
66 CHAR8 StringId[4];///< A four-character ASCII string that is sent in the class identifier field of\r
67 ///< option 60 in DHCP. For a Type of EfiNetworkInterfaceUndi, this field is UNDI.\r
68 UINT8 Type; ///< Network interface type. This will be set to one of the values\r
69 ///< in EFI_NETWORK_INTERFACE_TYPE.\r
70 UINT8 MajorVer; ///< Major version number.\r
71 UINT8 MinorVer; ///< Minor version number.\r
72 BOOLEAN Ipv6Supported; ///< TRUE if the network interface supports IPv6; otherwise FALSE.\r
73 UINT8 IfNum; ///< The network interface number that is being identified by this Network\r
74 ///< Interface Identifier Protocol. This field must be less than or equal\r
75 ///< to the IFcnt field in the !PXE structure.\r
76\r
77};\r
78\r
79///\r
80///*******************************************************\r
81/// EFI_NETWORK_INTERFACE_TYPE\r
82///*******************************************************\r
83///\r
84typedef enum {\r
85 EfiNetworkInterfaceUndi = 1\r
86} EFI_NETWORK_INTERFACE_TYPE;\r
87\r
88///\r
89/// Forward reference for pure ANSI compatability.\r
90///\r
91typedef struct undiconfig_table UNDI_CONFIG_TABLE;\r
92\r
93///\r
94/// The format of the configuration table for UNDI\r
95///\r
96struct undiconfig_table {\r
97 UINT32 NumberOfInterfaces; ///< The number of NIC devices\r
98 ///< that this UNDI controls.\r
99 UINT32 reserved;\r
100 UNDI_CONFIG_TABLE *nextlink; ///< A pointer to the next UNDI\r
101 ///< configuration table.\r
102 ///\r
103 /// The length of this array is given in the NumberOfInterfaces field.\r
104 ///\r
105 struct {\r
106 VOID *NII_InterfacePointer; ///< Pointer to the NII interface structure.\r
107 VOID *DevicePathPointer; ///< Pointer to the device path for this NIC.\r
108 } NII_entry[1]; \r
109};\r
110\r
111extern EFI_GUID gEfiNetworkInterfaceIdentifierProtocolGuid;\r
112extern EFI_GUID gEfiNetworkInterfaceIdentifierProtocolGuid_31;\r
113\r
114#endif\r