Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp125554ybb; Tue, 24 Mar 2020 18:07:55 -0700 (PDT) X-Google-Smtp-Source: ADFU+vsYXlKgke/FTv7IrjlEf63qbLKCUjdYH0s7nL5NgDhpCZDHJk6qRIuw+WwRGH5IyxjapZEQ X-Received: by 2002:a9d:3d65:: with SMTP id a92mr647760otc.326.1585098475689; Tue, 24 Mar 2020 18:07:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585098475; cv=none; d=google.com; s=arc-20160816; b=z5DUUOKfdXfeQgPNkhZe0AScDloJpvWCUCnziWnfuC7N8eE2txd90QURB/XqRdgLcg R33zXzGrsSoADdwaM+x1aEEsM4mKqLlV2eGwNPXf3xJaUQYieNCjoNj9cZDWO31fx/wL gHKDwn+u1pfJVn8CsNWst+w1hW6nCUgVeUc+CYxBb/1SCCPruhmYb/6YHbq0QlAWnotd D9D5smeRdThRv2+SykN6ulu7ykj4gbWEXJ70MTrldFbg7DErkyyf2Pl0h94Uxv/jhzyC esZNGMSKH7g3BBlpQ6AYEo8An9hwpsd8YpR5P9HNg9MXUfOCvaAXhzwxWdc9DPJOO1LI zYAw== 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:ironport-sdr:ironport-sdr; bh=gjgX2uqB+jmO8XF2442GwHfygAGj9sjIIYZtEZJuk28=; b=S5L0EJ72yjo2KBWBDxQdIJTuRuTrpVnTv7B1eFK5v9n/I+xOEcx7CNNQhgMjSet/Bd iQbb/07B4O75CkKO5/T13+OEEhdjSktmCVqYkqt9B6UJldiLmRO304DtKvffKtXuU/xP v5HNobght/zTsLHSAHsJKVEW+9Gf1nFfKmPT/lRMZyqoVYRE6NI5nprEJNQHsnB01XcL t1RI6g3+BTMjnNDgv0tkty3bQ0oTZtfYxG0toE3+iBtQ9GTtDPHcoO2HsG+zrkzsDADm AC3NMjGBdnRfl//EcHqe2AH5XYKAwulqyyPKjLZr9PIxAmrmdfd5g469FldyrwFIzv8A 722Q== 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=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j84si10019567oia.126.2020.03.24.18.07.41; Tue, 24 Mar 2020 18:07:55 -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=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727229AbgCYBGL (ORCPT + 99 others); Tue, 24 Mar 2020 21:06:11 -0400 Received: from mga01.intel.com ([192.55.52.88]:32038 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727113AbgCYBGK (ORCPT ); Tue, 24 Mar 2020 21:06:10 -0400 IronPort-SDR: ay7TFHOeaJW50VAXg7l3jaenbZgbJsPVBDEB4Y+bVy36KnY9b5Op1l+e93oEBA9LSNX4H0Z+/+ gFdRlu6zEybg== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga003.jf.intel.com ([10.7.209.27]) by fmsmga101.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 24 Mar 2020 18:06:09 -0700 IronPort-SDR: z5R6lpjG8+2Oc1MM89RRMHOBYnTW4DVLrjfbD/wS/e2JrgHpwwTPP0nHfUphaKQqI2BmxmGIG/ bf8OkxO1AWWg== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.72,302,1580803200"; d="scan'208";a="246951513" Received: from joy-optiplex-7040.sh.intel.com (HELO joy-OptiPlex-7040) ([10.239.13.16]) by orsmga003.jf.intel.com with ESMTP; 24 Mar 2020 18:06:03 -0700 Date: Tue, 24 Mar 2020 20:56:32 -0400 From: Yan Zhao To: Alex Williamson Cc: "Dr. David Alan Gilbert" , "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" , "Yang, Ziye" , "mlevitsk@redhat.com" , "pasic@linux.ibm.com" , "libvir-list@redhat.com" , "felipe@nutanix.com" , "Ken.Xue@amd.com" , "Tian, Kevin" , "zhenyuw@linux.intel.com" , "dinechin@redhat.com" , "intel-gvt-dev@lists.freedesktop.org" , "Liu, Changpeng" , "berrange@redhat.com" , "cohuck@redhat.com" , "linux-kernel@vger.kernel.org" , "Wang, Zhi A" , "jonathan.davies@nutanix.com" , "He, Shaopeng" Subject: Re: [PATCH v4 0/2] introduction of migration_version attribute for VFIO live migration Message-ID: <20200325005631.GA20109@joy-OptiPlex-7040> Reply-To: Yan Zhao References: <20190531004438.24528-1-yan.y.zhao@intel.com> <20190603132932.1b5dc7fe@x1.home> <20190604003422.GA30229@joy-OptiPlex-7040> <20200323152959.1c39e9a7@w520.home> <20200324035316.GE5456@joy-OptiPlex-7040> <20200324092331.GA2645@work-vm> <20200324084954.0dd835e2@w520.home> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200324084954.0dd835e2@w520.home> User-Agent: Mutt/1.9.4 (2018-02-28) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Mar 24, 2020 at 10:49:54PM +0800, Alex Williamson wrote: > On Tue, 24 Mar 2020 09:23:31 +0000 > "Dr. David Alan Gilbert" wrote: > > > * Yan Zhao (yan.y.zhao@intel.com) wrote: > > > On Tue, Mar 24, 2020 at 05:29:59AM +0800, Alex Williamson wrote: > > > > On Mon, 3 Jun 2019 20:34:22 -0400 > > > > Yan Zhao wrote: > > > > > > > > > On Tue, Jun 04, 2019 at 03:29:32AM +0800, Alex Williamson wrote: > > > > > > On Thu, 30 May 2019 20:44:38 -0400 > > > > > > Yan Zhao wrote: > > > > > > > > > > > > > This patchset introduces a migration_version attribute under sysfs of VFIO > > > > > > > Mediated devices. > > > > > > > > > > > > > > This migration_version attribute is used to check migration compatibility > > > > > > > between two mdev devices of the same mdev type. > > > > > > > > > > > > > > Patch 1 defines migration_version attribute in > > > > > > > Documentation/vfio-mediated-device.txt > > > > > > > > > > > > > > Patch 2 uses GVT as an example to show how to expose migration_version > > > > > > > attribute and check migration compatibility in vendor driver. > > > > > > > > > > > > Thanks for iterating through this, it looks like we've settled on > > > > > > something reasonable, but now what? This is one piece of the puzzle to > > > > > > supporting mdev migration, but I don't think it makes sense to commit > > > > > > this upstream on its own without also defining the remainder of how we > > > > > > actually do migration, preferably with more than one working > > > > > > implementation and at least prototyped, if not final, QEMU support. I > > > > > > hope that was the intent, and maybe it's now time to look at the next > > > > > > piece of the puzzle. Thanks, > > > > > > > > > > > > Alex > > > > > > > > > > Got it. > > > > > Also thank you and all for discussing and guiding all along:) > > > > > We'll move to the next episode now. > > > > > > > > Hi Yan, > > > > > > > > As we're hopefully moving towards a migration API, would it make sense > > > > to refresh this series at the same time? I think we're still expecting > > > > a vendor driver implementing Kirti's migration API to also implement > > > > this sysfs interface for compatibility verification. Thanks, > > > > > > > Hi Alex > > > Got it! > > > Thanks for reminding of this. And as now we have vfio-pci implementing > > > vendor ops to allow live migration of pass-through devices, is it > > > necessary to implement similar sysfs node for those devices? > > > or do you think just PCI IDs of those devices are enough for libvirt to > > > know device compatibility ? > > > > Wasn't the problem that we'd have to know how to check for things like: > > a) Whether different firmware versions in the device were actually > > compatible > > b) Whether minor hardware differences were compatible - e.g. some > > hardware might let you migrate to the next version of hardware up. > > Yes, minor changes in hardware or firmware that may not be represented > in the device ID or hardware revision. Also the version is as much for > indicating the compatibility of the vendor defined migration protocol > as it is for the hardware itself. I certainly wouldn't be so bold as > to create a protocol that is guaranteed compatible forever. We'll need > to expose the same sysfs attribute in some standard location for > non-mdev devices. I assume vfio-pci would provide the vendor ops some > mechanism to expose these in a standard namespace of sysfs attributes > under the device itself. Perhaps that indicates we need to link the > mdev type version under the mdev device as well to make this > transparent to userspace tools like libvirt. Thanks, > Got it. will do it. Thanks! Yan