diff options
| author | Ingo Molnar <mingo@elte.hu> | 2009-08-29 09:30:41 +0200 | 
|---|---|---|
| committer | Ingo Molnar <mingo@elte.hu> | 2009-08-29 09:31:47 +0200 | 
| commit | eebc57f73d42095b778e899f6aa90ad050c72655 (patch) | |
| tree | 2ba80c75e9284093e6d7606dbb1b6a4bb752a2a5 /kernel/trace/ring_buffer.c | |
| parent | d3a247bfb2c26f5b67367d58af7ad8c2efbbc6c1 (diff) | |
| parent | 2a4ab640d3c28c2952967e5f63ea495555bf2a5f (diff) | |
Merge branch 'for-ingo' of git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux-sfi-2.6 into x86/apic
Merge reason: the SFI (Simple Firmware Interface) feature in the ACPI
              tree needs this cleanup, pull it into the APIC branch as
	      well so that there's no interactions.
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/trace/ring_buffer.c')
| -rw-r--r-- | kernel/trace/ring_buffer.c | 15 | 
1 files changed, 7 insertions, 8 deletions
| diff --git a/kernel/trace/ring_buffer.c b/kernel/trace/ring_buffer.c index bf27bb7a63e2..a330513d96ce 100644 --- a/kernel/trace/ring_buffer.c +++ b/kernel/trace/ring_buffer.c @@ -735,6 +735,7 @@ ring_buffer_free(struct ring_buffer *buffer)  	put_online_cpus(); +	kfree(buffer->buffers);  	free_cpumask_var(buffer->cpumask);  	kfree(buffer); @@ -1785,7 +1786,7 @@ void ring_buffer_discard_commit(struct ring_buffer *buffer,  	 */  	RB_WARN_ON(buffer, !local_read(&cpu_buffer->committing)); -	if (!rb_try_to_discard(cpu_buffer, event)) +	if (rb_try_to_discard(cpu_buffer, event))  		goto out;  	/* @@ -2383,7 +2384,6 @@ rb_buffer_peek(struct ring_buffer *buffer, int cpu, u64 *ts)  		 * the box. Return the padding, and we will release  		 * the current locks, and try again.  		 */ -		rb_advance_reader(cpu_buffer);  		return event;  	case RINGBUF_TYPE_TIME_EXTEND: @@ -2486,7 +2486,7 @@ static inline int rb_ok_to_lock(void)  	 * buffer too. A one time deal is all you get from reading  	 * the ring buffer from an NMI.  	 */ -	if (likely(!in_nmi() && !oops_in_progress)) +	if (likely(!in_nmi()))  		return 1;  	tracing_off_permanent(); @@ -2519,6 +2519,8 @@ ring_buffer_peek(struct ring_buffer *buffer, int cpu, u64 *ts)  	if (dolock)  		spin_lock(&cpu_buffer->reader_lock);  	event = rb_buffer_peek(buffer, cpu, ts); +	if (event && event->type_len == RINGBUF_TYPE_PADDING) +		rb_advance_reader(cpu_buffer);  	if (dolock)  		spin_unlock(&cpu_buffer->reader_lock);  	local_irq_restore(flags); @@ -2590,12 +2592,9 @@ ring_buffer_consume(struct ring_buffer *buffer, int cpu, u64 *ts)  		spin_lock(&cpu_buffer->reader_lock);  	event = rb_buffer_peek(buffer, cpu, ts); -	if (!event) -		goto out_unlock; - -	rb_advance_reader(cpu_buffer); +	if (event) +		rb_advance_reader(cpu_buffer); - out_unlock:  	if (dolock)  		spin_unlock(&cpu_buffer->reader_lock);  	local_irq_restore(flags); | 
