• Arvind Sankar's avatar
    x86/cpu/amd: Remove dead code for TSEG region remapping · 262bd572
    Arvind Sankar authored
    Commit
    
      26bfa5f8 ("x86, amd: Cleanup init_amd")
    
    moved the code that remaps the TSEG region using 4k pages from
    init_amd() to bsp_init_amd().
    
    However, bsp_init_amd() is executed well before the direct mapping is
    actually created:
    
      setup_arch()
        -> early_cpu_init()
          -> early_identify_cpu()
            -> this_cpu->c_bsp_init()
    	  -> bsp_init_amd()
        ...
        -> init_mem_mapping()
    
    So the change effectively disabled the 4k remapping, because
    pfn_range_is_mapped() is always false at this point.
    
    It has been over six years since the commit, and no-one seems to have
    noticed this, so just remove the code. The original code was also
    incomplete, since it doesn't check how large the TSEG address range
    actually is, so it might remap only part of it in any case.
    
    Hygon has copied the incorrect version, so the code has never run on it
    since the cpu support was added two years ago. Remove it from there as
    well.
    
    Committer notes:
    
    This workaround is incomplete anyway:
    
    1. The code must check MSRC001_0113.TValid (SMM TSeg Mask MSR) first, to
    check whether the TSeg address range is enabled.
    
    2. The code must check whether the range is not 2M aligned - if it is,
    there's nothing to work around.
    
    3. In all the BIOSes tested, the TSeg range is in a e820 reserved area
    and those are not mapped anymore, after
    
      66520ebc ("x86, mm: Only direct map addresses that are marked as E820_RAM")
    
    which means, there's nothing to be worked around either.
    
    So let's rip it out.
    Signed-off-by: default avatarArvind Sankar <nivedita@alum.mit.edu>
    Signed-off-by: default avatarBorislav Petkov <bp@suse.de>
    Link: https://lkml.kernel.org/r/20201127171324.1846019-1-nivedita@alum.mit.edu
    262bd572
amd.c 29.5 KB