From: Ian Rogers <irogers@google.com> To: Peter Zijlstra <peterz@infradead.org>, Ingo Molnar <mingo@redhat.com>, Arnaldo Carvalho de Melo <acme@kernel.org>, Mark Rutland <mark.rutland@arm.com>, Alexander Shishkin <alexander.shishkin@linux.intel.com>, Jiri Olsa <jolsa@redhat.com>, Namhyung Kim <namhyung@kernel.org>, linux-kernel@vger.kernel.org, Andi Kleen <ak@linux.intel.com>, Jin Yao <yao.jin@linux.intel.com>, John Garry <john.garry@huawei.com>, Paul Clarke <pc@us.ibm.com>, kajoljain <kjain@linux.ibm.com> Cc: Stephane Eranian <eranian@google.com>, Sandeep Dasgupta <sdasgup@google.com>, linux-perf-users@vger.kernel.org, Ian Rogers <irogers@google.com> Subject: [RFC PATCH 09/12] perf topdown-paser: Add code generation API. Date: Tue, 10 Nov 2020 02:03:43 -0800 Message-ID: <20201110100346.2527031-10-irogers@google.com> (raw) In-Reply-To: <20201110100346.2527031-1-irogers@google.com> From: Sandeep Dasgupta <sdasgup@google.com> Add API that is called to generate code using all registered targets. Co-authored-by: Stephane Eranian <eranian@google.com> Signed-off-by: Ian Rogers <irogers@google.com> Signed-off-by: Sandeep Dasgupta <sdasgup@google.com> --- .../topdown-parser/code_gen_target.cpp | 51 ++++++++++++ .../topdown-parser/code_gen_target.h | 77 +++++++++++++++++++ 2 files changed, 128 insertions(+) create mode 100644 tools/perf/pmu-events/topdown-parser/code_gen_target.cpp create mode 100644 tools/perf/pmu-events/topdown-parser/code_gen_target.h diff --git a/tools/perf/pmu-events/topdown-parser/code_gen_target.cpp b/tools/perf/pmu-events/topdown-parser/code_gen_target.cpp new file mode 100644 index 000000000000..c6d7ce8eb661 --- /dev/null +++ b/tools/perf/pmu-events/topdown-parser/code_gen_target.cpp @@ -0,0 +1,51 @@ +/* + * Copyright 2020 Google LLC. + * SPDX-License-Identifier: GPL-2.0 + */ + +#include "code_gen_target.h" + +#include "configuration.h" + +namespace topdown_parser +{ +/** + * Dump event list. Used for testing of auto-generation. + */ +bool g_DumpEvents = false; + +namespace +{ +/** + * `kRegisteredTargets` enumerates all the target supported by the + * topdown generator tool. Each target is responsible for generating a + * "code", which essentially encodes the topdown metric expressions, in + * a particular language or format support. + */ +TargetInfo *kRegisteredTargets[] = { + &kTargetPerfJson /* target to generate JSon code */, +}; + +} // namespace + +void CodeGenTarget( + const std::unordered_map<std::string, MappedData> &dependence_dag) +{ + for (size_t i = 0; + i < sizeof(kRegisteredTargets) / sizeof(TargetInfo *); ++i) { + const std::string &target_name = kRegisteredTargets[i]->name; + + if (target_name == kConfigParams->target_) { + kRegisteredTargets[i]->codegen_entry_point( + dependence_dag); + if (kRegisteredTargets[i] + ->codegen_test_harness_entry_point) { + kRegisteredTargets[i] + ->codegen_test_harness_entry_point(); + } + break; + } + } +} + +} // namespace topdown_parser diff --git a/tools/perf/pmu-events/topdown-parser/code_gen_target.h b/tools/perf/pmu-events/topdown-parser/code_gen_target.h new file mode 100644 index 000000000000..ab3e2b48bebc --- /dev/null +++ b/tools/perf/pmu-events/topdown-parser/code_gen_target.h @@ -0,0 +1,77 @@ +/* SPDX-License-Identifier: GPL-2.0 */ + +// -------------------------------------------------- +// File: code_gen_target.h +// -------------------------------------------------- +// + +// The header provides the interface `CodeGenTarget` to generate code, encoding +// the topdown metric expressions, using the data `dependence_dag` read from +// the input csv file. The language or format of the generated code is the one +// supported by a specific project (e.g. perf or projects using perf ) to encode +// the topdown metric metric expressions. We define a `target` as a specific +// project and use that to guide generation of topdown code in a language +// supported by the project. + +#ifndef TOPDOWN_PARSER_CODE_GEN_TARGET_H_ +#define TOPDOWN_PARSER_CODE_GEN_TARGET_H_ + +#include <string> +#include <unordered_map> + +namespace topdown_parser +{ +class MappedData; + +/** + * Dump event list. Used for testing of auto-generation. + */ +extern bool g_DumpEvents; + +/** + * The structure `TargetInfo` is used to specify a target. + */ +struct TargetInfo { + /** + * Name of the target. This will be used to invoke code generation for a + * particular target. + */ + std::string name; + + /** + * Descriptive information of the target (Optional). + */ + std::string description; + + /** + * The entry point function for generating code. + */ + void (*codegen_entry_point)( + const std::unordered_map<std::string, MappedData> + &dependence_dag); + + /** + * Function to generate golden reference for testing the auto-generated + * code. + * (Optional) + */ + void (*codegen_test_harness_entry_point)(); +}; + +/** + * Target information for generating JSon code for perf encoding the topdown + * metric expressions. + */ +extern TargetInfo kTargetPerfJson; + +/** + * `CodeGenTarget` dispatches an appropriate callback, based on the + * configuration variable `kConfigParams->target_`, to generate "code" for a + * particular target. + */ +void CodeGenTarget( + const std::unordered_map<std::string, MappedData> &dependence_dag); + +} // namespace topdown_parser + +#endif // TOPDOWN_PARSER_CODE_GEN_TARGET_H_ -- 2.29.2.222.g5d2a92d10f8-goog
next prev parent reply index Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top 2020-11-10 10:03 [RFC PATCH 00/12] Topdown parser Ian Rogers 2020-11-10 10:03 ` [RFC PATCH 01/12] perf topdown-parser: Add a simple logging API Ian Rogers 2020-11-10 10:03 ` [RFC PATCH 02/12] perf topdown-parser: Add utility functions Ian Rogers 2020-11-10 10:03 ` [RFC PATCH 03/12] perf topdown-paser: Add a CSV file reader Ian Rogers 2020-11-10 10:03 ` [RFC PATCH 04/12] perf topdown-parser: Add a json " Ian Rogers 2020-11-10 10:03 ` [RFC PATCH 05/12] perf topdown-parser: Add a configuration Ian Rogers 2020-11-10 10:03 ` [RFC PATCH 06/12] perf topdown-parser: Interface for TMA_Metrics.csv Ian Rogers 2020-11-10 10:03 ` [RFC PATCH 07/12] perf topdown-parser: Metric expression parser Ian Rogers 2020-11-10 10:03 ` [RFC PATCH 08/12] perf topdown-parser: Add event interface Ian Rogers 2020-11-10 10:03 ` Ian Rogers [this message] 2020-11-10 10:03 ` [RFC PATCH 10/12] perf topdown-parser: Add json metric code generation Ian Rogers 2020-11-10 10:03 ` [RFC PATCH 11/12] perf topdown-parser: Main driver Ian Rogers 2020-11-10 10:03 ` [RFC PATCH 12/12] perf pmu-events: Topdown parser tool Ian Rogers 2020-11-11 21:46 ` [RFC PATCH 00/12] Topdown parser Andi Kleen [not found] ` <CAP-5=fXedJEZcYhxmPAzRVx5kdW2YA71Ks3BycqurAHydtXh8A@mail.gmail.com> 2020-11-12 3:10 ` Andi Kleen [not found] ` <CAP-5=fUDOLzfpuJNjk_D6KrAGMNXKXOFKfVi9O7qXRDdP_4Rpg@mail.gmail.com> 2020-11-12 6:35 ` Andi Kleen
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20201110100346.2527031-10-irogers@google.com \ --to=irogers@google.com \ --cc=acme@kernel.org \ --cc=ak@linux.intel.com \ --cc=alexander.shishkin@linux.intel.com \ --cc=eranian@google.com \ --cc=john.garry@huawei.com \ --cc=jolsa@redhat.com \ --cc=kjain@linux.ibm.com \ --cc=linux-kernel@vger.kernel.org \ --cc=linux-perf-users@vger.kernel.org \ --cc=mark.rutland@arm.com \ --cc=mingo@redhat.com \ --cc=namhyung@kernel.org \ --cc=pc@us.ibm.com \ --cc=peterz@infradead.org \ --cc=sdasgup@google.com \ --cc=yao.jin@linux.intel.com \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
Linux-perf-users Archive on lore.kernel.org Archives are clonable: git clone --mirror https://lore.kernel.org/linux-perf-users/0 linux-perf-users/git/0.git # If you have public-inbox 1.1+ installed, you may # initialize and index your mirror using the following commands: public-inbox-init -V2 linux-perf-users linux-perf-users/ https://lore.kernel.org/linux-perf-users \ linux-perf-users@vger.kernel.org public-inbox-index linux-perf-users Example config snippet for mirrors Newsgroup available over NNTP: nntp://nntp.lore.kernel.org/org.kernel.vger.linux-perf-users AGPL code for this site: git clone https://public-inbox.org/public-inbox.git