Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: TYBLE16_simple_data_logger TYBLE16_MP3_Air
lwip_ip6.c File Reference
IPv6 layer. More...
Go to the source code of this file.
| Functions | |
| struct netif * | ip6_route (const ip6_addr_t *src, const ip6_addr_t *dest) | 
| Finds the appropriate network interface for a given IPv6 address. | |
| const ip_addr_t * | ip6_select_source_address (struct netif *netif, const ip6_addr_t *dest) | 
| Select the best IPv6 source address for a given destination IPv6 address. | |
| static void | ip6_forward (struct pbuf *p, struct ip6_hdr *iphdr, struct netif *inp) | 
| Forwards an IPv6 packet. | |
| static int | ip6_input_accept (struct netif *netif) | 
| Return true if the current input packet should be accepted on this netif. | |
| err_t | ip6_input (struct pbuf *p, struct netif *inp) | 
| This function is called by the network interface device driver when an IPv6 packet is received. | |
Detailed Description
IPv6 layer.
Definition in file lwip_ip6.c.
Function Documentation
Forwards an IPv6 packet.
It finds an appropriate route for the packet, decrements the HL value of the packet, and outputs the packet on the appropriate interface.
- Parameters:
- 
  p the packet to forward (p->payload points to IP header) iphdr the IPv6 header of the input packet inp the netif on which this packet was received 
Definition at line 366 of file lwip_ip6.c.
This function is called by the network interface device driver when an IPv6 packet is received.
The function does the basic checks of the IP header such as packet size being at least larger than the header size etc. If the packet was not destined for us, the packet is forwarded (using ip6_forward).
Finally, the packet is sent to the upper layer protocol input function.
- Parameters:
- 
  p the received IPv6 packet (p->payload points to IPv6 header) inp the netif on which this packet was received 
- Returns:
- ERR_OK if the packet was processed (could return ERR_* if it wasn't processed, but currently always returns ERR_OK)
Sends an IPv6 packet on a network interface. This function constructs the IPv6 header. If the source IPv6 address is NULL, the IPv6 "ANY" address is used as source (usually during network startup). If the source IPv6 address it IP6_ADDR_ANY, the most appropriate IPv6 address of the outgoing network interface is filled in as source address. If the destination IPv6 address is LWIP_IP_HDRINCL, p is assumed to already include an IPv6 header and p->payload points to it instead of the data.
- Parameters:
- 
  p the packet to send (p->payload points to the data, e.g. next protocol header; if dest == LWIP_IP_HDRINCL, p already includes an IPv6 header and p->payload points to that IPv6 header) src the source IPv6 address to send from (if src == IP6_ADDR_ANY, an IP address of the netif is selected and used as source address. if src == NULL, IP6_ADDR_ANY is used as source) (src is possibly not properly zoned) dest the destination IPv6 address to send the packet to (possibly not properly zoned) hl the Hop Limit value to be set in the IPv6 header tc the Traffic Class value to be set in the IPv6 header nexth the Next Header to be set in the IPv6 header netif the netif on which to send this packet 
- Returns:
- ERR_OK if the packet was sent OK ERR_BUF if p doesn't have enough space for IPv6/LINK headers returns errors returned by netif->output_ip6
Same as ip6_output_if() but 'src' address is not replaced by netif address when it is 'any'.
Simple interface to ip6_output_if. It finds the outgoing network interface and calls upon ip6_output_if to do the actual work.
- Parameters:
- 
  p the packet to send (p->payload points to the data, e.g. next protocol header; if dest == LWIP_IP_HDRINCL, p already includes an IPv6 header and p->payload points to that IPv6 header) src the source IPv6 address to send from (if src == IP6_ADDR_ANY, an IP address of the netif is selected and used as source address. if src == NULL, IP6_ADDR_ANY is used as source) dest the destination IPv6 address to send the packet to hl the Hop Limit value to be set in the IPv6 header tc the Traffic Class value to be set in the IPv6 header nexth the Next Header to be set in the IPv6 header 
- Returns:
- ERR_RTE if no route is found see ip_output_if() for more return values
Like ip6_output, but takes and addr_hint pointer that is passed on to netif->addr_hint before calling ip6_output_if.
- Parameters:
- 
  p the packet to send (p->payload points to the data, e.g. next protocol header; if dest == LWIP_IP_HDRINCL, p already includes an IPv6 header and p->payload points to that IPv6 header) src the source IPv6 address to send from (if src == IP6_ADDR_ANY, an IP address of the netif is selected and used as source address. if src == NULL, IP6_ADDR_ANY is used as source) dest the destination IPv6 address to send the packet to hl the Hop Limit value to be set in the IPv6 header tc the Traffic Class value to be set in the IPv6 header nexth the Next Header to be set in the IPv6 header netif_hint netif output hint pointer set to netif->hint before calling ip_output_if() 
- Returns:
- ERR_RTE if no route is found see ip_output_if() for more return values
Add a hop-by-hop options header with a router alert option and padding.
Used by MLD when sending a Multicast listener report/done message.
- Parameters:
- 
  p the packet to which we will prepend the options header nexth the next header protocol number (e.g. IP6_NEXTH_ICMP6) value the value of the router alert option data (e.g. IP6_ROUTER_ALERT_VALUE_MLD) 
- Returns:
- ERR_OK if hop-by-hop header was added, ERR_* otherwise
Definition at line 509 of file lwip_ip6.c.
| static int ip6_input_accept | ( | struct netif * | netif ) |  [static] | 
Return true if the current input packet should be accepted on this netif.
Definition at line 469 of file lwip_ip6.c.
| struct netif* ip6_route | ( | const ip6_addr_t * | src, | 
| const ip6_addr_t * | dest | ||
| ) |  [read] | 
Finds the appropriate network interface for a given IPv6 address.
It tries to select a netif following a sequence of heuristics: 1) if there is only 1 netif, return it 2) if the destination is a zoned address, match its zone to a netif 3) if the either the source or destination address is a scoped address, match the source address's zone (if set) or address (if not) to a netif 4) tries to match the destination subnet to a configured address 5) tries to find a router-announced route 6) tries to match the (unscoped) source address to the netif 7) returns the default netif, if configured
Note that each of the two given addresses may or may not be properly zoned.
- Parameters:
- 
  src the source IPv6 address, if known dest the destination IPv6 address for which to find the route 
- Returns:
- the netif on which to send to reach dest
Definition at line 86 of file lwip_ip6.c.
Generated on Tue Jul 12 2022 13:55:13 by
 1.7.2
 1.7.2