Re: [PATCH net] netlink: not trim skb for mmaped socket when dump

2016-01-29 Thread David Miller
From: Ken-ichirou MATSUZAWA 
Date: Fri, 29 Jan 2016 10:45:50 +0900

> We should not trim skb for mmaped socket since its buf size is fixed
> and userspace will read as frame which data equals head. mmaped
> socket will not call recvmsg, means max_recvmsg_len is 0,
> skb_reserve was not called before commit: db65a3aaf29e.
> 
> Fixes: db65a3aaf29e (netlink: Trim skb to alloc size to avoid MSG_TRUNC)
> Signed-off-by: Ken-ichirou MATSUZAWA 

Applied, thank you.


[PATCH net] netlink: not trim skb for mmaped socket when dump

2016-01-28 Thread Ken-ichirou MATSUZAWA
We should not trim skb for mmaped socket since its buf size is fixed
and userspace will read as frame which data equals head. mmaped
socket will not call recvmsg, means max_recvmsg_len is 0,
skb_reserve was not called before commit: db65a3aaf29e.

Fixes: db65a3aaf29e (netlink: Trim skb to alloc size to avoid MSG_TRUNC)
Signed-off-by: Ken-ichirou MATSUZAWA 

---
 net/netlink/af_netlink.c |3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/net/netlink/af_netlink.c b/net/netlink/af_netlink.c
index 81dc1bb..f1ffb34 100644
--- a/net/netlink/af_netlink.c
+++ b/net/netlink/af_netlink.c
@@ -2831,7 +2831,8 @@ static int netlink_dump(struct sock *sk)
 * reasonable static buffer based on the expected largest dump of a
 * single netdev. The outcome is MSG_TRUNC error.
 */
-   skb_reserve(skb, skb_tailroom(skb) - alloc_size);
+   if (!netlink_rx_is_mmaped(sk))
+   skb_reserve(skb, skb_tailroom(skb) - alloc_size);
netlink_skb_set_owner_r(skb, sk);
 
len = cb->dump(skb, cb);
-- 
1.7.10.4