mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	iommu/vt-d: Check VT-d RMRR region in BIOS is reported as reserved
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 <baolu.lu@linux.intel.com> Reviewed-by: Sohil Mehta <sohil.mehta@intel.com> Signed-off-by: Yian Chen <yian.chen@intel.com> Signed-off-by: Joerg Roedel <jroedel@suse.de>
This commit is contained in:
		
							parent
							
								
									1ee0186b9a
								
							
						
					
					
						commit
						f036c7fa0a
					
				| @ -2,6 +2,8 @@ | |||||||
| #ifndef _ASM_IA64_IOMMU_H | #ifndef _ASM_IA64_IOMMU_H | ||||||
| #define _ASM_IA64_IOMMU_H 1 | #define _ASM_IA64_IOMMU_H 1 | ||||||
| 
 | 
 | ||||||
|  | #include <linux/acpi.h> | ||||||
|  | 
 | ||||||
| /* 10 seconds */ | /* 10 seconds */ | ||||||
| #define DMAR_OPERATION_TIMEOUT (((cycles_t) local_cpu_data->itc_freq)*10) | #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 | #ifdef	CONFIG_INTEL_IOMMU | ||||||
| extern int force_iommu, no_iommu; | extern int force_iommu, no_iommu; | ||||||
| extern int iommu_detected; | extern int iommu_detected; | ||||||
|  | 
 | ||||||
|  | static inline int __init | ||||||
|  | arch_rmrr_sanity_check(struct acpi_dmar_reserved_memory *rmrr) { return 0; } | ||||||
| #else | #else | ||||||
| #define no_iommu		(1) | #define no_iommu		(1) | ||||||
| #define iommu_detected		(0) | #define iommu_detected		(0) | ||||||
|  | |||||||
| @ -2,10 +2,28 @@ | |||||||
| #ifndef _ASM_X86_IOMMU_H | #ifndef _ASM_X86_IOMMU_H | ||||||
| #define _ASM_X86_IOMMU_H | #define _ASM_X86_IOMMU_H | ||||||
| 
 | 
 | ||||||
|  | #include <linux/acpi.h> | ||||||
|  | 
 | ||||||
|  | #include <asm/e820/api.h> | ||||||
|  | 
 | ||||||
| extern int force_iommu, no_iommu; | extern int force_iommu, no_iommu; | ||||||
| extern int iommu_detected; | extern int iommu_detected; | ||||||
| 
 | 
 | ||||||
| /* 10 seconds */ | /* 10 seconds */ | ||||||
| #define DMAR_OPERATION_TIMEOUT ((cycles_t) tsc_khz*10*1000) | #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 */ | #endif /* _ASM_X86_IOMMU_H */ | ||||||
|  | |||||||
| @ -4311,13 +4311,19 @@ int __init dmar_parse_one_rmrr(struct acpi_dmar_header *header, void *arg) | |||||||
| { | { | ||||||
| 	struct acpi_dmar_reserved_memory *rmrr; | 	struct acpi_dmar_reserved_memory *rmrr; | ||||||
| 	struct dmar_rmrr_unit *rmrru; | 	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); | 	rmrru = kzalloc(sizeof(*rmrru), GFP_KERNEL); | ||||||
| 	if (!rmrru) | 	if (!rmrru) | ||||||
| 		goto out; | 		goto out; | ||||||
| 
 | 
 | ||||||
| 	rmrru->hdr = header; | 	rmrru->hdr = header; | ||||||
| 	rmrr = (struct acpi_dmar_reserved_memory *)header; | 
 | ||||||
| 	rmrru->base_address = rmrr->base_address; | 	rmrru->base_address = rmrr->base_address; | ||||||
| 	rmrru->end_address = rmrr->end_address; | 	rmrru->end_address = rmrr->end_address; | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Yian Chen
						Yian Chen