Pass state necessary for core_wide into the expression parser. Add system_wide and user_requested_cpu_list to perf_stat_config to make it available at display time. evlist isn't used as the evlist__create_maps, that computes user_requested_cpus, needs the list of events which is generated by the metric. Signed-off-by: Ian Rogers <irogers@google.com> Cc: Ahmad Yasin <ahmad.yasin@intel.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Andi Kleen <ak@linux.intel.com> Cc: Caleb Biggers <caleb.biggers@intel.com> Cc: Florian Fischer <florian.fischer@muhq.space> Cc: Ingo Molnar <mingo@redhat.com> Cc: James Clark <james.clark@arm.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: John Garry <john.garry@huawei.com> Cc: Kan Liang <kan.liang@linux.intel.com> Cc: Kshipra Bopardikar <kshipra.bopardikar@intel.com> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Miaoqian Lin <linmq006@gmail.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Perry Taylor <perry.taylor@intel.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Stephane Eranian <eranian@google.com> Cc: Thomas Richter <tmricht@linux.ibm.com> Cc: Xing Zhengjun <zhengjun.xing@linux.intel.com> Link: https://lore.kernel.org/r/20220831174926.579643-7-irogers@google.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
		
			
				
	
	
		
			63 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0 */
 | 
						|
#ifndef PARSE_CTX_H
 | 
						|
#define PARSE_CTX_H 1
 | 
						|
 | 
						|
#ifdef HAVE_LIBBPF_SUPPORT
 | 
						|
#include <bpf/hashmap.h>
 | 
						|
#else
 | 
						|
#include "util/hashmap.h"
 | 
						|
#endif
 | 
						|
 | 
						|
struct metric_ref;
 | 
						|
 | 
						|
struct expr_scanner_ctx {
 | 
						|
	char *user_requested_cpu_list;
 | 
						|
	int runtime;
 | 
						|
	bool system_wide;
 | 
						|
};
 | 
						|
 | 
						|
struct expr_parse_ctx {
 | 
						|
	struct hashmap	*ids;
 | 
						|
	struct expr_scanner_ctx sctx;
 | 
						|
};
 | 
						|
 | 
						|
struct expr_id_data;
 | 
						|
 | 
						|
struct hashmap *ids__new(void);
 | 
						|
void ids__free(struct hashmap *ids);
 | 
						|
int ids__insert(struct hashmap *ids, const char *id);
 | 
						|
/*
 | 
						|
 * Union two sets of ids (hashmaps) and construct a third, freeing ids1 and
 | 
						|
 * ids2.
 | 
						|
 */
 | 
						|
struct hashmap *ids__union(struct hashmap *ids1, struct hashmap *ids2);
 | 
						|
 | 
						|
struct expr_parse_ctx *expr__ctx_new(void);
 | 
						|
void expr__ctx_clear(struct expr_parse_ctx *ctx);
 | 
						|
void expr__ctx_free(struct expr_parse_ctx *ctx);
 | 
						|
 | 
						|
void expr__del_id(struct expr_parse_ctx *ctx, const char *id);
 | 
						|
int expr__add_id(struct expr_parse_ctx *ctx, const char *id);
 | 
						|
int expr__add_id_val(struct expr_parse_ctx *ctx, const char *id, double val);
 | 
						|
int expr__add_id_val_source_count(struct expr_parse_ctx *ctx, const char *id,
 | 
						|
				double val, int source_count);
 | 
						|
int expr__add_ref(struct expr_parse_ctx *ctx, struct metric_ref *ref);
 | 
						|
int expr__get_id(struct expr_parse_ctx *ctx, const char *id,
 | 
						|
		 struct expr_id_data **data);
 | 
						|
bool expr__subset_of_ids(struct expr_parse_ctx *haystack,
 | 
						|
			 struct expr_parse_ctx *needles);
 | 
						|
int expr__resolve_id(struct expr_parse_ctx *ctx, const char *id,
 | 
						|
		     struct expr_id_data **datap);
 | 
						|
 | 
						|
int expr__parse(double *final_val, struct expr_parse_ctx *ctx,
 | 
						|
		const char *expr);
 | 
						|
 | 
						|
int expr__find_ids(const char *expr, const char *one,
 | 
						|
		   struct expr_parse_ctx *ids);
 | 
						|
 | 
						|
double expr_id_data__value(const struct expr_id_data *data);
 | 
						|
double expr_id_data__source_count(const struct expr_id_data *data);
 | 
						|
double expr__get_literal(const char *literal, const struct expr_scanner_ctx *ctx);
 | 
						|
 | 
						|
#endif
 |