mirror of
https://github.com/lwip-tcpip/lwip.git
synced 2024-12-26 03:16:18 +00:00
fixed bug #35927: missing refragmentaion in ip_forward
This commit is contained in:
parent
2b4c10e705
commit
d95bcab053
@ -76,6 +76,9 @@ HISTORY
|
|||||||
|
|
||||||
++ Bugfixes:
|
++ Bugfixes:
|
||||||
|
|
||||||
|
2012-03-22: Simon Goldschmidt
|
||||||
|
* ip4.c: fixed bug #35927: missing refragmentaion in ip_forward
|
||||||
|
|
||||||
2012-03-20: Simon Goldschmidt (patch by Mason)
|
2012-03-20: Simon Goldschmidt (patch by Mason)
|
||||||
* netdb.c: fixed bug #35907: lwip_gethostbyname_r returns an invalid h_addr_list
|
* netdb.c: fixed bug #35907: lwip_gethostbyname_r returns an invalid h_addr_list
|
||||||
|
|
||||||
|
@ -211,6 +211,7 @@ ip_forward(struct pbuf *p, struct ip_hdr *iphdr, struct netif *inp)
|
|||||||
LWIP_DEBUGF(IP_DEBUG, ("ip_forward: no forwarding route for %"U16_F".%"U16_F".%"U16_F".%"U16_F" found\n",
|
LWIP_DEBUGF(IP_DEBUG, ("ip_forward: no forwarding route for %"U16_F".%"U16_F".%"U16_F".%"U16_F" found\n",
|
||||||
ip4_addr1_16(ip_current_dest_addr()), ip4_addr2_16(ip_current_dest_addr()),
|
ip4_addr1_16(ip_current_dest_addr()), ip4_addr2_16(ip_current_dest_addr()),
|
||||||
ip4_addr3_16(ip_current_dest_addr()), ip4_addr4_16(ip_current_dest_addr())));
|
ip4_addr3_16(ip_current_dest_addr()), ip4_addr4_16(ip_current_dest_addr())));
|
||||||
|
/* @todo: send ICMP_DUR_NET? */
|
||||||
goto return_noroute;
|
goto return_noroute;
|
||||||
}
|
}
|
||||||
#if !IP_FORWARD_ALLOW_TX_ON_RX_NETIF
|
#if !IP_FORWARD_ALLOW_TX_ON_RX_NETIF
|
||||||
@ -252,6 +253,20 @@ ip_forward(struct pbuf *p, struct ip_hdr *iphdr, struct netif *inp)
|
|||||||
snmp_inc_ipforwdatagrams();
|
snmp_inc_ipforwdatagrams();
|
||||||
|
|
||||||
PERF_STOP("ip_forward");
|
PERF_STOP("ip_forward");
|
||||||
|
/* don't fragment if interface has mtu set to 0 [loopif] */
|
||||||
|
if (netif->mtu && (p->tot_len > netif->mtu)) {
|
||||||
|
#if IP_FRAG
|
||||||
|
if ((IPH_OFFSET(iphdr) & PP_NTOHS(IP_DF)) == 0) {
|
||||||
|
ip_frag(p, netif, ip_current_dest_addr());
|
||||||
|
} else {
|
||||||
|
/* send ICMP Destination Unreacheable code 4: "Fragmentation Needed and DF Set" */
|
||||||
|
icmp_dest_unreach(p, ICMP_DUR_FRAG);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
#else /* IP_FRAG */
|
||||||
|
/* @todo: send ICMP Destination Unreacheable code 13 "Communication administratively prohibited"? */
|
||||||
|
#endif /* IP_FRAG */
|
||||||
|
}
|
||||||
/* transmit pbuf on chosen interface */
|
/* transmit pbuf on chosen interface */
|
||||||
netif->output(netif, p, ip_current_dest_addr());
|
netif->output(netif, p, ip_current_dest_addr());
|
||||||
return;
|
return;
|
||||||
|
Loading…
Reference in New Issue
Block a user