2007-09-30 05:08:02 +02:00
|
|
|
/** @file
|
2009-01-16 01:09:52 +01:00
|
|
|
EFI DHCP protocol implementation.
|
|
|
|
RFCs supported are:
|
|
|
|
RFC 2131: Dynamic Host Configuration Protocol
|
|
|
|
RFC 2132: DHCP Options and BOOTP Vendor Extensions
|
|
|
|
RFC 1534: Interoperation Between DHCP and BOOTP
|
|
|
|
RFC 3396: Encoding Long Options in DHCP.
|
2018-06-27 15:08:52 +02:00
|
|
|
|
2018-01-10 08:24:53 +01:00
|
|
|
Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:05:13 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2007-09-30 05:08:02 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __EFI_DHCP4_IMPL_H__
|
|
|
|
#define __EFI_DHCP4_IMPL_H__
|
|
|
|
|
|
|
|
|
2007-07-30 04:37:10 +02:00
|
|
|
|
2009-02-09 03:59:07 +01:00
|
|
|
#include <Uefi.h>
|
2007-07-30 04:37:10 +02:00
|
|
|
|
|
|
|
#include <Protocol/Dhcp4.h>
|
|
|
|
#include <Protocol/Udp4.h>
|
2016-06-22 04:25:00 +02:00
|
|
|
#include <IndustryStandard/Dhcp.h>
|
2007-07-30 04:37:10 +02:00
|
|
|
#include <Library/DebugLib.h>
|
|
|
|
#include <Library/UefiDriverEntryPoint.h>
|
|
|
|
#include <Library/UefiBootServicesTableLib.h>
|
|
|
|
#include <Library/UefiLib.h>
|
2007-09-30 05:08:02 +02:00
|
|
|
#include <Library/BaseLib.h>
|
|
|
|
#include <Library/NetLib.h>
|
|
|
|
|
|
|
|
typedef struct _DHCP_SERVICE DHCP_SERVICE;
|
|
|
|
typedef struct _DHCP_PROTOCOL DHCP_PROTOCOL;
|
|
|
|
|
|
|
|
#include "Dhcp4Option.h"
|
|
|
|
#include "Dhcp4Io.h"
|
|
|
|
|
2008-12-16 16:34:21 +01:00
|
|
|
#define DHCP_SERVICE_SIGNATURE SIGNATURE_32 ('D', 'H', 'C', 'P')
|
|
|
|
#define DHCP_PROTOCOL_SIGNATURE SIGNATURE_32 ('d', 'h', 'c', 'p')
|
2007-09-30 05:08:02 +02:00
|
|
|
|
2017-12-18 02:16:36 +01:00
|
|
|
#define DHCP_CHECK_MEDIA_WAITING_TIME EFI_TIMER_PERIOD_SECONDS(20)
|
2009-11-04 09:18:34 +01:00
|
|
|
|
|
|
|
//
|
|
|
|
// The state of the DHCP service. It starts as UNCONFIGED. If
|
|
|
|
// and active child configures the service successfully, it
|
|
|
|
// goes to CONFIGED. If the active child configures NULL, it
|
2012-10-17 10:23:41 +02:00
|
|
|
// goes back to UNCONFIGED. It becomes DESTROY if it is (partly)
|
|
|
|
// destroyed.
|
2009-11-04 09:18:34 +01:00
|
|
|
//
|
|
|
|
#define DHCP_UNCONFIGED 0
|
|
|
|
#define DHCP_CONFIGED 1
|
2012-10-17 10:23:41 +02:00
|
|
|
#define DHCP_DESTROY 2
|
2009-11-04 09:18:34 +01:00
|
|
|
|
2007-09-30 05:08:02 +02:00
|
|
|
|
|
|
|
struct _DHCP_PROTOCOL {
|
|
|
|
UINT32 Signature;
|
|
|
|
EFI_DHCP4_PROTOCOL Dhcp4Protocol;
|
2008-02-14 10:40:22 +01:00
|
|
|
LIST_ENTRY Link;
|
2007-09-30 05:08:02 +02:00
|
|
|
EFI_HANDLE Handle;
|
|
|
|
DHCP_SERVICE *Service;
|
|
|
|
|
2012-10-17 10:23:41 +02:00
|
|
|
BOOLEAN InDestroy;
|
2007-09-30 05:08:02 +02:00
|
|
|
|
|
|
|
EFI_EVENT CompletionEvent;
|
|
|
|
EFI_EVENT RenewRebindEvent;
|
|
|
|
|
|
|
|
EFI_DHCP4_TRANSMIT_RECEIVE_TOKEN *Token;
|
2009-10-30 06:11:38 +01:00
|
|
|
UDP_IO *UdpIo; // The UDP IO used for TransmitReceive.
|
2007-12-18 08:01:23 +01:00
|
|
|
UINT32 Timeout;
|
2011-11-21 04:40:24 +01:00
|
|
|
UINT16 ElaspedTime;
|
2007-12-18 08:01:23 +01:00
|
|
|
NET_BUF_QUEUE ResponseQueue;
|
2007-09-30 05:08:02 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
//
|
|
|
|
// DHCP driver is specical in that it is a singleton. Although it
|
|
|
|
// has a service binding, there can be only one active child.
|
|
|
|
//
|
|
|
|
struct _DHCP_SERVICE {
|
|
|
|
UINT32 Signature;
|
|
|
|
EFI_SERVICE_BINDING_PROTOCOL ServiceBinding;
|
|
|
|
|
2012-10-17 10:23:41 +02:00
|
|
|
INTN ServiceState; // CONFIGED, UNCONFIGED, and DESTROY
|
2007-09-30 05:08:02 +02:00
|
|
|
|
|
|
|
EFI_HANDLE Controller;
|
|
|
|
EFI_HANDLE Image;
|
|
|
|
|
2008-02-14 10:40:22 +01:00
|
|
|
LIST_ENTRY Children;
|
2007-09-30 05:08:02 +02:00
|
|
|
UINTN NumChildren;
|
|
|
|
|
|
|
|
INTN DhcpState;
|
|
|
|
EFI_STATUS IoStatus; // the result of last user operation
|
|
|
|
UINT32 Xid;
|
|
|
|
|
|
|
|
IP4_ADDR ClientAddr; // lease IP or configured client address
|
|
|
|
IP4_ADDR Netmask;
|
|
|
|
IP4_ADDR ServerAddr;
|
|
|
|
|
|
|
|
EFI_DHCP4_PACKET *LastOffer; // The last received offer
|
|
|
|
EFI_DHCP4_PACKET *Selected;
|
|
|
|
DHCP_PARAMETER *Para;
|
|
|
|
|
|
|
|
UINT32 Lease;
|
|
|
|
UINT32 T1;
|
|
|
|
UINT32 T2;
|
|
|
|
INTN ExtraRefresh; // This refresh is reqested by user
|
|
|
|
|
2009-10-30 06:11:38 +01:00
|
|
|
UDP_IO *UdpIo; // Udp child receiving all DHCP message
|
|
|
|
UDP_IO *LeaseIoPort; // Udp child with lease IP
|
2009-06-08 04:13:36 +02:00
|
|
|
EFI_DHCP4_PACKET *LastPacket; // The last sent packet for retransmission
|
2007-09-30 05:08:02 +02:00
|
|
|
EFI_MAC_ADDRESS Mac;
|
|
|
|
UINT8 HwType;
|
|
|
|
UINT8 HwLen;
|
2008-04-02 10:45:36 +02:00
|
|
|
UINT8 ClientAddressSendOut[16];
|
2007-09-30 05:08:02 +02:00
|
|
|
|
|
|
|
DHCP_PROTOCOL *ActiveChild;
|
|
|
|
EFI_DHCP4_CONFIG_DATA ActiveConfig;
|
|
|
|
UINT32 UserOptionLen;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Timer event and various timer
|
|
|
|
//
|
|
|
|
EFI_EVENT Timer;
|
|
|
|
|
|
|
|
UINT32 PacketToLive; // Retransmission timer for our packets
|
2009-06-08 04:13:36 +02:00
|
|
|
UINT32 LastTimeout; // Record the init value of PacketToLive every time
|
2007-09-30 05:08:02 +02:00
|
|
|
INTN CurRetry;
|
|
|
|
INTN MaxRetries;
|
|
|
|
UINT32 LeaseLife;
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
EFI_DHCP4_PACKET_OPTION **Option;
|
|
|
|
UINT32 OptionCount;
|
|
|
|
UINT32 Index;
|
|
|
|
} DHCP_PARSE_CONTEXT;
|
|
|
|
|
|
|
|
#define DHCP_INSTANCE_FROM_THIS(Proto) \
|
|
|
|
CR ((Proto), DHCP_PROTOCOL, Dhcp4Protocol, DHCP_PROTOCOL_SIGNATURE)
|
|
|
|
|
|
|
|
#define DHCP_SERVICE_FROM_THIS(Sb) \
|
|
|
|
CR ((Sb), DHCP_SERVICE, ServiceBinding, DHCP_SERVICE_SIGNATURE)
|
|
|
|
|
|
|
|
extern EFI_DHCP4_PROTOCOL mDhcp4ProtocolTemplate;
|
|
|
|
|
2008-06-30 09:20:33 +02:00
|
|
|
/**
|
|
|
|
Give up the control of the DHCP service to let other child
|
|
|
|
resume. Don't change the service's DHCP state and the Client
|
|
|
|
address and option list configure as required by RFC2131.
|
|
|
|
|
|
|
|
@param DhcpSb The DHCP service instance.
|
|
|
|
|
|
|
|
**/
|
2007-09-30 05:08:02 +02:00
|
|
|
VOID
|
|
|
|
DhcpYieldControl (
|
2008-11-18 15:30:46 +01:00
|
|
|
IN DHCP_SERVICE *DhcpSb
|
2007-09-30 05:08:02 +02:00
|
|
|
);
|
|
|
|
|
2008-11-18 15:30:46 +01:00
|
|
|
/**
|
|
|
|
Complete a Dhcp4 transaction and signal the upper layer.
|
2010-02-23 02:43:45 +01:00
|
|
|
|
2008-11-18 15:30:46 +01:00
|
|
|
@param Instance Dhcp4 instance.
|
|
|
|
|
|
|
|
**/
|
2007-12-18 08:01:23 +01:00
|
|
|
VOID
|
|
|
|
PxeDhcpDone (
|
|
|
|
IN DHCP_PROTOCOL *Instance
|
|
|
|
);
|
|
|
|
|
2010-02-23 02:43:45 +01:00
|
|
|
/**
|
|
|
|
Free the resource related to the configure parameters.
|
|
|
|
DHCP driver will make a copy of the user's configure
|
|
|
|
such as the time out value.
|
|
|
|
|
|
|
|
@param Config The DHCP configure data
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
DhcpCleanConfigure (
|
|
|
|
IN OUT EFI_DHCP4_CONFIG_DATA *Config
|
|
|
|
);
|
|
|
|
|
2018-01-10 08:24:53 +01:00
|
|
|
/**
|
|
|
|
Callback of Dhcp packet. Does nothing.
|
|
|
|
|
|
|
|
@param Arg The context.
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
DhcpDummyExtFree (
|
|
|
|
IN VOID *Arg
|
|
|
|
);
|
|
|
|
|
2011-11-21 04:40:24 +01:00
|
|
|
/**
|
|
|
|
Set the elapsed time based on the given instance and the pointer to the
|
|
|
|
elapsed time option.
|
|
|
|
|
|
|
|
@param[in] Elapsed The pointer to the position to append.
|
|
|
|
@param[in] Instance The pointer to the Dhcp4 instance.
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
SetElapsedTime (
|
|
|
|
IN UINT16 *Elapsed,
|
|
|
|
IN DHCP_PROTOCOL *Instance
|
|
|
|
);
|
|
|
|
|
2007-09-30 05:08:02 +02:00
|
|
|
#endif
|