diff options
| author | Dave Kleikamp <shaggy@linux.vnet.ibm.com> | 2009-02-02 14:40:55 -0500 |
|---|---|---|
| committer | Dave Kleikamp <shaggy@linux.vnet.ibm.com> | 2009-02-02 14:40:55 -0500 |
| commit | 8db0c5d5ef3ab99fe9e5151872b75f45c4282e3c (patch) | |
| tree | da9759151e00221c58cdd9f4de893c0b08753670 /kernel/trace/ring_buffer.c | |
| parent | 1ad53a98c927a9b5b1b57288ac0edec562fbcf8d (diff) | |
| parent | 45c82b5a770be66845687a7d027c8b52946d59af (diff) | |
Merge branch 'master' of /home/shaggy/git/linus-clean/
Diffstat (limited to 'kernel/trace/ring_buffer.c')
| -rw-r--r-- | kernel/trace/ring_buffer.c | 23 |
1 files changed, 16 insertions, 7 deletions
diff --git a/kernel/trace/ring_buffer.c b/kernel/trace/ring_buffer.c index a9d9760dc7b6..bd38c5cfd8ad 100644 --- a/kernel/trace/ring_buffer.c +++ b/kernel/trace/ring_buffer.c | |||
| @@ -168,7 +168,13 @@ rb_event_length(struct ring_buffer_event *event) | |||
| 168 | */ | 168 | */ |
| 169 | unsigned ring_buffer_event_length(struct ring_buffer_event *event) | 169 | unsigned ring_buffer_event_length(struct ring_buffer_event *event) |
| 170 | { | 170 | { |
| 171 | return rb_event_length(event); | 171 | unsigned length = rb_event_length(event); |
| 172 | if (event->type != RINGBUF_TYPE_DATA) | ||
| 173 | return length; | ||
| 174 | length -= RB_EVNT_HDR_SIZE; | ||
| 175 | if (length > RB_MAX_SMALL_DATA + sizeof(event->array[0])) | ||
| 176 | length -= sizeof(event->array[0]); | ||
| 177 | return length; | ||
| 172 | } | 178 | } |
| 173 | EXPORT_SYMBOL_GPL(ring_buffer_event_length); | 179 | EXPORT_SYMBOL_GPL(ring_buffer_event_length); |
| 174 | 180 | ||
| @@ -240,7 +246,7 @@ static inline int test_time_stamp(u64 delta) | |||
| 240 | return 0; | 246 | return 0; |
| 241 | } | 247 | } |
| 242 | 248 | ||
| 243 | #define BUF_PAGE_SIZE (PAGE_SIZE - sizeof(struct buffer_data_page)) | 249 | #define BUF_PAGE_SIZE (PAGE_SIZE - offsetof(struct buffer_data_page, data)) |
| 244 | 250 | ||
| 245 | /* | 251 | /* |
| 246 | * head_page == tail_page && head == tail then buffer is empty. | 252 | * head_page == tail_page && head == tail then buffer is empty. |
| @@ -1019,12 +1025,8 @@ __rb_reserve_next(struct ring_buffer_per_cpu *cpu_buffer, | |||
| 1019 | } | 1025 | } |
| 1020 | 1026 | ||
| 1021 | if (next_page == head_page) { | 1027 | if (next_page == head_page) { |
| 1022 | if (!(buffer->flags & RB_FL_OVERWRITE)) { | 1028 | if (!(buffer->flags & RB_FL_OVERWRITE)) |
| 1023 | /* reset write */ | ||
| 1024 | if (tail <= BUF_PAGE_SIZE) | ||
| 1025 | local_set(&tail_page->write, tail); | ||
| 1026 | goto out_unlock; | 1029 | goto out_unlock; |
| 1027 | } | ||
| 1028 | 1030 | ||
| 1029 | /* tail_page has not moved yet? */ | 1031 | /* tail_page has not moved yet? */ |
| 1030 | if (tail_page == cpu_buffer->tail_page) { | 1032 | if (tail_page == cpu_buffer->tail_page) { |
| @@ -1099,6 +1101,10 @@ __rb_reserve_next(struct ring_buffer_per_cpu *cpu_buffer, | |||
| 1099 | return event; | 1101 | return event; |
| 1100 | 1102 | ||
| 1101 | out_unlock: | 1103 | out_unlock: |
| 1104 | /* reset write */ | ||
| 1105 | if (tail <= BUF_PAGE_SIZE) | ||
| 1106 | local_set(&tail_page->write, tail); | ||
| 1107 | |||
| 1102 | __raw_spin_unlock(&cpu_buffer->lock); | 1108 | __raw_spin_unlock(&cpu_buffer->lock); |
| 1103 | local_irq_restore(flags); | 1109 | local_irq_restore(flags); |
| 1104 | return NULL; | 1110 | return NULL; |
| @@ -2168,6 +2174,9 @@ rb_reset_cpu(struct ring_buffer_per_cpu *cpu_buffer) | |||
| 2168 | 2174 | ||
| 2169 | cpu_buffer->overrun = 0; | 2175 | cpu_buffer->overrun = 0; |
| 2170 | cpu_buffer->entries = 0; | 2176 | cpu_buffer->entries = 0; |
| 2177 | |||
| 2178 | cpu_buffer->write_stamp = 0; | ||
| 2179 | cpu_buffer->read_stamp = 0; | ||
| 2171 | } | 2180 | } |
| 2172 | 2181 | ||
| 2173 | /** | 2182 | /** |
