diff options
author | Steven Rostedt <srostedt@redhat.com> | 2009-03-11 22:00:13 -0400 |
---|---|---|
committer | Steven Rostedt <srostedt@redhat.com> | 2009-03-11 22:15:27 -0400 |
commit | 554f786e284a6ce859d51f62240d615603944c8e (patch) | |
tree | d3710f97dac93861b3ff1f389276e643798f9b2e /kernel/trace/trace.c | |
parent | 9aba60fe6eb20453de53a572143bef22fa929fba (diff) | |
download | kernel_samsung_smdk4412-554f786e284a6ce859d51f62240d615603944c8e.zip kernel_samsung_smdk4412-554f786e284a6ce859d51f62240d615603944c8e.tar.gz kernel_samsung_smdk4412-554f786e284a6ce859d51f62240d615603944c8e.tar.bz2 |
ring-buffer: only allocate buffers for online cpus
Impact: save on memory
Currently, a ring buffer was allocated for each "possible_cpus". On
some systems, this is the same as NR_CPUS. Thus, if a system defined
NR_CPUS = 64 but it only had 1 CPU, we could have possibly 63 useless
ring buffers taking up space. With a default buffer of 3 megs, this
could be quite drastic.
This patch changes the ring buffer code to only allocate ring buffers
for online CPUs. If a CPU goes off line, we do not free the buffer.
This is because the user may still have trace data in that buffer
that they would like to look at.
Perhaps in the future we could add code to delete a ring buffer if
the CPU is offline and the ring buffer becomes empty.
Signed-off-by: Steven Rostedt <srostedt@redhat.com>
Diffstat (limited to 'kernel/trace/trace.c')
-rw-r--r-- | kernel/trace/trace.c | 6 |
1 files changed, 0 insertions, 6 deletions
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index e60f4be..14c98f6 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c @@ -1805,17 +1805,11 @@ __tracing_open(struct inode *inode, struct file *file) iter->buffer_iter[cpu] = ring_buffer_read_start(iter->tr->buffer, cpu); - - if (!iter->buffer_iter[cpu]) - goto fail_buffer; } } else { cpu = iter->cpu_file; iter->buffer_iter[cpu] = ring_buffer_read_start(iter->tr->buffer, cpu); - - if (!iter->buffer_iter[cpu]) - goto fail; } /* TODO stop tracer */ |