2010-11-01 07:13:54 +01:00
|
|
|
/** @file
|
|
|
|
Functions declaration related with DHCPv6 for UefiPxeBc Driver.
|
|
|
|
|
2018-06-27 15:12:32 +02:00
|
|
|
Copyright (c) 2009 - 2018, Intel Corporation. All rights reserved.<BR>
|
2010-11-01 07:13:54 +01:00
|
|
|
|
2019-04-04 01:06:13 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2010-11-01 07:13:54 +01:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __EFI_PXEBC_DHCP6_H__
|
|
|
|
#define __EFI_PXEBC_DHCP6_H__
|
|
|
|
|
2021-12-05 23:54:07 +01:00
|
|
|
#define PXEBC_DHCP6_OPTION_MAX_NUM 16
|
|
|
|
#define PXEBC_DHCP6_OPTION_MAX_SIZE 312
|
|
|
|
#define PXEBC_DHCP6_PACKET_MAX_SIZE (sizeof (EFI_PXE_BASE_CODE_PACKET))
|
|
|
|
#define PXEBC_IP6_POLICY_MAX 0xff
|
|
|
|
#define PXEBC_IP6_ROUTE_TABLE_TIMEOUT 10
|
2010-11-01 07:13:54 +01:00
|
|
|
|
2021-12-05 23:54:07 +01:00
|
|
|
#define PXEBC_DHCP6_S_PORT 547
|
|
|
|
#define PXEBC_DHCP6_C_PORT 546
|
2010-11-01 07:13:54 +01:00
|
|
|
|
2021-12-05 23:54:07 +01:00
|
|
|
#define PXEBC_DHCP6_ENTERPRISE_NUM 343 // TODO: IANA TBD: temporarily using Intel's
|
|
|
|
#define PXEBC_DHCP6_MAX_BOOT_FILE_SIZE 65535 // It's a limitation of bit length, 65535*512 bytes.
|
2010-11-01 07:13:54 +01:00
|
|
|
|
2021-12-05 23:54:07 +01:00
|
|
|
#define PXEBC_DHCP6_IDX_IA_NA 0
|
|
|
|
#define PXEBC_DHCP6_IDX_BOOT_FILE_URL 1
|
|
|
|
#define PXEBC_DHCP6_IDX_BOOT_FILE_PARAM 2
|
|
|
|
#define PXEBC_DHCP6_IDX_VENDOR_CLASS 3
|
|
|
|
#define PXEBC_DHCP6_IDX_DNS_SERVER 4
|
|
|
|
#define PXEBC_DHCP6_IDX_MAX 5
|
2010-11-01 07:13:54 +01:00
|
|
|
|
|
|
|
#define PXEBC_DHCP6_BOOT_FILE_URL_PREFIX "tftp://"
|
|
|
|
#define PXEBC_TFTP_URL_SEPARATOR '/'
|
|
|
|
#define PXEBC_ADDR_START_DELIMITER '['
|
|
|
|
#define PXEBC_ADDR_END_DELIMITER ']'
|
|
|
|
|
|
|
|
#define GET_NEXT_DHCP6_OPTION(Opt) \
|
|
|
|
(EFI_DHCP6_PACKET_OPTION *) ((UINT8 *) (Opt) + \
|
|
|
|
sizeof (EFI_DHCP6_PACKET_OPTION) + (NTOHS ((Opt)->OpLen)) - 1)
|
|
|
|
|
|
|
|
#define GET_DHCP6_OPTION_SIZE(Pkt) \
|
|
|
|
((Pkt)->Length - sizeof (EFI_DHCP6_HEADER))
|
|
|
|
|
|
|
|
#define IS_PROXY_OFFER(Type) \
|
|
|
|
((Type) == PxeOfferTypeProxyBinl || \
|
|
|
|
(Type) == PxeOfferTypeProxyPxe10 || \
|
|
|
|
(Type) == PxeOfferTypeProxyWfm11a)
|
|
|
|
|
|
|
|
#pragma pack(1)
|
|
|
|
typedef struct {
|
2021-12-05 23:54:07 +01:00
|
|
|
UINT16 OpCode[256];
|
2010-11-01 07:13:54 +01:00
|
|
|
} PXEBC_DHCP6_OPTION_ORO;
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:54:07 +01:00
|
|
|
UINT8 Type;
|
|
|
|
UINT8 MajorVer;
|
|
|
|
UINT8 MinorVer;
|
2010-11-01 07:13:54 +01:00
|
|
|
} PXEBC_DHCP6_OPTION_UNDI;
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:54:07 +01:00
|
|
|
UINT16 Type;
|
2010-11-01 07:13:54 +01:00
|
|
|
} PXEBC_DHCP6_OPTION_ARCH;
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:54:07 +01:00
|
|
|
UINT8 ClassIdentifier[10];
|
|
|
|
UINT8 ArchitecturePrefix[5];
|
|
|
|
UINT8 ArchitectureType[5];
|
|
|
|
UINT8 Lit3[1];
|
|
|
|
UINT8 InterfaceName[4];
|
|
|
|
UINT8 Lit4[1];
|
|
|
|
UINT8 UndiMajor[3];
|
|
|
|
UINT8 UndiMinor[3];
|
2010-11-01 07:13:54 +01:00
|
|
|
} PXEBC_CLASS_ID;
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:54:07 +01:00
|
|
|
UINT32 Vendor;
|
|
|
|
UINT16 ClassLen;
|
|
|
|
PXEBC_CLASS_ID ClassId;
|
2010-11-01 07:13:54 +01:00
|
|
|
} PXEBC_DHCP6_OPTION_VENDOR_CLASS;
|
|
|
|
|
|
|
|
#pragma pack()
|
|
|
|
|
|
|
|
typedef union {
|
2021-12-05 23:54:07 +01:00
|
|
|
PXEBC_DHCP6_OPTION_ORO *Oro;
|
|
|
|
PXEBC_DHCP6_OPTION_UNDI *Undi;
|
|
|
|
PXEBC_DHCP6_OPTION_ARCH *Arch;
|
|
|
|
PXEBC_DHCP6_OPTION_VENDOR_CLASS *VendorClass;
|
2010-11-01 07:13:54 +01:00
|
|
|
} PXEBC_DHCP6_OPTION_ENTRY;
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:54:07 +01:00
|
|
|
LIST_ENTRY Link;
|
|
|
|
EFI_DHCP6_PACKET_OPTION *Option;
|
|
|
|
UINT8 Precedence;
|
2010-11-01 07:13:54 +01:00
|
|
|
} PXEBC_DHCP6_OPTION_NODE;
|
|
|
|
|
2016-11-16 06:37:15 +01:00
|
|
|
#define PXEBC_CACHED_DHCP6_PACKET_MAX_SIZE (OFFSET_OF (EFI_DHCP6_PACKET, Dhcp6) + PXEBC_DHCP6_PACKET_MAX_SIZE)
|
|
|
|
|
2010-11-01 07:13:54 +01:00
|
|
|
typedef union {
|
2021-12-05 23:54:07 +01:00
|
|
|
EFI_DHCP6_PACKET Offer;
|
|
|
|
EFI_DHCP6_PACKET Ack;
|
|
|
|
UINT8 Buffer[PXEBC_CACHED_DHCP6_PACKET_MAX_SIZE];
|
2010-11-01 07:13:54 +01:00
|
|
|
} PXEBC_DHCP6_PACKET;
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:54:07 +01:00
|
|
|
PXEBC_DHCP6_PACKET Packet;
|
|
|
|
PXEBC_OFFER_TYPE OfferType;
|
|
|
|
EFI_DHCP6_PACKET_OPTION *OptList[PXEBC_DHCP6_IDX_MAX];
|
2010-11-01 07:13:54 +01:00
|
|
|
} PXEBC_DHCP6_PACKET_CACHE;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Parse the Boot File URL option.
|
|
|
|
|
2016-10-14 09:12:09 +02:00
|
|
|
@param[in] Private Pointer to PxeBc private data.
|
2010-11-01 07:13:54 +01:00
|
|
|
@param[out] FileName The pointer to the boot file name.
|
|
|
|
@param[in, out] SrvAddr The pointer to the boot server address.
|
|
|
|
@param[in] BootFile The pointer to the boot file URL option data.
|
|
|
|
@param[in] Length Length of the boot file URL option data.
|
|
|
|
|
|
|
|
@retval EFI_ABORTED User canceled the operation.
|
|
|
|
@retval EFI_SUCCESS Selected the boot menu successfully.
|
2020-02-07 02:08:05 +01:00
|
|
|
@retval EFI_NOT_READY Read the input key from the keyboard has not finish.
|
2010-11-01 07:13:54 +01:00
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
PxeBcExtractBootFileUrl (
|
2021-12-05 23:54:07 +01:00
|
|
|
IN PXEBC_PRIVATE_DATA *Private,
|
|
|
|
OUT UINT8 **FileName,
|
|
|
|
IN OUT EFI_IPv6_ADDRESS *SrvAddr,
|
|
|
|
IN CHAR8 *BootFile,
|
|
|
|
IN UINT16 Length
|
2010-11-01 07:13:54 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Parse the Boot File Parameter option.
|
|
|
|
|
|
|
|
@param[in] BootFilePara The pointer to the boot file parameter option data.
|
|
|
|
@param[out] BootFileSize The pointer to the parsed boot file size.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Successfully obtained the boot file size from parameter option.
|
|
|
|
@retval EFI_NOT_FOUND Failed to extract the boot file size from parameter option.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
PxeBcExtractBootFileParam (
|
2021-12-05 23:54:07 +01:00
|
|
|
IN CHAR8 *BootFilePara,
|
|
|
|
OUT UINT16 *BootFileSize
|
2010-11-01 07:13:54 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Parse the cached DHCPv6 packet, including all the options.
|
|
|
|
|
|
|
|
@param[in] Cache6 The pointer to a cached DHCPv6 packet.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Parsed the DHCPv6 packet successfully.
|
|
|
|
@retval EFI_DEVICE_ERROR Failed to parse and invalid packet.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
PxeBcParseDhcp6Packet (
|
|
|
|
IN PXEBC_DHCP6_PACKET_CACHE *Cache6
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Register the ready address by Ip6Config protocol.
|
|
|
|
|
|
|
|
@param[in] Private The pointer to the PxeBc private data.
|
|
|
|
@param[in] Address The pointer to the ready address.
|
|
|
|
|
2020-02-07 02:08:05 +01:00
|
|
|
@retval EFI_SUCCESS Registered the address successfully.
|
2010-11-01 07:13:54 +01:00
|
|
|
@retval Others Failed to register the address.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
PxeBcRegisterIp6Address (
|
2021-12-05 23:54:07 +01:00
|
|
|
IN PXEBC_PRIVATE_DATA *Private,
|
|
|
|
IN EFI_IPv6_ADDRESS *Address
|
2010-11-01 07:13:54 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Unregister the address by Ip6Config protocol.
|
|
|
|
|
|
|
|
@param[in] Private The pointer to the PxeBc private data.
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
PxeBcUnregisterIp6Address (
|
2021-12-05 23:54:07 +01:00
|
|
|
IN PXEBC_PRIVATE_DATA *Private
|
2010-11-01 07:13:54 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Build and send out the request packet for the bootfile, and parse the reply.
|
|
|
|
|
|
|
|
@param[in] Private The pointer to the PxeBc private data.
|
|
|
|
@param[in] Type PxeBc option boot item type.
|
|
|
|
@param[in] Layer The pointer to the option boot item layer.
|
|
|
|
@param[in] UseBis Use BIS or not.
|
|
|
|
@param[in] DestIp The pointer to the server address.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Successfully discovered theboot file.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Failed to allocate resource.
|
|
|
|
@retval EFI_NOT_FOUND Can't get the PXE reply packet.
|
|
|
|
@retval Others Failed to discover boot file.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
PxeBcDhcp6Discover (
|
2021-12-05 23:54:07 +01:00
|
|
|
IN PXEBC_PRIVATE_DATA *Private,
|
|
|
|
IN UINT16 Type,
|
|
|
|
IN UINT16 *Layer,
|
|
|
|
IN BOOLEAN UseBis,
|
|
|
|
IN EFI_IP_ADDRESS *DestIp
|
2010-11-01 07:13:54 +01:00
|
|
|
);
|
|
|
|
|
2014-09-18 13:44:36 +02:00
|
|
|
/**
|
|
|
|
Set the IP6 policy to Automatic.
|
|
|
|
|
|
|
|
@param[in] Private The pointer to PXEBC_PRIVATE_DATA.
|
|
|
|
|
2020-02-07 02:08:05 +01:00
|
|
|
@retval EFI_SUCCESS Switch the IP policy successfully.
|
|
|
|
@retval Others Unexpected error happened.
|
2014-09-18 13:44:36 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
PxeBcSetIp6Policy (
|
2021-12-05 23:54:07 +01:00
|
|
|
IN PXEBC_PRIVATE_DATA *Private
|
2014-09-18 13:44:36 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
This function will register the station IP address and flush IP instance to start using the new IP address.
|
2018-06-27 15:12:32 +02:00
|
|
|
|
2014-09-18 13:44:36 +02:00
|
|
|
@param[in] Private The pointer to PXEBC_PRIVATE_DATA.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The new IP address has been configured successfully.
|
|
|
|
@retval Others Failed to configure the address.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
PxeBcSetIp6Address (
|
2021-12-05 23:54:07 +01:00
|
|
|
IN PXEBC_PRIVATE_DATA *Private
|
2014-09-18 13:44:36 +02:00
|
|
|
);
|
2010-11-01 07:13:54 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
Start the DHCPv6 S.A.R.R. process to acquire the IPv6 address and other PXE boot information.
|
|
|
|
|
|
|
|
@param[in] Private The pointer to the PxeBc private data.
|
|
|
|
@param[in] Dhcp6 The pointer to EFI_DHCP6_PROTOCOL.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The S.A.R.R. process successfully finished.
|
|
|
|
@retval Others Failed to finish the S.A.R.R. process.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
PxeBcDhcp6Sarr (
|
2021-12-05 23:54:07 +01:00
|
|
|
IN PXEBC_PRIVATE_DATA *Private,
|
|
|
|
IN EFI_DHCP6_PROTOCOL *Dhcp6
|
2010-11-01 07:13:54 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
#endif
|