]> git.proxmox.com Git - mirror_edk2.git/blame - NetworkPkg/HttpBootDxe/HttpBootDhcp6.h
NetworkPkg/HttpBootDxe: Add HTTP Boot Callback protocol support.
[mirror_edk2.git] / NetworkPkg / HttpBootDxe / HttpBootDhcp6.h
CommitLineData
b659408b
ZL
1/** @file\r
2 Functions declaration related with DHCPv6 for HTTP boot driver.\r
3\r
142c00c3 4Copyright (c) 2015 - 2016, Intel Corporation. All rights reserved.<BR>\r
b659408b
ZL
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**/\r
14\r
15\r
16#ifndef __EFI_HTTP_BOOT_DHCP6_H__\r
17#define __EFI_HTTP_BOOT_DHCP6_H__\r
18\r
19#define HTTP_BOOT_OFFER_MAX_NUM 16\r
20#define HTTP_BOOT_DHCP6_OPTION_MAX_NUM 16\r
21#define HTTP_BOOT_DHCP6_OPTION_MAX_SIZE 312\r
22#define HTTP_BOOT_DHCP6_PACKET_MAX_SIZE 1472\r
23#define HTTP_BOOT_IP6_ROUTE_TABLE_TIMEOUT 10\r
24#define HTTP_BOOT_DEFAULT_HOPLIMIT 64\r
25#define HTTP_BOOT_DEFAULT_LIFETIME 50000\r
26\r
b659408b
ZL
27#define HTTP_BOOT_DHCP6_ENTERPRISE_NUM 343 // TODO: IANA TBD: temporarily using Intel's\r
28#define HTTP_BOOT_DHCP6_MAX_BOOT_FILE_SIZE 65535 // It's a limitation of bit length, 65535*512 bytes.\r
29\r
30#define HTTP_BOOT_DHCP6_IDX_IA_NA 0\r
31#define HTTP_BOOT_DHCP6_IDX_BOOT_FILE_URL 1\r
32#define HTTP_BOOT_DHCP6_IDX_BOOT_FILE_PARAM 2\r
33#define HTTP_BOOT_DHCP6_IDX_VENDOR_CLASS 3\r
34#define HTTP_BOOT_DHCP6_IDX_DNS_SERVER 4\r
35#define HTTP_BOOT_DHCP6_IDX_MAX 5\r
36\r
37#pragma pack(1)\r
38typedef struct {\r
39 UINT16 OpCode[256];\r
40} HTTP_BOOT_DHCP6_OPTION_ORO;\r
41\r
42typedef struct {\r
43 UINT8 Type;\r
44 UINT8 MajorVer;\r
45 UINT8 MinorVer;\r
46} HTTP_BOOT_DHCP6_OPTION_UNDI;\r
47\r
48typedef struct {\r
49 UINT16 Type;\r
50} HTTP_BOOT_DHCP6_OPTION_ARCH;\r
51\r
52typedef struct {\r
c243b744 53 UINT8 ClassIdentifier[11];\r
b659408b
ZL
54 UINT8 ArchitecturePrefix[5];\r
55 UINT8 ArchitectureType[5];\r
56 UINT8 Lit3[1];\r
57 UINT8 InterfaceName[4];\r
58 UINT8 Lit4[1];\r
59 UINT8 UndiMajor[3];\r
60 UINT8 UndiMinor[3];\r
61} HTTP_BOOT_CLASS_ID;\r
62\r
63typedef struct {\r
64 UINT32 Vendor;\r
65 UINT16 ClassLen;\r
66 HTTP_BOOT_CLASS_ID ClassId;\r
67} HTTP_BOOT_DHCP6_OPTION_VENDOR_CLASS;\r
68\r
69#pragma pack()\r
70\r
71typedef union {\r
72 HTTP_BOOT_DHCP6_OPTION_ORO *Oro;\r
73 HTTP_BOOT_DHCP6_OPTION_UNDI *Undi;\r
74 HTTP_BOOT_DHCP6_OPTION_ARCH *Arch;\r
75 HTTP_BOOT_DHCP6_OPTION_VENDOR_CLASS *VendorClass;\r
76} HTTP_BOOT_DHCP6_OPTION_ENTRY;\r
77\r
632dcfd6
FS
78#define HTTP_CACHED_DHCP6_PACKET_MAX_SIZE (OFFSET_OF (EFI_DHCP6_PACKET, Dhcp6) + HTTP_BOOT_DHCP6_PACKET_MAX_SIZE)\r
79\r
b659408b
ZL
80typedef union {\r
81 EFI_DHCP6_PACKET Offer;\r
82 EFI_DHCP6_PACKET Ack;\r
632dcfd6 83 UINT8 Buffer[HTTP_CACHED_DHCP6_PACKET_MAX_SIZE];\r
b659408b
ZL
84} HTTP_BOOT_DHCP6_PACKET;\r
85\r
86typedef struct {\r
87 HTTP_BOOT_DHCP6_PACKET Packet;\r
88 HTTP_BOOT_OFFER_TYPE OfferType;\r
89 EFI_DHCP6_PACKET_OPTION *OptList[HTTP_BOOT_DHCP6_IDX_MAX];\r
90 VOID *UriParser;\r
91} HTTP_BOOT_DHCP6_PACKET_CACHE;\r
92\r
93#define GET_NEXT_DHCP6_OPTION(Opt) \\r
94 (EFI_DHCP6_PACKET_OPTION *) ((UINT8 *) (Opt) + \\r
95 sizeof (EFI_DHCP6_PACKET_OPTION) + (NTOHS ((Opt)->OpLen)) - 1)\r
96\r
97#define GET_DHCP6_OPTION_SIZE(Pkt) \\r
98 ((Pkt)->Length - sizeof (EFI_DHCP6_HEADER))\r
99\r
100/**\r
101 Start the S.A.R.R DHCPv6 process to acquire the IPv6 address and other Http boot information.\r
102\r
103 @param[in] Private Pointer to HTTP_BOOT private data.\r
104\r
105 @retval EFI_SUCCESS The S.A.R.R process successfully finished.\r
106 @retval Others Failed to finish the S.A.R.R process.\r
107\r
108**/\r
109EFI_STATUS\r
110HttpBootDhcp6Sarr (\r
111 IN HTTP_BOOT_PRIVATE_DATA *Private\r
112 );\r
113\r
114/**\r
115 Set the IP6 policy to Automatic.\r
116\r
117 @param[in] Private The pointer to HTTP_BOOT_PRIVATE_DATA.\r
118\r
119 @retval EFI_SUCCESS Switch the IP policy succesfully.\r
120 @retval Others Unexpect error happened.\r
121\r
122**/\r
123EFI_STATUS\r
124HttpBootSetIp6Policy (\r
125 IN HTTP_BOOT_PRIVATE_DATA *Private\r
126 );\r
127\r
128/**\r
129 This function will register the default DNS addresses to the network device.\r
130 \r
131 @param[in] Private The pointer to HTTP_BOOT_PRIVATE_DATA.\r
132 @param[in] DataLength Size of the buffer pointed to by DnsServerData in bytes.\r
133 @param[in] DnsServerData Point a list of DNS server address in an array\r
134 of EFI_IPv6_ADDRESS instances.\r
135\r
136 @retval EFI_SUCCESS The DNS configuration has been configured successfully.\r
137 @retval Others Failed to configure the address.\r
138\r
139**/\r
140EFI_STATUS\r
141HttpBootSetIp6Dns (\r
142 IN HTTP_BOOT_PRIVATE_DATA *Private,\r
143 IN UINTN DataLength,\r
144 IN VOID *DnsServerData\r
145 );\r
146\r
147/**\r
148 This function will register the IPv6 gateway address to the network device.\r
149 \r
150 @param[in] Private The pointer to HTTP_BOOT_PRIVATE_DATA.\r
151\r
152 @retval EFI_SUCCESS The new IP configuration has been configured successfully.\r
153 @retval Others Failed to configure the address.\r
154\r
155**/\r
156EFI_STATUS\r
157HttpBootSetIp6Gateway (\r
158 IN HTTP_BOOT_PRIVATE_DATA *Private\r
159 );\r
160\r
161/**\r
162 This function will register the station IP address.\r
163 \r
164 @param[in] Private The pointer to HTTP_BOOT_PRIVATE_DATA.\r
165\r
166 @retval EFI_SUCCESS The new IP address has been configured successfully.\r
167 @retval Others Failed to configure the address.\r
168\r
169**/\r
170EFI_STATUS\r
171HttpBootSetIp6Address (\r
172 IN HTTP_BOOT_PRIVATE_DATA *Private\r
173 );\r
174\r
175#endif\r