Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp389398pxb; Mon, 13 Sep 2021 22:57:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxRusCfb8+GW4paFrr6u577FGa8a4ogCKQOxKO5RyNfdCn2h2fX2xwgm7EO1ZiSm2dBsJlE X-Received: by 2002:a17:906:308d:: with SMTP id 13mr16759275ejv.570.1631599036892; Mon, 13 Sep 2021 22:57:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1631599036; cv=none; d=google.com; s=arc-20160816; b=tPuFAGfxUkG12HVwEyLnLn99EXzd8aM+Fkgjj/s/wPlVY6IbvUZlFioggyRs/tuSaO N5HwYK/KZZKag7XnlNCTCKJEO6EGwCUslhhWNEAXYaMO9vwkFYFqc29zWGlNdMOcP0U9 iAlLE+ZWoBm6dc6UFwFLIakCwH3D1/p1ws9p/bRaBzkZbxQJ2N2Mai0T438CYze3cnza R3+6GHj0nB0MBDj3+s15yPu5uZbHAqUhC0uPHqeusTPVp3AaapcZQjIdQTQUcx5WvpFu O8yprtdrQhXdsI9WMEdkianLLyOppGrRMQQ62KZTX6KWLeLDB6yvgcNhg2Lcti6XAWLg VtiA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=6P3Hg4gutReG5Sbg1AE6RT45vebLhTpUQQ0b1X0Vkms=; b=zE6xiugnmGRklTtS/PN6PIVJNLX0GsqVzPUxXx9aV5SOYhQ9OV6QLoEXUSK02bSNaN mZ58VkdvDeAWqRgzjAtzD8RWDTYvbqBJ1nnSQQwRsmtIpWfu+5xddBUW8cmRiOyn1qru Ro6N/aOg8Zkeuk4j8lKyJG2fdHpRXtlEmDQ5S2nZx1OIL+3e3oiM2yKn8qyyoJQHD1J8 meK2RZeAWOdswbjjhYT/fPhgWkVmL2FrQx0mfSYYMxijtCiXxPQ6bLQang5tHskm/KyE QBRFR10RoiNyo3tTlY2BnEVONGgo2q1sjKTJ1y88QCYfJFGcUriD27yXL89ur7e3Od5K hFug== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=MTzR0KmU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id cx2si8985958edb.344.2021.09.13.22.56.53; Mon, 13 Sep 2021 22:57:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=MTzR0KmU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239893AbhINF4h (ORCPT + 99 others); Tue, 14 Sep 2021 01:56:37 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59540 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239698AbhINF4g (ORCPT ); Tue, 14 Sep 2021 01:56:36 -0400 Received: from mail-pf1-x435.google.com (mail-pf1-x435.google.com [IPv6:2607:f8b0:4864:20::435]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 00F14C061764 for ; Mon, 13 Sep 2021 22:55:20 -0700 (PDT) Received: by mail-pf1-x435.google.com with SMTP id f65so11119832pfb.10 for ; Mon, 13 Sep 2021 22:55:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=6P3Hg4gutReG5Sbg1AE6RT45vebLhTpUQQ0b1X0Vkms=; b=MTzR0KmUJ1q87fdNpZpMK9h6XXbkg3fNZXH1AdkDVsoU3folKJwrb7SxjpFephEJ+s Co9XYjV55zRvYYAZqUnw6dO4OMIo8ugxiV0uPZtcCDCHNYWlF++UvRgPoWrYlnf3+3U0 3Anob837AbiXEBBpPm/SKtgL2qJkxWYS9phkXAGetq1PZCNQZPdzkCxIx5xxDuDLQxN8 3CbGgvObm98SUG0bw9brVu0UgqOsKtB11gRlqpzemoPM4lmQHqmIVG9OWn0XkMSRb79W nFTzBA0FqXd/Kd+xCv1JFnHJkeax4Z+gFbP9DwSy2dC0cdz6pCuDHdB+g7eumCL2TwRJ 0j3Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=6P3Hg4gutReG5Sbg1AE6RT45vebLhTpUQQ0b1X0Vkms=; b=oul9GoLAWW7z22vDV65t7Bc5R5dXHE45adO+WSN03UlOl1mDC2ZJO0QSe4aH1HgYkg WCTE4ilFR8rUmbC7k4baX9rjAKYnHb5w25RfJBoJsCiQGQYrkr9tzEFvr0waI7AWekfu iOmmCYB88iy9yhEjel/18YDUabty/WxK5l+xzRRwnhq793FW6cRlPNtElb/smCjRr6Zo eSQzcuq/9pYmbyLhsIFAbgTtK+5P4lxdMGgPz595PyyMKyTna6Q7KXiKR6dkKZ2tmN5/ pkMWNyIzZz9qAIOtn/yq4aJSGrNoCwLlzxub6c9aWeBh+Gp3lZApSKiyueGE6ByogZd6 wSRw== X-Gm-Message-State: AOAM533gvrMKvN2Jm8qSp1vP2hVFOJACqeB3RlC6q5ktg5+Y2Kd3CclW kAM6L2YxWTeOodamQdgXbQ/0Wg== X-Received: by 2002:aa7:9115:0:b029:359:69db:bc89 with SMTP id 21-20020aa791150000b029035969dbbc89mr3185623pfh.32.1631598919355; Mon, 13 Sep 2021 22:55:19 -0700 (PDT) Received: from ip-10-124-121-13.byted.org (ec2-54-241-92-238.us-west-1.compute.amazonaws.com. [54.241.92.238]) by smtp.gmail.com with ESMTPSA id v14sm719432pfi.111.2021.09.13.22.55.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 13 Sep 2021 22:55:18 -0700 (PDT) From: Jiang Wang To: jiangleetcode@gmail.com Cc: virtualization@lists.linux-foundation.org, stefanha@redhat.com, sgarzare@redhat.com, mst@redhat.com, arseny.krasnov@kaspersky.com, jhansen@vmware.com, cong.wang@bytedance.com, duanxiongchun@bytedance.com, xieyongji@bytedance.com, chaiwen.cc@bytedance.com, Jason Wang , "David S. Miller" , Jakub Kicinski , Steven Rostedt , Ingo Molnar , kvm@vger.kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [RFC v2 0/5] virtio/vsock: introduce SOCK_DGRAM support Date: Tue, 14 Sep 2021 05:54:33 +0000 Message-Id: <20210914055440.3121004-1-jiang.wang@bytedance.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patchset implements support of SOCK_DGRAM for virtio transport. Datagram sockets are connectionless and unreliable. To avoid unfair contention with stream and other sockets, add two more virtqueues and a new feature bit to indicate if those two new queues exist or not. Dgram does not use the existing credit update mechanism for stream sockets. When sending from the guest/driver, sending packets synchronously, so the sender will get an error when the virtqueue is full. When sending from the host/device, send packets asynchronously because the descriptor memory belongs to the corresponding QEMU process. The virtio spec patch is here: https://www.mail-archive.com/virtualization@lists.linux-foundation.org/msg47457.html For those who prefer git repo, here is the link for the linux kernel: https://github.com/Jiang1155/linux/tree/vsock-dgram-v2 qemu patch link: https://lists.gnu.org/archive/html/qemu-devel/2021-09/msg03462.html To do: 1. use skb when receiving packets 2. support multiple transport 3. support mergeable rx buffer 4. support disabling F_STREAM feature bit v1 -> v2 : - fix migration bug in vhost-vsock - rename some variables - clean up some code in virtio-vsock - use le_to_cpu16 in virtio-vsock Jiang Wang (5): virtio/vsock: add VIRTIO_VSOCK_F_DGRAM feature bit virtio/vsock: add support for virtio datagram vhost/vsock: add support for vhost dgram. vsock_test: add tests for vsock dgram virtio/vsock: add sysfs for rx buf len for dgram drivers/vhost/vsock.c | 220 +++++++-- include/linux/virtio_vsock.h | 9 + include/net/af_vsock.h | 1 + .../events/vsock_virtio_transport_common.h | 2 + include/uapi/linux/virtio_vsock.h | 3 + net/vmw_vsock/af_vsock.c | 12 + net/vmw_vsock/virtio_transport.c | 463 +++++++++++++++--- net/vmw_vsock/virtio_transport_common.c | 181 ++++++- tools/testing/vsock/util.c | 105 ++++ tools/testing/vsock/util.h | 4 + tools/testing/vsock/vsock_test.c | 195 ++++++++ 11 files changed, 1083 insertions(+), 112 deletions(-) -- 2.20.1