diff options
-rw-r--r-- | include/linux/ring_buffer.h | 14 | ||||
-rw-r--r-- | kernel/trace/ring_buffer.c | 9 |
2 files changed, 20 insertions, 3 deletions
diff --git a/include/linux/ring_buffer.h b/include/linux/ring_buffer.h index f1345828c7c5..8670f1575fe1 100644 --- a/include/linux/ring_buffer.h +++ b/include/linux/ring_buffer.h | |||
@@ -105,7 +105,19 @@ void ring_buffer_discard_commit(struct ring_buffer *buffer, | |||
105 | * size is in bytes for each per CPU buffer. | 105 | * size is in bytes for each per CPU buffer. |
106 | */ | 106 | */ |
107 | struct ring_buffer * | 107 | struct ring_buffer * |
108 | ring_buffer_alloc(unsigned long size, unsigned flags); | 108 | __ring_buffer_alloc(unsigned long size, unsigned flags, struct lock_class_key *key); |
109 | |||
110 | /* | ||
111 | * Because the ring buffer is generic, if other users of the ring buffer get | ||
112 | * traced by ftrace, it can produce lockdep warnings. We need to keep each | ||
113 | * ring buffer's lock class separate. | ||
114 | */ | ||
115 | #define ring_buffer_alloc(size, flags) \ | ||
116 | ({ \ | ||
117 | static struct lock_class_key __key; \ | ||
118 | __ring_buffer_alloc((size), (flags), &__key); \ | ||
119 | }) | ||
120 | |||
109 | void ring_buffer_free(struct ring_buffer *buffer); | 121 | void ring_buffer_free(struct ring_buffer *buffer); |
110 | 122 | ||
111 | int ring_buffer_resize(struct ring_buffer *buffer, unsigned long size); | 123 | int ring_buffer_resize(struct ring_buffer *buffer, unsigned long size); |
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. |