x86/amd_nb, EDAC/amd64: Move DF Indirect Read to AMD64 EDAC
authorYazen Ghannam <yazen.ghannam@amd.com>
Thu, 28 Oct 2021 17:56:57 +0000 (17:56 +0000)
committerBorislav Petkov <bp@suse.de>
Mon, 15 Nov 2021 11:44:47 +0000 (12:44 +0100)
df_indirect_read() is used only for address translation. Move it to EDAC
along with the translation code.

Signed-off-by: Yazen Ghannam <yazen.ghannam@amd.com>
Signed-off-by: Borislav Petkov <bp@suse.de>
Link: https://lkml.kernel.org/r/20211028175728.121452-3-yazen.ghannam@amd.com
arch/x86/include/asm/amd_nb.h
arch/x86/kernel/amd_nb.c
drivers/edac/amd64_edac.c

index 455066a06f607eb5ba54f5fb68097f0ec289e7d5..00d1a400b7a17a272f2cbbf796682b8a18aa3665 100644 (file)
@@ -24,7 +24,6 @@ extern int amd_set_subcaches(int, unsigned long);
 
 extern int amd_smn_read(u16 node, u32 address, u32 *value);
 extern int amd_smn_write(u16 node, u32 address, u32 value);
-extern int amd_df_indirect_read(u16 node, u8 func, u16 reg, u8 instance_id, u32 *lo);
 
 struct amd_l3_cache {
        unsigned indices;
index c92c9c774c0e5207042708a434deb4ffc12f8743..f814d5fc333e5000446336862d3866898f7b3bb3 100644 (file)
@@ -29,7 +29,7 @@
 #define PCI_DEVICE_ID_AMD_19H_M40H_DF_F4 0x167d
 #define PCI_DEVICE_ID_AMD_19H_M50H_DF_F4 0x166e
 
-/* Protect the PCI config register pairs used for SMN and DF indirect access. */
+/* Protect the PCI config register pairs used for SMN. */
 static DEFINE_MUTEX(smn_mutex);
 
 static u32 *flush_words;
@@ -182,53 +182,6 @@ int amd_smn_write(u16 node, u32 address, u32 value)
 }
 EXPORT_SYMBOL_GPL(amd_smn_write);
 
-/*
- * Data Fabric Indirect Access uses FICAA/FICAD.
- *
- * Fabric Indirect Configuration Access Address (FICAA): Constructed based
- * on the device's Instance Id and the PCI function and register offset of
- * the desired register.
- *
- * Fabric Indirect Configuration Access Data (FICAD): There are FICAD LO
- * and FICAD HI registers but so far we only need the LO register.
- */
-int amd_df_indirect_read(u16 node, u8 func, u16 reg, u8 instance_id, u32 *lo)
-{
-       struct pci_dev *F4;
-       u32 ficaa;
-       int err = -ENODEV;
-
-       if (node >= amd_northbridges.num)
-               goto out;
-
-       F4 = node_to_amd_nb(node)->link;
-       if (!F4)
-               goto out;
-
-       ficaa  = 1;
-       ficaa |= reg & 0x3FC;
-       ficaa |= (func & 0x7) << 11;
-       ficaa |= instance_id << 16;
-
-       mutex_lock(&smn_mutex);
-
-       err = pci_write_config_dword(F4, 0x5C, ficaa);
-       if (err) {
-               pr_warn("Error writing DF Indirect FICAA, FICAA=0x%x\n", ficaa);
-               goto out_unlock;
-       }
-
-       err = pci_read_config_dword(F4, 0x98, lo);
-       if (err)
-               pr_warn("Error reading DF Indirect FICAD LO, FICAA=0x%x.\n", ficaa);
-
-out_unlock:
-       mutex_unlock(&smn_mutex);
-
-out:
-       return err;
-}
-EXPORT_SYMBOL_GPL(amd_df_indirect_read);
 
 int amd_cache_northbridges(void)
 {
index d2ad9f06abb78f3196bdd0e8f05318c50fb337e7..034d9863bcf989e5a53dca0f07910b3be45bd566 100644 (file)
@@ -988,6 +988,56 @@ static int sys_addr_to_csrow(struct mem_ctl_info *mci, u64 sys_addr)
        return csrow;
 }
 
+/* Protect the PCI config register pairs used for DF indirect access. */
+static DEFINE_MUTEX(df_indirect_mutex);
+
+/*
+ * Data Fabric Indirect Access uses FICAA/FICAD.
+ *
+ * Fabric Indirect Configuration Access Address (FICAA): Constructed based
+ * on the device's Instance Id and the PCI function and register offset of
+ * the desired register.
+ *
+ * Fabric Indirect Configuration Access Data (FICAD): There are FICAD LO
+ * and FICAD HI registers but so far we only need the LO register.
+ */
+static int amd_df_indirect_read(u16 node, u8 func, u16 reg, u8 instance_id, u32 *lo)
+{
+       struct pci_dev *F4;
+       u32 ficaa;
+       int err = -ENODEV;
+
+       if (node >= amd_nb_num())
+               goto out;
+
+       F4 = node_to_amd_nb(node)->link;
+       if (!F4)
+               goto out;
+
+       ficaa  = 1;
+       ficaa |= reg & 0x3FC;
+       ficaa |= (func & 0x7) << 11;
+       ficaa |= instance_id << 16;
+
+       mutex_lock(&df_indirect_mutex);
+
+       err = pci_write_config_dword(F4, 0x5C, ficaa);
+       if (err) {
+               pr_warn("Error writing DF Indirect FICAA, FICAA=0x%x\n", ficaa);
+               goto out_unlock;
+       }
+
+       err = pci_read_config_dword(F4, 0x98, lo);
+       if (err)
+               pr_warn("Error reading DF Indirect FICAD LO, FICAA=0x%x.\n", ficaa);
+
+out_unlock:
+       mutex_unlock(&df_indirect_mutex);
+
+out:
+       return err;
+}
+
 static int umc_normaddr_to_sysaddr(u64 norm_addr, u16 nid, u8 umc, u64 *sys_addr)
 {
        u64 dram_base_addr, dram_limit_addr, dram_hole_base;