Received: by 2002:a05:6a10:2785:0:0:0:0 with SMTP id ia5csp219243pxb; Fri, 15 Jan 2021 01:13:43 -0800 (PST) X-Google-Smtp-Source: ABdhPJw+T4TEZT6m+/bXNSPY7jIEZ/UalpnO3ASLFU/pSX8Oh6OzivWXs2/zA4DwDWsB++qxaW/0 X-Received: by 2002:a17:907:16a2:: with SMTP id hc34mr8280098ejc.9.1610702023308; Fri, 15 Jan 2021 01:13:43 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1610702023; cv=none; d=google.com; s=arc-20160816; b=Cn1OCFmAqQDCYBtwTTkr5GdWp6xE2AQenImQ3Vt8lCJbMxbrgO/rYQ+BXpMZJfeCZq YmfzdpBYhi5f3oU70qgkP3KZfCWMmaLVur8sle+ivqcH8H0H8w3h/wsAplg0Ck8EEaXa hZpLy9Rb2YV/lVzmCUdoE+YCnynqQlVSk+BRoFN7T20yEzZukCdxTtuwadp9/s92rQUS dAQG7pkc5W0CDl0cv6llosqMBzRIvgmiNAOqsofpknXFRoTjqTyk+uNt1Y2rf4EpiIGo S1Nm26mlV/xIrtL2g7mAh27giRs5ON6CuJOVwSYB+nZ6XQUsEv2OikHWqiIPIKoOgnnR 56jg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:ironport-sdr:ironport-sdr; bh=oeNbBzgHUwutCF0hIjEz+2/9yAYTawCKDafFz/Bi0Ug=; b=R5XB5gWJfxODlqUA2bxuIVjnc82zNv2tNtJkBKtzDt06I713Rmc25Mx0K7sy19dfu4 38BPhpV9M937d4ZWguPUWTH+d7oOMXTBw+ROOYQZFHybdLOIh4O50AdM1usTEyTAIFTR I7XK/4FT6pQwCJftwr5JqvKUwukBCRoZLjvy5+KC1PPvLiVlbfuB9+FJfg+f3bbWWoMY Zzz5t/kveYboJc8fbL5RtUt9MMBo8bEsTyySksQr63MQNlcza9DK/JHDbjM+TMSDnAsY 6UQTn8HvCRbC9CqT+GfF3B4yd9t2Vyq3se5xAmu/mDl0FxBvDEw7QNknnl2V0ID25ruJ YzjQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ay17si267854ejb.356.2021.01.15.01.13.19; Fri, 15 Jan 2021 01:13:43 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729905AbhAOJLe (ORCPT + 99 others); Fri, 15 Jan 2021 04:11:34 -0500 Received: from mga11.intel.com ([192.55.52.93]:49687 "EHLO mga11.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725950AbhAOJLa (ORCPT ); Fri, 15 Jan 2021 04:11:30 -0500 IronPort-SDR: NhGmWwPySrQbnunATPmq4f4MyTVXJCB6Ur91Xhn7CLUzT/PBUFKWvmzKa/3fwCMigoEndZcYo9 8BvzVStC01VA== X-IronPort-AV: E=McAfee;i="6000,8403,9864"; a="175016673" X-IronPort-AV: E=Sophos;i="5.79,349,1602572400"; d="scan'208";a="175016673" Received: from orsmga008.jf.intel.com ([10.7.209.65]) by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 15 Jan 2021 01:10:46 -0800 IronPort-SDR: hyqMqS9LAQ+GZ9lyH+qIC3M7r21DHMaIizgfY4hmQLs2p3gAHxdpca5L4ZWkfvIWkx/dbgW6IG VxbDoniilpcg== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.79,349,1602572400"; d="scan'208";a="382597793" Received: from power-sh.sh.intel.com ([10.239.48.130]) by orsmga008.jf.intel.com with ESMTP; 15 Jan 2021 01:10:44 -0800 From: Zhang Rui To: peterz@infradead.org, mingo@redhat.com, acme@kernel.org Cc: mark.rutland@arm.com, alexander.shishkin@linux.intel.com, jolsa@redhat.com, namhyung@kernel.org, linux-kernel@vger.kernel.org, x86@kernel.org, kan.liang@linux.intel.com, ak@linux.intel.com Subject: [PATCH 2/3] perf/x86/rapl: Fix energy counter detection Date: Fri, 15 Jan 2021 17:22:07 +0800 Message-Id: <20210115092208.20866-2-rui.zhang@intel.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20210115092208.20866-1-rui.zhang@intel.com> References: <20210115092208.20866-1-rui.zhang@intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In the RAPL ENERGY_COUNTER MSR, only the lower 32bits represent the energy counter, and the higher 32bits are reserved. Add the MSR mask for these MSRs to fix a problem that the RAPL PMU events are added erroneously when higher 32bits contain non-zero value. Signed-off-by: Zhang Rui Reviewed-by: Andi Kleen --- arch/x86/events/rapl.c | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/arch/x86/events/rapl.c b/arch/x86/events/rapl.c index 7dbbeaacd995..7ed25b2ba05f 100644 --- a/arch/x86/events/rapl.c +++ b/arch/x86/events/rapl.c @@ -523,12 +523,15 @@ static bool test_msr(int idx, void *data) return test_bit(idx, (unsigned long *) data); } +/* Only lower 32bits of the MSR represents the energy counter */ +#define RAPL_MSR_MASK 0xFFFFFFFF + static struct perf_msr intel_rapl_msrs[] = { - [PERF_RAPL_PP0] = { MSR_PP0_ENERGY_STATUS, &rapl_events_cores_group, test_msr }, - [PERF_RAPL_PKG] = { MSR_PKG_ENERGY_STATUS, &rapl_events_pkg_group, test_msr }, - [PERF_RAPL_RAM] = { MSR_DRAM_ENERGY_STATUS, &rapl_events_ram_group, test_msr }, - [PERF_RAPL_PP1] = { MSR_PP1_ENERGY_STATUS, &rapl_events_gpu_group, test_msr }, - [PERF_RAPL_PSYS] = { MSR_PLATFORM_ENERGY_STATUS, &rapl_events_psys_group, test_msr }, + [PERF_RAPL_PP0] = { MSR_PP0_ENERGY_STATUS, &rapl_events_cores_group, test_msr, false, RAPL_MSR_MASK }, + [PERF_RAPL_PKG] = { MSR_PKG_ENERGY_STATUS, &rapl_events_pkg_group, test_msr, false, RAPL_MSR_MASK }, + [PERF_RAPL_RAM] = { MSR_DRAM_ENERGY_STATUS, &rapl_events_ram_group, test_msr, false, RAPL_MSR_MASK }, + [PERF_RAPL_PP1] = { MSR_PP1_ENERGY_STATUS, &rapl_events_gpu_group, test_msr, false, RAPL_MSR_MASK }, + [PERF_RAPL_PSYS] = { MSR_PLATFORM_ENERGY_STATUS, &rapl_events_psys_group, test_msr, false, RAPL_MSR_MASK }, }; /* -- 2.17.1