Commit 9d31c676 authored by Jacob Pan's avatar Jacob Pan Committed by Rafael J. Wysocki

powercap / RAPL: further relax energy counter checks

Energy counters may roll slowly for some RAPL domains, checking all
of them can be time consuming and takes unpredictable amount of time.
Therefore, we relax the sanity check by only checking availability of the
MSRs and non-zero value of the energy status counters. It has been shown
sufficient for all the platforms tested to filter out inactive domains.
Signed-off-by: default avatarJacob Pan <jacob.jun.pan@linux.intel.com>
Acked-by: default avatarDurgadoss R <durgadoss.r@intel.com>
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent d1db0eea
...@@ -1124,8 +1124,7 @@ static int rapl_register_powercap(void) ...@@ -1124,8 +1124,7 @@ static int rapl_register_powercap(void)
static int rapl_check_domain(int cpu, int domain) static int rapl_check_domain(int cpu, int domain)
{ {
unsigned msr; unsigned msr;
u64 val1, val2 = 0; u64 val = 0;
int retry = 0;
switch (domain) { switch (domain) {
case RAPL_DOMAIN_PACKAGE: case RAPL_DOMAIN_PACKAGE:
...@@ -1144,26 +1143,13 @@ static int rapl_check_domain(int cpu, int domain) ...@@ -1144,26 +1143,13 @@ static int rapl_check_domain(int cpu, int domain)
pr_err("invalid domain id %d\n", domain); pr_err("invalid domain id %d\n", domain);
return -EINVAL; return -EINVAL;
} }
if (rdmsrl_safe_on_cpu(cpu, msr, &val1)) /* make sure domain counters are available and contains non-zero
return -ENODEV; * values, otherwise skip it.
/* PP1/uncore/graphics domain may not be active at the time of
* driver loading. So skip further checks.
*/ */
if (domain == RAPL_DOMAIN_PP1) if (rdmsrl_safe_on_cpu(cpu, msr, &val) || !val)
return 0; return -ENODEV;
/* energy counters roll slowly on some domains */
while (++retry < 10) {
usleep_range(10000, 15000);
rdmsrl_safe_on_cpu(cpu, msr, &val2);
if ((val1 & ENERGY_STATUS_MASK) != (val2 & ENERGY_STATUS_MASK))
return 0;
}
/* if energy counter does not change, report as bad domain */
pr_info("domain %s energy ctr %llu:%llu not working, skip\n",
rapl_domain_names[domain], val1, val2);
return -ENODEV; return 0;
} }
/* Detect active and valid domains for the given CPU, caller must /* Detect active and valid domains for the given CPU, caller must
...@@ -1180,6 +1166,9 @@ static int rapl_detect_domains(struct rapl_package *rp, int cpu) ...@@ -1180,6 +1166,9 @@ static int rapl_detect_domains(struct rapl_package *rp, int cpu)
/* use physical package id to read counters */ /* use physical package id to read counters */
if (!rapl_check_domain(cpu, i)) if (!rapl_check_domain(cpu, i))
rp->domain_map |= 1 << i; rp->domain_map |= 1 << i;
else
pr_warn("RAPL domain %s detection failed\n",
rapl_domain_names[i]);
} }
rp->nr_domains = bitmap_weight(&rp->domain_map, RAPL_DOMAIN_MAX); rp->nr_domains = bitmap_weight(&rp->domain_map, RAPL_DOMAIN_MAX);
if (!rp->nr_domains) { if (!rp->nr_domains) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment