diff options
| author | Ingo Molnar <mingo@kernel.org> | 2016-04-14 15:30:59 +0200 | 
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2016-04-14 15:30:59 +0200 | 
| commit | 0b22cd276cec21107d9d69453fa58abba73e71df (patch) | |
| tree | 12aeecb0452bd85432b8c15f48fb1e7957bbc498 /tools/perf/builtin-config.c | |
| parent | c5ab6ad7f627f031e2bbde575c7e6e27ea36da55 (diff) | |
| parent | 860b8d4b3f893c97f905b978ecf62f48816dc5de (diff) | |
| download | talos-op-linux-0b22cd276cec21107d9d69453fa58abba73e71df.tar.gz talos-op-linux-0b22cd276cec21107d9d69453fa58abba73e71df.zip | |
Merge tag 'perf-core-for-mingo-20160414' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux into perf/core
Pull perf/core improvements from Arnaldo Carvalho de Melo:
User visible changes:
- Introduce 'perf record --timestamp-filename', to add a timestamp
  at the end of the 'perf data' file. Will get added value when
  the patch to make 'perf.data' file snapshots gets merged (Wang Nan)
- Fix display of variables present in both --config and --user in
  'perf list' (Taeung Song)
Build fixes:
- Add seccomp and getradom beautifier related defines to fix
  the build in older systems where those definitions are not
  available (Arnaldo Carvalho de Melo)
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'tools/perf/builtin-config.c')
| -rw-r--r-- | tools/perf/builtin-config.c | 39 | 
1 files changed, 32 insertions, 7 deletions
| diff --git a/tools/perf/builtin-config.c b/tools/perf/builtin-config.c index c42448ed5dfe..fe1b77fa21f9 100644 --- a/tools/perf/builtin-config.c +++ b/tools/perf/builtin-config.c @@ -12,6 +12,7 @@  #include <subcmd/parse-options.h>  #include "util/util.h"  #include "util/debug.h" +#include "util/config.h"  static bool use_system_config, use_user_config; @@ -32,13 +33,28 @@ static struct option config_options[] = {  	OPT_END()  }; -static int show_config(const char *key, const char *value, -		       void *cb __maybe_unused) +static int show_config(struct perf_config_set *set)  { -	if (value) -		printf("%s=%s\n", key, value); -	else -		printf("%s\n", key); +	struct perf_config_section *section; +	struct perf_config_item *item; +	struct list_head *sections; + +	if (set == NULL) +		return -1; + +	sections = &set->sections; +	if (list_empty(sections)) +		return -1; + +	list_for_each_entry(section, sections, node) { +		list_for_each_entry(item, §ion->items, node) { +			char *value = item->value; + +			if (value) +				printf("%s.%s=%s\n", section->name, +				       item->name, value); +		} +	}  	return 0;  } @@ -46,6 +62,7 @@ static int show_config(const char *key, const char *value,  int cmd_config(int argc, const char **argv, const char *prefix __maybe_unused)  {  	int ret = 0; +	struct perf_config_set *set;  	char *user_config = mkpath("%s/.perfconfig", getenv("HOME"));  	argc = parse_options(argc, argv, config_options, config_usage, @@ -63,13 +80,19 @@ int cmd_config(int argc, const char **argv, const char *prefix __maybe_unused)  	else if (use_user_config)  		config_exclusive_filename = user_config; +	set = perf_config_set__new(); +	if (!set) { +		ret = -1; +		goto out_err; +	} +  	switch (actions) {  	case ACTION_LIST:  		if (argc) {  			pr_err("Error: takes no arguments\n");  			parse_options_usage(config_usage, config_options, "l", 1);  		} else { -			ret = perf_config(show_config, NULL); +			ret = show_config(set);  			if (ret < 0) {  				const char * config_filename = config_exclusive_filename;  				if (!config_exclusive_filename) @@ -83,5 +106,7 @@ int cmd_config(int argc, const char **argv, const char *prefix __maybe_unused)  		usage_with_options(config_usage, config_options);  	} +	perf_config_set__delete(set); +out_err:  	return ret;  } | 

