aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSteven Rostedt (Red Hat) <srostedt@redhat.com>2013-03-05 14:50:23 -0500
committerSteven Rostedt <rostedt@goodmis.org>2013-03-15 00:35:47 -0400
commit0b85ffc293044393623059eda9904a7d5b644e36 (patch)
treee74d33f01afe541d82f02ba727c421ea71ed470a
parentf1affcaaa861f27752a769f889bf1486ebd301fe (diff)
tracing: Add config option to allow snapshot to swap per cpu
When the preempt or irq latency tracers are enabled, they require the ring buffer to be able to swap the per cpu sub buffers between two main buffers. This adds a slight overhead to tracing as the trace recording needs to perform some checks to synchronize between recording and swaps that might be happening on other CPUs. The config RING_BUFFER_ALLOW_SWAP is set when a user of the ring buffer needs the "swap cpu" feature, otherwise the extra checks are not implemented and removed from the tracing overhead. The snapshot feature will swap per CPU if the RING_BUFFER_ALLOW_SWAP config is set. But that only gets set by things like OPROFILE and the irqs and preempt latency tracers. This config is added to let the user decide to include this feature with the snapshot agnostic from whether or not another user of the ring buffer sets this config. Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
-rw-r--r--kernel/trace/Kconfig23
1 files changed, 23 insertions, 0 deletions
diff --git a/kernel/trace/Kconfig b/kernel/trace/Kconfig
index 590a27fc212f..f78eab251897 100644
--- a/kernel/trace/Kconfig
+++ b/kernel/trace/Kconfig
@@ -192,6 +192,7 @@ config IRQSOFF_TRACER
192 select TRACER_MAX_TRACE 192 select TRACER_MAX_TRACE
193 select RING_BUFFER_ALLOW_SWAP 193 select RING_BUFFER_ALLOW_SWAP
194 select TRACER_SNAPSHOT 194 select TRACER_SNAPSHOT
195 select TRACER_SNAPSHOT_PER_CPU_SWAP
195 help 196 help
196 This option measures the time spent in irqs-off critical 197 This option measures the time spent in irqs-off critical
197 sections, with microsecond accuracy. 198 sections, with microsecond accuracy.
@@ -215,6 +216,7 @@ config PREEMPT_TRACER
215 select TRACER_MAX_TRACE 216 select TRACER_MAX_TRACE
216 select RING_BUFFER_ALLOW_SWAP 217 select RING_BUFFER_ALLOW_SWAP
217 select TRACER_SNAPSHOT 218 select TRACER_SNAPSHOT
219 select TRACER_SNAPSHOT_PER_CPU_SWAP
218 help 220 help
219 This option measures the time spent in preemption-off critical 221 This option measures the time spent in preemption-off critical
220 sections, with microsecond accuracy. 222 sections, with microsecond accuracy.
@@ -266,6 +268,27 @@ config TRACER_SNAPSHOT
266 echo 1 > /sys/kernel/debug/tracing/snapshot 268 echo 1 > /sys/kernel/debug/tracing/snapshot
267 cat snapshot 269 cat snapshot
268 270
271config TRACER_SNAPSHOT_PER_CPU_SWAP
272 bool "Allow snapshot to swap per CPU"
273 depends on TRACER_SNAPSHOT
274 select RING_BUFFER_ALLOW_SWAP
275 help
276 Allow doing a snapshot of a single CPU buffer instead of a
277 full swap (all buffers). If this is set, then the following is
278 allowed:
279
280 echo 1 > /sys/kernel/debug/tracing/per_cpu/cpu2/snapshot
281
282 After which, only the tracing buffer for CPU 2 was swapped with
283 the main tracing buffer, and the other CPU buffers remain the same.
284
285 When this is enabled, this adds a little more overhead to the
286 trace recording, as it needs to add some checks to synchronize
287 recording with swaps. But this does not affect the performance
288 of the overall system. This is enabled by default when the preempt
289 or irq latency tracers are enabled, as those need to swap as well
290 and already adds the overhead (plus a lot more).
291
269config TRACE_BRANCH_PROFILING 292config TRACE_BRANCH_PROFILING
270 bool 293 bool
271 select GENERIC_TRACER 294 select GENERIC_TRACER