Commit 339bc418 authored by Alexander Shishkin's avatar Alexander Shishkin Committed by Ingo Molnar

perf/ring_buffer: Fix AUX record suppression

The following commit:

  1627314f ("perf: Suppress AUX/OVERWRITE records")

has an unintended side-effect of also suppressing all AUX records with no flags
and non-zero size, so all the regular records in the full trace mode.
This breaks some use cases for people.

Fix this by restoring "regular" AUX records.
Reported-by: default avatarBen Gainey <Ben.Gainey@arm.com>
Tested-by: default avatarBen Gainey <Ben.Gainey@arm.com>
Signed-off-by: default avatarAlexander Shishkin <alexander.shishkin@linux.intel.com>
Signed-off-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
Cc: <stable@vger.kernel.org>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Vince Weaver <vincent.weaver@maine.edu>
Fixes: 1627314f ("perf: Suppress AUX/OVERWRITE records")
Link: https://lkml.kernel.org/r/20190329091338.29999-1-alexander.shishkin@linux.intel.comSigned-off-by: default avatarIngo Molnar <mingo@kernel.org>
parent 52a44f83
...@@ -455,7 +455,6 @@ void perf_aux_output_end(struct perf_output_handle *handle, unsigned long size) ...@@ -455,7 +455,6 @@ void perf_aux_output_end(struct perf_output_handle *handle, unsigned long size)
rb->aux_head += size; rb->aux_head += size;
} }
if (size || handle->aux_flags) {
/* /*
* Only send RECORD_AUX if we have something useful to communicate * Only send RECORD_AUX if we have something useful to communicate
* *
...@@ -468,11 +467,9 @@ void perf_aux_output_end(struct perf_output_handle *handle, unsigned long size) ...@@ -468,11 +467,9 @@ void perf_aux_output_end(struct perf_output_handle *handle, unsigned long size)
* offset. So, from now on we don't output AUX records that * offset. So, from now on we don't output AUX records that
* have *only* OVERWRITE flag set. * have *only* OVERWRITE flag set.
*/ */
if (size || (handle->aux_flags & ~(u64)PERF_AUX_FLAG_OVERWRITE))
if (handle->aux_flags & ~(u64)PERF_AUX_FLAG_OVERWRITE)
perf_event_aux_event(handle->event, aux_head, size, perf_event_aux_event(handle->event, aux_head, size,
handle->aux_flags); handle->aux_flags);
}
rb->user_page->aux_head = rb->aux_head; rb->user_page->aux_head = rb->aux_head;
if (rb_need_aux_wakeup(rb)) if (rb_need_aux_wakeup(rb))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment