OSDN Git Service

vsock/virtio: fix locking in virtio_transport_inc_tx_pkt()
authorStefano Garzarella <sgarzare@redhat.com>
Tue, 30 Jul 2019 15:43:32 +0000 (17:43 +0200)
committerDavid S. Miller <davem@davemloft.net>
Tue, 30 Jul 2019 22:00:00 +0000 (15:00 -0700)
fwd_cnt and last_fwd_cnt are protected by rx_lock, so we should use
the same spinlock also if we are in the TX path.

Move also buf_alloc under the same lock.

Signed-off-by: Stefano Garzarella <sgarzare@redhat.com>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Acked-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/linux/virtio_vsock.h
net/vmw_vsock/virtio_transport_common.c

index 49fc9d2..4c7781f 100644 (file)
@@ -35,7 +35,6 @@ struct virtio_vsock_sock {
 
        /* Protected by tx_lock */
        u32 tx_cnt;
-       u32 buf_alloc;
        u32 peer_fwd_cnt;
        u32 peer_buf_alloc;
 
@@ -43,6 +42,7 @@ struct virtio_vsock_sock {
        u32 fwd_cnt;
        u32 last_fwd_cnt;
        u32 rx_bytes;
+       u32 buf_alloc;
        struct list_head rx_queue;
 };
 
index a85559d..34a2b42 100644 (file)
@@ -210,11 +210,11 @@ static void virtio_transport_dec_rx_pkt(struct virtio_vsock_sock *vvs,
 
 void virtio_transport_inc_tx_pkt(struct virtio_vsock_sock *vvs, struct virtio_vsock_pkt *pkt)
 {
-       spin_lock_bh(&vvs->tx_lock);
+       spin_lock_bh(&vvs->rx_lock);
        vvs->last_fwd_cnt = vvs->fwd_cnt;
        pkt->hdr.fwd_cnt = cpu_to_le32(vvs->fwd_cnt);
        pkt->hdr.buf_alloc = cpu_to_le32(vvs->buf_alloc);
-       spin_unlock_bh(&vvs->tx_lock);
+       spin_unlock_bh(&vvs->rx_lock);
 }
 EXPORT_SYMBOL_GPL(virtio_transport_inc_tx_pkt);