mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-17 15:27:36 +00:00
If we don't get a suggested MTU during path MTU discovery
look up the packet size of the packet that generated the response, step down the MTU by one step through ip_next_mtu() and try again. Suggested by: dwmalone
This commit is contained in:
parent
1f8f08e1c9
commit
9e4ca6315d
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=145869
@ -1168,22 +1168,33 @@ tcp_ctlinput(cmd, sa, vip)
|
||||
* If we got a needfrag set the MTU
|
||||
* in the route to the suggested new
|
||||
* value (if given) and then notify.
|
||||
* If no new MTU was suggested, then
|
||||
* we guess a new one less than the
|
||||
* current value.
|
||||
* If the new MTU is unreasonably
|
||||
* small (defined by sysctl tcp_minmss),
|
||||
* then we up the MTU value to minimum.
|
||||
*/
|
||||
bzero(&inc, sizeof(inc));
|
||||
inc.inc_flags = 0; /* IPv4 */
|
||||
inc.inc_faddr = faddr;
|
||||
|
||||
mtu = ntohs(icp->icmp_nextmtu);
|
||||
/*
|
||||
* If no alternative MTU was
|
||||
* proposed, try the next smaller
|
||||
* one.
|
||||
*/
|
||||
if (!mtu)
|
||||
mtu = ip_next_mtu(mtu, 1);
|
||||
if (mtu >= max(296, (tcp_minmss
|
||||
+ sizeof(struct tcpiphdr))))
|
||||
mtu = ip_next_mtu(ntohs(ip->ip_len),
|
||||
1);
|
||||
if (mtu < max(296, (tcp_minmss)
|
||||
+ sizeof(struct tcpiphdr)))
|
||||
mtu = 0;
|
||||
if (!mtu)
|
||||
mtu = tcp_mssdflt
|
||||
+ sizeof(struct tcpiphdr);
|
||||
/*
|
||||
* Only cache the the MTU if it
|
||||
* is smaller than the interface
|
||||
* or route MTU. tcp_mtudisc()
|
||||
* will do right thing by itself.
|
||||
*/
|
||||
if (mtu <= tcp_maxmtu(&inc))
|
||||
tcp_hc_updatemtu(&inc, mtu);
|
||||
}
|
||||
|
||||
|
@ -1168,22 +1168,33 @@ tcp_ctlinput(cmd, sa, vip)
|
||||
* If we got a needfrag set the MTU
|
||||
* in the route to the suggested new
|
||||
* value (if given) and then notify.
|
||||
* If no new MTU was suggested, then
|
||||
* we guess a new one less than the
|
||||
* current value.
|
||||
* If the new MTU is unreasonably
|
||||
* small (defined by sysctl tcp_minmss),
|
||||
* then we up the MTU value to minimum.
|
||||
*/
|
||||
bzero(&inc, sizeof(inc));
|
||||
inc.inc_flags = 0; /* IPv4 */
|
||||
inc.inc_faddr = faddr;
|
||||
|
||||
mtu = ntohs(icp->icmp_nextmtu);
|
||||
/*
|
||||
* If no alternative MTU was
|
||||
* proposed, try the next smaller
|
||||
* one.
|
||||
*/
|
||||
if (!mtu)
|
||||
mtu = ip_next_mtu(mtu, 1);
|
||||
if (mtu >= max(296, (tcp_minmss
|
||||
+ sizeof(struct tcpiphdr))))
|
||||
mtu = ip_next_mtu(ntohs(ip->ip_len),
|
||||
1);
|
||||
if (mtu < max(296, (tcp_minmss)
|
||||
+ sizeof(struct tcpiphdr)))
|
||||
mtu = 0;
|
||||
if (!mtu)
|
||||
mtu = tcp_mssdflt
|
||||
+ sizeof(struct tcpiphdr);
|
||||
/*
|
||||
* Only cache the the MTU if it
|
||||
* is smaller than the interface
|
||||
* or route MTU. tcp_mtudisc()
|
||||
* will do right thing by itself.
|
||||
*/
|
||||
if (mtu <= tcp_maxmtu(&inc))
|
||||
tcp_hc_updatemtu(&inc, mtu);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user