Received: by 2002:a05:6a10:8395:0:0:0:0 with SMTP id n21csp251174pxh; Tue, 9 Nov 2021 10:07:32 -0800 (PST) X-Google-Smtp-Source: ABdhPJwpdSrX83SXuPSldZ6eMMZgna8oXVfunDjVFu77jE3/UCQmVpZJopXZPgWU2TGkWhyXQQ/t X-Received: by 2002:a17:906:76d4:: with SMTP id q20mr12129169ejn.380.1636481251712; Tue, 09 Nov 2021 10:07:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1636481251; cv=none; d=google.com; s=arc-20160816; b=gpWErugKoy+S8cYK2mQbVWaXy/i5KzW3srMUVcG3SA0LALzvP0jMMpPrXrft9jKtRS 4KGhbJOHQKgdmEGhlQrKmRBUY/aCgOeHPI6Ju3MvvJ5S40Jq6Ttepg6+4ArA8MboJF9x 4BYqnyuz0Pe6I/VY7QV2vrEIDaexOVDWOSi2WWCFjjOmKIpR87Uog4FO8fE3qkzhaaPY 4DqObsJ7aVwJOrANkwjVEEmRmV8OgWC4YNfKDn+REHGZpYxbOV6QuxnOqH8kprHARkW6 kmevfCKwUdvxq47MqYZZQJA7IH10wy68gWmNcpyhzWXEV1zqG600nzefvI3U7k/xhvN/ e9fg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :ironport-sdr; bh=gitQ9+B3xPOdDy5e7rL2M761rmK63eMOPxVPa5oDzuY=; b=E6UZcB5wl7rBTYkDO1mUqfo6zTUo2ddD8JNExxuiClcdeDgycY+9UZkDZ3GO5X/MZi cLFQHjNkDvfIng7I1+bwQxj+3ZHK6RrJlFazKlmiDE8QY7CrKqgRfBr59rtZIpNqKzDA 6bIqxy4hRT1T9zO8jf7sT4nbYus+RtgIdHcjr0kit2sM/sEkYC062PUiP1HXNlKt8aod fYpFNmZgMoDGdSdyEPFCMSF3QlVA6rIreS2ybrpSjq5NF40Ry/9j3n6yh/vais77rNCo p+huH2Sy7+cNt0OUJ85jPL8DcTzgeaZ/LzTdlfvPYHa9caXjbwwgJxGxHnArxA/Zub7C swdw== 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=fujitsu.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n1si30212879edb.494.2021.11.09.10.07.05; Tue, 09 Nov 2021 10:07:31 -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=fujitsu.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242162AbhKIJKD (ORCPT + 99 others); Tue, 9 Nov 2021 04:10:03 -0500 Received: from esa7.hc1455-7.c3s2.iphmx.com ([139.138.61.252]:31882 "EHLO esa7.hc1455-7.c3s2.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242256AbhKIJJ5 (ORCPT ); Tue, 9 Nov 2021 04:09:57 -0500 IronPort-SDR: mo6xdfCXWCg8QzaIdfP0YI3Dzz6+qCncrdehwSMVUa9MQOZO6nJriuIb2fEySX1gML9/zPQeAK Zg1trZLVyftZvWVxtEjLlBsIWSEQ2jE1eB1/iiqfZVl7zjBu8XhalcfZNI+j9mSjUQr8gW6c5H 4FOlH9QNpEQBqil8O6bN2JxcoZQYGa0rP1p8ytML0kvA+8BizdNoBrGlvF2hiSTORXJeMzd8Ln hij0/LznzoZC9OxilysxX8vkGq2fJPY1mT2eljCxE9ZfKBMQIVMdhkWd7QJ20id7GmiSifiEmt PWQBMK9AYuKd8Rcoilrt67RJ X-IronPort-AV: E=McAfee;i="6200,9189,10162"; a="30750655" X-IronPort-AV: E=Sophos;i="5.87,219,1631545200"; d="scan'208";a="30750655" Received: from unknown (HELO oym-r3.gw.nic.fujitsu.com) ([210.162.30.91]) by esa7.hc1455-7.c3s2.iphmx.com with ESMTP; 09 Nov 2021 17:58:37 +0900 Received: from oym-m4.gw.nic.fujitsu.com (oym-nat-oym-m4.gw.nic.fujitsu.com [192.168.87.61]) by oym-r3.gw.nic.fujitsu.com (Postfix) with ESMTP id A2F1B15946; Tue, 9 Nov 2021 17:58:36 +0900 (JST) Received: from yto-om2.fujitsu.com (yto-om2.o.css.fujitsu.com [10.128.89.163]) by oym-m4.gw.nic.fujitsu.com (Postfix) with ESMTP id B8DC3E129D; Tue, 9 Nov 2021 17:58:35 +0900 (JST) Received: from pumpkin.openstacklocal (pumpkin.fct.css.fujitsu.com [10.130.70.189]) by yto-om2.fujitsu.com (Postfix) with ESMTP id 919F34006D7F4; Tue, 9 Nov 2021 17:58:35 +0900 (JST) From: Shunsuke Nakamura To: peterz@infradead.org, mingo@redhat.com, acme@kernel.org, mark.rutland@arm.com, alexander.shishkin@linux.intel.com, jolsa@redhat.com, namhyung@kernel.org, robh@kernel.org Cc: linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org Subject: [PATCH v3 1/3] libperf: Move perf_counts_values__scale to tools/lib/perf Date: Tue, 9 Nov 2021 17:58:29 +0900 Message-Id: <20211109085831.3770594-2-nakamura.shun@fujitsu.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20211109085831.3770594-1-nakamura.shun@fujitsu.com> References: <20211109085831.3770594-1-nakamura.shun@fujitsu.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-TM-AS-GCONF: 00 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Move perf_counts_values__scale from tools/perf/util to tools/lib/perf so that it can be used with libperf. Signed-off-by: Shunsuke Nakamura --- tools/lib/perf/evsel.c | 19 +++++++++++++++++++ tools/lib/perf/include/perf/evsel.h | 4 ++++ tools/lib/perf/libperf.map | 1 + tools/perf/util/evsel.c | 19 ------------------- tools/perf/util/evsel.h | 3 --- 5 files changed, 24 insertions(+), 22 deletions(-) diff --git a/tools/lib/perf/evsel.c b/tools/lib/perf/evsel.c index 8441e3e1aaac..5097aadea37a 100644 --- a/tools/lib/perf/evsel.c +++ b/tools/lib/perf/evsel.c @@ -431,3 +431,22 @@ void perf_evsel__free_id(struct perf_evsel *evsel) zfree(&evsel->id); evsel->ids = 0; } + +void perf_counts_values__scale(struct perf_counts_values *count, + bool scale, s8 *pscaled) +{ + s8 scaled = 0; + + if (scale) { + if (count->run == 0) { + scaled = -1; + count->val = 0; + } else if (count->run < count->ena) { + scaled = 1; + count->val = (u64)((double)count->val * count->ena / count->run); + } + } + + if (pscaled) + *pscaled = scaled; +} diff --git a/tools/lib/perf/include/perf/evsel.h b/tools/lib/perf/include/perf/evsel.h index 60eae25076d3..9013d73af22d 100644 --- a/tools/lib/perf/include/perf/evsel.h +++ b/tools/lib/perf/include/perf/evsel.h @@ -4,6 +4,8 @@ #include #include +#include +#include struct perf_evsel; struct perf_event_attr; @@ -39,5 +41,7 @@ LIBPERF_API int perf_evsel__disable_cpu(struct perf_evsel *evsel, int cpu); LIBPERF_API struct perf_cpu_map *perf_evsel__cpus(struct perf_evsel *evsel); LIBPERF_API struct perf_thread_map *perf_evsel__threads(struct perf_evsel *evsel); LIBPERF_API struct perf_event_attr *perf_evsel__attr(struct perf_evsel *evsel); +LIBPERF_API void perf_counts_values__scale(struct perf_counts_values *count, + bool scale, s8 *pscaled); #endif /* __LIBPERF_EVSEL_H */ diff --git a/tools/lib/perf/libperf.map b/tools/lib/perf/libperf.map index 71468606e8a7..5979bf92d98f 100644 --- a/tools/lib/perf/libperf.map +++ b/tools/lib/perf/libperf.map @@ -50,6 +50,7 @@ LIBPERF_0.0.1 { perf_mmap__read_init; perf_mmap__read_done; perf_mmap__read_event; + perf_counts_values__scale; local: *; }; diff --git a/tools/perf/util/evsel.c b/tools/perf/util/evsel.c index dbfeceb2546c..49e4d0bdd7cc 100644 --- a/tools/perf/util/evsel.c +++ b/tools/perf/util/evsel.c @@ -1457,25 +1457,6 @@ void evsel__compute_deltas(struct evsel *evsel, int cpu, int thread, count->run = count->run - tmp.run; } -void perf_counts_values__scale(struct perf_counts_values *count, - bool scale, s8 *pscaled) -{ - s8 scaled = 0; - - if (scale) { - if (count->run == 0) { - scaled = -1; - count->val = 0; - } else if (count->run < count->ena) { - scaled = 1; - count->val = (u64)((double) count->val * count->ena / count->run); - } - } - - if (pscaled) - *pscaled = scaled; -} - static int evsel__read_one(struct evsel *evsel, int cpu, int thread) { struct perf_counts_values *count = perf_counts(evsel->counts, cpu, thread); diff --git a/tools/perf/util/evsel.h b/tools/perf/util/evsel.h index 1f7edfa8568a..8a6a4182c5fd 100644 --- a/tools/perf/util/evsel.h +++ b/tools/perf/util/evsel.h @@ -190,9 +190,6 @@ static inline int evsel__nr_cpus(struct evsel *evsel) return evsel__cpus(evsel)->nr; } -void perf_counts_values__scale(struct perf_counts_values *count, - bool scale, s8 *pscaled); - void evsel__compute_deltas(struct evsel *evsel, int cpu, int thread, struct perf_counts_values *count); -- 2.27.0