Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp1243171ybb; Fri, 20 Mar 2020 16:23:28 -0700 (PDT) X-Google-Smtp-Source: ADFU+vufXkrUCx+fa+Xaqiy9NC/FViD2HInL/psBqiOvgsNME2skU5jHhxJr1GaIHzcjLFLmQmL4 X-Received: by 2002:a05:6808:a0a:: with SMTP id n10mr8797963oij.10.1584746608341; Fri, 20 Mar 2020 16:23:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1584746608; cv=none; d=google.com; s=arc-20160816; b=BfcFV43kR0l1HBvG2Z6MWXOuknnNEvk2UZabepS0i7/yaRlGgdHGK5vXu7W5bFjP1r 0pFwnTQpEyLK50/xbvMi5xYUN05IpvtXyFOf37fEP7yrdwEk/1JfaV9m/qB/xN+M6klO fraPt2YWlY9e5Dj3ahOmIMu8vlApyH2+wOyabz+ZCTZ30MywwtTQc3gXlkYAApRkvhU/ f2xmqB2vbmVQ5Dk8QD/5hnsjDtnqTJvx99ZZV+zfLnRfB0J33FY1ZnXLG4qvd51CbMPq G0+lb5EEk13hBR3cTw6D9XyjbmdlhE+nxQIejp0d8kgNN+LJFZ+s6hJTFlOKAp9AIvIh JNSw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :ironport-sdr:ironport-sdr; bh=wTOX47qTlbfWriV+Lmqp678sCjpmiu/2NaRvn0rBG/c=; b=c9ZygXQKj9I5yLEASWej9gWebtsCBHOx7ykbT975U7RevFyyR5aOvS0fmdXGr36vy3 OO2Q7aZc4G/bO7ZUyXHrTMPyjAUpaHZOP29vMpSeLSpkIiS/ZcJTeOIGxbL/kRxsouzR +1PwM3vEdAXsD+1odUNCn66Bf09cSPUWjPYpRVp9rw6PblgubwoWGjQWgvy0/rScEYH2 cGt5H8F7+ssdv4e3IjE9IEGFLTA6MiRlw42vpjiC3qtTlOLm0y37HFZl0q6sSEig4wYJ BgoSkcXO31zLaomP4ivQ2HI28OJQ1+EfxMByNdlvfdhIJDNlWSAwjzAs6ew7NlmxnIgf gE5w== 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 i19si3854664otp.177.2020.03.20.16.23.15; Fri, 20 Mar 2020 16:23:28 -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 S1727223AbgCTXWB (ORCPT + 99 others); Fri, 20 Mar 2020 19:22:01 -0400 Received: from mga18.intel.com ([134.134.136.126]:42258 "EHLO mga18.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726738AbgCTXWB (ORCPT ); Fri, 20 Mar 2020 19:22:01 -0400 IronPort-SDR: Y1E55qnDJUzPwKtumWHgauBDKtYzx+6ZkySil5VvcM59OSDyyQkf6/0dJSN1tfMkRGwbe232oI QIOALHbTf+sw== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga005.jf.intel.com ([10.7.209.41]) by orsmga106.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 20 Mar 2020 16:22:00 -0700 IronPort-SDR: 988XkkfJkl3+ca1Qw0DK45LdNZoF2y3/3rtHzxTnXfH+rkbkZwxag3KAVzuXJKBqFEoYXViDHq jJeeKJ2VNpKw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.72,286,1580803200"; d="scan'208";a="418877215" Received: from jacob-builder.jf.intel.com ([10.7.199.155]) by orsmga005.jf.intel.com with ESMTP; 20 Mar 2020 16:22:00 -0700 From: Jacob Pan To: "Lu Baolu" , iommu@lists.linux-foundation.org, LKML , Joerg Roedel , David Woodhouse , Alex Williamson , Jean-Philippe Brucker Cc: "Yi Liu" , "Tian, Kevin" , Raj Ashok , "Christoph Hellwig" , Jonathan Cameron , Eric Auger , Jacob Pan Subject: [PATCH V10 00/11] Nested Shared Virtual Address (SVA) VT-d support Date: Fri, 20 Mar 2020 16:27:30 -0700 Message-Id: <1584746861-76386-1-git-send-email-jacob.jun.pan@linux.intel.com> X-Mailer: git-send-email 2.7.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Shared virtual address (SVA), a.k.a, Shared virtual memory (SVM) on Intel platforms allow address space sharing between device DMA and applications. SVA can reduce programming complexity and enhance security. This series is intended to enable SVA virtualization, i.e. enable use of SVA within a guest user application. This is the remaining portion of the original patchset that is based on Joerg's x86/vt-d branch. The preparatory and cleanup patches are merged here. (git://git.kernel.org/pub/scm/linux/kernel/git/joro/iommu.git) Only IOMMU portion of the changes are included in this series. Additional support is needed in VFIO and QEMU (will be submitted separately) to complete this functionality. To make incremental changes and reduce the size of each patchset. This series does not inlcude support for page request services. In VT-d implementation, PASID table is per device and maintained in the host. Guest PASID table is shadowed in VMM where virtual IOMMU is emulated. .-------------. .---------------------------. | vIOMMU | | Guest process CR3, FL only| | | '---------------------------' .----------------/ | PASID Entry |--- PASID cache flush - '-------------' | | | V | | CR3 in GPA '-------------' Guest ------| Shadow |--------------------------|-------- v v v Host .-------------. .----------------------. | pIOMMU | | Bind FL for GVA-GPA | | | '----------------------' .----------------/ | | PASID Entry | V (Nested xlate) '----------------\.------------------------------. | | |SL for GPA-HPA, default domain| | | '------------------------------' '-------------' Where: - FL = First level/stage one page tables - SL = Second level/stage two page tables This is the remaining VT-d only portion of V5 since the uAPIs and IOASID common code have been applied to Joerg's IOMMU core branch. (https://lkml.org/lkml/2019/10/2/833) The complete set with VFIO patches are here: https://github.com/jacobpan/linux.git:siov_sva The complete nested SVA upstream patches are divided into three phases: 1. Common APIs and PCI device direct assignment 2. Page Request Services (PRS) support 3. Mediated device assignment With this set and the accompanied VFIO code, we will achieve phase #1. Thanks, Jacob ChangeLog: - v10 - Addressed Eric's review in v7 and v9. Most fixes are in 3/10 and 6/10. Extra condition checks and consolidation of duplicated codes. - v9 - Addressed Baolu's comments for v8 for IOTLB flush consolidation, bug fixes - Removed IOASID notifier code which will be submitted separately to address PASID life cycle management with multiple users. - v8 - Extracted cleanup patches from V7 and accepted into maintainer's tree (https://lkml.org/lkml/2019/12/2/514). - Added IOASID notifier and VT-d handler for termination of PASID IOMMU context upon free. This will ensure success of VFIO IOASID free API regardless PASID is in use. (https://lore.kernel.org/linux-iommu/1571919983-3231-1-git-send-email-yi.l.liu@intel.com/) - V7 - Respect vIOMMU PASID range in virtual command PASID/IOASID allocator - Caching virtual command capabilities to avoid runtime checks that could cause vmexits. - V6 - Rebased on top of Joerg's core branch (git://git.kernel.org/pub/scm/linux/kernel/git/joro/iommu.git core) - Adapt to new uAPIs and IOASID allocators - V5 Rebased on v5.3-rc4 which has some of the IOMMU fault APIs merged. Addressed v4 review comments from Eric Auger, Baolu Lu, and Jonathan Cameron. Specific changes are as follows: - Refined custom IOASID allocator to support multiple vIOMMU, hotplug cases. - Extracted vendor data from IOMMU guest PASID bind data, for VT-d will support all necessary guest PASID entry fields for PASID bind. - Support non-identity host-guest PASID mapping - Exception handling in various cases - V4 - Redesigned IOASID allocator such that it can support custom allocators with shared helper functions. Use separate XArray to store IOASIDs per allocator. Took advice from Eric Auger to have default allocator use the generic allocator structure. Combined into one patch in that the default allocator is just "another" allocator now. Can be built as a module in case of driver use without IOMMU. - Extended bind guest PASID data to support SMMU and non-identity guest to host PASID mapping https://lkml.org/lkml/2019/5/21/802 - Rebased on Jean's sva/api common tree, new patches starts with [PATCH v4 10/22] - V3 - Addressed thorough review comments from Eric Auger (Thank you!) - Moved IOASID allocator from driver core to IOMMU code per suggestion by Christoph Hellwig (https://lkml.org/lkml/2019/4/26/462) - Rebased on top of Jean's SVA API branch and Eric's v7[1] (git://linux-arm.org/linux-jpb.git sva/api) - All IOMMU APIs are unmodified (except the new bind guest PASID call in patch 9/16) - V2 - Rebased on Joerg's IOMMU x86/vt-d branch v5.1-rc4 - Integrated with Eric Auger's new v7 series for common APIs (https://github.com/eauger/linux/tree/v5.1-rc3-2stage-v7) - Addressed review comments from Andy Shevchenko and Alex Williamson on IOASID custom allocator. - Support multiple custom IOASID allocators (vIOMMUs) and dynamic registration. Jacob Pan (10): iommu/vt-d: Move domain helper to header iommu/uapi: Define a mask for bind data iommu/vt-d: Add a helper function to skip agaw iommu/vt-d: Use helper function to skip agaw for SL iommu/vt-d: Add nested translation helper function iommu/vt-d: Add bind guest PASID support iommu/vt-d: Support flushing more translation cache types iommu/vt-d: Add svm/sva invalidate function iommu/vt-d: Cache virtual command capability register iommu/vt-d: Add custom allocator for IOASID Lu Baolu (1): iommu/vt-d: Enlightened PASID allocation drivers/iommu/dmar.c | 37 +++++ drivers/iommu/intel-iommu.c | 276 +++++++++++++++++++++++++++++++++++- drivers/iommu/intel-pasid.c | 336 ++++++++++++++++++++++++++++++++++++++++++-- drivers/iommu/intel-pasid.h | 25 +++- drivers/iommu/intel-svm.c | 224 +++++++++++++++++++++++++++++ include/linux/intel-iommu.h | 45 +++++- include/linux/intel-svm.h | 17 +++ include/uapi/linux/iommu.h | 5 +- 8 files changed, 938 insertions(+), 27 deletions(-) -- 2.7.4