mirror of https://github.com/acidanthera/audk.git
390 lines
13 KiB
C
390 lines
13 KiB
C
|
/** @file
|
||
|
Functions declaration related with DHCPv4 for UefiPxeBc Driver.
|
||
|
|
||
|
Copyright (c) 2009 - 2010, Intel Corporation. All rights reserved.<BR>
|
||
|
|
||
|
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_PXEBC_DHCP4_H__
|
||
|
#define __EFI_PXEBC_DHCP4_H__
|
||
|
|
||
|
#define PXEBC_DHCP4_OPTION_MAX_NUM 16
|
||
|
#define PXEBC_DHCP4_OPTION_MAX_SIZE 312
|
||
|
#define PXEBC_DHCP4_PACKET_MAX_SIZE 1472
|
||
|
#define PXEBC_DHCP4_S_PORT 67
|
||
|
#define PXEBC_DHCP4_C_PORT 68
|
||
|
#define PXEBC_BS_DOWNLOAD_PORT 69
|
||
|
#define PXEBC_BS_DISCOVER_PORT 4011
|
||
|
#define PXEBC_DHCP4_OPCODE_REQUEST 1
|
||
|
#define PXEBC_DHCP4_OPCODE_REPLY 2
|
||
|
#define PXEBC_DHCP4_MSG_TYPE_REQUEST 3
|
||
|
#define PXEBC_DHCP4_MAGIC 0x63538263 // network byte order
|
||
|
|
||
|
//
|
||
|
// Dhcp Options
|
||
|
//
|
||
|
#define PXEBC_DHCP4_TAG_PAD 0 // Pad Option
|
||
|
#define PXEBC_DHCP4_TAG_EOP 255 // End Option
|
||
|
#define PXEBC_DHCP4_TAG_NETMASK 1 // Subnet Mask
|
||
|
#define PXEBC_DHCP4_TAG_TIME_OFFSET 2 // Time Offset from UTC
|
||
|
#define PXEBC_DHCP4_TAG_ROUTER 3 // Router option,
|
||
|
#define PXEBC_DHCP4_TAG_TIME_SERVER 4 // Time Server
|
||
|
#define PXEBC_DHCP4_TAG_NAME_SERVER 5 // Name Server
|
||
|
#define PXEBC_DHCP4_TAG_DNS_SERVER 6 // Domain Name Server
|
||
|
#define PXEBC_DHCP4_TAG_HOSTNAME 12 // Host Name
|
||
|
#define PXEBC_DHCP4_TAG_BOOTFILE_LEN 13 // Boot File Size
|
||
|
#define PXEBC_DHCP4_TAG_DUMP 14 // Merit Dump File
|
||
|
#define PXEBC_DHCP4_TAG_DOMAINNAME 15 // Domain Name
|
||
|
#define PXEBC_DHCP4_TAG_ROOTPATH 17 // Root path
|
||
|
#define PXEBC_DHCP4_TAG_EXTEND_PATH 18 // Extensions Path
|
||
|
#define PXEBC_DHCP4_TAG_EMTU 22 // Maximum Datagram Reassembly Size
|
||
|
#define PXEBC_DHCP4_TAG_TTL 23 // Default IP Time-to-live
|
||
|
#define PXEBC_DHCP4_TAG_BROADCAST 28 // Broadcast Address
|
||
|
#define PXEBC_DHCP4_TAG_NIS_DOMAIN 40 // Network Information Service Domain
|
||
|
#define PXEBC_DHCP4_TAG_NIS_SERVER 41 // Network Information Servers
|
||
|
#define PXEBC_DHCP4_TAG_NTP_SERVER 42 // Network Time Protocol Servers
|
||
|
#define PXEBC_DHCP4_TAG_VENDOR 43 // Vendor Specific Information
|
||
|
#define PXEBC_DHCP4_TAG_REQUEST_IP 50 // Requested IP Address
|
||
|
#define PXEBC_DHCP4_TAG_LEASE 51 // IP Address Lease Time
|
||
|
#define PXEBC_DHCP4_TAG_OVERLOAD 52 // Option Overload
|
||
|
#define PXEBC_DHCP4_TAG_MSG_TYPE 53 // DHCP Message Type
|
||
|
#define PXEBC_DHCP4_TAG_SERVER_ID 54 // Server Identifier
|
||
|
#define PXEBC_DHCP4_TAG_PARA_LIST 55 // Parameter Request List
|
||
|
#define PXEBC_DHCP4_TAG_MAXMSG 57 // Maximum DHCP Message Size
|
||
|
#define PXEBC_DHCP4_TAG_T1 58 // Renewal (T1) Time Value
|
||
|
#define PXEBC_DHCP4_TAG_T2 59 // Rebinding (T2) Time Value
|
||
|
#define PXEBC_DHCP4_TAG_CLASS_ID 60 // Vendor class identifier
|
||
|
#define PXEBC_DHCP4_TAG_CLIENT_ID 61 // Client-identifier
|
||
|
#define PXEBC_DHCP4_TAG_TFTP 66 // TFTP server name
|
||
|
#define PXEBC_DHCP4_TAG_BOOTFILE 67 // Bootfile name
|
||
|
#define PXEBC_PXE_DHCP4_TAG_ARCH 93
|
||
|
#define PXEBC_PXE_DHCP4_TAG_UNDI 94
|
||
|
#define PXEBC_PXE_DHCP4_TAG_UUID 97
|
||
|
//
|
||
|
// Sub-Options in Dhcp Vendor Option
|
||
|
//
|
||
|
#define PXEBC_VENDOR_TAG_MTFTP_IP 1
|
||
|
#define PXEBC_VENDOR_TAG_MTFTP_CPORT 2
|
||
|
#define PXEBC_VENDOR_TAG_MTFTP_SPORT 3
|
||
|
#define PXEBC_VENDOR_TAG_MTFTP_TIMEOUT 4
|
||
|
#define PXEBC_VENDOR_TAG_MTFTP_DELAY 5
|
||
|
#define PXEBC_VENDOR_TAG_DISCOVER_CTRL 6
|
||
|
#define PXEBC_VENDOR_TAG_DISCOVER_MCAST 7
|
||
|
#define PXEBC_VENDOR_TAG_BOOT_SERVERS 8
|
||
|
#define PXEBC_VENDOR_TAG_BOOT_MENU 9
|
||
|
#define PXEBC_VENDOR_TAG_MENU_PROMPT 10
|
||
|
#define PXEBC_VENDOR_TAG_MCAST_ALLOC 11
|
||
|
#define PXEBC_VENDOR_TAG_CREDENTIAL_TYPES 12
|
||
|
#define PXEBC_VENDOR_TAG_BOOT_ITEM 71
|
||
|
|
||
|
#define PXEBC_BOOT_REQUEST_TIMEOUT 1
|
||
|
#define PXEBC_BOOT_REQUEST_RETRIES 4
|
||
|
|
||
|
#define PXEBC_DHCP4_OVERLOAD_FILE 1
|
||
|
#define PXEBC_DHCP4_OVERLOAD_SERVER_NAME 2
|
||
|
|
||
|
|
||
|
//
|
||
|
// The array index of the DHCP4 option tag interested
|
||
|
//
|
||
|
#define PXEBC_DHCP4_TAG_INDEX_BOOTFILE_LEN 0
|
||
|
#define PXEBC_DHCP4_TAG_INDEX_VENDOR 1
|
||
|
#define PXEBC_DHCP4_TAG_INDEX_OVERLOAD 2
|
||
|
#define PXEBC_DHCP4_TAG_INDEX_MSG_TYPE 3
|
||
|
#define PXEBC_DHCP4_TAG_INDEX_SERVER_ID 4
|
||
|
#define PXEBC_DHCP4_TAG_INDEX_CLASS_ID 5
|
||
|
#define PXEBC_DHCP4_TAG_INDEX_BOOTFILE 6
|
||
|
#define PXEBC_DHCP4_TAG_INDEX_MAX 7
|
||
|
|
||
|
//
|
||
|
// Dhcp4 and Dhcp6 share this definition, and corresponding
|
||
|
// relatioinship is as follows:
|
||
|
//
|
||
|
// Dhcp4Discover <> Dhcp6Solicit
|
||
|
// Dhcp4Offer <> Dhcp6Advertise
|
||
|
// Dhcp4Request <> Dhcp6Request
|
||
|
// Dhcp4Ack <> DHcp6Reply
|
||
|
//
|
||
|
typedef enum {
|
||
|
PxeOfferTypeDhcpOnly,
|
||
|
PxeOfferTypeDhcpPxe10,
|
||
|
PxeOfferTypeDhcpWfm11a,
|
||
|
PxeOfferTypeDhcpBinl,
|
||
|
PxeOfferTypeProxyPxe10,
|
||
|
PxeOfferTypeProxyWfm11a,
|
||
|
PxeOfferTypeProxyBinl,
|
||
|
PxeOfferTypeBootp,
|
||
|
PxeOfferTypeMax
|
||
|
} PXEBC_OFFER_TYPE;
|
||
|
|
||
|
#define BIT(x) (1 << x)
|
||
|
#define CTRL(x) (0x1F & (x))
|
||
|
#define DEFAULT_CLASS_ID_DATA "PXEClient:Arch:?????:????:??????"
|
||
|
#define DEFAULT_UNDI_TYPE 1
|
||
|
#define DEFAULT_UNDI_MAJOR 3
|
||
|
#define DEFAULT_UNDI_MINOR 0
|
||
|
|
||
|
#define MTFTP_VENDOR_OPTION_BIT_MAP \
|
||
|
(BIT (PXEBC_VENDOR_TAG_MTFTP_IP) | \
|
||
|
BIT (PXEBC_VENDOR_TAG_MTFTP_CPORT) | \
|
||
|
BIT (PXEBC_VENDOR_TAG_MTFTP_SPORT) | \
|
||
|
BIT (PXEBC_VENDOR_TAG_MTFTP_TIMEOUT) | \
|
||
|
BIT (PXEBC_VENDOR_TAG_MTFTP_DELAY))
|
||
|
|
||
|
#define DISCOVER_VENDOR_OPTION_BIT_MAP \
|
||
|
(BIT (PXEBC_VENDOR_TAG_DISCOVER_CTRL) | \
|
||
|
BIT (PXEBC_VENDOR_TAG_DISCOVER_MCAST) | \
|
||
|
BIT (PXEBC_VENDOR_TAG_BOOT_SERVERS) | \
|
||
|
BIT (PXEBC_VENDOR_TAG_BOOT_MENU) | \
|
||
|
BIT (PXEBC_VENDOR_TAG_MENU_PROMPT))
|
||
|
|
||
|
#define IS_VALID_BOOT_PROMPT(x) \
|
||
|
((((x)[0]) & BIT (PXEBC_VENDOR_TAG_MENU_PROMPT)) \
|
||
|
== BIT (PXEBC_VENDOR_TAG_MENU_PROMPT))
|
||
|
|
||
|
#define IS_VALID_BOOT_MENU(x) \
|
||
|
((((x)[0]) & BIT (PXEBC_VENDOR_TAG_BOOT_MENU)) \
|
||
|
== BIT (PXEBC_VENDOR_TAG_BOOT_MENU))
|
||
|
|
||
|
#define IS_VALID_MTFTP_VENDOR_OPTION(x) \
|
||
|
(((UINT32) ((x)[0]) & MTFTP_VENDOR_OPTION_BIT_MAP) \
|
||
|
== MTFTP_VENDOR_OPTION_BIT_MAP)
|
||
|
|
||
|
#define IS_VALID_DISCOVER_VENDOR_OPTION(x) \
|
||
|
(((UINT32) ((x)[0]) & DISCOVER_VENDOR_OPTION_BIT_MAP) != 0)
|
||
|
|
||
|
#define IS_VALID_CREDENTIAL_VENDOR_OPTION(x) \
|
||
|
(((UINT32) ((x)[0]) & BIT (PXEBC_VENDOR_TAG_CREDENTIAL_TYPES)) \
|
||
|
== BIT (PXEBC_VENDOR_TAG_CREDENTIAL_TYPES))
|
||
|
|
||
|
#define IS_VALID_BOOTITEM_VENDOR_OPTION(x) \
|
||
|
(((UINT32) ((x)[PXEBC_VENDOR_TAG_BOOT_ITEM / 32]) & \
|
||
|
BIT (PXEBC_VENDOR_TAG_BOOT_ITEM % 32)) \
|
||
|
== BIT (PXEBC_VENDOR_TAG_BOOT_ITEM % 32))
|
||
|
|
||
|
#define SET_VENDOR_OPTION_BIT_MAP(x, y) \
|
||
|
(*(x + ((y) / 32)) = (UINT32) ((UINT32) ((x)[(y) / 32]) | BIT ((y) % 32)))
|
||
|
|
||
|
#define GET_NEXT_DHCP_OPTION(Opt) \
|
||
|
(EFI_DHCP4_PACKET_OPTION *) ((UINT8 *) (Opt) + \
|
||
|
sizeof (EFI_DHCP4_PACKET_OPTION) + (Opt)->Length - 1)
|
||
|
|
||
|
#define GET_OPTION_BUFFER_LEN(Pkt) \
|
||
|
((Pkt)->Length - sizeof (EFI_DHCP4_HEADER) - 4)
|
||
|
|
||
|
#define GET_NEXT_BOOT_SVR_ENTRY(Ent) \
|
||
|
(PXEBC_BOOT_SVR_ENTRY *) ((UINT8 *) Ent + sizeof (*(Ent)) + \
|
||
|
((Ent)->IpCnt - 1) * sizeof (EFI_IPv4_ADDRESS))
|
||
|
|
||
|
#define IS_PROXY_DHCP_OFFER(Offer) \
|
||
|
EFI_IP4_EQUAL (&(Offer)->Dhcp4.Header.YourAddr, &mZeroIp4Addr)
|
||
|
|
||
|
#define IS_DISABLE_BCAST_DISCOVER(x) \
|
||
|
(((x) & BIT (0)) == BIT (0))
|
||
|
|
||
|
#define IS_DISABLE_MCAST_DISCOVER(x) \
|
||
|
(((x) & BIT (1)) == BIT (1))
|
||
|
|
||
|
#define IS_ENABLE_USE_SERVER_LIST(x) \
|
||
|
(((x) & BIT (2)) == BIT (2))
|
||
|
|
||
|
#define IS_ENABLE_BOOT_FILE_NAME(x) \
|
||
|
(((x) & BIT (3)) == BIT (3))
|
||
|
|
||
|
|
||
|
#pragma pack(1)
|
||
|
typedef struct {
|
||
|
UINT8 ParaList[135];
|
||
|
} PXEBC_DHCP4_OPTION_PARA;
|
||
|
|
||
|
typedef struct {
|
||
|
UINT16 Size;
|
||
|
} PXEBC_DHCP4_OPTION_MAX_MESG_SIZE;
|
||
|
|
||
|
typedef struct {
|
||
|
UINT8 Type;
|
||
|
UINT8 MajorVer;
|
||
|
UINT8 MinorVer;
|
||
|
} PXEBC_DHCP4_OPTION_UNDI;
|
||
|
|
||
|
typedef struct {
|
||
|
UINT8 Type;
|
||
|
} PXEBC_DHCP4_OPTION_MESG;
|
||
|
|
||
|
typedef struct {
|
||
|
UINT16 Type;
|
||
|
} PXEBC_DHCP4_OPTION_ARCH;
|
||
|
|
||
|
typedef struct {
|
||
|
UINT8 ClassIdentifier[10];
|
||
|
UINT8 ArchitecturePrefix[5];
|
||
|
UINT8 ArchitectureType[5];
|
||
|
UINT8 Lit3[1];
|
||
|
UINT8 InterfaceName[4];
|
||
|
UINT8 Lit4[1];
|
||
|
UINT8 UndiMajor[3];
|
||
|
UINT8 UndiMinor[3];
|
||
|
} PXEBC_DHCP4_OPTION_CLID;
|
||
|
|
||
|
typedef struct {
|
||
|
UINT8 Type;
|
||
|
UINT8 Guid[16];
|
||
|
} PXEBC_DHCP4_OPTION_UUID;
|
||
|
|
||
|
typedef struct {
|
||
|
UINT16 Type;
|
||
|
UINT16 Layer;
|
||
|
} PXEBC_OPTION_BOOT_ITEM;
|
||
|
|
||
|
#pragma pack()
|
||
|
|
||
|
typedef union {
|
||
|
PXEBC_DHCP4_OPTION_PARA *Para;
|
||
|
PXEBC_DHCP4_OPTION_UNDI *Undi;
|
||
|
PXEBC_DHCP4_OPTION_ARCH *Arch;
|
||
|
PXEBC_DHCP4_OPTION_CLID *Clid;
|
||
|
PXEBC_DHCP4_OPTION_UUID *Uuid;
|
||
|
PXEBC_DHCP4_OPTION_MESG *Mesg;
|
||
|
PXEBC_DHCP4_OPTION_MAX_MESG_SIZE *MaxMesgSize;
|
||
|
} PXEBC_DHCP4_OPTION_ENTRY;
|
||
|
|
||
|
typedef struct {
|
||
|
UINT16 Type;
|
||
|
UINT8 IpCnt;
|
||
|
EFI_IPv4_ADDRESS IpAddr[1];
|
||
|
} PXEBC_BOOT_SVR_ENTRY;
|
||
|
|
||
|
typedef struct {
|
||
|
UINT16 Type;
|
||
|
UINT8 DescLen;
|
||
|
UINT8 DescStr[1];
|
||
|
} PXEBC_BOOT_MENU_ENTRY;
|
||
|
|
||
|
typedef struct {
|
||
|
UINT8 Timeout;
|
||
|
UINT8 Prompt[1];
|
||
|
} PXEBC_MENU_PROMPT;
|
||
|
|
||
|
typedef struct {
|
||
|
UINT32 BitMap[8];
|
||
|
EFI_IPv4_ADDRESS MtftpIp;
|
||
|
UINT16 MtftpCPort;
|
||
|
UINT16 MtftpSPort;
|
||
|
UINT8 MtftpTimeout;
|
||
|
UINT8 MtftpDelay;
|
||
|
UINT8 DiscoverCtrl;
|
||
|
EFI_IPv4_ADDRESS DiscoverMcastIp;
|
||
|
EFI_IPv4_ADDRESS McastIpBase;
|
||
|
UINT16 McastIpBlock;
|
||
|
UINT16 McastIpRange;
|
||
|
UINT16 BootSrvType;
|
||
|
UINT16 BootSrvLayer;
|
||
|
PXEBC_BOOT_SVR_ENTRY *BootSvr;
|
||
|
UINT8 BootSvrLen;
|
||
|
PXEBC_BOOT_MENU_ENTRY *BootMenu;
|
||
|
UINT8 BootMenuLen;
|
||
|
PXEBC_MENU_PROMPT *MenuPrompt;
|
||
|
UINT8 MenuPromptLen;
|
||
|
UINT32 *CredType;
|
||
|
UINT8 CredTypeLen;
|
||
|
} PXEBC_VENDOR_OPTION;
|
||
|
|
||
|
typedef union {
|
||
|
EFI_DHCP4_PACKET Offer;
|
||
|
EFI_DHCP4_PACKET Ack;
|
||
|
UINT8 Buffer[PXEBC_DHCP4_PACKET_MAX_SIZE];
|
||
|
} PXEBC_DHCP4_PACKET;
|
||
|
|
||
|
typedef struct {
|
||
|
PXEBC_DHCP4_PACKET Packet;
|
||
|
PXEBC_OFFER_TYPE OfferType;
|
||
|
EFI_DHCP4_PACKET_OPTION *OptList[PXEBC_DHCP4_TAG_INDEX_MAX];
|
||
|
PXEBC_VENDOR_OPTION VendorOpt;
|
||
|
} PXEBC_DHCP4_PACKET_CACHE;
|
||
|
|
||
|
|
||
|
/**
|
||
|
Create a template DHCPv4 packet as a seed.
|
||
|
|
||
|
@param[out] Seed Pointer to the seed packet.
|
||
|
@param[in] Udp4 Pointer to EFI_UDP4_PROTOCOL.
|
||
|
|
||
|
**/
|
||
|
VOID
|
||
|
PxeBcSeedDhcp4Packet (
|
||
|
OUT EFI_DHCP4_PACKET *Seed,
|
||
|
IN EFI_UDP4_PROTOCOL *Udp4
|
||
|
);
|
||
|
|
||
|
|
||
|
/**
|
||
|
Parse the cached DHCPv4 packet, including all the options.
|
||
|
|
||
|
@param[in] Cache4 Pointer to cached DHCPv4 packet.
|
||
|
|
||
|
@retval EFI_SUCCESS Parsed the DHCPv4 packet successfully.
|
||
|
@retval EFI_DEVICE_ERROR Failed to parse and invalid packet.
|
||
|
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
PxeBcParseDhcp4Packet (
|
||
|
IN PXEBC_DHCP4_PACKET_CACHE *Cache4
|
||
|
);
|
||
|
|
||
|
|
||
|
/**
|
||
|
Build and send out the request packet for the bootfile, and parse the reply.
|
||
|
|
||
|
@param[in] Private Pointer to PxeBc private data.
|
||
|
@param[in] Type PxeBc option boot item type.
|
||
|
@param[in] Layer Pointer to option boot item layer.
|
||
|
@param[in] UseBis Use BIS or not.
|
||
|
@param[in] DestIp Pointer to the server address.
|
||
|
@param[in] IpCount The total count of the server address.
|
||
|
@param[in] SrvList Pointer to EFI_PXE_BASE_CODE_SRVLIST.
|
||
|
|
||
|
@retval EFI_SUCCESS Successfully discovered boot 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
|
||
|
PxeBcDhcp4Discover (
|
||
|
IN PXEBC_PRIVATE_DATA *Private,
|
||
|
IN UINT16 Type,
|
||
|
IN UINT16 *Layer,
|
||
|
IN BOOLEAN UseBis,
|
||
|
IN EFI_IP_ADDRESS *DestIp,
|
||
|
IN UINT16 IpCount,
|
||
|
IN EFI_PXE_BASE_CODE_SRVLIST *SrvList
|
||
|
);
|
||
|
|
||
|
|
||
|
/**
|
||
|
Start the D.O.R.A DHCPv4 process to acquire the IPv4 address and other PXE boot information.
|
||
|
|
||
|
@param[in] Private Pointer to PxeBc private data.
|
||
|
@param[in] Dhcp4 Pointer to the EFI_DHCP4_PROTOCOL
|
||
|
|
||
|
@retval EFI_SUCCESS The D.O.R.A process successfully finished.
|
||
|
@retval Others Failed to finish the D.O.R.A process.
|
||
|
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
PxeBcDhcp4Dora (
|
||
|
IN PXEBC_PRIVATE_DATA *Private,
|
||
|
IN EFI_DHCP4_PROTOCOL *Dhcp4
|
||
|
);
|
||
|
|
||
|
#endif
|
||
|
|