netfilter: Use flowi4 and flowi6 in xt_TCPMSS
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
5a49d0e04d
commit
a1bbb0e698
|
@ -148,16 +148,21 @@ tcpmss_mangle_packet(struct sk_buff *skb,
|
||||||
static u_int32_t tcpmss_reverse_mtu(const struct sk_buff *skb,
|
static u_int32_t tcpmss_reverse_mtu(const struct sk_buff *skb,
|
||||||
unsigned int family)
|
unsigned int family)
|
||||||
{
|
{
|
||||||
struct flowi fl = {};
|
struct flowi fl;
|
||||||
const struct nf_afinfo *ai;
|
const struct nf_afinfo *ai;
|
||||||
struct rtable *rt = NULL;
|
struct rtable *rt = NULL;
|
||||||
u_int32_t mtu = ~0U;
|
u_int32_t mtu = ~0U;
|
||||||
|
|
||||||
if (family == PF_INET)
|
if (family == PF_INET) {
|
||||||
fl.fl4_dst = ip_hdr(skb)->saddr;
|
struct flowi4 *fl4 = &fl.u.ip4;
|
||||||
else
|
memset(fl4, 0, sizeof(*fl4));
|
||||||
fl.fl6_dst = ipv6_hdr(skb)->saddr;
|
fl4->daddr = ip_hdr(skb)->saddr;
|
||||||
|
} else {
|
||||||
|
struct flowi6 *fl6 = &fl.u.ip6;
|
||||||
|
|
||||||
|
memset(fl6, 0, sizeof(*fl6));
|
||||||
|
ipv6_addr_copy(&fl6->daddr, &ipv6_hdr(skb)->saddr);
|
||||||
|
}
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
ai = nf_get_afinfo(family);
|
ai = nf_get_afinfo(family);
|
||||||
if (ai != NULL)
|
if (ai != NULL)
|
||||||
|
|
Loading…
Reference in New Issue