Received: by 10.192.165.148 with SMTP id m20csp3821774imm; Mon, 23 Apr 2018 13:01:21 -0700 (PDT) X-Google-Smtp-Source: AIpwx48HI16X+EZKZvgHCrzZdfgm+HjPXhpiJsMaNiP3R/Zq30ZI+MBunUrxe5xR/LfIKHgTG3F2 X-Received: by 2002:a17:902:c81:: with SMTP id 1-v6mr16891351plt.126.1524513681496; Mon, 23 Apr 2018 13:01:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524513681; cv=none; d=google.com; s=arc-20160816; b=L1ONCOI8IKjIEMR9qdUOhwWgFIydospFu0EyWOfeAMBTD9trf/rti3CaEEOKKehTnw aAtqNXv9xNPl60zGwmLB5ysX78EuUOzaJi0+SgSULbGNDnEn7mRhGDlhGK3b3J8dWg82 lRKpAAjxrJ2HYhonLbVq9RWP/jLUL042phKT03n1QPG8bm/fHF1D25JOCimoaruGXL/K VAPxdvMjlzzNGs3h9gta4KH8i/pNd5KX4CuGM9s3297rAHPJmztJpWZL3cO9pkxlF7H5 WaUTlVWjiwHVnRAXQnUDMkBndTPBUAMrKbH3PyyZ+ihcHtEZ2BjeCHDhx/DfN6P+uAny GsBg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :arc-authentication-results; bh=s8eRNWexpUN0tKfAEt8CcD9mWdzhalGuyxqDviw6TJQ=; b=uOlEzxVKclpDzYXFMZMCH/rclWldHyJsHYJ0HenbiSSJMcRAfb0corwj+sv/I3Nrc1 DxKDYxzo5sdZwv1f2mSawc+/aWcdQbNoM/Uw814gv0FmR8EE6xmZkN2pUUHcFTWxQ8T6 +SY36gtSTGOhMr5wOOuuwIvhTCWHrYQy7h04haqHO+pfy99cxHpZPg0MZNLkDvgAcQEn 2OfoWrzSX/H5aS/Z0ksfgZWfT1rRbngahNYcFjiyEwffD7SxH64czUDu0gXaxJSAiDPY +Y/iGHLmpxVQ3kISbReYPz+fzEdohXiclLSPEEpKru3krYjjlmi2yLkXmd7YYWpLCQAL XHuA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q28si12134986pfl.317.2018.04.23.13.01.03; Mon, 23 Apr 2018 13:01:21 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932409AbeDWT7t (ORCPT + 99 others); Mon, 23 Apr 2018 15:59:49 -0400 Received: from mx3-rdu2.redhat.com ([66.187.233.73]:34172 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S932306AbeDWT7s (ORCPT ); Mon, 23 Apr 2018 15:59:48 -0400 Received: from smtp.corp.redhat.com (int-mx03.intmail.prod.int.rdu2.redhat.com [10.11.54.3]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 7897D40711B2; Mon, 23 Apr 2018 19:59:46 +0000 (UTC) Received: from redhat.com (ovpn-123-116.rdu2.redhat.com [10.10.123.116]) by smtp.corp.redhat.com (Postfix) with SMTP id AAE721208F7B; Mon, 23 Apr 2018 19:59:43 +0000 (UTC) Date: Mon, 23 Apr 2018 22:59:43 +0300 From: "Michael S. Tsirkin" To: Konrad Rzeszutek Wilk Cc: Jason Wang , kvm@vger.kernel.org, virtualization@lists.linux-foundation.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, tiwei.bie@intel.com, jfreimann@redhat.com, wexu@redhat.com Subject: Re: [RFC V3 PATCH 0/8] Packed ring for vhost Message-ID: <20180423224715-mutt-send-email-mst@kernel.org> References: <1524461700-5469-1-git-send-email-jasowang@redhat.com> <20180423193120.GD30033@char.us.oracle.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180423193120.GD30033@char.us.oracle.com> X-Scanned-By: MIMEDefang 2.78 on 10.11.54.3 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.7]); Mon, 23 Apr 2018 19:59:47 +0000 (UTC) X-Greylist: inspected by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.7]); Mon, 23 Apr 2018 19:59:47 +0000 (UTC) for IP:'10.11.54.3' DOMAIN:'int-mx03.intmail.prod.int.rdu2.redhat.com' HELO:'smtp.corp.redhat.com' FROM:'mst@redhat.com' RCPT:'' Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Apr 23, 2018 at 03:31:20PM -0400, Konrad Rzeszutek Wilk wrote: > On Mon, Apr 23, 2018 at 01:34:52PM +0800, Jason Wang wrote: > > Hi all: > > > > This RFC implement packed ring layout. The code were tested with > > Tiwei's RFC V2 a thttps://lkml.org/lkml/2018/4/1/48. Some fixups and > > tweaks were needed on top of Tiwei's code to make it run. TCP stream > > and pktgen does not show obvious difference compared with split ring. > > I have to ask then - what is the benefit of this? You can use this with dpdk within guest. The DPDK version did see a performance improvement so hopefully with future versions this will too. > > > > Changes from V2: > > - do not use & in checking desc_event_flags > > - off should be most significant bit > > - remove the workaround of mergeable buffer for dpdk prototype > > - id should be in the last descriptor in the chain > > - keep _F_WRITE for write descriptor when adding used > > - device flags updating should use ADDR_USED type > > - return error on unexpected unavail descriptor in a chain > > - return false in vhost_ve_avail_empty is descriptor is available > > - track last seen avail_wrap_counter > > - correctly examine available descriptor in get_indirect_packed() > > - vhost_idx_diff should return u16 instead of bool > > > > Changes from V1: > > > > - Refactor vhost used elem code to avoid open coding on used elem > > - Event suppression support (compile test only). > > - Indirect descriptor support (compile test only). > > - Zerocopy support. > > - vIOMMU support. > > - SCSI/VSOCK support (compile test only). > > - Fix several bugs > > > > For simplicity, I don't implement batching or other optimizations. > > > > Please review. > > > > Jason Wang (8): > > vhost: move get_rx_bufs to vhost.c > > vhost: hide used ring layout from device > > vhost: do not use vring_used_elem > > vhost_net: do not explicitly manipulate vhost_used_elem > > vhost: vhost_put_user() can accept metadata type > > virtio: introduce packed ring defines > > vhost: packed ring support > > vhost: event suppression for packed ring > > > > drivers/vhost/net.c | 136 ++---- > > drivers/vhost/scsi.c | 62 +-- > > drivers/vhost/vhost.c | 824 ++++++++++++++++++++++++++++++++++--- > > drivers/vhost/vhost.h | 47 ++- > > drivers/vhost/vsock.c | 42 +- > > include/uapi/linux/virtio_config.h | 9 + > > include/uapi/linux/virtio_ring.h | 32 ++ > > 7 files changed, 926 insertions(+), 226 deletions(-) > > > > -- > > 2.7.4 > >