diff options
Diffstat (limited to 'kernel/trace')
-rw-r--r-- | kernel/trace/ring_buffer.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/kernel/trace/ring_buffer.c b/kernel/trace/ring_buffer.c index 7102d7a2fadb..22878b0d370c 100644 --- a/kernel/trace/ring_buffer.c +++ b/kernel/trace/ring_buffer.c | |||
@@ -426,6 +426,8 @@ struct ring_buffer { | |||
426 | atomic_t record_disabled; | 426 | atomic_t record_disabled; |
427 | cpumask_var_t cpumask; | 427 | cpumask_var_t cpumask; |
428 | 428 | ||
429 | struct lock_class_key *reader_lock_key; | ||
430 | |||
429 | struct mutex mutex; | 431 | struct mutex mutex; |
430 | 432 | ||
431 | struct ring_buffer_per_cpu **buffers; | 433 | struct ring_buffer_per_cpu **buffers; |
@@ -565,6 +567,7 @@ rb_allocate_cpu_buffer(struct ring_buffer *buffer, int cpu) | |||
565 | cpu_buffer->cpu = cpu; | 567 | cpu_buffer->cpu = cpu; |
566 | cpu_buffer->buffer = buffer; | 568 | cpu_buffer->buffer = buffer; |
567 | spin_lock_init(&cpu_buffer->reader_lock); | 569 | spin_lock_init(&cpu_buffer->reader_lock); |
570 | lockdep_set_class(&cpu_buffer->reader_lock, buffer->reader_lock_key); | ||
568 | cpu_buffer->lock = (raw_spinlock_t)__RAW_SPIN_LOCK_UNLOCKED; | 571 | cpu_buffer->lock = (raw_spinlock_t)__RAW_SPIN_LOCK_UNLOCKED; |
569 | INIT_LIST_HEAD(&cpu_buffer->pages); | 572 | INIT_LIST_HEAD(&cpu_buffer->pages); |
570 | 573 | ||
@@ -635,7 +638,8 @@ static int rb_cpu_notify(struct notifier_block *self, | |||
635 | * when the buffer wraps. If this flag is not set, the buffer will | 638 | * when the buffer wraps. If this flag is not set, the buffer will |
636 | * drop data when the tail hits the head. | 639 | * drop data when the tail hits the head. |
637 | */ | 640 | */ |
638 | struct ring_buffer *ring_buffer_alloc(unsigned long size, unsigned flags) | 641 | struct ring_buffer *__ring_buffer_alloc(unsigned long size, unsigned flags, |
642 | struct lock_class_key *key) | ||
639 | { | 643 | { |
640 | struct ring_buffer *buffer; | 644 | struct ring_buffer *buffer; |
641 | int bsize; | 645 | int bsize; |
@@ -658,6 +662,7 @@ struct ring_buffer *ring_buffer_alloc(unsigned long size, unsigned flags) | |||
658 | buffer->pages = DIV_ROUND_UP(size, BUF_PAGE_SIZE); | 662 | buffer->pages = DIV_ROUND_UP(size, BUF_PAGE_SIZE); |
659 | buffer->flags = flags; | 663 | buffer->flags = flags; |
660 | buffer->clock = trace_clock_local; | 664 | buffer->clock = trace_clock_local; |
665 | buffer->reader_lock_key = key; | ||
661 | 666 | ||
662 | /* need at least two pages */ | 667 | /* need at least two pages */ |
663 | if (buffer->pages == 1) | 668 | if (buffer->pages == 1) |
@@ -715,7 +720,7 @@ struct ring_buffer *ring_buffer_alloc(unsigned long size, unsigned flags) | |||
715 | kfree(buffer); | 720 | kfree(buffer); |
716 | return NULL; | 721 | return NULL; |
717 | } | 722 | } |
718 | EXPORT_SYMBOL_GPL(ring_buffer_alloc); | 723 | EXPORT_SYMBOL_GPL(__ring_buffer_alloc); |
719 | 724 | ||
720 | /** | 725 | /** |
721 | * ring_buffer_free - free a ring buffer. | 726 | * ring_buffer_free - free a ring buffer. |