diff options
author | Masami Hiramatsu <mhiramat@redhat.com> | 2010-04-14 18:39:42 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2010-04-14 16:41:21 -0400 |
commit | d3b63d7ae04879a817bac5c0bf09749f73629d32 (patch) | |
tree | 80501b4ed6110221160b9486dd24b480c3424f41 /tools/perf/util/probe-finder.c | |
parent | dd259c5db26ccda46409dbf6efc79d5a2b259e38 (diff) |
perf probe: Fix a bug that --line range can be overflow
Since line_finder.lno_s/e are signed int but line_range.start/end
are unsigned int, it is possible to be overflow when converting
line_range->start/end to line_finder->lno_s/e.
This changes line_range.start/end and line_list.line to signed int
and adds overflow checks when setting line_finder.lno_s/e.
LKML-Reference: <20100414223942.14630.72730.stgit@localhost6.localdomain6>
Signed-off-by: Masami Hiramatsu <mhiramat@redhat.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/probe-finder.c')
-rw-r--r-- | tools/perf/util/probe-finder.c | 19 |
1 files changed, 9 insertions, 10 deletions
diff --git a/tools/perf/util/probe-finder.c b/tools/perf/util/probe-finder.c index e443e69a4d2..b4c93659929 100644 --- a/tools/perf/util/probe-finder.c +++ b/tools/perf/util/probe-finder.c | |||
@@ -111,7 +111,7 @@ static int strtailcmp(const char *s1, const char *s2) | |||
111 | /* Line number list operations */ | 111 | /* Line number list operations */ |
112 | 112 | ||
113 | /* Add a line to line number list */ | 113 | /* Add a line to line number list */ |
114 | static int line_list__add_line(struct list_head *head, unsigned int line) | 114 | static int line_list__add_line(struct list_head *head, int line) |
115 | { | 115 | { |
116 | struct line_node *ln; | 116 | struct line_node *ln; |
117 | struct list_head *p; | 117 | struct list_head *p; |
@@ -138,7 +138,7 @@ found: | |||
138 | } | 138 | } |
139 | 139 | ||
140 | /* Check if the line in line number list */ | 140 | /* Check if the line in line number list */ |
141 | static int line_list__has_line(struct list_head *head, unsigned int line) | 141 | static int line_list__has_line(struct list_head *head, int line) |
142 | { | 142 | { |
143 | struct line_node *ln; | 143 | struct line_node *ln; |
144 | 144 | ||
@@ -1146,7 +1146,7 @@ static int find_line_range_by_line(Dwarf_Die *sp_die, struct line_finder *lf) | |||
1146 | if (lf->lr->path == NULL) | 1146 | if (lf->lr->path == NULL) |
1147 | return -ENOMEM; | 1147 | return -ENOMEM; |
1148 | } | 1148 | } |
1149 | line_list__add_line(&lf->lr->line_list, (unsigned int)lineno); | 1149 | line_list__add_line(&lf->lr->line_list, lineno); |
1150 | } | 1150 | } |
1151 | /* Update status */ | 1151 | /* Update status */ |
1152 | if (!list_empty(&lf->lr->line_list)) | 1152 | if (!list_empty(&lf->lr->line_list)) |
@@ -1179,10 +1179,12 @@ static int line_range_search_cb(Dwarf_Die *sp_die, void *data) | |||
1179 | dwarf_decl_line(sp_die, &lr->offset); | 1179 | dwarf_decl_line(sp_die, &lr->offset); |
1180 | pr_debug("fname: %s, lineno:%d\n", lf->fname, lr->offset); | 1180 | pr_debug("fname: %s, lineno:%d\n", lf->fname, lr->offset); |
1181 | lf->lno_s = lr->offset + lr->start; | 1181 | lf->lno_s = lr->offset + lr->start; |
1182 | if (!lr->end) | 1182 | if (lf->lno_s < 0) /* Overflow */ |
1183 | lf->lno_s = INT_MAX; | ||
1184 | lf->lno_e = lr->offset + lr->end; | ||
1185 | if (lf->lno_e < 0) /* Overflow */ | ||
1183 | lf->lno_e = INT_MAX; | 1186 | lf->lno_e = INT_MAX; |
1184 | else | 1187 | pr_debug("New line range: %d to %d\n", lf->lno_s, lf->lno_e); |
1185 | lf->lno_e = lr->offset + lr->end; | ||
1186 | lr->start = lf->lno_s; | 1188 | lr->start = lf->lno_s; |
1187 | lr->end = lf->lno_e; | 1189 | lr->end = lf->lno_e; |
1188 | if (dwarf_func_inline(sp_die)) { | 1190 | if (dwarf_func_inline(sp_die)) { |
@@ -1244,10 +1246,7 @@ int find_line_range(int fd, struct line_range *lr) | |||
1244 | ret = find_line_range_by_func(&lf); | 1246 | ret = find_line_range_by_func(&lf); |
1245 | else { | 1247 | else { |
1246 | lf.lno_s = lr->start; | 1248 | lf.lno_s = lr->start; |
1247 | if (!lr->end) | 1249 | lf.lno_e = lr->end; |
1248 | lf.lno_e = INT_MAX; | ||
1249 | else | ||
1250 | lf.lno_e = lr->end; | ||
1251 | ret = find_line_range_by_line(NULL, &lf); | 1250 | ret = find_line_range_by_line(NULL, &lf); |
1252 | } | 1251 | } |
1253 | } | 1252 | } |