• Dan Williams's avatar
    efi: Enumerate EFI_MEMORY_SP · fe3e5e65
    Dan Williams authored
    UEFI 2.8 defines an EFI_MEMORY_SP attribute bit to augment the
    interpretation of the EFI Memory Types as "reserved for a specific
    purpose". The intent of this bit is to allow the OS to identify precious
    or scarce memory resources and optionally manage it separately from
    EfiConventionalMemory. As defined older OSes that do not know about this
    attribute are permitted to ignore it and the memory will be handled
    according to the OS default policy for the given memory type.
    
    In other words, this "specific purpose" hint is deliberately weaker than
    EfiReservedMemoryType in that the system continues to operate if the OS
    takes no action on the attribute. The risk of taking no action is
    potentially unwanted / unmovable kernel allocations from the designated
    resource that prevent the full realization of the "specific purpose".
    For example, consider a system with a high-bandwidth memory pool. Older
    kernels are permitted to boot and consume that memory as conventional
    "System-RAM" newer kernels may arrange for that memory to be set aside
    (soft reserved) by the system administrator for a dedicated
    high-bandwidth memory aware application to consume.
    
    Specifically, this mechanism allows for the elimination of scenarios
    where platform firmware tries to game OS policy by lying about ACPI SLIT
    values, i.e. claiming that a precious memory resource has a high
    distance to trigger the OS to avoid it by default. This reservation hint
    allows platform-firmware to instead tell the truth about performance
    characteristics by indicate to OS memory management to put immovable
    allocations elsewhere.
    
    Implement simple detection of the bit for EFI memory table dumps and
    save the kernel policy for a follow-on change.
    Reviewed-by: default avatarArd Biesheuvel <ard.biesheuvel@linaro.org>
    Reviewed-by: default avatarDave Hansen <dave.hansen@linux.intel.com>
    Signed-off-by: default avatarDan Williams <dan.j.williams@intel.com>
    Acked-by: default avatarThomas Gleixner <tglx@linutronix.de>
    Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
    fe3e5e65
efi.c 26.6 KB