Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp584876ybt; Fri, 19 Jun 2020 08:43:29 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwxUzsZg9mfa2Zp3gi/np8EHhB4g1gcDbXGg8NjrqEKOmfOeNLx8aS8llNI9lyPdY9JaywP X-Received: by 2002:a17:906:39b:: with SMTP id b27mr4109028eja.421.1592581408870; Fri, 19 Jun 2020 08:43:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592581408; cv=none; d=google.com; s=arc-20160816; b=wbmZFU/0bvWjDaGqD/ZDJpF0FvJ3VLx/rqCuC2o5Sy0ei7V7TNxe6sPgoYi/3JQgqz Rm1GoJ57A14C6qAgVhCm7Vp6CiSs9JERnz6igPxncKE+XjhXGMrtds5K1grZapyNoSf8 vssUEG+CvcUomPishbKFyTQklnpxD0DzfucPWkxTv91ZWkzqYNasICCSbvfhr0wlZyzA /wQCeSUSaWU4uTpyvvOtZAm7sWEzQMGrJCgcelEjlSkwJzv2wFXgMU/YvtPeAK1wPNBR rN6SfeBKNJWmIdAMXTgqoMP86gbyCzMX9hAjishc8HYX04Usg40P/v/g5TXCwwf2ArdY 5I9w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=836g3NhgbBbGobMEkn7UuQBNspybiu2+mlFsKa00M9k=; b=SbDB3y092/oPcagj+p8jkcluNo1lz7P8nbxJm76MDXlGCEzy3eEEIuzc5gR2S61IAH qyiwwvQIHgNuvpRxSy0CRnFQyJ16Wxlr4MjPR6VrsLRBQC6OGd2IER3aEeIgFg80CJ/R F2Y6phhcL2tuNEcxDBUvv/PFPMeEAwxBRed2QMN3ARAIB8SVh95CYQtk60DnjG6lMxpm 8maRsda112WnXIrnDF7qk/AIwtKFg9PmOWHY5P/yQoZihsQJNtE2Jdmug8tMwxP5mb6S AvLbvpmg9XV/En7B1fYXAzNaGDAAnPQfEbhRRJXPBfmmuJBRYBBNiB+/m3cFaMxDMnuX 2mPQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=TzVCTmtX; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d17si3985756ejw.42.2020.06.19.08.43.06; Fri, 19 Jun 2020 08:43:28 -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; dkim=pass header.i=@kernel.org header.s=default header.b=TzVCTmtX; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2404630AbgFSP31 (ORCPT + 99 others); Fri, 19 Jun 2020 11:29:27 -0400 Received: from mail.kernel.org ([198.145.29.99]:60764 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2393650AbgFSP2z (ORCPT ); Fri, 19 Jun 2020 11:28:55 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 0DDF721941; Fri, 19 Jun 2020 15:28:53 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1592580534; bh=eSdH4ZAfWrNI/AJwttCSABF3KDnoMDsC/kislijVpgU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=TzVCTmtXRDfayRCooykMbriRHxyEqnuX1bnQk7Yjl+iteZrzCGssqSF5l1ODl8PXZ a6X2LLfLXXvctpe0tf9tmUo/TzPfE2BWUo89dAO+PWKOPF+kjymvmM91XIg7vEiLXy IDjA0xf2GuC4eaEpfaR4oI17cEgAsWXkWgALm1nk= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Darrel Goeddel , Ashok Raj , Bjorn Helgaas , Alex Williamson , Lu Baolu , Romil Sharma , Sasha Levin , Mark Scott Subject: [PATCH 5.7 287/376] PCI: Add ACS quirk for Intel Root Complex Integrated Endpoints Date: Fri, 19 Jun 2020 16:33:25 +0200 Message-Id: <20200619141723.918159003@linuxfoundation.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200619141710.350494719@linuxfoundation.org> References: <20200619141710.350494719@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Ashok Raj [ Upstream commit 3247bd10a4502a3075ce8e1c3c7d31ef76f193ce ] All Intel platforms guarantee that all root complex implementations must send transactions up to IOMMU for address translations. Hence for Intel RCiEP devices, we can assume some ACS-type isolation even without an ACS capability. >From the Intel VT-d spec, r3.1, sec 3.16 ("Root-Complex Peer to Peer Considerations"): When DMA remapping is enabled, peer-to-peer requests through the Root-Complex must be handled as follows: - The input address in the request is translated (through first-level, second-level or nested translation) to a host physical address (HPA). The address decoding for peer addresses must be done only on the translated HPA. Hardware implementations are free to further limit peer-to-peer accesses to specific host physical address regions (or to completely disallow peer-forwarding of translated requests). - Since address translation changes the contents (address field) of the PCI Express Transaction Layer Packet (TLP), for PCI Express peer-to-peer requests with ECRC, the Root-Complex hardware must use the new ECRC (re-computed with the translated address) if it decides to forward the TLP as a peer request. - Root-ports, and multi-function root-complex integrated endpoints, may support additional peer-to-peer control features by supporting PCI Express Access Control Services (ACS) capability. Refer to ACS capability in PCI Express specifications for details. Since Linux didn't give special treatment to allow this exception, certain RCiEP MFD devices were grouped in a single IOMMU group. This doesn't permit a single device to be assigned to a guest for instance. In one vendor system: Device 14.x were grouped in a single IOMMU group. /sys/kernel/iommu_groups/5/devices/0000:00:14.0 /sys/kernel/iommu_groups/5/devices/0000:00:14.2 /sys/kernel/iommu_groups/5/devices/0000:00:14.3 After this patch: /sys/kernel/iommu_groups/5/devices/0000:00:14.0 /sys/kernel/iommu_groups/5/devices/0000:00:14.2 /sys/kernel/iommu_groups/6/devices/0000:00:14.3 <<< new group 14.0 and 14.2 are integrated devices, but legacy end points, whereas 14.3 was a PCIe-compliant RCiEP. 00:14.3 Network controller: Intel Corporation Device 9df0 (rev 30) Capabilities: [40] Express (v2) Root Complex Integrated Endpoint, MSI 00 This permits assigning this device to a guest VM. [bhelgaas: drop "Fixes" tag since this doesn't fix a bug in that commit] Link: https://lore.kernel.org/r/1590699462-7131-1-git-send-email-ashok.raj@intel.com Tested-by: Darrel Goeddel Signed-off-by: Ashok Raj Signed-off-by: Bjorn Helgaas Reviewed-by: Alex Williamson Cc: stable@vger.kernel.org Cc: Lu Baolu Cc: Mark Scott , Cc: Romil Sharma Signed-off-by: Sasha Levin --- drivers/pci/quirks.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index 226a4c5b2b7a..5067562924f0 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -4682,6 +4682,20 @@ static int pci_quirk_mf_endpoint_acs(struct pci_dev *dev, u16 acs_flags) PCI_ACS_CR | PCI_ACS_UF | PCI_ACS_DT); } +static int pci_quirk_rciep_acs(struct pci_dev *dev, u16 acs_flags) +{ + /* + * Intel RCiEP's are required to allow p2p only on translated + * addresses. Refer to Intel VT-d specification, r3.1, sec 3.16, + * "Root-Complex Peer to Peer Considerations". + */ + if (pci_pcie_type(dev) != PCI_EXP_TYPE_RC_END) + return -ENOTTY; + + return pci_acs_ctrl_enabled(acs_flags, + PCI_ACS_SV | PCI_ACS_RR | PCI_ACS_CR | PCI_ACS_UF); +} + static int pci_quirk_brcm_acs(struct pci_dev *dev, u16 acs_flags) { /* @@ -4764,6 +4778,7 @@ static const struct pci_dev_acs_enabled { /* I219 */ { PCI_VENDOR_ID_INTEL, 0x15b7, pci_quirk_mf_endpoint_acs }, { PCI_VENDOR_ID_INTEL, 0x15b8, pci_quirk_mf_endpoint_acs }, + { PCI_VENDOR_ID_INTEL, PCI_ANY_ID, pci_quirk_rciep_acs }, /* QCOM QDF2xxx root ports */ { PCI_VENDOR_ID_QCOM, 0x0400, pci_quirk_qcom_rp_acs }, { PCI_VENDOR_ID_QCOM, 0x0401, pci_quirk_qcom_rp_acs }, -- 2.25.1