/** @file | |
Definition of Neighbor Discovery support routines. | |
Copyright (c) 2009 - 2012, 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_IP6_ND_H__ | |
#define __EFI_IP6_ND_H__ | |
#define IP6_GET_TICKS(Ms) (((Ms) + IP6_TIMER_INTERVAL_IN_MS - 1) / IP6_TIMER_INTERVAL_IN_MS) | |
enum { | |
IP6_INF_ROUTER_LIFETIME = 0xFFFF, | |
IP6_MAX_RTR_SOLICITATION_DELAY = 1000, ///< 1000 milliseconds | |
IP6_MAX_RTR_SOLICITATIONS = 3, | |
IP6_RTR_SOLICITATION_INTERVAL = 4000, | |
IP6_MIN_RANDOM_FACTOR_SCALED = 1, | |
IP6_MAX_RANDOM_FACTOR_SCALED = 3, | |
IP6_RANDOM_FACTOR_SCALE = 2, | |
IP6_MAX_MULTICAST_SOLICIT = 3, | |
IP6_MAX_UNICAST_SOLICIT = 3, | |
IP6_MAX_ANYCAST_DELAY_TIME = 1, | |
IP6_MAX_NEIGHBOR_ADV = 3, | |
IP6_REACHABLE_TIME = 30000, | |
IP6_RETRANS_TIMER = 1000, | |
IP6_DELAY_FIRST_PROBE_TIME = 5000, | |
IP6_MIN_LINK_MTU = 1280, | |
IP6_MAX_LINK_MTU = 1500, | |
IP6_IS_ROUTER_FLAG = 0x80, | |
IP6_SOLICITED_FLAG = 0x40, | |
IP6_OVERRIDE_FLAG = 0x20, | |
IP6_M_ADDR_CONFIG_FLAG = 0x80, | |
IP6_O_CONFIG_FLAG = 0x40, | |
IP6_ON_LINK_FLAG = 0x80, | |
IP6_AUTO_CONFIG_FLAG = 0x40, | |
IP6_ND_LENGTH = 24, | |
IP6_RA_LENGTH = 16, | |
IP6_REDITECT_LENGTH = 40, | |
IP6_DAD_ENTRY_SIGNATURE = SIGNATURE_32 ('I', 'P', 'D', 'E') | |
}; | |
typedef | |
VOID | |
(*IP6_ARP_CALLBACK) ( | |
VOID *Context | |
); | |
typedef struct _IP6_ETHE_ADDR_OPTION { | |
UINT8 Type; | |
UINT8 Length; | |
UINT8 EtherAddr[6]; | |
} IP6_ETHER_ADDR_OPTION; | |
typedef struct _IP6_MTU_OPTION { | |
UINT8 Type; | |
UINT8 Length; | |
UINT16 Reserved; | |
UINT32 Mtu; | |
} IP6_MTU_OPTION; | |
typedef struct _IP6_PREFIX_INFO_OPTION { | |
UINT8 Type; | |
UINT8 Length; | |
UINT8 PrefixLength; | |
UINT8 Reserved1; | |
UINT32 ValidLifetime; | |
UINT32 PreferredLifetime; | |
UINT32 Reserved2; | |
EFI_IPv6_ADDRESS Prefix; | |
} IP6_PREFIX_INFO_OPTION; | |
typedef | |
VOID | |
(*IP6_DAD_CALLBACK) ( | |
IN BOOLEAN IsDadPassed, | |
IN EFI_IPv6_ADDRESS *TargetAddress, | |
IN VOID *Context | |
); | |
typedef struct _IP6_DAD_ENTRY { | |
UINT32 Signature; | |
LIST_ENTRY Link; | |
UINT32 MaxTransmit; | |
UINT32 Transmit; | |
UINT32 Receive; | |
UINT32 RetransTick; | |
IP6_ADDRESS_INFO *AddressInfo; | |
EFI_IPv6_ADDRESS Destination; | |
IP6_DAD_CALLBACK Callback; | |
VOID *Context; | |
} IP6_DAD_ENTRY; | |
typedef struct _IP6_DELAY_JOIN_LIST { | |
LIST_ENTRY Link; | |
UINT32 DelayTime; ///< in tick per 50 milliseconds | |
IP6_INTERFACE *Interface; | |
IP6_ADDRESS_INFO *AddressInfo; | |
IP6_DAD_CALLBACK DadCallback; | |
VOID *Context; | |
} IP6_DELAY_JOIN_LIST; | |
typedef struct _IP6_NEIGHBOR_ENTRY { | |
LIST_ENTRY Link; | |
LIST_ENTRY ArpList; | |
INTN RefCnt; | |
BOOLEAN IsRouter; | |
BOOLEAN ArpFree; | |
BOOLEAN Dynamic; | |
EFI_IPv6_ADDRESS Neighbor; | |
EFI_MAC_ADDRESS LinkAddress; | |
EFI_IP6_NEIGHBOR_STATE State; | |
UINT32 Transmit; | |
UINT32 Ticks; | |
LIST_ENTRY Frames; | |
IP6_INTERFACE *Interface; | |
IP6_ARP_CALLBACK CallBack; | |
} IP6_NEIGHBOR_ENTRY; | |
typedef struct _IP6_DEFAULT_ROUTER { | |
LIST_ENTRY Link; | |
INTN RefCnt; | |
UINT16 Lifetime; | |
EFI_IPv6_ADDRESS Router; | |
IP6_NEIGHBOR_ENTRY *NeighborCache; | |
} IP6_DEFAULT_ROUTER; | |
typedef struct _IP6_PREFIX_LIST_ENTRY { | |
LIST_ENTRY Link; | |
INTN RefCnt; | |
UINT32 ValidLifetime; | |
UINT32 PreferredLifetime; | |
UINT8 PrefixLength; | |
EFI_IPv6_ADDRESS Prefix; | |
} IP6_PREFIX_LIST_ENTRY; | |
/** | |
Build a array of EFI_IP6_NEIGHBOR_CACHE to be returned to the caller. The number | |
of EFI_IP6_NEIGHBOR_CACHE is also returned. | |
@param[in] IpInstance The pointer to IP6_PROTOCOL instance. | |
@param[out] NeighborCount The number of returned neighbor cache entries. | |
@param[out] NeighborCache The pointer to the array of EFI_IP6_NEIGHBOR_CACHE. | |
@retval EFI_SUCCESS The EFI_IP6_NEIGHBOR_CACHE successfully built. | |
@retval EFI_OUT_OF_RESOURCES Failed to allocate the memory for the route table. | |
**/ | |
EFI_STATUS | |
Ip6BuildEfiNeighborCache ( | |
IN IP6_PROTOCOL *IpInstance, | |
OUT UINT32 *NeighborCount, | |
OUT EFI_IP6_NEIGHBOR_CACHE **NeighborCache | |
); | |
/** | |
Build a array of EFI_IP6_ADDRESS_INFO to be returned to the caller. The number | |
of prefix entries is also returned. | |
@param[in] IpInstance The pointer to IP6_PROTOCOL instance. | |
@param[out] PrefixCount The number of returned prefix entries. | |
@param[out] PrefixTable The pointer to the array of PrefixTable. | |
@retval EFI_SUCCESS The prefix table successfully built. | |
@retval EFI_OUT_OF_RESOURCES Failed to allocate the memory for the prefix table. | |
**/ | |
EFI_STATUS | |
Ip6BuildPrefixTable ( | |
IN IP6_PROTOCOL *IpInstance, | |
OUT UINT32 *PrefixCount, | |
OUT EFI_IP6_ADDRESS_INFO **PrefixTable | |
); | |
/** | |
Allocate and initialize an IP6 default router entry. | |
@param[in] IpSb The pointer to the IP6_SERVICE instance. | |
@param[in] Ip6Address The IPv6 address of the default router. | |
@param[in] RouterLifetime The lifetime associated with the default | |
router, in units of seconds. | |
@return NULL if it failed to allocate memory for the default router node. | |
Otherwise, point to the created default router node. | |
**/ | |
IP6_DEFAULT_ROUTER * | |
Ip6CreateDefaultRouter ( | |
IN IP6_SERVICE *IpSb, | |
IN EFI_IPv6_ADDRESS *Ip6Address, | |
IN UINT16 RouterLifetime | |
); | |
/** | |
Destroy an IP6 default router entry. | |
@param[in] IpSb The pointer to the IP6_SERVICE instance. | |
@param[in] DefaultRouter The to be destroyed IP6_DEFAULT_ROUTER. | |
**/ | |
VOID | |
Ip6DestroyDefaultRouter ( | |
IN IP6_SERVICE *IpSb, | |
IN IP6_DEFAULT_ROUTER *DefaultRouter | |
); | |
/** | |
Clean an IP6 default router list. | |
@param[in] IpSb The pointer to the IP6_SERVICE instance. | |
**/ | |
VOID | |
Ip6CleanDefaultRouterList ( | |
IN IP6_SERVICE *IpSb | |
); | |
/** | |
Search a default router node from an IP6 default router list. | |
@param[in] IpSb The pointer to the IP6_SERVICE instance. | |
@param[in] Ip6Address The IPv6 address of the to be searched default router node. | |
@return NULL if it failed to find the matching default router node. | |
Otherwise, point to the found default router node. | |
**/ | |
IP6_DEFAULT_ROUTER * | |
Ip6FindDefaultRouter ( | |
IN IP6_SERVICE *IpSb, | |
IN EFI_IPv6_ADDRESS *Ip6Address | |
); | |
/** | |
The function to be called after DAD (Duplicate Address Detection) is performed. | |
@param[in] IsDadPassed If TRUE, the DAD operation succeed. Otherwise, the DAD operation failed. | |
@param[in] IpIf Points to the IP6_INTERFACE. | |
@param[in] DadEntry The DAD entry which already performed DAD. | |
**/ | |
VOID | |
Ip6OnDADFinished ( | |
IN BOOLEAN IsDadPassed, | |
IN IP6_INTERFACE *IpIf, | |
IN IP6_DAD_ENTRY *DadEntry | |
); | |
/** | |
Create a DAD (Duplicate Address Detection) entry and queue it to be performed. | |
@param[in] IpIf Points to the IP6_INTERFACE. | |
@param[in] AddressInfo The address information which needs DAD performed. | |
@param[in] Callback The callback routine that will be called after DAD | |
is performed. This is an optional parameter that | |
may be NULL. | |
@param[in] Context The opaque parameter for a DAD callback routine. | |
This is an optional parameter that may be NULL. | |
@retval EFI_SUCCESS The DAD entry was created and queued. | |
@retval EFI_OUT_OF_RESOURCES Failed to allocate the memory to complete the | |
operation. | |
**/ | |
EFI_STATUS | |
Ip6InitDADProcess ( | |
IN IP6_INTERFACE *IpIf, | |
IN IP6_ADDRESS_INFO *AddressInfo, | |
IN IP6_DAD_CALLBACK Callback OPTIONAL, | |
IN VOID *Context OPTIONAL | |
); | |
/** | |
Search IP6_DAD_ENTRY from the Duplicate Address Detection List. | |
@param[in] IpSb The pointer to the IP6_SERVICE instance. | |
@param[in] Target The address information which needs DAD performed . | |
@param[out] Interface If not NULL, output the IP6 interface that configures | |
the tentative address. | |
@return NULL if failed to find the matching DAD entry. | |
Otherwise, point to the found DAD entry. | |
**/ | |
IP6_DAD_ENTRY * | |
Ip6FindDADEntry ( | |
IN IP6_SERVICE *IpSb, | |
IN EFI_IPv6_ADDRESS *Target, | |
OUT IP6_INTERFACE **Interface OPTIONAL | |
); | |
/** | |
Allocate and initialize a IP6 prefix list entry. | |
@param[in] IpSb The pointer to IP6_SERVICE instance. | |
@param[in] OnLinkOrAuto If TRUE, the entry is created for the on link prefix list. | |
Otherwise, it is created for the autoconfiguration prefix list. | |
@param[in] ValidLifetime The length of time in seconds that the prefix | |
is valid for the purpose of on-link determination. | |
@param[in] PreferredLifetime The length of time in seconds that addresses | |
generated from the prefix via stateless address | |
autoconfiguration remain preferred. | |
@param[in] PrefixLength The prefix length of the Prefix. | |
@param[in] Prefix The prefix address. | |
@return NULL if it failed to allocate memory for the prefix node. Otherwise, point | |
to the created or existing prefix list entry. | |
**/ | |
IP6_PREFIX_LIST_ENTRY * | |
Ip6CreatePrefixListEntry ( | |
IN IP6_SERVICE *IpSb, | |
IN BOOLEAN OnLinkOrAuto, | |
IN UINT32 ValidLifetime, | |
IN UINT32 PreferredLifetime, | |
IN UINT8 PrefixLength, | |
IN EFI_IPv6_ADDRESS *Prefix | |
); | |
/** | |
Destroy a IP6 prefix list entry. | |
@param[in] IpSb The pointer to IP6_SERVICE instance. | |
@param[in] PrefixEntry The to be destroyed prefix list entry. | |
@param[in] OnLinkOrAuto If TRUE, the entry is removed from on link prefix list. | |
Otherwise remove from autoconfiguration prefix list. | |
@param[in] ImmediateDelete If TRUE, remove the entry directly. | |
Otherwise, check the reference count to see whether | |
it should be removed. | |
**/ | |
VOID | |
Ip6DestroyPrefixListEntry ( | |
IN IP6_SERVICE *IpSb, | |
IN IP6_PREFIX_LIST_ENTRY *PrefixEntry, | |
IN BOOLEAN OnLinkOrAuto, | |
IN BOOLEAN ImmediateDelete | |
); | |
/** | |
Search the list array to find an IP6 prefix list entry. | |
@param[in] IpSb The pointer to IP6_SERVICE instance. | |
@param[in] OnLinkOrAuto If TRUE, the search the link prefix list, | |
Otherwise search the autoconfiguration prefix list. | |
@param[in] PrefixLength The prefix length of the Prefix | |
@param[in] Prefix The prefix address. | |
@return NULL if cannot find the IP6 prefix list entry. Otherwise, return the | |
pointer to the IP6 prefix list entry. | |
**/ | |
IP6_PREFIX_LIST_ENTRY * | |
Ip6FindPrefixListEntry ( | |
IN IP6_SERVICE *IpSb, | |
IN BOOLEAN OnLinkOrAuto, | |
IN UINT8 PrefixLength, | |
IN EFI_IPv6_ADDRESS *Prefix | |
); | |
/** | |
Release the resource in prefix list table, and destroy the list entry and | |
corresponding addresses or route entries. | |
@param[in] IpSb The pointer to the IP6_SERVICE instance. | |
@param[in] ListHead The list entry head of the prefix list table. | |
**/ | |
VOID | |
Ip6CleanPrefixListTable ( | |
IN IP6_SERVICE *IpSb, | |
IN LIST_ENTRY *ListHead | |
); | |
/** | |
Allocate and initialize an IP6 neighbor cache entry. | |
@param[in] IpSb The pointer to the IP6_SERVICE instance. | |
@param[in] CallBack The callback function to be called when | |
address resolution is finished. | |
@param[in] Ip6Address Points to the IPv6 address of the neighbor. | |
@param[in] LinkAddress Points to the MAC address of the neighbor. | |
Ignored if NULL. | |
@return NULL if failed to allocate memory for the neighbor cache entry. | |
Otherwise, point to the created neighbor cache entry. | |
**/ | |
IP6_NEIGHBOR_ENTRY * | |
Ip6CreateNeighborEntry ( | |
IN IP6_SERVICE *IpSb, | |
IN IP6_ARP_CALLBACK CallBack, | |
IN EFI_IPv6_ADDRESS *Ip6Address, | |
IN EFI_MAC_ADDRESS *LinkAddress OPTIONAL | |
); | |
/** | |
Search a IP6 neighbor cache entry. | |
@param[in] IpSb The pointer to the IP6_SERVICE instance. | |
@param[in] Ip6Address Points to the IPv6 address of the neighbor. | |
@return NULL if it failed to find the matching neighbor cache entry. | |
Otherwise, point to the found neighbor cache entry. | |
**/ | |
IP6_NEIGHBOR_ENTRY * | |
Ip6FindNeighborEntry ( | |
IN IP6_SERVICE *IpSb, | |
IN EFI_IPv6_ADDRESS *Ip6Address | |
); | |
/** | |
Free a IP6 neighbor cache entry and remove all the frames on the address | |
resolution queue that pass the FrameToCancel. That is, either FrameToCancel | |
is NULL, or it returns true for the frame. | |
@param[in] IpSb The pointer to the IP6_SERVICE instance. | |
@param[in] NeighborCache The to be free neighbor cache entry. | |
@param[in] SendIcmpError If TRUE, send out ICMP error. | |
@param[in] FullFree If TRUE, remove the neighbor cache entry. | |
Otherwise remove the pending frames. | |
@param[in] IoStatus The status returned to the cancelled frames' | |
callback function. | |
@param[in] FrameToCancel Function to select which frame to cancel. | |
This is an optional parameter that may be NULL. | |
@param[in] Context Opaque parameter to the FrameToCancel. | |
Ignored if FrameToCancel is NULL. | |
@retval EFI_INVALID_PARAMETER The input parameter is invalid. | |
@retval EFI_SUCCESS The operation finished successfully. | |
**/ | |
EFI_STATUS | |
Ip6FreeNeighborEntry ( | |
IN IP6_SERVICE *IpSb, | |
IN IP6_NEIGHBOR_ENTRY *NeighborCache, | |
IN BOOLEAN SendIcmpError, | |
IN BOOLEAN FullFree, | |
IN EFI_STATUS IoStatus, | |
IN IP6_FRAME_TO_CANCEL FrameToCancel OPTIONAL, | |
IN VOID *Context OPTIONAL | |
); | |
/** | |
Add Neighbor cache entries. It is a work function for EfiIp6Neighbors(). | |
@param[in] IpSb The IP6 service binding instance. | |
@param[in] TargetIp6Address Pointer to Target IPv6 address. | |
@param[in] TargetLinkAddress Pointer to link-layer address of the target. Ignored if NULL. | |
@param[in] Timeout Time in 100-ns units that this entry will remain in the neighbor | |
cache. It will be deleted after Timeout. A value of zero means that | |
the entry is permanent. A non-zero value means that the entry is | |
dynamic. | |
@param[in] Override If TRUE, the cached link-layer address of the matching entry will | |
be overridden and updated; if FALSE, and if a | |
corresponding cache entry already existed, EFI_ACCESS_DENIED | |
will be returned. | |
@retval EFI_SUCCESS The neighbor cache entry has been added. | |
@retval EFI_OUT_OF_RESOURCES Could not add the entry to the neighbor cache | |
due to insufficient resources. | |
@retval EFI_NOT_FOUND TargetLinkAddress is NULL. | |
@retval EFI_ACCESS_DENIED The to-be-added entry is already defined in the neighbor cache, | |
and that entry is tagged as un-overridden (when DeleteFlag | |
is FALSE). | |
**/ | |
EFI_STATUS | |
Ip6AddNeighbor ( | |
IN IP6_SERVICE *IpSb, | |
IN EFI_IPv6_ADDRESS *TargetIp6Address, | |
IN EFI_MAC_ADDRESS *TargetLinkAddress OPTIONAL, | |
IN UINT32 Timeout, | |
IN BOOLEAN Override | |
); | |
/** | |
Delete or update Neighbor cache entries. It is a work function for EfiIp6Neighbors(). | |
@param[in] IpSb The IP6 service binding instance. | |
@param[in] TargetIp6Address Pointer to Target IPv6 address. | |
@param[in] TargetLinkAddress Pointer to link-layer address of the target. Ignored if NULL. | |
@param[in] Timeout Time in 100-ns units that this entry will remain in the neighbor | |
cache. It will be deleted after Timeout. A value of zero means that | |
the entry is permanent. A non-zero value means that the entry is | |
dynamic. | |
@param[in] Override If TRUE, the cached link-layer address of the matching entry will | |
be overridden and updated; if FALSE, and if a | |
corresponding cache entry already existed, EFI_ACCESS_DENIED | |
will be returned. | |
@retval EFI_SUCCESS The neighbor cache entry has been updated or deleted. | |
@retval EFI_NOT_FOUND This entry is not in the neighbor cache. | |
**/ | |
EFI_STATUS | |
Ip6DelNeighbor ( | |
IN IP6_SERVICE *IpSb, | |
IN EFI_IPv6_ADDRESS *TargetIp6Address, | |
IN EFI_MAC_ADDRESS *TargetLinkAddress OPTIONAL, | |
IN UINT32 Timeout, | |
IN BOOLEAN Override | |
); | |
/** | |
Process the Neighbor Solicitation message. The message may be sent for Duplicate | |
Address Detection or Address Resolution. | |
@param[in] IpSb The IP service that received the packet. | |
@param[in] Head The IP head of the message. | |
@param[in] Packet The content of the message with IP head removed. | |
@retval EFI_SUCCESS The packet processed successfully. | |
@retval EFI_INVALID_PARAMETER The packet is invalid. | |
@retval EFI_ICMP_ERROR The packet indicates that DAD is failed. | |
@retval Others Failed to process the packet. | |
**/ | |
EFI_STATUS | |
Ip6ProcessNeighborSolicit ( | |
IN IP6_SERVICE *IpSb, | |
IN EFI_IP6_HEADER *Head, | |
IN NET_BUF *Packet | |
); | |
/** | |
Process the Neighbor Advertisement message. | |
@param[in] IpSb The IP service that received the packet. | |
@param[in] Head The IP head of the message. | |
@param[in] Packet The content of the message with IP head removed. | |
@retval EFI_SUCCESS The packet processed successfully. | |
@retval EFI_INVALID_PARAMETER The packet is invalid. | |
@retval EFI_ICMP_ERROR The packet indicates that DAD is failed. | |
@retval Others Failed to process the packet. | |
**/ | |
EFI_STATUS | |
Ip6ProcessNeighborAdvertise ( | |
IN IP6_SERVICE *IpSb, | |
IN EFI_IP6_HEADER *Head, | |
IN NET_BUF *Packet | |
); | |
/** | |
Process the Router Advertisement message according to RFC4861. | |
@param[in] IpSb The IP service that received the packet. | |
@param[in] Head The IP head of the message. | |
@param[in] Packet The content of the message with the IP head removed. | |
@retval EFI_SUCCESS The packet processed successfully. | |
@retval EFI_INVALID_PARAMETER The packet is invalid. | |
@retval EFI_OUT_OF_RESOURCES Insufficient resources to complete the operation. | |
@retval Others Failed to process the packet. | |
**/ | |
EFI_STATUS | |
Ip6ProcessRouterAdvertise ( | |
IN IP6_SERVICE *IpSb, | |
IN EFI_IP6_HEADER *Head, | |
IN NET_BUF *Packet | |
); | |
/** | |
Process the ICMPv6 redirect message. Find the instance, then update | |
its route cache. | |
@param[in] IpSb The IP6 service binding instance that received | |
the packet. | |
@param[in] Head The IP head of the received ICMPv6 packet. | |
@param[in] Packet The content of the ICMPv6 redirect packet with | |
the IP head removed. | |
@retval EFI_INVALID_PARAMETER The parameter is invalid. | |
@retval EFI_OUT_OF_RESOURCES Insuffcient resources to complete the | |
operation. | |
@retval EFI_SUCCESS Successfully updated the route caches. | |
**/ | |
EFI_STATUS | |
Ip6ProcessRedirect ( | |
IN IP6_SERVICE *IpSb, | |
IN EFI_IP6_HEADER *Head, | |
IN NET_BUF *Packet | |
); | |
/** | |
Generate router solicit message and send it out to Destination Address or | |
All Router Link Local scope multicast address. | |
@param[in] IpSb The IP service to send the packet. | |
@param[in] Interface If not NULL, points to the IP6 interface to send | |
the packet. | |
@param[in] SourceAddress If not NULL, the source address of the message. | |
@param[in] DestinationAddress If not NULL, the destination address of the message. | |
@param[in] SourceLinkAddress If not NULL, the MAC address of the source. | |
A source link-layer address option will be appended | |
to the message. | |
@retval EFI_OUT_OF_RESOURCES Insufficient resources to complete the operation. | |
@retval EFI_SUCCESS The router solicit message was successfully sent. | |
**/ | |
EFI_STATUS | |
Ip6SendRouterSolicit ( | |
IN IP6_SERVICE *IpSb, | |
IN IP6_INTERFACE *Interface OPTIONAL, | |
IN EFI_IPv6_ADDRESS *SourceAddress OPTIONAL, | |
IN EFI_IPv6_ADDRESS *DestinationAddress OPTIONAL, | |
IN EFI_MAC_ADDRESS *SourceLinkAddress OPTIONAL | |
); | |
/** | |
Generate the Neighbor Solicitation message and send it to the Destination Address. | |
@param[in] IpSb The IP service to send the packet | |
@param[in] SourceAddress The source address of the message. | |
@param[in] DestinationAddress The destination address of the message. | |
@param[in] TargetIp6Address The IP address of the target of the solicitation. | |
It must not be a multicast address. | |
@param[in] SourceLinkAddress The MAC address for the sender. If not NULL, | |
a source link-layer address option will be appended | |
to the message. | |
@retval EFI_INVALID_PARAMETER Any input parameter is invalid. | |
@retval EFI_OUT_OF_RESOURCES Insufficient resources to complete the | |
operation. | |
@retval EFI_SUCCESS The Neighbor Advertise message was successfully sent. | |
**/ | |
EFI_STATUS | |
Ip6SendNeighborSolicit ( | |
IN IP6_SERVICE *IpSb, | |
IN EFI_IPv6_ADDRESS *SourceAddress, | |
IN EFI_IPv6_ADDRESS *DestinationAddress, | |
IN EFI_IPv6_ADDRESS *TargetIp6Address, | |
IN EFI_MAC_ADDRESS *SourceLinkAddress OPTIONAL | |
); | |
/** | |
Set the interface's address. This will trigger the DAD process for the | |
address to set. To set an already set address, the lifetimes wil be | |
updated to the new value passed in. | |
@param[in] Interface The interface to set the address. | |
@param[in] Ip6Addr The interface's to be assigned IPv6 address. | |
@param[in] IsAnycast If TRUE, the unicast IPv6 address is anycast. | |
Otherwise, it is not anycast. | |
@param[in] PrefixLength The prefix length of the Ip6Addr. | |
@param[in] ValidLifetime The valid lifetime for this address. | |
@param[in] PreferredLifetime The preferred lifetime for this address. | |
@param[in] DadCallback The caller's callback to trigger when DAD finishes. | |
This is an optional parameter that may be NULL. | |
@param[in] Context The context that will be passed to DadCallback. | |
This is an optional parameter that may be NULL. | |
@retval EFI_SUCCESS The interface is scheduled to be configured with | |
the specified address. | |
@retval EFI_OUT_OF_RESOURCES Failed to set the interface's address due to | |
lack of resources. | |
**/ | |
EFI_STATUS | |
Ip6SetAddress ( | |
IN IP6_INTERFACE *Interface, | |
IN EFI_IPv6_ADDRESS *Ip6Addr, | |
IN BOOLEAN IsAnycast, | |
IN UINT8 PrefixLength, | |
IN UINT32 ValidLifetime, | |
IN UINT32 PreferredLifetime, | |
IN IP6_DAD_CALLBACK DadCallback OPTIONAL, | |
IN VOID *Context OPTIONAL | |
); | |
/** | |
The heartbeat timer of ND module in IP6_TIMER_INTERVAL_IN_MS milliseconds. | |
This time routine handles DAD module and neighbor state transition. | |
It is also responsible for sending out router solicitations. | |
@param[in] Event The IP6 service instance's heartbeat timer. | |
@param[in] Context The IP6 service instance. | |
**/ | |
VOID | |
EFIAPI | |
Ip6NdFasterTimerTicking ( | |
IN EFI_EVENT Event, | |
IN VOID *Context | |
); | |
/** | |
The heartbeat timer of ND module in 1 second. This time routine handles following | |
things: 1) maitain default router list; 2) maintain prefix options; | |
3) maintain route caches. | |
@param[in] IpSb The IP6 service binding instance. | |
**/ | |
VOID | |
Ip6NdTimerTicking ( | |
IN IP6_SERVICE *IpSb | |
); | |
/** | |
Callback function when address resolution is finished. It will cancel | |
all the queued frames if the address resolution failed, or transmit them | |
if the request succeeded. | |
@param[in] Context The context of the callback, a pointer to IP6_NEIGHBOR_ENTRY. | |
**/ | |
VOID | |
Ip6OnArpResolved ( | |
IN VOID *Context | |
); | |
/** | |
Update the ReachableTime in IP6 service binding instance data, in milliseconds. | |
@param[in, out] IpSb Points to the IP6_SERVICE. | |
**/ | |
VOID | |
Ip6UpdateReachableTime ( | |
IN OUT IP6_SERVICE *IpSb | |
); | |
#endif |