Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp1392698imm; Wed, 17 Oct 2018 19:46:33 -0700 (PDT) X-Google-Smtp-Source: ACcGV62EfioM7uvEMu4cXUIpxgm/MmQDp3JpRJE2ijePwVHP2sA2ow2u0FYjAYUJ+m5r8z26h4I9 X-Received: by 2002:a62:6a06:: with SMTP id f6-v6mr19426304pfc.31.1539830793065; Wed, 17 Oct 2018 19:46:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539830793; cv=none; d=google.com; s=arc-20160816; b=FFknfu6nvEE01sqRA1tGsI/WfzjkZF/3RGCRRVOCVfHulVByw6ReWvEmeVB0xFaPi5 gUOvS4nwxtj7DxUNhgLHCFppUas/BnjKGz0TfQ3k2GIQcSC3eTmOZthiWytijSHZcOon MAdVc6MoJ+Jp1PR5bXZQBFI71oy2fvx2A2hGtV+l/EopLoFz7ofWs0OrBurXoM5mQsgX qSeexnWaptxB6ubVq3TfVVvxnRXHhQ3ts2zLDjHfnLygSCh3ykTJ4c8AXSjTYbnhwJem TxAn5bI5BPGr2CkJWaD3jyXw1HK66wbcE79vRV7fcdzRdRrmw6HTuqsUPb2xgNSfds+l 0B9A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=52Angq1BV7HO8YHSyoW2kBMScdDb8eyxldxnwpZzCzw=; b=YuvV+Q1LHnolWZHzSGoAAOqdsL4vuUXNnFGnHCb8RahAnUJJ/Tmn1MgKR90SQBN6Xs k0HXYGzHF7WtJ9UfS+iM6ffewSjO9K5mT0sOqFaWz2hYWFKutxTPXBfxbJ6e2Ll+d28k daSZ76BAndLxfvycVVOPFyq6U3vke1V1bMwqc4tVNQJgRLsFMGeYLXm7Dy5Z7G9JTsUf bXRztCuOqpLNcith+zU9U+yNgbEH/1OPNrbcGfOQoN7r5CFTs+TsdDvkAYch7Upxbaqn TtovVY9Ejp5nlnfko41Ji5FWAM/wbcY8VZldY3SXVWDD88/8PmzMQ+cZKq41XS26UA51 hWGg== 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 r16-v6si18415423pgv.548.2018.10.17.19.46.16; Wed, 17 Oct 2018 19:46:33 -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 S1727453AbeJRKnb (ORCPT + 99 others); Thu, 18 Oct 2018 06:43:31 -0400 Received: from mx1.redhat.com ([209.132.183.28]:48030 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727267AbeJRKnb (ORCPT ); Thu, 18 Oct 2018 06:43:31 -0400 Received: from smtp.corp.redhat.com (int-mx07.intmail.prod.int.phx2.redhat.com [10.5.11.22]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 69C40C03D466; Thu, 18 Oct 2018 02:44:50 +0000 (UTC) Received: from [10.72.12.103] (ovpn-12-103.pek2.redhat.com [10.72.12.103]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 2A2651062243; Thu, 18 Oct 2018 02:44:38 +0000 (UTC) Subject: Re: [PATCH net-next V2 6/8] vhost: packed ring support To: "Michael S. Tsirkin" Cc: Tiwei Bie , kvm@vger.kernel.org, virtualization@lists.linux-foundation.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, wexu@redhat.com, jfreimann@redhat.com, maxime.coquelin@redhat.com References: <1531711691-6769-1-git-send-email-jasowang@redhat.com> <1531711691-6769-7-git-send-email-jasowang@redhat.com> <20181012143244.GA28400@debian> <20181012131812-mutt-send-email-mst@kernel.org> <447f47fa-32dd-a408-dd81-13a9839e0748@redhat.com> <20181014224208-mutt-send-email-mst@kernel.org> <20181015062241-mutt-send-email-mst@kernel.org> From: Jason Wang Message-ID: Date: Thu, 18 Oct 2018 10:44:36 +0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.2.1 MIME-Version: 1.0 In-Reply-To: <20181015062241-mutt-send-email-mst@kernel.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US X-Scanned-By: MIMEDefang 2.84 on 10.5.11.22 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.31]); Thu, 18 Oct 2018 02:44:50 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2018/10/15 下午6:25, Michael S. Tsirkin wrote: > On Mon, Oct 15, 2018 at 10:51:06AM +0800, Jason Wang wrote: >> On 2018年10月15日 10:43, Michael S. Tsirkin wrote: >>> On Mon, Oct 15, 2018 at 10:22:33AM +0800, Jason Wang wrote: >>>> On 2018年10月13日 01:23, Michael S. Tsirkin wrote: >>>>> On Fri, Oct 12, 2018 at 10:32:44PM +0800, Tiwei Bie wrote: >>>>>> On Mon, Jul 16, 2018 at 11:28:09AM +0800, Jason Wang wrote: >>>>>> [...] >>>>>>> @@ -1367,10 +1397,48 @@ long vhost_vring_ioctl(struct vhost_dev *d, unsigned int ioctl, void __user *arg >>>>>>> vq->last_avail_idx = s.num; >>>>>>> /* Forget the cached index value. */ >>>>>>> vq->avail_idx = vq->last_avail_idx; >>>>>>> + if (vhost_has_feature(vq, VIRTIO_F_RING_PACKED)) { >>>>>>> + vq->last_avail_wrap_counter = wrap_counter; >>>>>>> + vq->avail_wrap_counter = vq->last_avail_wrap_counter; >>>>>>> + } >>>>>>> break; >>>>>>> case VHOST_GET_VRING_BASE: >>>>>>> s.index = idx; >>>>>>> s.num = vq->last_avail_idx; >>>>>>> + if (vhost_has_feature(vq, VIRTIO_F_RING_PACKED)) >>>>>>> + s.num |= vq->last_avail_wrap_counter << 31; >>>>>>> + if (copy_to_user(argp, &s, sizeof(s))) >>>>>>> + r = -EFAULT; >>>>>>> + break; >>>>>>> + case VHOST_SET_VRING_USED_BASE: >>>>>>> + /* Moving base with an active backend? >>>>>>> + * You don't want to do that. >>>>>>> + */ >>>>>>> + if (vq->private_data) { >>>>>>> + r = -EBUSY; >>>>>>> + break; >>>>>>> + } >>>>>>> + if (copy_from_user(&s, argp, sizeof(s))) { >>>>>>> + r = -EFAULT; >>>>>>> + break; >>>>>>> + } >>>>>>> + if (vhost_has_feature(vq, VIRTIO_F_RING_PACKED)) { >>>>>>> + wrap_counter = s.num >> 31; >>>>>>> + s.num &= ~(1 << 31); >>>>>>> + } >>>>>>> + if (s.num > 0xffff) { >>>>>>> + r = -EINVAL; >>>>>>> + break; >>>>>>> + } >>>>>> Do we want to put wrap_counter at bit 15? >>>>> I think I second that - seems to be consistent with >>>>> e.g. event suppression structure and the proposed >>>>> extension to driver notifications. >>>> Ok, I assumes packed virtqueue support 64K but looks not. I can change it to >>>> bit 15 and GET_VRING_BASE need to be changed as well. >>>> >>>>>> If put wrap_counter at bit 31, the check (s.num > 0xffff) >>>>>> won't be able to catch the illegal index 0x8000~0xffff for >>>>>> packed ring. >>>>>> >>>> Do we need to clarify this in the spec? >>> Isn't this all internal vhost stuff? >> I meant the illegal index 0x8000-0xffff. > It does say packed virtqueues support up to 2 15 entries each. > > But yes we can add a requirement that devices do not expose > larger rings. Split does not support 2**16 either, right? > With 2**16 enties avail index becomes 0 and ring looks empty. > Yes, so it's better to clarify this in the spec. Thanks