|
@@ -3563,24 +3563,27 @@ static struct intel_uncore_type *skx_msr_uncores[] = {
|
|
NULL,
|
|
NULL,
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+/*
|
|
|
|
+ * To determine the number of CHAs, it should read bits 27:0 in the CAPID6
|
|
|
|
+ * register which located at Device 30, Function 3, Offset 0x9C. PCI ID 0x2083.
|
|
|
|
+ */
|
|
|
|
+#define SKX_CAPID6 0x9c
|
|
|
|
+#define SKX_CHA_BIT_MASK GENMASK(27, 0)
|
|
|
|
+
|
|
static int skx_count_chabox(void)
|
|
static int skx_count_chabox(void)
|
|
{
|
|
{
|
|
- struct pci_dev *chabox_dev = NULL;
|
|
|
|
- int bus, count = 0;
|
|
|
|
|
|
+ struct pci_dev *dev = NULL;
|
|
|
|
+ u32 val = 0;
|
|
|
|
|
|
- while (1) {
|
|
|
|
- chabox_dev = pci_get_device(PCI_VENDOR_ID_INTEL, 0x208d, chabox_dev);
|
|
|
|
- if (!chabox_dev)
|
|
|
|
- break;
|
|
|
|
- if (count == 0)
|
|
|
|
- bus = chabox_dev->bus->number;
|
|
|
|
- if (bus != chabox_dev->bus->number)
|
|
|
|
- break;
|
|
|
|
- count++;
|
|
|
|
- }
|
|
|
|
|
|
+ dev = pci_get_device(PCI_VENDOR_ID_INTEL, 0x2083, dev);
|
|
|
|
+ if (!dev)
|
|
|
|
+ goto out;
|
|
|
|
|
|
- pci_dev_put(chabox_dev);
|
|
|
|
- return count;
|
|
|
|
|
|
+ pci_read_config_dword(dev, SKX_CAPID6, &val);
|
|
|
|
+ val &= SKX_CHA_BIT_MASK;
|
|
|
|
+out:
|
|
|
|
+ pci_dev_put(dev);
|
|
|
|
+ return hweight32(val);
|
|
}
|
|
}
|
|
|
|
|
|
void skx_uncore_cpu_init(void)
|
|
void skx_uncore_cpu_init(void)
|