aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAdrian Hunter <adrian.hunter@intel.com>2016-09-23 10:38:41 -0400
committerArnaldo Carvalho de Melo <acme@redhat.com>2016-09-29 10:17:03 -0400
commit810c398bc09b2f2dfde52a7d2483a710612c5fb8 (patch)
treeebe44843d9da07195820d5e07911696d69f109f0
parentf9655200ecd2d6cc13900a727150177b94ca229e (diff)
perf intel-pt: Fix snapshot overlap detection decoder errors
Fix occasional decoder errors decoding trace data collected in snapshot mode. Snapshot mode can take successive snapshots of trace which might overlap. The decoder checks whether there is an overlap but only looks at the current and previous buffer. However buffers that do not contain synchronization (i.e. PSB) packets cannot be decoded or used for overlap checking. That means the decoder actually needs to check overlaps between the current buffer and the previous buffer that contained usable data. Make that change. Signed-off-by: Adrian Hunter <adrian.hunter@intel.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Masami Hiramatsu <mhiramat@kernel.org> Cc: Mathieu Poirier <mathieu.poirier@linaro.org> Cc: stable@vger.kernel.org # v4.3+ Link: http://lkml.kernel.org/r/1474641528-18776-10-git-send-email-adrian.hunter@intel.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
-rw-r--r--tools/perf/util/intel-pt.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/tools/perf/util/intel-pt.c b/tools/perf/util/intel-pt.c
index b9cc353cace2..b744ea812a2e 100644
--- a/tools/perf/util/intel-pt.c
+++ b/tools/perf/util/intel-pt.c
@@ -241,7 +241,7 @@ static int intel_pt_get_trace(struct intel_pt_buffer *b, void *data)
241 } 241 }
242 242
243 queue = &ptq->pt->queues.queue_array[ptq->queue_nr]; 243 queue = &ptq->pt->queues.queue_array[ptq->queue_nr];
244 244next:
245 buffer = auxtrace_buffer__next(queue, buffer); 245 buffer = auxtrace_buffer__next(queue, buffer);
246 if (!buffer) { 246 if (!buffer) {
247 if (old_buffer) 247 if (old_buffer)
@@ -264,9 +264,6 @@ static int intel_pt_get_trace(struct intel_pt_buffer *b, void *data)
264 intel_pt_do_fix_overlap(ptq->pt, old_buffer, buffer)) 264 intel_pt_do_fix_overlap(ptq->pt, old_buffer, buffer))
265 return -ENOMEM; 265 return -ENOMEM;
266 266
267 if (old_buffer)
268 auxtrace_buffer__drop_data(old_buffer);
269
270 if (buffer->use_data) { 267 if (buffer->use_data) {
271 b->len = buffer->use_size; 268 b->len = buffer->use_size;
272 b->buf = buffer->use_data; 269 b->buf = buffer->use_data;
@@ -276,6 +273,16 @@ static int intel_pt_get_trace(struct intel_pt_buffer *b, void *data)
276 } 273 }
277 b->ref_timestamp = buffer->reference; 274 b->ref_timestamp = buffer->reference;
278 275
276 /*
277 * If in snapshot mode and the buffer has no usable data, get next
278 * buffer and again check overlap against old_buffer.
279 */
280 if (ptq->pt->snapshot_mode && !b->len)
281 goto next;
282
283 if (old_buffer)
284 auxtrace_buffer__drop_data(old_buffer);
285
279 if (!old_buffer || ptq->pt->sampling_mode || (ptq->pt->snapshot_mode && 286 if (!old_buffer || ptq->pt->sampling_mode || (ptq->pt->snapshot_mode &&
280 !buffer->consecutive)) { 287 !buffer->consecutive)) {
281 b->consecutive = false; 288 b->consecutive = false;