powercap/intel_rapl: Fix domain detection
authorZhang Rui <rui.zhang@intel.com>
Tue, 13 Oct 2020 07:42:40 +0000 (15:42 +0800)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Fri, 16 Oct 2020 15:35:36 +0000 (17:35 +0200)
As only the low 32 bits of the RAPL_DOMAIN_REG_STATUS register
represents the energy counter, and the high 32 bits are reserved,
detect the existence of a RAPL domain by checking the low 32 bits only.

Signed-off-by: Zhang Rui <rui.zhang@intel.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
drivers/powercap/intel_rapl_common.c

index 983d75bd5bd19a46efcf4c8d57e39cb1638d6dfb..2651ea6cd6d37680f53ac80fff53fb962d928bac 100644 (file)
@@ -1228,7 +1228,7 @@ static int rapl_check_domain(int cpu, int domain, struct rapl_package *rp)
         * values, otherwise skip it.
         */
 
-       ra.mask = ~0;
+       ra.mask = ENERGY_STATUS_MASK;
        if (rp->priv->read_raw(cpu, &ra) || !ra.value)
                return -ENODEV;