vsock: return errors other than -ENOMEM to socket
authorArseniy Krasnov <avkrasnov@sberdevices.ru>
Mon, 3 Apr 2023 11:25:12 +0000 (14:25 +0300)
committerPaolo Abeni <pabeni@redhat.com>
Tue, 4 Apr 2023 10:46:24 +0000 (12:46 +0200)
This removes behaviour, where error code returned from any transport
was always switched to ENOMEM. This works in the same way as:
commit
c43170b7e157 ("vsock: return errors other than -ENOMEM to socket"),
but for receive calls.

Signed-off-by: Arseniy Krasnov <AVKrasnov@sberdevices.ru>
Reviewed-by: Stefano Garzarella <sgarzare@redhat.com>
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
net/vmw_vsock/af_vsock.c

index 5f2dda3..413407b 100644 (file)
@@ -2043,7 +2043,7 @@ static int __vsock_stream_recvmsg(struct sock *sk, struct msghdr *msg,
 
                read = transport->stream_dequeue(vsk, msg, len - copied, flags);
                if (read < 0) {
-                       err = -ENOMEM;
+                       err = read;
                        break;
                }
 
@@ -2094,7 +2094,7 @@ static int __vsock_seqpacket_recvmsg(struct sock *sk, struct msghdr *msg,
        msg_len = transport->seqpacket_dequeue(vsk, msg, flags);
 
        if (msg_len < 0) {
-               err = -ENOMEM;
+               err = msg_len;
                goto out;
        }