Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2704084pxv; Sun, 27 Jun 2021 06:19:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyeLoVsx6hHaCigmy1ALzM+I/2eyaHTL1G9SYRy6PQO8UBnecJe2PIem9NOu8ZAvVr9n5Ys X-Received: by 2002:a05:6602:722:: with SMTP id g2mr16765944iox.118.1624799993805; Sun, 27 Jun 2021 06:19:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1624799993; cv=none; d=google.com; s=arc-20160816; b=V7qQ6TN/qy2HWv4uHtT0RGsGCtFPUn/Brc6LLEWNKrtBPPiTVHlIuu9tPvv/UrygGa xb6COGm+HflhLVe/RFEpWFoapPCm82jIjUoYWZbyj//GpLG1tZwOQTj7cdvYFI2GFLp9 ToF1jpwEbi7ulhh/OgXJe85fGybBp1xjV2kG5dzGywKE/lKQKpH7vN+1y+RXiiljSNK1 cTES8v1acHObgwNmwp95i/ETbFlk/eFgJyOWPTk/lBqUeqHltSsXR/UbhtovRnskuYlL 9yShkkQ72CwOXU8rFY781a5VIpJAxg06UUD76LmVEMMvRfe8kZyZ+gWx20IuGbPN6j2o 6V6g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:organization:references:in-reply-to:message-id :date:subject:cc:to:from; bh=tybK7E8rzb9Te9dpmzL//DLOqzqwjW6JKQ3Spa3srAw=; b=B61VC04X6jx8PowCUvtXV/Ryad/C7XWuhj5NGaZptnHWqFi2aaTzJKq/JhnO0nO7la mNEry1GEGLjtmsTvtooNOe7YT8B9vWD1n1BKO7tTJ9kmvujazv5nKXO4LsnKA29Asg3Y zwL8bj1KZmUJnyTakBs2fFERjbZj1hpyz6ZmwIQKrrz8aANtV9fyYUZWK7rJEXoNydhc BxZhVgvph/vey6OjqB1wNuQtIEgd9Ll9orop3tf4OiGSE3xSCTgODBfXnv1EHsT5EEID na++shZbjgeOkuFZswqs2M9UxjzHVAngSCStVG/XyxC3UqnfCSmzzuCaR5EzR1xA9SCe QZ6A== 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 x15si8670981ila.57.2021.06.27.06.19.41; Sun, 27 Jun 2021 06:19:53 -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 S231266AbhF0NU7 (ORCPT + 99 others); Sun, 27 Jun 2021 09:20:59 -0400 Received: from mga18.intel.com ([134.134.136.126]:60779 "EHLO mga18.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231182AbhF0NU4 (ORCPT ); Sun, 27 Jun 2021 09:20:56 -0400 X-IronPort-AV: E=McAfee;i="6200,9189,10027"; a="195137080" X-IronPort-AV: E=Sophos;i="5.83,302,1616482800"; d="scan'208";a="195137080" Received: from fmsmga006.fm.intel.com ([10.253.24.20]) by orsmga106.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 27 Jun 2021 06:18:31 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.83,302,1616482800"; d="scan'208";a="640589099" Received: from ahunter-desktop.fi.intel.com ([10.237.72.79]) by fmsmga006.fm.intel.com with ESMTP; 27 Jun 2021 06:18:27 -0700 From: Adrian Hunter To: Arnaldo Carvalho de Melo Cc: Jiri Olsa , Andi Kleen , Peter Zijlstra , Ingo Molnar , Mark Rutland , Namhyung Kim , Leo Yan , Kan Liang , linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH V2 09/10] perf dlfilter: Add attr() to perf_dlfilter_fns Date: Sun, 27 Jun 2021 16:18:17 +0300 Message-Id: <20210627131818.810-10-adrian.hunter@intel.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20210627131818.810-1-adrian.hunter@intel.com> References: <20210627131818.810-1-adrian.hunter@intel.com> Organization: Intel Finland Oy, Registered Address: PL 281, 00181 Helsinki, Business Identity Code: 0357606 - 4, Domiciled in Helsinki Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add a function, for use by dlfilters, to return the perf_event_attr structure. Signed-off-by: Adrian Hunter --- tools/perf/Documentation/perf-dlfilter.txt | 5 ++++- tools/perf/util/dlfilter.c | 11 +++++++++++ tools/perf/util/perf_dlfilter.h | 4 +++- 3 files changed, 18 insertions(+), 2 deletions(-) diff --git a/tools/perf/Documentation/perf-dlfilter.txt b/tools/perf/Documentation/perf-dlfilter.txt index df118ddcd7f4..6b1d9da16feb 100644 --- a/tools/perf/Documentation/perf-dlfilter.txt +++ b/tools/perf/Documentation/perf-dlfilter.txt @@ -126,7 +126,8 @@ struct perf_dlfilter_fns { __s32 (*resolve_address)(void *ctx, __u64 address, struct perf_dlfilter_al *al); const __u8 *(*insn)(void *ctx, __u32 *length); const char *(*srcline)(void *ctx, __u32 *line_number); - void *(*reserved[122])(void *); + struct perf_event_attr *(*attr)(void *ctx); + void *(*reserved[121])(void *); }; ---- @@ -143,6 +144,8 @@ before calling. Returns 0 on success, -1 otherwise. 'srcline' return source file name and line number. +'attr' returns perf_event_attr, refer . + The perf_dlfilter_al structure ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ diff --git a/tools/perf/util/dlfilter.c b/tools/perf/util/dlfilter.c index f4ce1a80bddc..e50d524906d6 100644 --- a/tools/perf/util/dlfilter.c +++ b/tools/perf/util/dlfilter.c @@ -235,6 +235,16 @@ static const char *dlfilter__srcline(void *ctx, __u32 *line_no) return srcfile; } +static struct perf_event_attr *dlfilter__attr(void *ctx) +{ + struct dlfilter *d = (struct dlfilter *)ctx; + + if (!d->ctx_valid) + return NULL; + + return &d->evsel->core.attr; +} + static const struct perf_dlfilter_fns perf_dlfilter_fns = { .resolve_ip = dlfilter__resolve_ip, .resolve_addr = dlfilter__resolve_addr, @@ -242,6 +252,7 @@ static const struct perf_dlfilter_fns perf_dlfilter_fns = { .resolve_address = dlfilter__resolve_address, .insn = dlfilter__insn, .srcline = dlfilter__srcline, + .attr = dlfilter__attr, }; static char *find_dlfilter(const char *file) diff --git a/tools/perf/util/perf_dlfilter.h b/tools/perf/util/perf_dlfilter.h index b989918056e2..f3fc92fcb3c0 100644 --- a/tools/perf/util/perf_dlfilter.h +++ b/tools/perf/util/perf_dlfilter.h @@ -101,8 +101,10 @@ struct perf_dlfilter_fns { const __u8 *(*insn)(void *ctx, __u32 *length); /* Return source file name and line number */ const char *(*srcline)(void *ctx, __u32 *line_number); + /* Return perf_event_attr, refer */ + struct perf_event_attr *(*attr)(void *ctx); /* Reserved */ - void *(*reserved[122])(void *); + void *(*reserved[121])(void *); }; /* -- 2.17.1