2020-09-30 17:17:25 +02:00

138 lines
4.1 KiB
C

/*++
Copyright (c) 2000 Microsoft Corporation
Module Name:
dhcplib.h
Abstract:
DHCP client implementation for XBox
Revision History:
04/21/2000 davidx
Created it.
--*/
#ifndef _DHCPLIB_H
#define _DHCPLIB_H
//
// Information we extract from DHCP options
//
typedef struct _DhcpOptionParam {
INT recvMsgType; // type message received
IPADDR dhcpmask; // subnet mask
IPADDR dhcpServer; // dhcp server address
DHCPTIME t1time; // when to enter renewing state
DHCPTIME t2time; // when to enter rebinding state
DHCPTIME exptime; // lease expiration time
UINT gatewayCount; // number of gateways
IPADDR gateways[MAX_DEFAULT_GATEWAYS];
UINT dnsServerCount; // number of DNS servers
IPADDR dnsServers[MAX_DEFAULT_DNSSERVERS];
CHAR domainName[256]; // domain name
} DhcpOptionParam;
//
// Information we maintain for each interface
//
typedef struct _DhcpInfo {
IfInfo* ifp; // Pointer back to the interface
KEVENT addrEvent; // address acquisition event
INT state; // current state of the interface
INT flags; // misc. flags (see constants below)
IPADDR activeaddr; // active IP address and mask
IPADDR activemask; //
IPADDR dhcpaddr; // last DHCP address
IPADDR autonetaddr; // last autonet address
DHCPTIME acqtime; // when lease acquisition started
DWORD xid; // XID for the next outgoing message
UINT retries; // number of retries for the current message
UINT initRetryCount; // how many retries into INIT state
UINT secsSinceStart; // secs since the address-req process started
UINT timer; // timer (unit = second)
union { // DHCP option paramters
// We're using this odd-looking syntax construct so that
// we can reference the fields in DhcpOptionParam directly.
DhcpOptionParam;
DhcpOptionParam optionParam;
};
} DhcpInfo;
//
// States for an interface
//
enum {
STATE_NONE, // temporary wait state after startup
STATE_STATIC_ADDR, // statically assigned address
STATE_INIT, // sending discover
STATE_REQUESTING, // waiting for DHCPACK after selecting
STATE_INIT_REBOOT, // rebooting with valid lease
STATE_BOUND, // bound with valid address lease
STATE_RENEWING, // renewing after T1 expires
STATE_REBINDING, // rebinding after T2 expires
STATE_DECLINING, // temporary wait state after sending decline
STATE_SELECT_AUTOADDR // checking autonet address conflicts
};
//
// Constants for the DhcpInfo.flags field:
//
#define FLAG_RELEASE_ON_REBOOT 0x0001
#define FLAG_SEND_DHCPINFORM 0x0002
#define FLAG_CREATED_BY_DEBUGGER 0x0004
#define FLAG_ACTIVE_DHCPADDR 0x00010000
#define FLAG_ACTIVE_AUTONETADDR 0x00020000
#define FLAG_ACTIVE_ADDRMASK (FLAG_ACTIVE_DHCPADDR | FLAG_ACTIVE_AUTONETADDR)
INLINE BOOL ActiveDhcpAddr(DhcpInfo* dhcp) {
return (dhcp->flags & FLAG_ACTIVE_DHCPADDR);
}
INLINE BOOL ActiveAutonetAddr(DhcpInfo* dhcp) {
return (dhcp->flags & FLAG_ACTIVE_AUTONETADDR);
}
//
// Dump DHCP message in the debugger
//
#if DBG
VOID DhcpDumpMessage(const DhcpMessage* msg, UINT msglen);
#else
#define DhcpDumpMessage(msg, msglen)
#endif
//
// Map interface hardware type to DHCP hardware type
//
INLINE BYTE DhcpMapHwtype(WORD iftype) {
return (BYTE) ((iftype == IFTYPE_ETHERNET) ?
HWTYPE_10MB_ETHERNET :
HWTYPE_PPP);
}
//
// Check whether there is a conflict with an IP address
//
INLINE VOID DhcpCheckAddressConflict(IfInfo* ifp, IPADDR ipaddr) {
ifp->Ioctl(ifp, IFCTL_CHECK_ADDR_CONFLICT, &ipaddr, sizeof(ipaddr), NULL, NULL);
}
//
// Signal address acquisition event
//
INLINE VOID DhcpSignalAddrEvent(DhcpInfo* dhcp) {
KeSetEvent(&dhcp->addrEvent, IO_NO_INCREMENT, FALSE);
}
#endif // !_DHCPLIB_H