mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-22 10:34:55 +08:00
88e9a5b796
In preparation for attaching a platform device per iomem resource teach the efi_fake_mem code to create an e820 entry per instance. Similar to E820_TYPE_PRAM, bypass merging resource when the e820 map is sanitized. Signed-off-by: Dan Williams <dan.j.williams@intel.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Acked-by: Ard Biesheuvel <ardb@kernel.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Ingo Molnar <mingo@redhat.com> Cc: Borislav Petkov <bp@alien8.de> Cc: "H. Peter Anvin" <hpa@zytor.com> Cc: Andy Lutomirski <luto@kernel.org> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Cc: Ben Skeggs <bskeggs@redhat.com> Cc: Brice Goglin <Brice.Goglin@inria.fr> Cc: Catalin Marinas <catalin.marinas@arm.com> Cc: Daniel Vetter <daniel@ffwll.ch> Cc: Dave Hansen <dave.hansen@linux.intel.com> Cc: Dave Jiang <dave.jiang@intel.com> Cc: David Airlie <airlied@linux.ie> Cc: David Hildenbrand <david@redhat.com> Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: Ira Weiny <ira.weiny@intel.com> Cc: Jason Gunthorpe <jgg@mellanox.com> Cc: Jeff Moyer <jmoyer@redhat.com> Cc: Jia He <justin.he@arm.com> Cc: Joao Martins <joao.m.martins@oracle.com> Cc: Jonathan Cameron <Jonathan.Cameron@huawei.com> Cc: Michael Ellerman <mpe@ellerman.id.au> Cc: Mike Rapoport <rppt@linux.ibm.com> Cc: Paul Mackerras <paulus@ozlabs.org> Cc: Pavel Tatashin <pasha.tatashin@soleen.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Rafael J. Wysocki <rafael.j.wysocki@intel.com> Cc: Tom Lendacky <thomas.lendacky@amd.com> Cc: Vishal Verma <vishal.l.verma@intel.com> Cc: Wei Yang <richard.weiyang@linux.alibaba.com> Cc: Will Deacon <will@kernel.org> Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org> Cc: Bjorn Helgaas <bhelgaas@google.com> Cc: Boris Ostrovsky <boris.ostrovsky@oracle.com> Cc: Hulk Robot <hulkci@huawei.com> Cc: Jason Yan <yanaijie@huawei.com> Cc: "Jérôme Glisse" <jglisse@redhat.com> Cc: Juergen Gross <jgross@suse.com> Cc: kernel test robot <lkp@intel.com> Cc: Randy Dunlap <rdunlap@infradead.org> Cc: Stefano Stabellini <sstabellini@kernel.org> Cc: Vivek Goyal <vgoyal@redhat.com> Link: https://lkml.kernel.org/r/159643096068.4062302.11590041070221681669.stgit@dwillia2-desk3.amr.corp.intel.com Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
76 lines
1.9 KiB
C
76 lines
1.9 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/* Copyright(c) 2019 Intel Corporation. All rights reserved. */
|
|
#include <linux/efi.h>
|
|
#include <asm/e820/api.h>
|
|
#include "fake_mem.h"
|
|
|
|
void __init efi_fake_memmap_early(void)
|
|
{
|
|
int i;
|
|
|
|
/*
|
|
* The late efi_fake_mem() call can handle all requests if
|
|
* EFI_MEMORY_SP support is disabled.
|
|
*/
|
|
if (!efi_soft_reserve_enabled())
|
|
return;
|
|
|
|
if (!efi_enabled(EFI_MEMMAP) || !nr_fake_mem)
|
|
return;
|
|
|
|
/*
|
|
* Given that efi_fake_memmap() needs to perform memblock
|
|
* allocations it needs to run after e820__memblock_setup().
|
|
* However, if efi_fake_mem specifies EFI_MEMORY_SP for a given
|
|
* address range that potentially needs to mark the memory as
|
|
* reserved prior to e820__memblock_setup(). Update e820
|
|
* directly if EFI_MEMORY_SP is specified for an
|
|
* EFI_CONVENTIONAL_MEMORY descriptor.
|
|
*/
|
|
for (i = 0; i < nr_fake_mem; i++) {
|
|
struct efi_mem_range *mem = &efi_fake_mems[i];
|
|
efi_memory_desc_t *md;
|
|
u64 m_start, m_end;
|
|
|
|
if ((mem->attribute & EFI_MEMORY_SP) == 0)
|
|
continue;
|
|
|
|
m_start = mem->range.start;
|
|
m_end = mem->range.end;
|
|
for_each_efi_memory_desc(md) {
|
|
u64 start, end, size;
|
|
|
|
if (md->type != EFI_CONVENTIONAL_MEMORY)
|
|
continue;
|
|
|
|
start = md->phys_addr;
|
|
end = md->phys_addr + (md->num_pages << EFI_PAGE_SHIFT) - 1;
|
|
|
|
if (m_start <= end && m_end >= start)
|
|
/* fake range overlaps descriptor */;
|
|
else
|
|
continue;
|
|
|
|
/*
|
|
* Trim the boundary of the e820 update to the
|
|
* descriptor in case the fake range overlaps
|
|
* !EFI_CONVENTIONAL_MEMORY
|
|
*/
|
|
start = max(start, m_start);
|
|
end = min(end, m_end);
|
|
size = end - start + 1;
|
|
|
|
if (end <= start)
|
|
continue;
|
|
|
|
/*
|
|
* Ensure each efi_fake_mem instance results in
|
|
* a unique e820 resource
|
|
*/
|
|
e820__range_remove(start, size, E820_TYPE_RAM, 1);
|
|
e820__range_add(start, size, E820_TYPE_SOFT_RESERVED);
|
|
e820__update_table(e820_table);
|
|
}
|
|
}
|
|
}
|