]> www.infradead.org Git - users/hch/misc.git/commitdiff
x86/mce/amd: Remove smca_banks_map
authorYazen Ghannam <yazen.ghannam@amd.com>
Mon, 25 Aug 2025 17:33:00 +0000 (17:33 +0000)
committerBorislav Petkov (AMD) <bp@alien8.de>
Fri, 5 Sep 2025 10:41:48 +0000 (12:41 +0200)
The MCx_MISC0[BlkPtr] field was used on legacy systems to hold a register
offset for the next MCx_MISC* register. In this way, an implementation-specific
number of registers can be discovered at runtime.

The MCAX/SMCA register space simplifies this by always including the
MCx_MISC[1-4] registers. The MCx_MISC0[BlkPtr] field is used to indicate
(true/false) whether any MCx_MISC[1-4] registers are present.

Currently, MCx_MISC0[BlkPtr] is checked early and cached to be used during
sysfs init later. This is unnecessary as the MCx_MISC0 register is read again
later anyway.

Remove the smca_banks_map variable as it is effectively redundant, and use
a direct register/bit check instead.

  [ bp: Zap smca_get_block_address() too. ]

Signed-off-by: Yazen Ghannam <yazen.ghannam@amd.com>
Signed-off-by: Borislav Petkov (AMD) <bp@alien8.de>
Reviewed-by: Qiuxu Zhuo <qiuxu.zhuo@intel.com>
Reviewed-by: Tony Luck <tony.luck@intel.com>
Tested-by: Tony Luck <tony.luck@intel.com>
Link: https://lore.kernel.org/20250825-wip-mca-updates-v5-3-865768a2eef8@amd.com
arch/x86/kernel/cpu/mce/amd.c

index f429451cafc8f177140a3041a49b4fdb4951d57e..7e36bc0d0e6c0f52cd26b23eb0ccc7f5a66252db 100644 (file)
@@ -252,9 +252,6 @@ static DEFINE_PER_CPU(struct threshold_bank **, threshold_banks);
  */
 static DEFINE_PER_CPU(u64, bank_map);
 
-/* Map of banks that have more than MCA_MISC0 available. */
-static DEFINE_PER_CPU(u64, smca_misc_banks_map);
-
 static void amd_threshold_interrupt(void);
 static void amd_deferred_error_interrupt(void);
 
@@ -264,28 +261,6 @@ static void default_deferred_error_interrupt(void)
 }
 void (*deferred_error_int_vector)(void) = default_deferred_error_interrupt;
 
-static void smca_set_misc_banks_map(unsigned int bank, unsigned int cpu)
-{
-       u32 low, high;
-
-       /*
-        * For SMCA enabled processors, BLKPTR field of the first MISC register
-        * (MCx_MISC0) indicates presence of additional MISC regs set (MISC1-4).
-        */
-       if (rdmsr_safe(MSR_AMD64_SMCA_MCx_CONFIG(bank), &low, &high))
-               return;
-
-       if (!(low & MCI_CONFIG_MCAX))
-               return;
-
-       if (rdmsr_safe(MSR_AMD64_SMCA_MCx_MISC(bank), &low, &high))
-               return;
-
-       if (low & MASK_BLKPTR_LO)
-               per_cpu(smca_misc_banks_map, cpu) |= BIT_ULL(bank);
-
-}
-
 static void smca_configure(unsigned int bank, unsigned int cpu)
 {
        u8 *bank_counts = this_cpu_ptr(smca_bank_counts);
@@ -326,8 +301,6 @@ static void smca_configure(unsigned int bank, unsigned int cpu)
                wrmsr(smca_config, low, high);
        }
 
-       smca_set_misc_banks_map(bank, cpu);
-
        if (rdmsr_safe(MSR_AMD64_SMCA_MCx_IPID(bank), &low, &high)) {
                pr_warn("Failed to read MCA_IPID for bank %d\n", bank);
                return;
@@ -525,18 +498,6 @@ static void deferred_error_interrupt_enable(struct cpuinfo_x86 *c)
        wrmsr(MSR_CU_DEF_ERR, low, high);
 }
 
-static u32 smca_get_block_address(unsigned int bank, unsigned int block,
-                                 unsigned int cpu)
-{
-       if (!block)
-               return MSR_AMD64_SMCA_MCx_MISC(bank);
-
-       if (!(per_cpu(smca_misc_banks_map, cpu) & BIT_ULL(bank)))
-               return 0;
-
-       return MSR_AMD64_SMCA_MCx_MISCy(bank, block - 1);
-}
-
 static u32 get_block_address(u32 current_addr, u32 low, u32 high,
                             unsigned int bank, unsigned int block,
                             unsigned int cpu)
@@ -546,8 +507,15 @@ static u32 get_block_address(u32 current_addr, u32 low, u32 high,
        if ((bank >= per_cpu(mce_num_banks, cpu)) || (block >= NR_BLOCKS))
                return addr;
 
-       if (mce_flags.smca)
-               return smca_get_block_address(bank, block, cpu);
+       if (mce_flags.smca) {
+               if (!block)
+                       return MSR_AMD64_SMCA_MCx_MISC(bank);
+
+               if (!(low & MASK_BLKPTR_LO))
+                       return 0;
+
+               return MSR_AMD64_SMCA_MCx_MISCy(bank, block - 1);
+       }
 
        /* Fall back to method we used for older processors: */
        switch (block) {