Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp222557ybh; Sun, 12 Jul 2020 04:18:41 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxdFdE4TmTpZqAp4TiLz69vHpQUSSeN8sjn8I8aIqH4lqtWCqlqQzKleuhfr+ntGlspCBC/ X-Received: by 2002:a17:906:3e54:: with SMTP id t20mr64277227eji.471.1594552721327; Sun, 12 Jul 2020 04:18:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594552721; cv=none; d=google.com; s=arc-20160816; b=R1Th4pWjfcNWfVjiYKao/O6ZjOCQD6X2axpWWWBs5m+CJOQW9Ci9g3nT9wGaGEoQh7 eOHIKFWGvnwWI/GHVY1K6r0zXCYa328vJ+R64R10wCNd8Hu/fh9TcrPH0iEn2CHK6pr7 E2KvTwkAX69LJxa5Ta+dimD5Wlp3et+ohebLOqPI0Q2O7hJ239psC9SSvaeo/HiofYyS PBgjaYVLd9aq4ZoOSDUiCDIsAUfELn7PSceAREyJdwGeuuyEKlvbZgjTYz89e5YNwRC+ MJV5IK2Spqe7KDHxg18LyquzA0KfzcP6ROJ2qsX4fakYQK+ONTdjsMTNKO4RF2LxQa63 G6Dg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:ironport-sdr:ironport-sdr; bh=hNDEelF0lImZVMM8XIHvpVJert/XeK2ixeMzsYDQ4Wo=; b=uRoZNGCx8UnbgcAtgryYEWB8htNnz2ldM6xMG4pda++OxfjaRLnodudPNr6iOy3bUK HEqJVNAWEGdlH0HRjsWQUzezV5Czk1NeZyn6UI1OyWUciOkPCXDDeYby8ZXtyopZHPaZ V5pRjBifv6vJpvv9iqtCbKHvU/n3y8GkBuDeltcH4gNBIEhL1eOunZ2T+jVgyPr3zdxx BZEhVGlPIYs7tg+TQlnc3usnJj7F4i//IadbKYl61wwL1PFJ4Zq/MA82OKbrzkOMBA7A WNgMtjxSVepR3huvB5+1XKFXBwzWFb4aQ3O77V6uOfOSHP76tGmMzYY3uBTtKbWEdrm/ yoxA== ARC-Authentication-Results: i=1; mx.google.com; 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=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d18si7320741edy.194.2020.07.12.04.18.18; Sun, 12 Jul 2020 04:18:41 -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; 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=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728965AbgGLLPg (ORCPT + 99 others); Sun, 12 Jul 2020 07:15:36 -0400 Received: from mga09.intel.com ([134.134.136.24]:45844 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728850AbgGLLOk (ORCPT ); Sun, 12 Jul 2020 07:14:40 -0400 IronPort-SDR: 9oMXTo0dD1t1Y6JxQPz3ORNpRZzO+ayGufIjg01v804AkcfF1Zv8DhVRIQ6nGCfSdldm30Jhqd kiz4RXSWV2cg== X-IronPort-AV: E=McAfee;i="6000,8403,9679"; a="149952703" X-IronPort-AV: E=Sophos;i="5.75,343,1589266800"; d="scan'208";a="149952703" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga008.jf.intel.com ([10.7.209.65]) by orsmga102.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 12 Jul 2020 04:14:30 -0700 IronPort-SDR: YmJF8CTH8rnWK0AEUWvBEnYh/2eJ1HYKPr1BnTrOPzwgtj+OI/t2zQ9ZAsraudOf/vKjOLaW2C YHYRYgURAVMw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.75,343,1589266800"; d="scan'208";a="315788588" Received: from jacob-builder.jf.intel.com ([10.7.199.155]) by orsmga008.jf.intel.com with ESMTP; 12 Jul 2020 04:14:30 -0700 From: Liu Yi L To: alex.williamson@redhat.com, eric.auger@redhat.com, baolu.lu@linux.intel.com, joro@8bytes.org Cc: kevin.tian@intel.com, jacob.jun.pan@linux.intel.com, ashok.raj@intel.com, yi.l.liu@intel.com, jun.j.tian@intel.com, yi.y.sun@intel.com, jean-philippe@linaro.org, peterx@redhat.com, hao.wu@intel.com, stefanha@gmail.com, iommu@lists.linux-foundation.org, kvm@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v5 13/15] vfio/pci: Expose PCIe PASID capability to guest Date: Sun, 12 Jul 2020 04:21:08 -0700 Message-Id: <1594552870-55687-14-git-send-email-yi.l.liu@intel.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1594552870-55687-1-git-send-email-yi.l.liu@intel.com> References: <1594552870-55687-1-git-send-email-yi.l.liu@intel.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch exposes PCIe PASID capability to guest for assigned devices. Existing vfio_pci driver hides it from guest by setting the capability length as 0 in pci_ext_cap_length[]. And this patch only exposes PASID capability for devices which has PCIe PASID extended struture in its configuration space. So VFs, will will not see PASID capability on VFs as VF doesn't implement PASID extended structure in its configuration space. For VF, it is a TODO in future. Related discussion can be found in below link: https://lkml.org/lkml/2020/4/7/693 Cc: Kevin Tian CC: Jacob Pan Cc: Alex Williamson Cc: Eric Auger Cc: Jean-Philippe Brucker Cc: Joerg Roedel Cc: Lu Baolu Signed-off-by: Liu Yi L --- v1 -> v2: *) added in v2, but it was sent in a separate patchseries before --- drivers/vfio/pci/vfio_pci_config.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/vfio/pci/vfio_pci_config.c b/drivers/vfio/pci/vfio_pci_config.c index d98843f..07ff2e6 100644 --- a/drivers/vfio/pci/vfio_pci_config.c +++ b/drivers/vfio/pci/vfio_pci_config.c @@ -95,7 +95,7 @@ static const u16 pci_ext_cap_length[PCI_EXT_CAP_ID_MAX + 1] = { [PCI_EXT_CAP_ID_LTR] = PCI_EXT_CAP_LTR_SIZEOF, [PCI_EXT_CAP_ID_SECPCI] = 0, /* not yet */ [PCI_EXT_CAP_ID_PMUX] = 0, /* not yet */ - [PCI_EXT_CAP_ID_PASID] = 0, /* not yet */ + [PCI_EXT_CAP_ID_PASID] = PCI_EXT_CAP_PASID_SIZEOF, }; /* -- 2.7.4