aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf
diff options
context:
space:
mode:
Diffstat (limited to 'tools/perf')
-rw-r--r--tools/perf/builtin-report.c15
-rw-r--r--tools/perf/util/callchain.c7
-rw-r--r--tools/perf/util/callchain.h3
3 files changed, 11 insertions, 14 deletions
diff --git a/tools/perf/builtin-report.c b/tools/perf/builtin-report.c
index 196473b51257..1cae87713792 100644
--- a/tools/perf/builtin-report.c
+++ b/tools/perf/builtin-report.c
@@ -123,19 +123,6 @@ static int perf_session__add_hist_entry(struct perf_session *self,
123 return 0; 123 return 0;
124} 124}
125 125
126static int validate_chain(struct ip_callchain *chain, event_t *event)
127{
128 unsigned int chain_size;
129
130 chain_size = event->header.size;
131 chain_size -= (unsigned long)&event->ip.__more_data - (unsigned long)event;
132
133 if (chain->nr*sizeof(u64) > chain_size)
134 return -1;
135
136 return 0;
137}
138
139static int add_event_total(struct perf_session *session, 126static int add_event_total(struct perf_session *session,
140 struct sample_data *data, 127 struct sample_data *data,
141 struct perf_event_attr *attr) 128 struct perf_event_attr *attr)
@@ -171,7 +158,7 @@ static int process_sample_event(event_t *event, struct perf_session *session)
171 158
172 dump_printf("... chain: nr:%Lu\n", data.callchain->nr); 159 dump_printf("... chain: nr:%Lu\n", data.callchain->nr);
173 160
174 if (validate_chain(data.callchain, event) < 0) { 161 if (!ip_callchain__valid(data.callchain, event)) {
175 pr_debug("call-chain problem with event, " 162 pr_debug("call-chain problem with event, "
176 "skipping it.\n"); 163 "skipping it.\n");
177 return 0; 164 return 0;
diff --git a/tools/perf/util/callchain.c b/tools/perf/util/callchain.c
index db628af6d20d..ac148613afe8 100644
--- a/tools/perf/util/callchain.c
+++ b/tools/perf/util/callchain.c
@@ -17,6 +17,13 @@
17 17
18#include "callchain.h" 18#include "callchain.h"
19 19
20bool ip_callchain__valid(struct ip_callchain *chain, event_t *event)
21{
22 unsigned int chain_size = event->header.size;
23 chain_size -= (unsigned long)&event->ip.__more_data - (unsigned long)event;
24 return chain->nr * sizeof(u64) <= chain_size;
25}
26
20#define chain_for_each_child(child, parent) \ 27#define chain_for_each_child(child, parent) \
21 list_for_each_entry(child, &parent->children, brothers) 28 list_for_each_entry(child, &parent->children, brothers)
22 29
diff --git a/tools/perf/util/callchain.h b/tools/perf/util/callchain.h
index 8a7e8bbd0fda..0f4da093cbd8 100644
--- a/tools/perf/util/callchain.h
+++ b/tools/perf/util/callchain.h
@@ -4,6 +4,7 @@
4#include "../perf.h" 4#include "../perf.h"
5#include <linux/list.h> 5#include <linux/list.h>
6#include <linux/rbtree.h> 6#include <linux/rbtree.h>
7#include "event.h"
7#include "util.h" 8#include "util.h"
8#include "symbol.h" 9#include "symbol.h"
9 10
@@ -58,4 +59,6 @@ static inline u64 cumul_hits(struct callchain_node *node)
58int register_callchain_param(struct callchain_param *param); 59int register_callchain_param(struct callchain_param *param);
59int append_chain(struct callchain_node *root, struct ip_callchain *chain, 60int append_chain(struct callchain_node *root, struct ip_callchain *chain,
60 struct map_symbol *syms); 61 struct map_symbol *syms);
62
63bool ip_callchain__valid(struct ip_callchain *chain, event_t *event);
61#endif /* __PERF_CALLCHAIN_H */ 64#endif /* __PERF_CALLCHAIN_H */