virtualization.lists.linux-foundation.org archive mirror
 help / color / mirror / Atom feed
  • [parent not found: <20230227-vsock-sockmap-upstream-v3-2-7e7f4ce623ee@bytedance.com>]
  • [parent not found: <20230227-vsock-sockmap-upstream-v3-3-7e7f4ce623ee@bytedance.com>]
  • * Re: [PATCH net-next v3 0/3] vsock: add support for sockmap
           [not found] <20230227-vsock-sockmap-upstream-v3-0-7e7f4ce623ee@bytedance.com>
                       ` (2 preceding siblings ...)
           [not found] ` <20230227-vsock-sockmap-upstream-v3-3-7e7f4ce623ee@bytedance.com>
    @ 2023-03-10  8:53 ` Michael S. Tsirkin
      3 siblings, 0 replies; 6+ messages in thread
    From: Michael S. Tsirkin @ 2023-03-10  8:53 UTC (permalink / raw)
      To: Bobby Eshleman
      Cc: Cong Wang, kvm, Alexei Starovoitov, virtualization, Song Liu,
    	Eric Dumazet, Stanislav Fomichev, linux-kselftest, Shuah Khan,
    	Mykola Lysenko, Daniel Borkmann, John Fastabend, Andrii Nakryiko,
    	Yonghong Song, Paolo Abeni, KP Singh, Stefan Hajnoczi,
    	Jakub Kicinski, Hao Luo, netdev, linux-kernel, Jiri Olsa, bpf,
    	Martin KaFai Lau, David S. Miller
    
    On Tue, Feb 28, 2023 at 07:04:33PM +0000, Bobby Eshleman wrote:
    > Add support for sockmap to vsock.
    > 
    > We're testing usage of vsock as a way to redirect guest-local UDS
    > requests to the host and this patch series greatly improves the
    > performance of such a setup.
    > 
    > Compared to copying packets via userspace, this improves throughput by
    > 121% in basic testing.
    
    
    besides the small comment, looks ok. Feel free to include my ack
    in v4:
    
    Acked-by: Michael S. Tsirkin <mst@redhat.com>
    
    > Tested as follows.
    > 
    > Setup: guest unix dgram sender -> guest vsock redirector -> host vsock
    >        server
    > Threads: 1
    > Payload: 64k
    > No sockmap:
    > - 76.3 MB/s
    > - The guest vsock redirector was
    >   "socat VSOCK-CONNECT:2:1234 UNIX-RECV:/path/to/sock"
    > Using sockmap (this patch):
    > - 168.8 MB/s (+121%)
    > - The guest redirector was a simple sockmap echo server,
    >   redirecting unix ingress to vsock 2:1234 egress.
    > - Same sender and server programs
    > 
    > *Note: these numbers are from RFC v1
    > 
    > Only the virtio transport has been tested. The loopback transport was
    > used in writing bpf/selftests, but not thoroughly tested otherwise.
    > 
    > This series requires the skb patch.
    > 
    > Changes in v3:
    > - vsock/bpf: Refactor wait logic in vsock_bpf_recvmsg() to avoid
    >   backwards goto
    > - vsock/bpf: Check psock before acquiring slock
    > - vsock/bpf: Return bool instead of int of 0 or 1
    > - vsock/bpf: Wrap macro args __sk/__psock in parens
    > - vsock/bpf: Place comment trailer */ on separate line
    > 
    > Changes in v2:
    > - vsock/bpf: rename vsock_dgram_* -> vsock_*
    > - vsock/bpf: change sk_psock_{get,put} and {lock,release}_sock() order
    >   to minimize slock hold time
    > - vsock/bpf: use "new style" wait
    > - vsock/bpf: fix bug in wait log
    > - vsock/bpf: add check that recvmsg sk_type is one dgram, seqpacket, or
    >   stream.  Return error if not one of the three.
    > - virtio/vsock: comment __skb_recv_datagram() usage
    > - virtio/vsock: do not init copied in read_skb()
    > - vsock/bpf: add ifdef guard around struct proto in dgram_recvmsg()
    > - selftests/bpf: add vsock loopback config for aarch64
    > - selftests/bpf: add vsock loopback config for s390x
    > - selftests/bpf: remove vsock device from vmtest.sh qemu machine
    > - selftests/bpf: remove CONFIG_VIRTIO_VSOCKETS=y from config.x86_64
    > - vsock/bpf: move transport-related (e.g., if (!vsk->transport)) checks
    >   out of fast path
    > 
    > Signed-off-by: Bobby Eshleman <bobby.eshleman@bytedance.com>
    > ---
    > Bobby Eshleman (3):
    >       vsock: support sockmap
    >       selftests/bpf: add vsock to vmtest.sh
    >       selftests/bpf: Add a test case for vsock sockmap
    > 
    >  drivers/vhost/vsock.c                              |   1 +
    >  include/linux/virtio_vsock.h                       |   1 +
    >  include/net/af_vsock.h                             |  17 ++
    >  net/vmw_vsock/Makefile                             |   1 +
    >  net/vmw_vsock/af_vsock.c                           |  55 ++++++-
    >  net/vmw_vsock/virtio_transport.c                   |   2 +
    >  net/vmw_vsock/virtio_transport_common.c            |  24 +++
    >  net/vmw_vsock/vsock_bpf.c                          | 175 +++++++++++++++++++++
    >  net/vmw_vsock/vsock_loopback.c                     |   2 +
    >  tools/testing/selftests/bpf/config.aarch64         |   2 +
    >  tools/testing/selftests/bpf/config.s390x           |   3 +
    >  tools/testing/selftests/bpf/config.x86_64          |   3 +
    >  .../selftests/bpf/prog_tests/sockmap_listen.c      | 163 +++++++++++++++++++
    >  13 files changed, 443 insertions(+), 6 deletions(-)
    > ---
    > base-commit: d83115ce337a632f996e44c9f9e18cadfcf5a094
    > change-id: 20230118-support-vsock-sockmap-connectible-2e1297d2111a
    > 
    > Best regards,
    > --
    > Bobby Eshleman <bobby.eshleman@bytedance.com>
    > 
    > ---
    > Bobby Eshleman (3):
    >       vsock: support sockmap
    >       selftests/bpf: add vsock to vmtest.sh
    >       selftests/bpf: add a test case for vsock sockmap
    > 
    >  drivers/vhost/vsock.c                              |   1 +
    >  include/linux/virtio_vsock.h                       |   1 +
    >  include/net/af_vsock.h                             |  17 ++
    >  net/vmw_vsock/Makefile                             |   1 +
    >  net/vmw_vsock/af_vsock.c                           |  55 ++++++-
    >  net/vmw_vsock/virtio_transport.c                   |   2 +
    >  net/vmw_vsock/virtio_transport_common.c            |  25 +++
    >  net/vmw_vsock/vsock_bpf.c                          | 174 +++++++++++++++++++++
    >  net/vmw_vsock/vsock_loopback.c                     |   2 +
    >  tools/testing/selftests/bpf/config.aarch64         |   2 +
    >  tools/testing/selftests/bpf/config.s390x           |   3 +
    >  tools/testing/selftests/bpf/config.x86_64          |   3 +
    >  .../selftests/bpf/prog_tests/sockmap_listen.c      | 163 +++++++++++++++++++
    >  13 files changed, 443 insertions(+), 6 deletions(-)
    > ---
    > base-commit: c2ea552065e43d05bce240f53c3185fd3a066204
    > change-id: 20230227-vsock-sockmap-upstream-9d65c84174a2
    > 
    > Best regards,
    > -- 
    > Bobby Eshleman <bobby.eshleman@bytedance.com>
    
    _______________________________________________
    Virtualization mailing list
    Virtualization@lists.linux-foundation.org
    https://lists.linuxfoundation.org/mailman/listinfo/virtualization
    
    ^ permalink raw reply	[flat|nested] 6+ messages in thread

  • end of thread, other threads:[~2023-03-10  8:53 UTC | newest]
    
    Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
    -- links below jump to the message on this page --
         [not found] <20230227-vsock-sockmap-upstream-v3-0-7e7f4ce623ee@bytedance.com>
         [not found] ` <20230227-vsock-sockmap-upstream-v3-1-7e7f4ce623ee@bytedance.com>
    2023-02-28 21:36   ` [PATCH net-next v3 1/3] vsock: support sockmap Michael S. Tsirkin
         [not found]     ` <Y/B9ddkfQw6Ae/lY@bullseye>
    2023-03-02  9:20       ` Stefano Garzarella
    2023-03-02  9:42   ` Stefano Garzarella
         [not found] ` <20230227-vsock-sockmap-upstream-v3-2-7e7f4ce623ee@bytedance.com>
    2023-03-02  9:53   ` [PATCH net-next v3 2/3] selftests/bpf: add vsock to vmtest.sh Stefano Garzarella
         [not found] ` <20230227-vsock-sockmap-upstream-v3-3-7e7f4ce623ee@bytedance.com>
    2023-03-02  9:54   ` [PATCH net-next v3 3/3] selftests/bpf: add a test case for vsock sockmap Stefano Garzarella
    2023-03-10  8:53 ` [PATCH net-next v3 0/3] vsock: add support for sockmap Michael S. Tsirkin
    

    This is a public inbox, see mirroring instructions
    for how to clone and mirror all data and code used for this inbox;
    as well as URLs for NNTP newsgroup(s).