diff options
| author | Maxime Ripard <maxime@cerno.tech> | 2020-02-17 10:34:34 +0100 | 
|---|---|---|
| committer | Maxime Ripard <maxime@cerno.tech> | 2020-02-17 10:34:34 +0100 | 
| commit | 28f2aff1caa4997f58ca31179cad1b4a84a62827 (patch) | |
| tree | 69fb4b0a752f3660ce022a4313f8c7b276bbcceb /tools/perf/util/sort.c | |
| parent | 3e8a3844fefbaad911c596f02dd48c39188ffa81 (diff) | |
| parent | 11a48a5a18c63fd7621bb050228cebf13566e4d8 (diff) | |
Merge v5.6-rc2 into drm-misc-next
Lyude needs some patches in 5.6-rc2 and we didn't bring drm-misc-next
forward yet, so it looks like a good occasion.
Signed-off-by: Maxime Ripard <maxime@cerno.tech>
Diffstat (limited to 'tools/perf/util/sort.c')
| -rw-r--r-- | tools/perf/util/sort.c | 19 | 
1 files changed, 12 insertions, 7 deletions
| diff --git a/tools/perf/util/sort.c b/tools/perf/util/sort.c index 345b5ccc90f6..ab0cfd790ad0 100644 --- a/tools/perf/util/sort.c +++ b/tools/perf/util/sort.c @@ -324,8 +324,7 @@ static int _hist_entry__sym_snprintf(struct map_symbol *ms,  	return ret;  } -static int hist_entry__sym_snprintf(struct hist_entry *he, char *bf, -				    size_t size, unsigned int width) +int hist_entry__sym_snprintf(struct hist_entry *he, char *bf, size_t size, unsigned int width)  {  	return _hist_entry__sym_snprintf(&he->ms, he->ip,  					 he->level, bf, size, width); @@ -2681,12 +2680,12 @@ static int setup_sort_list(struct perf_hpp_list *list, char *str,  			ret = sort_dimension__add(list, tok, evlist, level);  			if (ret == -EINVAL) {  				if (!cacheline_size() && !strncasecmp(tok, "dcacheline", strlen(tok))) -					pr_err("The \"dcacheline\" --sort key needs to know the cacheline size and it couldn't be determined on this system"); +					ui__error("The \"dcacheline\" --sort key needs to know the cacheline size and it couldn't be determined on this system");  				else -					pr_err("Invalid --sort key: `%s'", tok); +					ui__error("Invalid --sort key: `%s'", tok);  				break;  			} else if (ret == -ESRCH) { -				pr_err("Unknown --sort key: `%s'", tok); +				ui__error("Unknown --sort key: `%s'", tok);  				break;  			}  		} @@ -2743,7 +2742,7 @@ static int setup_sort_order(struct evlist *evlist)  		return 0;  	if (sort_order[1] == '\0') { -		pr_err("Invalid --sort key: `+'"); +		ui__error("Invalid --sort key: `+'");  		return -EINVAL;  	} @@ -2959,6 +2958,9 @@ int output_field_add(struct perf_hpp_list *list, char *tok)  		if (strncasecmp(tok, sd->name, strlen(tok)))  			continue; +		if (sort__mode != SORT_MODE__MEMORY) +			return -EINVAL; +  		return __sort_dimension__add_output(list, sd);  	} @@ -2968,6 +2970,9 @@ int output_field_add(struct perf_hpp_list *list, char *tok)  		if (strncasecmp(tok, sd->name, strlen(tok)))  			continue; +		if (sort__mode != SORT_MODE__BRANCH) +			return -EINVAL; +  		return __sort_dimension__add_output(list, sd);  	} @@ -3034,7 +3039,7 @@ static int __setup_output_field(void)  		strp++;  	if (!strlen(strp)) { -		pr_err("Invalid --fields key: `+'"); +		ui__error("Invalid --fields key: `+'");  		goto out;  	} | 
