mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-09 23:00:21 +00:00
tools/power/turbostat: Obey allowed CPUs for primary thread/core detection
Thread_id doesn't tell if a CPU is allowed or not. Detect allowed CPUs only and use the first detected thread/core as the primary thread/core of a core/package. Signed-off-by: Zhang Rui <rui.zhang@intel.com>
This commit is contained in:
parent
74318add13
commit
ccf8a05280
@ -926,12 +926,11 @@ struct thread_data {
|
|||||||
unsigned int x2apic_id;
|
unsigned int x2apic_id;
|
||||||
unsigned int flags;
|
unsigned int flags;
|
||||||
bool is_atom;
|
bool is_atom;
|
||||||
#define CPU_IS_FIRST_THREAD_IN_CORE 0x2
|
|
||||||
#define CPU_IS_FIRST_CORE_IN_PACKAGE 0x4
|
|
||||||
unsigned long long counter[MAX_ADDED_THREAD_COUNTERS];
|
unsigned long long counter[MAX_ADDED_THREAD_COUNTERS];
|
||||||
} *thread_even, *thread_odd;
|
} *thread_even, *thread_odd;
|
||||||
|
|
||||||
struct core_data {
|
struct core_data {
|
||||||
|
int base_cpu;
|
||||||
unsigned long long c3;
|
unsigned long long c3;
|
||||||
unsigned long long c6;
|
unsigned long long c6;
|
||||||
unsigned long long c7;
|
unsigned long long c7;
|
||||||
@ -944,6 +943,7 @@ struct core_data {
|
|||||||
} *core_even, *core_odd;
|
} *core_even, *core_odd;
|
||||||
|
|
||||||
struct pkg_data {
|
struct pkg_data {
|
||||||
|
int base_cpu;
|
||||||
unsigned long long pc2;
|
unsigned long long pc2;
|
||||||
unsigned long long pc3;
|
unsigned long long pc3;
|
||||||
unsigned long long pc6;
|
unsigned long long pc6;
|
||||||
@ -1200,26 +1200,21 @@ int for_all_cpus(int (func) (struct thread_data *, struct core_data *, struct pk
|
|||||||
|
|
||||||
int is_cpu_first_thread_in_core(struct thread_data *t, struct core_data *c, struct pkg_data *p)
|
int is_cpu_first_thread_in_core(struct thread_data *t, struct core_data *c, struct pkg_data *p)
|
||||||
{
|
{
|
||||||
UNUSED(c);
|
|
||||||
UNUSED(p);
|
UNUSED(p);
|
||||||
|
|
||||||
return (t->flags & CPU_IS_FIRST_THREAD_IN_CORE);
|
return ((int)t->cpu_id == c->base_cpu || c->base_cpu < 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
int is_cpu_first_core_in_package(struct thread_data *t, struct core_data *c, struct pkg_data *p)
|
int is_cpu_first_core_in_package(struct thread_data *t, struct core_data *c, struct pkg_data *p)
|
||||||
{
|
{
|
||||||
UNUSED(c);
|
UNUSED(c);
|
||||||
UNUSED(p);
|
|
||||||
|
|
||||||
return (t->flags & CPU_IS_FIRST_CORE_IN_PACKAGE);
|
return ((int)t->cpu_id == p->base_cpu || p->base_cpu < 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
int is_cpu_first_thread_in_package(struct thread_data *t, struct core_data *c, struct pkg_data *p)
|
int is_cpu_first_thread_in_package(struct thread_data *t, struct core_data *c, struct pkg_data *p)
|
||||||
{
|
{
|
||||||
UNUSED(c);
|
return is_cpu_first_thread_in_core(t, c, p) && is_cpu_first_core_in_package(t, c, p);
|
||||||
UNUSED(p);
|
|
||||||
|
|
||||||
return (t->flags & CPU_IS_FIRST_THREAD_IN_CORE) && (t->flags & CPU_IS_FIRST_CORE_IN_PACKAGE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int cpu_migrate(int cpu)
|
int cpu_migrate(int cpu)
|
||||||
@ -2263,9 +2258,6 @@ void clear_counters(struct thread_data *t, struct core_data *c, struct pkg_data
|
|||||||
t->irq_count = 0;
|
t->irq_count = 0;
|
||||||
t->smi_count = 0;
|
t->smi_count = 0;
|
||||||
|
|
||||||
/* tells format_counters to dump all fields from this set */
|
|
||||||
t->flags = CPU_IS_FIRST_THREAD_IN_CORE | CPU_IS_FIRST_CORE_IN_PACKAGE;
|
|
||||||
|
|
||||||
c->c3 = 0;
|
c->c3 = 0;
|
||||||
c->c6 = 0;
|
c->c6 = 0;
|
||||||
c->c7 = 0;
|
c->c7 = 0;
|
||||||
@ -5872,15 +5864,19 @@ void allocate_counters(struct thread_data **t, struct core_data **c, struct pkg_
|
|||||||
if (*c == NULL)
|
if (*c == NULL)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
for (i = 0; i < num_cores; i++)
|
for (i = 0; i < num_cores; i++) {
|
||||||
(*c)[i].core_id = -1;
|
(*c)[i].core_id = -1;
|
||||||
|
(*c)[i].base_cpu = -1;
|
||||||
|
}
|
||||||
|
|
||||||
*p = calloc(topo.num_packages, sizeof(struct pkg_data));
|
*p = calloc(topo.num_packages, sizeof(struct pkg_data));
|
||||||
if (*p == NULL)
|
if (*p == NULL)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
for (i = 0; i < topo.num_packages; i++)
|
for (i = 0; i < topo.num_packages; i++) {
|
||||||
(*p)[i].package_id = i;
|
(*p)[i].package_id = i;
|
||||||
|
(*p)[i].base_cpu = -1;
|
||||||
|
}
|
||||||
|
|
||||||
return;
|
return;
|
||||||
error:
|
error:
|
||||||
@ -5913,10 +5909,11 @@ void init_counter(struct thread_data *thread_base, struct core_data *core_base,
|
|||||||
p = GET_PKG(pkg_base, pkg_id);
|
p = GET_PKG(pkg_base, pkg_id);
|
||||||
|
|
||||||
t->cpu_id = cpu_id;
|
t->cpu_id = cpu_id;
|
||||||
if (thread_id == 0) {
|
if (!cpu_is_not_allowed(cpu_id)) {
|
||||||
t->flags |= CPU_IS_FIRST_THREAD_IN_CORE;
|
if (c->base_cpu < 0)
|
||||||
if (cpu_is_first_core_in_package(cpu_id))
|
c->base_cpu = t->cpu_id;
|
||||||
t->flags |= CPU_IS_FIRST_CORE_IN_PACKAGE;
|
if (p->base_cpu < 0)
|
||||||
|
p->base_cpu = t->cpu_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
c->core_id = core_id;
|
c->core_id = core_id;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user