|
@@ -1001,21 +1001,22 @@ out: kfree_skb(skb);
|
|
static void __ip_rt_update_pmtu(struct rtable *rt, struct flowi4 *fl4, u32 mtu)
|
|
static void __ip_rt_update_pmtu(struct rtable *rt, struct flowi4 *fl4, u32 mtu)
|
|
{
|
|
{
|
|
struct dst_entry *dst = &rt->dst;
|
|
struct dst_entry *dst = &rt->dst;
|
|
|
|
+ u32 old_mtu = ipv4_mtu(dst);
|
|
struct fib_result res;
|
|
struct fib_result res;
|
|
bool lock = false;
|
|
bool lock = false;
|
|
|
|
|
|
if (ip_mtu_locked(dst))
|
|
if (ip_mtu_locked(dst))
|
|
return;
|
|
return;
|
|
|
|
|
|
- if (ipv4_mtu(dst) < mtu)
|
|
|
|
|
|
+ if (old_mtu < mtu)
|
|
return;
|
|
return;
|
|
|
|
|
|
if (mtu < ip_rt_min_pmtu) {
|
|
if (mtu < ip_rt_min_pmtu) {
|
|
lock = true;
|
|
lock = true;
|
|
- mtu = ip_rt_min_pmtu;
|
|
|
|
|
|
+ mtu = min(old_mtu, ip_rt_min_pmtu);
|
|
}
|
|
}
|
|
|
|
|
|
- if (rt->rt_pmtu == mtu &&
|
|
|
|
|
|
+ if (rt->rt_pmtu == mtu && !lock &&
|
|
time_before(jiffies, dst->expires - ip_rt_mtu_expires / 2))
|
|
time_before(jiffies, dst->expires - ip_rt_mtu_expires / 2))
|
|
return;
|
|
return;
|
|
|
|
|