]> Git Repo - linux.git/commitdiff
perf/x86/intel/uncore: Wrap the max dies calculation into an accessor
authorRoman Sudarikov <[email protected]>
Mon, 1 Jun 2020 08:35:42 +0000 (11:35 +0300)
committerPeter Zijlstra <[email protected]>
Mon, 15 Jun 2020 12:09:51 +0000 (14:09 +0200)
The accessor to return number of dies on the platform.

Signed-off-by: Alexander Antonov <[email protected]>
Signed-off-by: Roman Sudarikov <[email protected]>
Signed-off-by: Peter Zijlstra (Intel) <[email protected]>
Reviewed-by: Kan Liang <[email protected]>
Reviewed-by: Alexander Shishkin <[email protected]>
Link: https://lkml.kernel.org/r/[email protected]
arch/x86/events/intel/uncore.c
arch/x86/events/intel/uncore.h

index 49255e656e85dc0e467f287b57c72f975695fce1..d5c6d3b340c503cebeab5d79d683a3739fb362fe 100644 (file)
@@ -16,7 +16,7 @@ struct pci_driver *uncore_pci_driver;
 DEFINE_RAW_SPINLOCK(pci2phy_map_lock);
 struct list_head pci2phy_map_head = LIST_HEAD_INIT(pci2phy_map_head);
 struct pci_extra_dev *uncore_extra_pci_dev;
-static int max_dies;
+int __uncore_max_dies;
 
 /* mask of cpus that collect uncore events */
 static cpumask_t uncore_cpu_mask;
@@ -108,7 +108,7 @@ struct intel_uncore_box *uncore_pmu_to_box(struct intel_uncore_pmu *pmu, int cpu
         * The unsigned check also catches the '-1' return value for non
         * existent mappings in the topology map.
         */
-       return dieid < max_dies ? pmu->boxes[dieid] : NULL;
+       return dieid < uncore_max_dies() ? pmu->boxes[dieid] : NULL;
 }
 
 u64 uncore_msr_read_counter(struct intel_uncore_box *box, struct perf_event *event)
@@ -882,7 +882,7 @@ static void uncore_free_boxes(struct intel_uncore_pmu *pmu)
 {
        int die;
 
-       for (die = 0; die < max_dies; die++)
+       for (die = 0; die < uncore_max_dies(); die++)
                kfree(pmu->boxes[die]);
        kfree(pmu->boxes);
 }
@@ -923,7 +923,7 @@ static int __init uncore_type_init(struct intel_uncore_type *type, bool setid)
        if (!pmus)
                return -ENOMEM;
 
-       size = max_dies * sizeof(struct intel_uncore_box *);
+       size = uncore_max_dies() * sizeof(struct intel_uncore_box *);
 
        for (i = 0; i < type->num_boxes; i++) {
                pmus[i].func_id = setid ? i : -1;
@@ -1123,7 +1123,7 @@ static int __init uncore_pci_init(void)
        size_t size;
        int ret;
 
-       size = max_dies * sizeof(struct pci_extra_dev);
+       size = uncore_max_dies() * sizeof(struct pci_extra_dev);
        uncore_extra_pci_dev = kzalloc(size, GFP_KERNEL);
        if (!uncore_extra_pci_dev) {
                ret = -ENOMEM;
@@ -1552,7 +1552,8 @@ static int __init intel_uncore_init(void)
        if (boot_cpu_has(X86_FEATURE_HYPERVISOR))
                return -ENODEV;
 
-       max_dies = topology_max_packages() * topology_max_die_per_package();
+       __uncore_max_dies =
+               topology_max_packages() * topology_max_die_per_package();
 
        uncore_init = (struct intel_uncore_init_fun *)id->driver_data;
        if (uncore_init->pci_init) {
index 7caba06c7df5df4a066b12d50a02e4bec83eb9a1..594a2fe20de96e8f9d98d5e568050ca343fa7b00 100644 (file)
@@ -182,6 +182,9 @@ int uncore_pcibus_to_physid(struct pci_bus *bus);
 ssize_t uncore_event_show(struct kobject *kobj,
                          struct kobj_attribute *attr, char *buf);
 
+extern int __uncore_max_dies;
+#define uncore_max_dies()      (__uncore_max_dies)
+
 #define INTEL_UNCORE_EVENT_DESC(_name, _config)                        \
 {                                                              \
        .attr   = __ATTR(_name, 0444, uncore_event_show, NULL), \
This page took 0.063393 seconds and 4 git commands to generate.