Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/klassert/ipsec-next
Steffen Klassert says: ==================== pull request (net-next): ipsec-next 2020-10-02 1) Add a full xfrm compatible layer for 32-bit applications on 64-bit kernels. From Dmitry Safonov. Please pull or let me know if there are problems. ==================== Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
@@ -2186,13 +2186,35 @@ EXPORT_SYMBOL(__nlmsg_put);
|
||||
* It would be better to create kernel thread.
|
||||
*/
|
||||
|
||||
static int netlink_dump_done(struct netlink_sock *nlk, struct sk_buff *skb,
|
||||
struct netlink_callback *cb,
|
||||
struct netlink_ext_ack *extack)
|
||||
{
|
||||
struct nlmsghdr *nlh;
|
||||
|
||||
nlh = nlmsg_put_answer(skb, cb, NLMSG_DONE, sizeof(nlk->dump_done_errno),
|
||||
NLM_F_MULTI | cb->answer_flags);
|
||||
if (WARN_ON(!nlh))
|
||||
return -ENOBUFS;
|
||||
|
||||
nl_dump_check_consistent(cb, nlh);
|
||||
memcpy(nlmsg_data(nlh), &nlk->dump_done_errno, sizeof(nlk->dump_done_errno));
|
||||
|
||||
if (extack->_msg && nlk->flags & NETLINK_F_EXT_ACK) {
|
||||
nlh->nlmsg_flags |= NLM_F_ACK_TLVS;
|
||||
if (!nla_put_string(skb, NLMSGERR_ATTR_MSG, extack->_msg))
|
||||
nlmsg_end(skb, nlh);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int netlink_dump(struct sock *sk)
|
||||
{
|
||||
struct netlink_sock *nlk = nlk_sk(sk);
|
||||
struct netlink_ext_ack extack = {};
|
||||
struct netlink_callback *cb;
|
||||
struct sk_buff *skb = NULL;
|
||||
struct nlmsghdr *nlh;
|
||||
struct module *module;
|
||||
int err = -ENOBUFS;
|
||||
int alloc_min_size;
|
||||
@@ -2258,22 +2280,19 @@ static int netlink_dump(struct sock *sk)
|
||||
return 0;
|
||||
}
|
||||
|
||||
nlh = nlmsg_put_answer(skb, cb, NLMSG_DONE,
|
||||
sizeof(nlk->dump_done_errno),
|
||||
NLM_F_MULTI | cb->answer_flags);
|
||||
if (WARN_ON(!nlh))
|
||||
if (netlink_dump_done(nlk, skb, cb, &extack))
|
||||
goto errout_skb;
|
||||
|
||||
nl_dump_check_consistent(cb, nlh);
|
||||
|
||||
memcpy(nlmsg_data(nlh), &nlk->dump_done_errno,
|
||||
sizeof(nlk->dump_done_errno));
|
||||
|
||||
if (extack._msg && nlk->flags & NETLINK_F_EXT_ACK) {
|
||||
nlh->nlmsg_flags |= NLM_F_ACK_TLVS;
|
||||
if (!nla_put_string(skb, NLMSGERR_ATTR_MSG, extack._msg))
|
||||
nlmsg_end(skb, nlh);
|
||||
#ifdef CONFIG_COMPAT_NETLINK_MESSAGES
|
||||
/* frag_list skb's data is used for compat tasks
|
||||
* and the regular skb's data for normal (non-compat) tasks.
|
||||
* See netlink_recvmsg().
|
||||
*/
|
||||
if (unlikely(skb_shinfo(skb)->frag_list)) {
|
||||
if (netlink_dump_done(nlk, skb_shinfo(skb)->frag_list, cb, &extack))
|
||||
goto errout_skb;
|
||||
}
|
||||
#endif
|
||||
|
||||
if (sk_filter(sk, skb))
|
||||
kfree_skb(skb);
|
||||
|
Reference in New Issue
Block a user