Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp2241362pxk; Sat, 26 Sep 2020 23:55:50 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzt8UkYfYea6ubNN6BjUQ2k4c+ViTbY6ccZMPM3LQ7rdTtiOb/M7cGDQJiaYbb090BfZZd5 X-Received: by 2002:a17:906:4993:: with SMTP id p19mr10597465eju.277.1601189750805; Sat, 26 Sep 2020 23:55:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601189750; cv=none; d=google.com; s=arc-20160816; b=tPyCOAiVR3o7m2KO/ep/0a9fybyk76U/p3UnRQ5RwwsSpzBr+aLkAwfBzP1PD6jhKB NrHON8N3bddMrZcKYaBMPBwD2IViaA1s11BHQ/siU9/plYQ+PWhs4aD+E83Q+VhUtkJ3 7cYSyYvwhPq8UZf1BA8h2oN4CiByAtg+7rfr+wrj168hpBvhaz4g0TMsWEht352/VHyH QUHVYdk9te9VxhPgQJ/ie+NTr6mlDwWjGnHPSLIfcE0nwdTzLup6ckptu+RNZoX3vIIA INYkvQ+MALDYPKpJhYgwmILGgiGCxvTI0dU2zfEmFADvsWkCuS1YLZ0kz24OhGn45mvN 9s3A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:ironport-sdr:ironport-sdr; bh=NxCD6eafOfMM2IWP3vPXC32R6jFMVtU/kwW79jhN1Xw=; b=xikwBrE3RvFIoI1dCL5oOIzjGQn7TuDs7PrntH3oHE38mdAk+T88Ig7aj0aFdZ5Net txrosk97UZ5lrmYF/5sl/R1V6qiAfZszaTIEsYxRmDf6a0w8i0votB7maqcck0TsD113 HFSqs7eq9CX6W8EP7IP/ni7pTk+T2zxixJbkCIY+5aAfzXH1sWhSl7KcWjygmS3roptD 2u9zuiACFo/giY4Dp0POIXjWwUg/HJ3wZcbPbut2rm/hIZOT9/rfoR4OIUxbXv1RZFf4 cm6cVz02lv383rSGjHLpxwKbHio7rMQN/9/3O42vDixQWqLqlNlL9cgETe/Ihr/tPM3c i/zA== 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 bt13si5169881ejb.259.2020.09.26.23.55.26; Sat, 26 Sep 2020 23:55:50 -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 S1730398AbgI0Gvz (ORCPT + 99 others); Sun, 27 Sep 2020 02:51:55 -0400 Received: from mga17.intel.com ([192.55.52.151]:36625 "EHLO mga17.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730330AbgI0Gvy (ORCPT ); Sun, 27 Sep 2020 02:51:54 -0400 IronPort-SDR: UTtzCuqgEnuwzMO4T1OWxjsihedPKXlH6H6OyROUeFrVbgkRNoA+zQ+1X5BcxaRvRIAW9DB5Nk Qc/t74lswPSQ== X-IronPort-AV: E=McAfee;i="6000,8403,9756"; a="141863664" X-IronPort-AV: E=Sophos;i="5.77,309,1596524400"; d="scan'208";a="141863664" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by fmsmga107.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 26 Sep 2020 23:41:01 -0700 IronPort-SDR: k1JBwksq+zQLGQg/GY67JMP3d5ieKmC8g4e5VzE0J+hFMT7I3qwQcs5mHGWqHYv/xd7tOH5DYL EPAXUwd+s4nw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.77,309,1596524400"; d="scan'208";a="349457853" Received: from allen-box.sh.intel.com ([10.239.159.139]) by FMSMGA003.fm.intel.com with ESMTP; 26 Sep 2020 23:40:59 -0700 From: Lu Baolu To: Joerg Roedel , Tom Murphy , David Woodhouse , Christoph Hellwig Cc: Ashok Raj , Tvrtko Ursulin , Intel-gfx@lists.freedesktop.org, iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org, Lu Baolu Subject: [PATCH v4 5/7] iommu/vt-d: Update domain geometry in iommu_ops.at(de)tach_dev Date: Sun, 27 Sep 2020 14:34:35 +0800 Message-Id: <20200927063437.13988-6-baolu.lu@linux.intel.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200927063437.13988-1-baolu.lu@linux.intel.com> References: <20200927063437.13988-1-baolu.lu@linux.intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The iommu-dma constrains IOVA allocation based on the domain geometry that the driver reports. Update domain geometry everytime a domain is attached to or detached from a device. Signed-off-by: Lu Baolu --- drivers/iommu/intel/iommu.c | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/drivers/iommu/intel/iommu.c b/drivers/iommu/intel/iommu.c index fdd514c8b2d4..7d3c73d1e498 100644 --- a/drivers/iommu/intel/iommu.c +++ b/drivers/iommu/intel/iommu.c @@ -67,8 +67,8 @@ #define MAX_AGAW_WIDTH 64 #define MAX_AGAW_PFN_WIDTH (MAX_AGAW_WIDTH - VTD_PAGE_SHIFT) -#define __DOMAIN_MAX_PFN(gaw) ((((uint64_t)1) << (gaw-VTD_PAGE_SHIFT)) - 1) -#define __DOMAIN_MAX_ADDR(gaw) ((((uint64_t)1) << gaw) - 1) +#define __DOMAIN_MAX_PFN(gaw) ((((uint64_t)1) << ((gaw) - VTD_PAGE_SHIFT)) - 1) +#define __DOMAIN_MAX_ADDR(gaw) ((((uint64_t)1) << (gaw)) - 1) /* We limit DOMAIN_MAX_PFN to fit in an unsigned long, and DOMAIN_MAX_ADDR to match. That way, we can use 'unsigned long' for PFNs with impunity. */ @@ -739,6 +739,18 @@ static void domain_update_iommu_cap(struct dmar_domain *domain) */ if (domain->nid == NUMA_NO_NODE) domain->nid = domain_update_device_node(domain); + + /* + * First-level translation restricts the input-address to a + * canonical address (i.e., address bits 63:N have the same + * value as address bit [N-1], where N is 48-bits with 4-level + * paging and 57-bits with 5-level paging). Hence, skip bit + * [N-1]. + */ + if (domain_use_first_level(domain)) + domain->domain.geometry.aperture_end = __DOMAIN_MAX_ADDR(domain->gaw - 1); + else + domain->domain.geometry.aperture_end = __DOMAIN_MAX_ADDR(domain->gaw); } struct context_entry *iommu_context_addr(struct intel_iommu *iommu, u8 bus, -- 2.17.1