aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--kernel/trace/ring_buffer.c14
1 files changed, 9 insertions, 5 deletions
diff --git a/kernel/trace/ring_buffer.c b/kernel/trace/ring_buffer.c
index fe40f6c3507c..493cba46abc9 100644
--- a/kernel/trace/ring_buffer.c
+++ b/kernel/trace/ring_buffer.c
@@ -367,6 +367,9 @@ static inline int test_time_stamp(u64 delta)
367 367
368#define BUF_PAGE_SIZE (PAGE_SIZE - BUF_PAGE_HDR_SIZE) 368#define BUF_PAGE_SIZE (PAGE_SIZE - BUF_PAGE_HDR_SIZE)
369 369
370/* Max payload is BUF_PAGE_SIZE - header (8bytes) */
371#define BUF_MAX_DATA_SIZE (BUF_PAGE_SIZE - (sizeof(u32) * 2))
372
370int ring_buffer_print_page_header(struct trace_seq *s) 373int ring_buffer_print_page_header(struct trace_seq *s)
371{ 374{
372 struct buffer_data_page field; 375 struct buffer_data_page field;
@@ -1396,6 +1399,7 @@ rb_reserve_next_event(struct ring_buffer_per_cpu *cpu_buffer,
1396 int commit = 0; 1399 int commit = 0;
1397 int nr_loops = 0; 1400 int nr_loops = 0;
1398 1401
1402 length = rb_calculate_event_length(length);
1399 again: 1403 again:
1400 /* 1404 /*
1401 * We allow for interrupts to reenter here and do a trace. 1405 * We allow for interrupts to reenter here and do a trace.
@@ -1552,8 +1556,7 @@ ring_buffer_lock_reserve(struct ring_buffer *buffer, unsigned long length)
1552 if (atomic_read(&cpu_buffer->record_disabled)) 1556 if (atomic_read(&cpu_buffer->record_disabled))
1553 goto out; 1557 goto out;
1554 1558
1555 length = rb_calculate_event_length(length); 1559 if (length > BUF_MAX_DATA_SIZE)
1556 if (length > BUF_PAGE_SIZE)
1557 goto out; 1560 goto out;
1558 1561
1559 event = rb_reserve_next_event(cpu_buffer, length); 1562 event = rb_reserve_next_event(cpu_buffer, length);
@@ -1758,7 +1761,6 @@ int ring_buffer_write(struct ring_buffer *buffer,
1758{ 1761{
1759 struct ring_buffer_per_cpu *cpu_buffer; 1762 struct ring_buffer_per_cpu *cpu_buffer;
1760 struct ring_buffer_event *event; 1763 struct ring_buffer_event *event;
1761 unsigned long event_length;
1762 void *body; 1764 void *body;
1763 int ret = -EBUSY; 1765 int ret = -EBUSY;
1764 int cpu, resched; 1766 int cpu, resched;
@@ -1781,8 +1783,10 @@ int ring_buffer_write(struct ring_buffer *buffer,
1781 if (atomic_read(&cpu_buffer->record_disabled)) 1783 if (atomic_read(&cpu_buffer->record_disabled))
1782 goto out; 1784 goto out;
1783 1785
1784 event_length = rb_calculate_event_length(length); 1786 if (length > BUF_MAX_DATA_SIZE)
1785 event = rb_reserve_next_event(cpu_buffer, event_length); 1787 goto out;
1788
1789 event = rb_reserve_next_event(cpu_buffer, length);
1786 if (!event) 1790 if (!event)
1787 goto out; 1791 goto out;
1788 1792