diff --git a/[refs] b/[refs] index efb64710f9de..44185730111c 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 990098068fe963f956c14f681bd88d90dcb14584 +refs/heads/master: a198d3a200313bca8261e30e6daaad790937fd7e diff --git a/trunk/net/tipc/socket.c b/trunk/net/tipc/socket.c index 91aa2dc51771..c1a199c0fa6d 100644 --- a/trunk/net/tipc/socket.c +++ b/trunk/net/tipc/socket.c @@ -1065,7 +1065,9 @@ static int recv_stream(struct kiocb *iocb, struct socket *sock, /* Loop around if more data is required */ if ((sz_copied < buf_len) /* didn't get all requested data */ - && (flags & MSG_WAITALL) /* ... and need to wait for more */ + && (!skb_queue_empty(&sock->sk->sk_receive_queue) || + (flags & MSG_WAITALL)) + /* ... and more is ready or required */ && (!(flags & MSG_PEEK)) /* ... and aren't just peeking at data */ && (!err) /* ... and haven't reached a FIN */ )