diff options
author | Ingo Molnar <mingo@elte.hu> | 2009-04-07 07:47:33 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-04-07 07:47:45 -0400 |
commit | 93776a8ec746cf9d32c36e5a5b23d28d8be28826 (patch) | |
tree | 6c472ae9f709246ee5268e1d71559d07839fb965 /kernel/relay.c | |
parent | 34886c8bc590f078d4c0b88f50d061326639198d (diff) | |
parent | d508afb437daee7cf07da085b635c44a4ebf9b38 (diff) |
Merge branch 'linus' into tracing/core
Merge reason: update to upstream tracing facilities
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/relay.c')
-rw-r--r-- | kernel/relay.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/kernel/relay.c b/kernel/relay.c index edc0ba6d8160..bc188549788f 100644 --- a/kernel/relay.c +++ b/kernel/relay.c | |||
@@ -748,7 +748,7 @@ size_t relay_switch_subbuf(struct rchan_buf *buf, size_t length) | |||
748 | * from the scheduler (trying to re-grab | 748 | * from the scheduler (trying to re-grab |
749 | * rq->lock), so defer it. | 749 | * rq->lock), so defer it. |
750 | */ | 750 | */ |
751 | __mod_timer(&buf->timer, jiffies + 1); | 751 | mod_timer(&buf->timer, jiffies + 1); |
752 | } | 752 | } |
753 | 753 | ||
754 | old = buf->data; | 754 | old = buf->data; |
@@ -795,13 +795,15 @@ void relay_subbufs_consumed(struct rchan *chan, | |||
795 | if (!chan) | 795 | if (!chan) |
796 | return; | 796 | return; |
797 | 797 | ||
798 | if (cpu >= NR_CPUS || !chan->buf[cpu]) | 798 | if (cpu >= NR_CPUS || !chan->buf[cpu] || |
799 | subbufs_consumed > chan->n_subbufs) | ||
799 | return; | 800 | return; |
800 | 801 | ||
801 | buf = chan->buf[cpu]; | 802 | buf = chan->buf[cpu]; |
802 | buf->subbufs_consumed += subbufs_consumed; | 803 | if (subbufs_consumed > buf->subbufs_produced - buf->subbufs_consumed) |
803 | if (buf->subbufs_consumed > buf->subbufs_produced) | ||
804 | buf->subbufs_consumed = buf->subbufs_produced; | 804 | buf->subbufs_consumed = buf->subbufs_produced; |
805 | else | ||
806 | buf->subbufs_consumed += subbufs_consumed; | ||
805 | } | 807 | } |
806 | EXPORT_SYMBOL_GPL(relay_subbufs_consumed); | 808 | EXPORT_SYMBOL_GPL(relay_subbufs_consumed); |
807 | 809 | ||