/** @file | |
Common definition for IP4. | |
Copyright (c) 2005 - 2018, Intel Corporation. All rights reserved.<BR> | |
SPDX-License-Identifier: BSD-2-Clause-Patent | |
**/ | |
#ifndef __EFI_IP4_COMMON_H__ | |
#define __EFI_IP4_COMMON_H__ | |
typedef struct _IP4_INTERFACE IP4_INTERFACE; | |
typedef struct _IP4_PROTOCOL IP4_PROTOCOL; | |
typedef struct _IP4_SERVICE IP4_SERVICE; | |
#define IP4_ETHER_PROTO 0x0800 | |
// | |
// The packet is received as link level broadcast/multicast/promiscuous. | |
// | |
#define IP4_LINK_BROADCAST 0x00000001 | |
#define IP4_LINK_MULTICAST 0x00000002 | |
#define IP4_LINK_PROMISC 0x00000004 | |
// | |
// IP4 address cast type classification. Keep it true that any | |
// type bigger than or equal to LOCAL_BROADCAST is broadcast. | |
// | |
#define IP4_PROMISCUOUS 1 | |
#define IP4_LOCAL_HOST 2 | |
#define IP4_MULTICAST 3 | |
#define IP4_LOCAL_BROADCAST 4 // Destination is 255.255.255.255 | |
#define IP4_SUBNET_BROADCAST 5 | |
#define IP4_NET_BROADCAST 6 | |
// | |
// IP4 header flags | |
// | |
#define IP4_HEAD_DF_MASK 0x4000 | |
#define IP4_HEAD_MF_MASK 0x2000 | |
#define IP4_HEAD_OFFSET_MASK 0x1fff | |
#define IP4_ALLZERO_ADDRESS 0x00000000u | |
#define IP4_ALLONE_ADDRESS 0xFFFFFFFFu | |
#define IP4_ALLSYSTEM_ADDRESS 0xE0000001u | |
#define IP4_ALLROUTER_ADDRESS 0xE0000002u | |
/// | |
/// Compose the fragment field to be used in the IP4 header. | |
/// | |
#define IP4_HEAD_FRAGMENT_FIELD(Df, Mf, Offset) \ | |
((UINT16)(((Df) ? IP4_HEAD_DF_MASK : 0) | ((Mf) ? IP4_HEAD_MF_MASK : 0) | (((Offset) >> 3) & IP4_HEAD_OFFSET_MASK))) | |
#define IP4_LAST_FRAGMENT(FragmentField) \ | |
(((FragmentField) & IP4_HEAD_MF_MASK) == 0) | |
#define IP4_FIRST_FRAGMENT(FragmentField) \ | |
((BOOLEAN)(((FragmentField) & IP4_HEAD_OFFSET_MASK) == 0)) | |
#define IP4_DO_NOT_FRAGMENT(FragmentField) \ | |
((BOOLEAN)(((FragmentField) & IP4_HEAD_DF_MASK) == IP4_HEAD_DF_MASK)) | |
#define IP4_IS_BROADCAST(CastType) ((CastType) >= IP4_LOCAL_BROADCAST) | |
/// | |
/// Convert the Microsecond to second. IP transmit/receive time is | |
/// in the unit of microsecond. IP ticks once per second. | |
/// | |
#define IP4_US_TO_SEC(Us) (((Us) + 999999) / 1000000) | |
/** | |
Return the cast type (Unicast/Broadcast) specific to an | |
interface. All the addresses are host byte ordered. | |
@param[in] IpAddr The IP address to classify in host byte order | |
@param[in] IpIf The interface that IpAddr received from | |
@return The cast type of this IP address specific to the interface. | |
@retval IP4_LOCAL_HOST The IpAddr equals to the interface's address | |
@retval IP4_SUBNET_BROADCAST The IpAddr is a directed subnet broadcast to the | |
interface | |
@retval IP4_NET_BROADCAST The IpAddr is a network broadcast to the interface | |
@retval 0 Otherwise. | |
**/ | |
INTN | |
Ip4GetNetCast ( | |
IN IP4_ADDR IpAddr, | |
IN IP4_INTERFACE *IpIf | |
); | |
/** | |
Find the cast type of the packet related to the local host. | |
This isn't the same as link layer cast type. For example, DHCP | |
server may send local broadcast to the local unicast MAC. | |
@param[in] IpSb The IP4 service binding instance that received the | |
packet | |
@param[in] Dst The destination address in the packet (host byte | |
order) | |
@param[in] Src The source address in the packet (host byte order) | |
@return The cast type for the Dst, it will return on the first non-promiscuous | |
cast type to a configured interface. If the packet doesn't match any of | |
the interface, multicast address and local broadcast address are checked. | |
**/ | |
INTN | |
Ip4GetHostCast ( | |
IN IP4_SERVICE *IpSb, | |
IN IP4_ADDR Dst, | |
IN IP4_ADDR Src | |
); | |
/** | |
Find an interface whose configured IP address is Ip. | |
@param[in] IpSb The IP4 service binding instance | |
@param[in] Ip The Ip address (host byte order) to find | |
@return The IP4_INTERFACE point if found, otherwise NULL | |
**/ | |
IP4_INTERFACE * | |
Ip4FindInterface ( | |
IN IP4_SERVICE *IpSb, | |
IN IP4_ADDR Ip | |
); | |
/** | |
Find an interface that Ip is on that connected network. | |
@param[in] IpSb The IP4 service binding instance | |
@param[in] Ip The Ip address (host byte order) to find | |
@return The IP4_INTERFACE point if found, otherwise NULL | |
**/ | |
IP4_INTERFACE * | |
Ip4FindNet ( | |
IN IP4_SERVICE *IpSb, | |
IN IP4_ADDR Ip | |
); | |
/** | |
Find an interface of the service with the same Ip/Netmask pair. | |
@param[in] IpSb Ip4 service binding instance | |
@param[in] Ip The Ip address to find (host byte order) | |
@param[in] Netmask The network to find (host byte order) | |
@return The IP4_INTERFACE point if found, otherwise NULL | |
**/ | |
IP4_INTERFACE * | |
Ip4FindStationAddress ( | |
IN IP4_SERVICE *IpSb, | |
IN IP4_ADDR Ip, | |
IN IP4_ADDR Netmask | |
); | |
/** | |
Get the MAC address for a multicast IP address. Call | |
Mnp's McastIpToMac to find the MAC address in stead of | |
hard code the NIC to be Ethernet. | |
@param[in] Mnp The Mnp instance to get the MAC address. | |
@param[in] Multicast The multicast IP address to translate. | |
@param[out] Mac The buffer to hold the translated address. | |
@retval EFI_SUCCESS if the multicast IP is successfully translated to a | |
multicast MAC address. | |
@retval other Otherwise some error. | |
**/ | |
EFI_STATUS | |
Ip4GetMulticastMac ( | |
IN EFI_MANAGED_NETWORK_PROTOCOL *Mnp, | |
IN IP4_ADDR Multicast, | |
OUT EFI_MAC_ADDRESS *Mac | |
); | |
/** | |
Convert the multibyte field in IP header's byter order. | |
In spite of its name, it can also be used to convert from | |
host to network byte order. | |
@param[in] Head The IP head to convert | |
@return Point to the converted IP head | |
**/ | |
IP4_HEAD * | |
Ip4NtohHead ( | |
IN IP4_HEAD *Head | |
); | |
/** | |
Validate that Ip/Netmask pair is OK to be used as station | |
address. Only continuous netmasks are supported. and check | |
that StationAddress is a unicast address on the network. | |
@param[in] Ip The IP address to validate. | |
@param[in] Netmask The netmask of the IP. | |
@retval TRUE The Ip/Netmask pair is valid. | |
@retval FALSE The Ip/Netmask pair is invalid. | |
**/ | |
BOOLEAN | |
Ip4StationAddressValid ( | |
IN IP4_ADDR Ip, | |
IN IP4_ADDR Netmask | |
); | |
#endif |