Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3412754yba; Tue, 23 Apr 2019 03:25:54 -0700 (PDT) X-Google-Smtp-Source: APXvYqxrpqC+zqDGbbfJW7FXUJXAvSURXo+3BogP3IdRY1S6k1cWaf+VTgTu4WmhWPRqejrlNDoe X-Received: by 2002:a63:6849:: with SMTP id d70mr23149367pgc.21.1556015154500; Tue, 23 Apr 2019 03:25:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556015154; cv=none; d=google.com; s=arc-20160816; b=ZIPMmSC7SvduQAhXd3Wu/exaRs7nDh5FDOXt+1zB/UxpYR2ZLWhwKjq2xFdbo5OYck hNQVo1tUjPrHmlx7DH+yVyZjs5a5H8rT3nLKwKDqBVeOcS7g85EpArDF27ivVKQYeequ /D+Xcc+W4zenyOK9sfoLMXNDwfVmcDXyo/vlTAVQSThfrarqCMbGcnl5DFGXj/oivvGX 4bw+mDIzfMDI69cCw7l/NcHqWrD+b+lk5zeuw4fs5Yu2MnVSQl1T5S8oS7KXCcVnAp5g Li3dT80X4kXUVqakXGgZoEg3QrGh5PkvR0kpvISUDcCnui3MWHvdRMMo2hfdws0rs+0N OpYg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:reply-to:message-id :subject:cc:to:from:date; bh=KrqNzWM4AIpeafa2TLDs84FLbrzu//QIVuk3sus0ZTc=; b=r8gBCqr9alfvgbbEMZnGcMj9RM1N/nlKpr0iLAJ3vKLjpvQJcnyhrHb4SvjPsfyNSi NpzqkhAHcLjFC8e8T+TjdyCpafVVunWSNkE3Fyi9Ttl2veXEZSB3BzS2Y0jb00SNZaXh HqmX5LBalZ+Y/jRhCiQ0dJaz50g54QHrSJ5kLkyLTJi/TXLhQe/8W5/CGR6itpWCkTjV YrxQxkDRqH1GXzGB+xYgdieuxUNZtF3aXv3yGj2u4eisuxl2Wu+ZWaRTVngXdIK1xFRN ue8kOBtbEhFzBgAcPsCgOmN6EDZCWR88xsFUWdgbgIX7ivgWB8AsAfzcX7rMHbqwSMxC yJow== 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 n1si14282048pgj.578.2019.04.23.03.25.39; Tue, 23 Apr 2019 03:25:54 -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 S1727373AbfDWKYn (ORCPT + 99 others); Tue, 23 Apr 2019 06:24:43 -0400 Received: from mx1.redhat.com ([209.132.183.28]:37732 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726150AbfDWKYk (ORCPT ); Tue, 23 Apr 2019 06:24:40 -0400 Received: from smtp.corp.redhat.com (int-mx03.intmail.prod.int.phx2.redhat.com [10.5.11.13]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 87D4D307CDD6; Tue, 23 Apr 2019 10:24:39 +0000 (UTC) Received: from redhat.com (ovpn-112-50.ams2.redhat.com [10.36.112.50]) by smtp.corp.redhat.com (Postfix) with ESMTPS id ADD1817CC4; Tue, 23 Apr 2019 10:24:22 +0000 (UTC) Date: Tue, 23 Apr 2019 11:24:19 +0100 From: Daniel =?utf-8?B?UC4gQmVycmFuZ8Op?= To: Yan Zhao Cc: Alex Williamson , "cjia@nvidia.com" , "kvm@vger.kernel.org" , "aik@ozlabs.ru" , "Zhengxiao.zx@alibaba-inc.com" , "shuangtai.tst@alibaba-inc.com" , "qemu-devel@nongnu.org" , "kwankhede@nvidia.com" , "eauger@redhat.com" , "Liu, Yi L" , "eskultet@redhat.com" , "Yang, Ziye" , "mlevitsk@redhat.com" , "pasic@linux.ibm.com" , "libvir-list@redhat.com" , "arei.gonglei@huawei.com" , "felipe@nutanix.com" , "Ken.Xue@amd.com" , "Tian, Kevin" , "dgilbert@redhat.com" , "zhenyuw@linux.intel.com" , "intel-gvt-dev@lists.freedesktop.org" , "Liu, Changpeng" , "cohuck@redhat.com" , "linux-kernel@vger.kernel.org" , "Wang, Zhi A" , "jonathan.davies@nutanix.com" , "He, Shaopeng" Subject: Re: [Qemu-devel] [PATCH 1/2] vfio/mdev: add version field as mandatory attribute for mdev device Message-ID: <20190423102419.GE6022@redhat.com> Reply-To: Daniel =?utf-8?B?UC4gQmVycmFuZ8Op?= References: <20190419083258.19580-1-yan.y.zhao@intel.com> <20190419083505.19654-1-yan.y.zhao@intel.com> <20190422083950.25eb9e7c@x1.home> <20190423010152.GC32217@joy-OptiPlex-7040> <20190422192100.4d577e4b@x1.home> <20190423054157.GA26190@joy-OptiPlex-7040> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20190423054157.GA26190@joy-OptiPlex-7040> User-Agent: Mutt/1.11.3 (2019-02-01) X-Scanned-By: MIMEDefang 2.79 on 10.5.11.13 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.49]); Tue, 23 Apr 2019 10:24:40 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Apr 23, 2019 at 01:41:57AM -0400, Yan Zhao wrote: > On Tue, Apr 23, 2019 at 09:21:00AM +0800, Alex Williamson wrote: > > On Mon, 22 Apr 2019 21:01:52 -0400 > > Yan Zhao wrote: > > > > > On Mon, Apr 22, 2019 at 10:39:50PM +0800, Alex Williamson wrote: > > > > On Fri, 19 Apr 2019 04:35:04 -0400 > > > > Yan Zhao wrote: > > > > > > > > > device version attribute in mdev sysfs is used by user space software > > > > > (e.g. libvirt) to query device compatibility for live migration of VFIO > > > > > mdev devices. This attribute is mandatory if a mdev device supports live > > > > > migration. > > > > > > > > The Subject: doesn't quite match what's being proposed here. > > > > > > > > > It consists of two parts: common part and vendor proprietary part. > > > > > common part: 32 bit. lower 16 bits is vendor id and higher 16 bits > > > > > identifies device type. e.g., for pci device, it is > > > > > "pci vendor id" | (VFIO_DEVICE_FLAGS_PCI << 16). > > > > > > > > What purpose does this serve? If it's intended as some sort of > > > > namespace feature, shouldn't we first assume that we can only support > > > > migration to devices of the same type? Therefore each type would > > > > already have its own namespace. Also that would make the trailing bit > > > > of the version string listed below in the example redundant. A vendor > > > > is still welcome to include this in their version string if they wish, > > > > but I think the string should be entirely vendor defined. > > > > > > > hi Alex, > > > This common part is a kind of namespace. > > > Because if version string is entirely defined by vendors, I'm worried about > > > if there is a case that one vendor's version string happens to deceive and > > > interfere with another vendor's version checking? > > > e.g. > > > vendor A has a version string like: vendor id + device id + mdev type > > > vendor B has a version string like: device id + vendor id + mdev type > > > but vendor A's vendor id is 0x8086, device id is 0x1217 > > > vendor B's vendor id is 0x1217, device id is 0x8086. > > > > > > In this corner case, the two vendors may regard the two device is > > > migratable but actually they are not. > > > > > > That's the reason for this common part that serve as a kind of namespace > > > that all vendors will comply with to avoid overlap. > > > > If we assume that migration can only occur between matching mdev types, > > this is redundant, each type already has their own namespace. > > > hi Alex, > do you mean user space software like libvirt needs to first check whether > mdev type is matching and then check whether version is matching? I would expect that libvirt (or other mgmt apps) will always first check that the vendor id, device id, mdev type all match. So for the version string it should suffice to be a "normal" numeric value. Essentially version string just needs to be there to distinguish revisions of the same mdev type over time. Regards, Daniel -- |: https://berrange.com -o- https://www.flickr.com/photos/dberrange :| |: https://libvirt.org -o- https://fstop138.berrange.com :| |: https://entangle-photo.org -o- https://www.instagram.com/dberrange :|