OSDN Git Service

netfilter: nft_compat: use nfnetlink_unicast()
authorPablo Neira Ayuso <pablo@netfilter.org>
Thu, 15 Jul 2021 09:11:26 +0000 (11:11 +0200)
committerPablo Neira Ayuso <pablo@netfilter.org>
Sun, 1 Aug 2021 10:00:49 +0000 (12:00 +0200)
Use nfnetlink_unicast() which already translates EAGAIN to ENOBUFS,
since EAGAIN is reserved to report missing module dependencies to the
nfnetlink core.

e0241ae6ac59 ("netfilter: use nfnetlink_unicast() forgot to update
this spot.

Reported-by: Yajun Deng <yajun.deng@linux.dev>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
net/netfilter/nft_compat.c

index 639c337..272bcdb 100644 (file)
@@ -683,14 +683,12 @@ static int nfnl_compat_get_rcu(struct sk_buff *skb,
                goto out_put;
        }
 
-       ret = netlink_unicast(info->sk, skb2, NETLINK_CB(skb).portid,
-                             MSG_DONTWAIT);
-       if (ret > 0)
-               ret = 0;
+       ret = nfnetlink_unicast(skb2, info->net, NETLINK_CB(skb).portid);
 out_put:
        rcu_read_lock();
        module_put(THIS_MODULE);
-       return ret == -EAGAIN ? -ENOBUFS : ret;
+
+       return ret;
 }
 
 static const struct nla_policy nfnl_compat_policy_get[NFTA_COMPAT_MAX+1] = {