u64 read_stamp;
};
+/* buffer may be either ring_buffer or ring_buffer_per_cpu */
#define RB_WARN_ON(buffer, cond) \
do { \
if (unlikely(cond)) { \
} while (0)
#define RB_WARN_ON_RET(buffer, cond) \
+ do { \
+ if (unlikely(cond)) { \
+ atomic_inc(&buffer->record_disabled); \
+ WARN_ON(1); \
+ return; \
+ } \
+ } while (0)
+
+#define RB_WARN_ON_RET_INT(buffer, cond) \
do { \
if (unlikely(cond)) { \
atomic_inc(&buffer->record_disabled); \
} \
} while (0)
+#define RB_WARN_ON_RET_NULL(buffer, cond) \
+ do { \
+ if (unlikely(cond)) { \
+ atomic_inc(&buffer->record_disabled); \
+ WARN_ON(1); \
+ return NULL; \
+ } \
+ } while (0)
+
#define RB_WARN_ON_ONCE(buffer, cond) \
do { \
static int once; \
} \
} while (0)
+/* buffer must be ring_buffer not per_cpu */
+#define RB_WARN_ON_UNLOCK(buffer, cond) \
+ do { \
+ if (unlikely(cond)) { \
+ mutex_unlock(&buffer->mutex); \
+ atomic_inc(&buffer->record_disabled); \
+ WARN_ON(1); \
+ return -1; \
+ } \
+ } while (0)
+
/**
* check_pages - integrity check of buffer pages
* @cpu_buffer: CPU buffer with pages to test
struct list_head *head = &cpu_buffer->pages;
struct buffer_page *page, *tmp;
- RB_WARN_ON_RET(cpu_buffer, head->next->prev != head);
- RB_WARN_ON_RET(cpu_buffer, head->prev->next != head);
+ RB_WARN_ON_RET_INT(cpu_buffer, head->next->prev != head);
+ RB_WARN_ON_RET_INT(cpu_buffer, head->prev->next != head);
list_for_each_entry_safe(page, tmp, head, list) {
- RB_WARN_ON_RET(cpu_buffer,
+ RB_WARN_ON_RET_INT(cpu_buffer,
page->list.next->prev != &page->list);
- RB_WARN_ON_RET(cpu_buffer,
+ RB_WARN_ON_RET_INT(cpu_buffer,
page->list.prev->next != &page->list);
}
synchronize_sched();
for (i = 0; i < nr_pages; i++) {
- BUG_ON(list_empty(&cpu_buffer->pages));
+ RB_WARN_ON_RET(cpu_buffer, list_empty(&cpu_buffer->pages));
p = cpu_buffer->pages.next;
page = list_entry(p, struct buffer_page, list);
list_del_init(&page->list);
free_buffer_page(page);
}
- BUG_ON(list_empty(&cpu_buffer->pages));
+ RB_WARN_ON_RET(cpu_buffer, list_empty(&cpu_buffer->pages));
rb_reset_cpu(cpu_buffer);
synchronize_sched();
for (i = 0; i < nr_pages; i++) {
- BUG_ON(list_empty(pages));
+ RB_WARN_ON_RET(cpu_buffer, list_empty(pages));
p = pages->next;
page = list_entry(p, struct buffer_page, list);
list_del_init(&page->list);
if (size < buffer_size) {
/* easy case, just free pages */
- BUG_ON(nr_pages >= buffer->pages);
+ RB_WARN_ON_UNLOCK(buffer, nr_pages >= buffer->pages);
rm_pages = buffer->pages - nr_pages;
* add these pages to the cpu_buffers. Otherwise we just free
* them all and return -ENOMEM;
*/
- BUG_ON(nr_pages <= buffer->pages);
+ RB_WARN_ON_UNLOCK(buffer, nr_pages <= buffer->pages);
+
new_pages = nr_pages - buffer->pages;
for_each_buffer_cpu(buffer, cpu) {
rb_insert_pages(cpu_buffer, &pages, new_pages);
}
- BUG_ON(!list_empty(&pages));
+ RB_WARN_ON_UNLOCK(buffer, !list_empty(&pages));
out:
buffer->pages = nr_pages;
head += rb_event_length(event)) {
event = __rb_page_index(cpu_buffer->head_page, head);
- BUG_ON(rb_null_event(event));
+ RB_WARN_ON_RET(cpu_buffer, rb_null_event(event));
/* Only count data entries */
if (event->type != RINGBUF_TYPE_DATA)
continue;
/* We reserved something on the buffer */
- BUG_ON(write > BUF_PAGE_SIZE);
+ RB_WARN_ON_RET_NULL(cpu_buffer, write > BUF_PAGE_SIZE);
event = __rb_page_index(tail_page, tail);
rb_update_event(event, type, length);
reader = rb_get_reader_page(cpu_buffer);
/* This function should not be called when buffer is empty */
- BUG_ON(!reader);
+ RB_WARN_ON_RET(cpu_buffer, !reader);
event = rb_reader_event(cpu_buffer);
* Check if we are at the end of the buffer.
*/
if (iter->head >= rb_page_size(iter->head_page)) {
- BUG_ON(iter->head_page == cpu_buffer->commit_page);
+ RB_WARN_ON_RET(buffer,
+ iter->head_page == cpu_buffer->commit_page);
rb_inc_iter(iter);
return;
}
* This should not be called to advance the header if we are
* at the tail of the buffer.
*/
- BUG_ON((iter->head_page == cpu_buffer->commit_page) &&
- (iter->head + length > rb_commit_index(cpu_buffer)));
+ RB_WARN_ON_RET(cpu_buffer,
+ (iter->head_page == cpu_buffer->commit_page) &&
+ (iter->head + length > rb_commit_index(cpu_buffer)));
rb_update_iter_read_stamp(iter, event);