Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp1067499ybk; Wed, 13 May 2020 22:41:22 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzU6kyWr5IngBTPW9juNod6tH1lLmqJ93LeFp+10rgu7z1/RwiJHyK06qUJkPEZy13fSxVb X-Received: by 2002:a05:6402:30bb:: with SMTP id df27mr2341746edb.267.1589434882605; Wed, 13 May 2020 22:41:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1589434882; cv=none; d=google.com; s=arc-20160816; b=zeIcb1HNEBvwkiduXS3VOSpOwAIJzLZzfnr/gqOf3G6p0fOtg00JldbU7EfAB6oBMj QsUE6AnSFO8n0TgH+HSGMDYopuNSJqosVkEsVbOY1rBXnORjEYYe798/xRL/EQQXazbE trTl7NKBAkKBg5mZeUIIz0vBYNjOZTQ+kG8D2l8bFoUNC/Op4Dkt/Bl9YI7sUO/vNvLN Pdpgd/OsJwU8R0HI+4VKOb2BmivGY4bxtBGG7chxp2m8Zvw/ZZVczeSFttNj7Ev21th6 gVhYETUgMQuPc6BDfrTX4y4FCq+9mIT8QN7IGvjmLBpRHqcD2UV5/x+NAQhXkgUMOtzP 1B0Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:ironport-sdr:ironport-sdr; bh=1jUmYKkjoxKnT4ad48UfPFPBAzKZPzOjFLivJYD7WS4=; b=rujLKPLWul4j9gyk41kiEm7FxGNLs+8rYq4sCvuMb/rZ0uvmpwg2vQ4dwnbtgXqY4r oTddh0scv/4jjcTvMWFXB9u7rlU15pk5VCweWeg/nOpov44m0UiVqyyuNpG+emjeVZMF VpCFrDYm1cHmLdODKq4brohi8jTJmi5CF8YEj6KAF0rBGN08TZ4ogA0wvxLMMFg7N+gq OSy8pRI4VOzBrGcjPvyzIleVSuXMM2jQJERic6AOwOACCkjDPfM24+eE/r5Ki73+Erna /ohzaFa627q7ykfpHzIBNugS+CMdPClq8yPNzEQPunbJlLPbGSPIWeoJzdSlMlEYLGLJ QeDA== 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 b13si1261209ejg.10.2020.05.13.22.40.43; Wed, 13 May 2020 22:41:22 -0700 (PDT) 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 S1726050AbgENFir (ORCPT + 99 others); Thu, 14 May 2020 01:38:47 -0400 Received: from mga03.intel.com ([134.134.136.65]:62468 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725794AbgENFiq (ORCPT ); Thu, 14 May 2020 01:38:46 -0400 IronPort-SDR: bTi+J8z9VS+kiuIDPTl5nj6wn9zwhpRdAUKtmcLtnpuxyDIV0cWtH6Y3chz7m0UKeb1RB18u8n cKynllKOm0ww== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by orsmga103.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 13 May 2020 22:38:46 -0700 IronPort-SDR: gdPu94T0KAwe4RcZaro6daVAdfHsdZDuuFAl86n74uM3tJfUbZF/ROQpmGAon1QziIQBu4MCt8 NznPoDzseyZw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.73,390,1583222400"; d="scan'208";a="287289063" Received: from kbl-ppc.sh.intel.com ([10.239.159.118]) by fmsmga004.fm.intel.com with ESMTP; 13 May 2020 22:38:43 -0700 From: Jin Yao To: acme@kernel.org, jolsa@kernel.org, peterz@infradead.org, mingo@redhat.com, alexander.shishkin@linux.intel.com Cc: Linux-kernel@vger.kernel.org, ak@linux.intel.com, kan.liang@intel.com, yao.jin@intel.com, Jin Yao Subject: [PATCH v5 2/5] perf counts: Reset prev_raw_counts counts Date: Thu, 14 May 2020 13:36:35 +0800 Message-Id: <20200514053638.3736-3-yao.jin@linux.intel.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200514053638.3736-1-yao.jin@linux.intel.com> References: <20200514053638.3736-1-yao.jin@linux.intel.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When we want to reset the evsel->prev_raw_counts, zeroing the aggr is not enough, we need to reset the perf_counts too. The perf_counts__reset zeros the perf_counts, and it should zero the aggr too. This patch changes perf_counts__reset to non-static, and calls it in evsel__reset_prev_raw_counts to reset the prev_raw_counts. v4: --- Zeroing the aggr in perf_counts__reset and use it to reset prev_raw_counts. Signed-off-by: Jin Yao --- tools/perf/util/counts.c | 4 +++- tools/perf/util/counts.h | 1 + tools/perf/util/stat.c | 7 ++----- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/tools/perf/util/counts.c b/tools/perf/util/counts.c index 615c9f3e95cb..582f3aeaf5e4 100644 --- a/tools/perf/util/counts.c +++ b/tools/perf/util/counts.c @@ -1,6 +1,7 @@ // SPDX-License-Identifier: GPL-2.0 #include #include +#include #include "evsel.h" #include "counts.h" #include @@ -42,10 +43,11 @@ void perf_counts__delete(struct perf_counts *counts) } } -static void perf_counts__reset(struct perf_counts *counts) +void perf_counts__reset(struct perf_counts *counts) { xyarray__reset(counts->loaded); xyarray__reset(counts->values); + memset(&counts->aggr, 0, sizeof(struct perf_counts_values)); } void evsel__reset_counts(struct evsel *evsel) diff --git a/tools/perf/util/counts.h b/tools/perf/util/counts.h index 8f556c6d98fa..7ff36bf6d644 100644 --- a/tools/perf/util/counts.h +++ b/tools/perf/util/counts.h @@ -37,6 +37,7 @@ perf_counts__set_loaded(struct perf_counts *counts, int cpu, int thread, bool lo struct perf_counts *perf_counts__new(int ncpus, int nthreads); void perf_counts__delete(struct perf_counts *counts); +void perf_counts__reset(struct perf_counts *counts); void evsel__reset_counts(struct evsel *evsel); int evsel__alloc_counts(struct evsel *evsel, int ncpus, int nthreads); diff --git a/tools/perf/util/stat.c b/tools/perf/util/stat.c index f4a44df9b221..e397815f0dfb 100644 --- a/tools/perf/util/stat.c +++ b/tools/perf/util/stat.c @@ -163,11 +163,8 @@ static void evsel__free_prev_raw_counts(struct evsel *evsel) static void evsel__reset_prev_raw_counts(struct evsel *evsel) { - if (evsel->prev_raw_counts) { - evsel->prev_raw_counts->aggr.val = 0; - evsel->prev_raw_counts->aggr.ena = 0; - evsel->prev_raw_counts->aggr.run = 0; - } + if (evsel->prev_raw_counts) + perf_counts__reset(evsel->prev_raw_counts); } static int evsel__alloc_stats(struct evsel *evsel, bool alloc_raw) -- 2.17.1