Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp127518pxf; Wed, 10 Mar 2021 23:10:42 -0800 (PST) X-Google-Smtp-Source: ABdhPJwUOlNGX8uGSwfFBnNrNB1gca/xq2qIhEt8hJh+y+B61vRMuKyL0AnXzbspy1LqCh3Y7Tcb X-Received: by 2002:aa7:df86:: with SMTP id b6mr7015990edy.294.1615446642789; Wed, 10 Mar 2021 23:10:42 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1615446642; cv=none; d=google.com; s=arc-20160816; b=HerFMZhWjC+O1jxYpaRP+uoEG/ZYaOybw+NGQ8r6zSucakPXqhDttqPfKp+TFOCnjo 9XR8Hd880MbfQzZlkgv2qOifcMCGfItC8a99UTpUdp0/4hpRhycjp4UIhgybWJHK7FcE iQcI48fcWhopxqsL1flxTYP8+g08odmLD+e03o2zXnV0OfcocISXkG0UqTRS0hWbKGXW /fmOuGNGghZ54gn6zZ2ukUkcZ7sTlIK2er5q3wfojF4pkxkpwFssz1YEGlRa5ICXFp8l Iiy1V5btel39oS9werA/07+HEeahV82/pIGeEmeK484sL5qXE40sX4dQoLYxHmTztjva 6Ugg== 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=oehU3dkeUDJ3Ggd/DIA3aKig+A0UXGNo2vG8UIyWfkU=; b=QLPIzWMsSQCyjpsYhvVzpThVRXI43tmzzYw2hhleoRNHfPmJ6eR4vip6jK2zHvcyuF v9I4ODGUcCZ9FwYATveb/9nD962o5NpBzXwWI4HoKe758+gAcAuMvfB0CBPHMGJIErOa OgDsan1TnKPrbAl0VaipacApwkYpKEQbcB802Xx4A3FjV53pnj9llLNeUvfshdvfC43x L2fYMV0x1KNTiIY4FQM6k+B+D74GuJUsAeTbEaP8Xg0U/oSXvJbznNUGHnfmJ9+BZAxz xDtKiUIC98ExgwnEOYv5aOpYiJfnF4zCoebxrK9xk3DdQUgw8++AVXRq31gVJfEkwaXL B77A== 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 b10si1170701edz.577.2021.03.10.23.10.20; Wed, 10 Mar 2021 23:10:42 -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 S231719AbhCKHJA (ORCPT + 99 others); Thu, 11 Mar 2021 02:09:00 -0500 Received: from mga04.intel.com ([192.55.52.120]:22599 "EHLO mga04.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231622AbhCKHIb (ORCPT ); Thu, 11 Mar 2021 02:08:31 -0500 IronPort-SDR: AIUCUI5Cbx5Q/Eb3AJ9XXuKci01B3zVECMGO1+r0i/G6omgAJPyvGxpXcdaBtRBnkQ2X1xGEV5 1QbmhTge348Q== X-IronPort-AV: E=McAfee;i="6000,8403,9919"; a="186246026" X-IronPort-AV: E=Sophos;i="5.81,239,1610438400"; d="scan'208";a="186246026" Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by fmsmga104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 10 Mar 2021 23:08:31 -0800 IronPort-SDR: +irwVmx/1UPu8w8/dHK3jOdnnlgM+aK9e5o/drIRIaP8n+HR0V6tKl8JVkWgv37zBn5NTqgGbl qUtB32gH9zLQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.81,239,1610438400"; d="scan'208";a="509937842" Received: from kbl-ppc.sh.intel.com ([10.239.159.163]) by fmsmga001.fm.intel.com with ESMTP; 10 Mar 2021 23:08:29 -0800 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 v2 05/27] perf pmu: Save detected hybrid pmus to a global pmu list Date: Thu, 11 Mar 2021 15:07:20 +0800 Message-Id: <20210311070742.9318-6-yao.jin@linux.intel.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20210311070742.9318-1-yao.jin@linux.intel.com> References: <20210311070742.9318-1-yao.jin@linux.intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org We identify the cpu_core pmu and cpu_atom pmu by explicitly checking following files: For cpu_core, checks: "/sys/bus/event_source/devices/cpu_core/cpus" For cpu_atom, checks: "/sys/bus/event_source/devices/cpu_atom/cpus" If the 'cpus' file exists, the pmu exists. But in order not to hardcode the "cpu_core" and "cpu_atom", and make the code in a generic way. So if the path "/sys/bus/event_source/devices/cpu_xxx/cpus" exists, the hybrid pmu exists. All the detected hybrid pmus are linked to a global list 'perf_pmu__hybrid_pmus' and then next we just need to iterate the list to get all hybrid pmu by using perf_pmu__for_each_hybrid_pmu. Signed-off-by: Jin Yao --- tools/perf/util/Build | 1 + tools/perf/util/pmu-hybrid.c | 35 +++++++++++++++++++++++++++++++++++ tools/perf/util/pmu-hybrid.h | 18 ++++++++++++++++++ tools/perf/util/pmu.c | 9 ++++++++- tools/perf/util/pmu.h | 4 ++++ 5 files changed, 66 insertions(+), 1 deletion(-) create mode 100644 tools/perf/util/pmu-hybrid.c create mode 100644 tools/perf/util/pmu-hybrid.h diff --git a/tools/perf/util/Build b/tools/perf/util/Build index e3e12f9d4733..37a8a63c7195 100644 --- a/tools/perf/util/Build +++ b/tools/perf/util/Build @@ -69,6 +69,7 @@ perf-y += parse-events-bison.o perf-y += pmu.o perf-y += pmu-flex.o perf-y += pmu-bison.o +perf-y += pmu-hybrid.o perf-y += trace-event-read.o perf-y += trace-event-info.o perf-y += trace-event-scripting.o diff --git a/tools/perf/util/pmu-hybrid.c b/tools/perf/util/pmu-hybrid.c new file mode 100644 index 000000000000..7316bf46e54b --- /dev/null +++ b/tools/perf/util/pmu-hybrid.c @@ -0,0 +1,35 @@ +// SPDX-License-Identifier: GPL-2.0 +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include "fncache.h" +#include "pmu-hybrid.h" + +LIST_HEAD(perf_pmu__hybrid_pmus); + +bool perf_pmu__hybrid_mounted(const char *name) +{ + char path[PATH_MAX]; + const char *sysfs; + + if (strncmp(name, "cpu_", 4)) + return false; + + sysfs = sysfs__mountpoint(); + if (!sysfs) + return false; + + snprintf(path, PATH_MAX, CPUS_TEMPLATE_CPU, sysfs, name); + return file_available(path); +} diff --git a/tools/perf/util/pmu-hybrid.h b/tools/perf/util/pmu-hybrid.h new file mode 100644 index 000000000000..35bed3714438 --- /dev/null +++ b/tools/perf/util/pmu-hybrid.h @@ -0,0 +1,18 @@ +/* SPDX-License-Identifier: GPL-2.0 */ +#ifndef __PMU_HYBRID_H +#define __PMU_HYBRID_H + +#include +#include +#include +#include +#include "pmu.h" + +extern struct list_head perf_pmu__hybrid_pmus; + +#define perf_pmu__for_each_hybrid_pmu(pmu) \ + list_for_each_entry(pmu, &perf_pmu__hybrid_pmus, hybrid_list) + +bool perf_pmu__hybrid_mounted(const char *name); + +#endif /* __PMU_HYBRID_H */ diff --git a/tools/perf/util/pmu.c b/tools/perf/util/pmu.c index 45d8db1af8d2..08280a3e45a8 100644 --- a/tools/perf/util/pmu.c +++ b/tools/perf/util/pmu.c @@ -25,6 +25,7 @@ #include "string2.h" #include "strbuf.h" #include "fncache.h" +#include "pmu-hybrid.h" struct perf_pmu perf_pmu__fake; @@ -613,7 +614,6 @@ static struct perf_cpu_map *__pmu_cpumask(const char *path) */ #define SYS_TEMPLATE_ID "./bus/event_source/devices/%s/identifier" #define CPUS_TEMPLATE_UNCORE "%s/bus/event_source/devices/%s/cpumask" -#define CPUS_TEMPLATE_CPU "%s/bus/event_source/devices/%s/cpus" static struct perf_cpu_map *pmu_cpumask(const char *name) { @@ -645,6 +645,9 @@ static bool pmu_is_uncore(const char *name) char path[PATH_MAX]; const char *sysfs; + if (perf_pmu__hybrid_mounted(name)) + return false; + sysfs = sysfs__mountpoint(); snprintf(path, PATH_MAX, CPUS_TEMPLATE_UNCORE, sysfs, name); return file_available(path); @@ -946,6 +949,7 @@ static struct perf_pmu *pmu_lookup(const char *name) pmu->is_uncore = pmu_is_uncore(name); if (pmu->is_uncore) pmu->id = pmu_id(name); + pmu->is_hybrid = perf_pmu__hybrid_mounted(name); pmu->max_precise = pmu_max_precise(name); pmu_add_cpu_aliases(&aliases, pmu); pmu_add_sys_aliases(&aliases, pmu); @@ -957,6 +961,9 @@ static struct perf_pmu *pmu_lookup(const char *name) list_splice(&aliases, &pmu->aliases); list_add_tail(&pmu->list, &pmus); + if (pmu->is_hybrid) + list_add_tail(&pmu->hybrid_list, &perf_pmu__hybrid_pmus); + pmu->default_config = perf_pmu__get_default_config(pmu); return pmu; diff --git a/tools/perf/util/pmu.h b/tools/perf/util/pmu.h index 0e724d5b84c6..3b9b4def6032 100644 --- a/tools/perf/util/pmu.h +++ b/tools/perf/util/pmu.h @@ -5,6 +5,7 @@ #include #include #include +#include #include #include "parse-events.h" #include "pmu-events/pmu-events.h" @@ -19,6 +20,7 @@ enum { #define PERF_PMU_FORMAT_BITS 64 #define EVENT_SOURCE_DEVICE_PATH "/bus/event_source/devices/" +#define CPUS_TEMPLATE_CPU "%s/bus/event_source/devices/%s/cpus" struct perf_event_attr; @@ -34,6 +36,7 @@ struct perf_pmu { __u32 type; bool selectable; bool is_uncore; + bool is_hybrid; bool auxtrace; int max_precise; struct perf_event_attr *default_config; @@ -42,6 +45,7 @@ struct perf_pmu { struct list_head aliases; /* HEAD struct perf_pmu_alias -> list */ struct list_head caps; /* HEAD struct perf_pmu_caps -> list */ struct list_head list; /* ELEM */ + struct list_head hybrid_list; }; extern struct perf_pmu perf_pmu__fake; -- 2.17.1