Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp1286403ybg; Fri, 18 Oct 2019 15:14:49 -0700 (PDT) X-Google-Smtp-Source: APXvYqwgZFJXom+C2Q7VWQXKMY8JVKc3zPfAjh+TSr5yeHpw5CfXE+kBOy6WUvkn+1bXYP8f02/u X-Received: by 2002:a05:6402:21c2:: with SMTP id bi2mr12240034edb.8.1571436889761; Fri, 18 Oct 2019 15:14:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571436889; cv=none; d=google.com; s=arc-20160816; b=es9MWmr9asWPTyEA2D3QzgizNvYtt0jUQbcMlNAzCaL/qpRA1/iaDeMLM84A+mnoip fzdufID38gXTDk36mV7TenzLJvkPCQZa/iq9SBdDtSx3GEGO4sXTtFMA/L4lGT58+IZ0 /aT8tLxg0I/BteBqPI6BMkxTvgRYSCqu2u2LciEWhTW22ZuWjeuML+WoDt1NSXdqo/aL 7v8GNI1f2RjwTl5w1tI69U2/4Ro0/fvOXLNqykWrN8b36I5p+hSbe3CZNXSVX+5hQp5n oPnu/LS0ENeq/rbsMICu3XT/PJUcrw84QpnpqPWhkwkvx11txcfzIohhJ0nRaRNssB0g yWkg== 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; bh=6dUzJODvr8rldRzr8ZvhxjbpYYlCCICWWyHLAC3esTY=; b=AbMrF4gCz59ZTb90j2xlwlmKxT+urI9IIlvAXtURt7nNIpzuVUpEEeYdjolSBpBMfC //ShZcQ5XnLQkl8mufNG6RLWihMT9HVLWaLCo3kl8kr4ws4Nm2NMmpnX1jelu2D2cskm uNCqqpa/qrG22Ly6iSZbQ2UK3xAczWqN6sCvkHJYsB3OfbAj2VtqiWRjsu4oUkXNXDnP xE9CR7eOzO0yMEUY99FpoEWBGoYHyGGgygZUYvCamg7avETxFA0VLmLnAs0f+X7jsU+u GFl6wGwYhianyEtrFXuaaLO+id3rMJixnT8AzVOSIOrIhRfGHicsiOWqPwtPjBcLzqEp +vcA== 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 p18si4776093ejn.370.2019.10.18.15.14.26; Fri, 18 Oct 2019 15:14:49 -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 S2406749AbfJQSqN (ORCPT + 99 others); Thu, 17 Oct 2019 14:46:13 -0400 Received: from mga11.intel.com ([192.55.52.93]:45978 "EHLO mga11.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388823AbfJQSqM (ORCPT ); Thu, 17 Oct 2019 14:46:12 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by fmsmga102.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 17 Oct 2019 11:46:12 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.67,308,1566889200"; d="scan'208";a="221477723" Received: from oux.sc.intel.com ([10.3.52.57]) by fmsmga004.fm.intel.com with ESMTP; 17 Oct 2019 11:46:11 -0700 From: Yian Chen To: iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org, linux-ia64@vger.kernel.org, David Woodhouse , Joerg Roedel , Ashok Raj , Sohil Mehta , Tony Luck , Lu Baolu , Ravi Shankar Cc: Yian Chen Subject: [PATCH v2] iommu/vt-d: Check VT-d RMRR region in BIOS is reported as reserved Date: Thu, 17 Oct 2019 04:39:19 -0700 Message-Id: <20191017113919.25424-1-yian.chen@intel.com> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org VT-d RMRR (Reserved Memory Region Reporting) regions are reserved for device use only and should not be part of allocable memory pool of OS. BIOS e820_table reports complete memory map to OS, including OS usable memory ranges and BIOS reserved memory ranges etc. x86 BIOS may not be trusted to include RMRR regions as reserved type of memory in its e820 memory map, hence validate every RMRR entry with the e820 memory map to make sure the RMRR regions will not be used by OS for any other purposes. ia64 EFI is working fine so implement RMRR validation as a dummy function Reviewed-by: Lu Baolu Reviewed-by: Sohil Mehta Signed-off-by: Yian Chen --- v2: - return -EINVAL instead of -EFAULT when there is an error --- arch/ia64/include/asm/iommu.h | 5 +++++ arch/x86/include/asm/iommu.h | 18 ++++++++++++++++++ drivers/iommu/intel-iommu.c | 8 +++++++- 3 files changed, 30 insertions(+), 1 deletion(-) diff --git a/arch/ia64/include/asm/iommu.h b/arch/ia64/include/asm/iommu.h index 7904f591a79b..eb0db20c9d4c 100644 --- a/arch/ia64/include/asm/iommu.h +++ b/arch/ia64/include/asm/iommu.h @@ -2,6 +2,8 @@ #ifndef _ASM_IA64_IOMMU_H #define _ASM_IA64_IOMMU_H 1 +#include + /* 10 seconds */ #define DMAR_OPERATION_TIMEOUT (((cycles_t) local_cpu_data->itc_freq)*10) @@ -9,6 +11,9 @@ extern void no_iommu_init(void); #ifdef CONFIG_INTEL_IOMMU extern int force_iommu, no_iommu; extern int iommu_detected; + +static inline int __init +arch_rmrr_sanity_check(struct acpi_dmar_reserved_memory *rmrr) { return 0; } #else #define no_iommu (1) #define iommu_detected (0) diff --git a/arch/x86/include/asm/iommu.h b/arch/x86/include/asm/iommu.h index b91623d521d9..bf1ed2ddc74b 100644 --- a/arch/x86/include/asm/iommu.h +++ b/arch/x86/include/asm/iommu.h @@ -2,10 +2,28 @@ #ifndef _ASM_X86_IOMMU_H #define _ASM_X86_IOMMU_H +#include + +#include + extern int force_iommu, no_iommu; extern int iommu_detected; /* 10 seconds */ #define DMAR_OPERATION_TIMEOUT ((cycles_t) tsc_khz*10*1000) +static inline int __init +arch_rmrr_sanity_check(struct acpi_dmar_reserved_memory *rmrr) +{ + u64 start = rmrr->base_address; + u64 end = rmrr->end_address + 1; + + if (e820__mapped_all(start, end, E820_TYPE_RESERVED)) + return 0; + + pr_err(FW_BUG "No firmware reserved region can cover this RMRR [%#018Lx-%#018Lx], contact BIOS vendor for fixes\n", + start, end - 1); + return -EINVAL; +} + #endif /* _ASM_X86_IOMMU_H */ diff --git a/drivers/iommu/intel-iommu.c b/drivers/iommu/intel-iommu.c index 3f974919d3bd..722290014143 100644 --- a/drivers/iommu/intel-iommu.c +++ b/drivers/iommu/intel-iommu.c @@ -4306,13 +4306,19 @@ int __init dmar_parse_one_rmrr(struct acpi_dmar_header *header, void *arg) { struct acpi_dmar_reserved_memory *rmrr; struct dmar_rmrr_unit *rmrru; + int ret; + + rmrr = (struct acpi_dmar_reserved_memory *)header; + ret = arch_rmrr_sanity_check(rmrr); + if (ret) + return ret; rmrru = kzalloc(sizeof(*rmrru), GFP_KERNEL); if (!rmrru) goto out; rmrru->hdr = header; - rmrr = (struct acpi_dmar_reserved_memory *)header; + rmrru->base_address = rmrr->base_address; rmrru->end_address = rmrr->end_address; -- 2.17.1