sock_diag: Do not use RTA_PUT() macros
Signed-off-by: Thomas Graf <tgraf@suug.ch> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Родитель
4245375db8
Коммит
7b46866dd0
|
@ -4,7 +4,6 @@
|
||||||
#include <net/netlink.h>
|
#include <net/netlink.h>
|
||||||
#include <net/net_namespace.h>
|
#include <net/net_namespace.h>
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/rtnetlink.h>
|
|
||||||
#include <net/sock.h>
|
#include <net/sock.h>
|
||||||
|
|
||||||
#include <linux/inet_diag.h>
|
#include <linux/inet_diag.h>
|
||||||
|
@ -35,9 +34,7 @@ EXPORT_SYMBOL_GPL(sock_diag_save_cookie);
|
||||||
|
|
||||||
int sock_diag_put_meminfo(struct sock *sk, struct sk_buff *skb, int attrtype)
|
int sock_diag_put_meminfo(struct sock *sk, struct sk_buff *skb, int attrtype)
|
||||||
{
|
{
|
||||||
__u32 *mem;
|
u32 mem[SK_MEMINFO_VARS];
|
||||||
|
|
||||||
mem = RTA_DATA(__RTA_PUT(skb, attrtype, SK_MEMINFO_VARS * sizeof(__u32)));
|
|
||||||
|
|
||||||
mem[SK_MEMINFO_RMEM_ALLOC] = sk_rmem_alloc_get(sk);
|
mem[SK_MEMINFO_RMEM_ALLOC] = sk_rmem_alloc_get(sk);
|
||||||
mem[SK_MEMINFO_RCVBUF] = sk->sk_rcvbuf;
|
mem[SK_MEMINFO_RCVBUF] = sk->sk_rcvbuf;
|
||||||
|
@ -48,10 +45,7 @@ int sock_diag_put_meminfo(struct sock *sk, struct sk_buff *skb, int attrtype)
|
||||||
mem[SK_MEMINFO_OPTMEM] = atomic_read(&sk->sk_omem_alloc);
|
mem[SK_MEMINFO_OPTMEM] = atomic_read(&sk->sk_omem_alloc);
|
||||||
mem[SK_MEMINFO_BACKLOG] = sk->sk_backlog.len;
|
mem[SK_MEMINFO_BACKLOG] = sk->sk_backlog.len;
|
||||||
|
|
||||||
return 0;
|
return nla_put(skb, attrtype, sizeof(mem), &mem);
|
||||||
|
|
||||||
rtattr_failure:
|
|
||||||
return -EMSGSIZE;
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(sock_diag_put_meminfo);
|
EXPORT_SYMBOL_GPL(sock_diag_put_meminfo);
|
||||||
|
|
||||||
|
@ -121,7 +115,7 @@ static inline void sock_diag_unlock_handler(const struct sock_diag_handler *h)
|
||||||
static int __sock_diag_rcv_msg(struct sk_buff *skb, struct nlmsghdr *nlh)
|
static int __sock_diag_rcv_msg(struct sk_buff *skb, struct nlmsghdr *nlh)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
struct sock_diag_req *req = NLMSG_DATA(nlh);
|
struct sock_diag_req *req = nlmsg_data(nlh);
|
||||||
const struct sock_diag_handler *hndl;
|
const struct sock_diag_handler *hndl;
|
||||||
|
|
||||||
if (nlmsg_len(nlh) < sizeof(*req))
|
if (nlmsg_len(nlh) < sizeof(*req))
|
||||||
|
|
Загрузка…
Ссылка в новой задаче