summaryrefslogtreecommitdiffstats
path: root/runtime/relayfs/relay.c
diff options
context:
space:
mode:
authortrz <trz>2005-06-22 18:57:39 +0000
committertrz <trz>2005-06-22 18:57:39 +0000
commitc32a1f6186a9fa45d2aa45241be04428a006db11 (patch)
tree68388ad0461292dcde56b0ce033a256bf3bf4e3b /runtime/relayfs/relay.c
parent44705a5756d7b47c02566e0fbc2df3ed106d9aee (diff)
downloadsystemtap-steved-c32a1f6186a9fa45d2aa45241be04428a006db11.tar.gz
systemtap-steved-c32a1f6186a9fa45d2aa45241be04428a006db11.tar.xz
systemtap-steved-c32a1f6186a9fa45d2aa45241be04428a006db11.zip
updated relayfs with latest patches
Diffstat (limited to 'runtime/relayfs/relay.c')
-rw-r--r--runtime/relayfs/relay.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/runtime/relayfs/relay.c b/runtime/relayfs/relay.c
index 5998db80..e35429ff 100644
--- a/runtime/relayfs/relay.c
+++ b/runtime/relayfs/relay.c
@@ -155,6 +155,10 @@ static inline void __relay_reset(struct rchan_buf *buf, int init)
if (init) {
init_waitqueue_head(&buf->read_wait);
kref_init(&buf->kref);
+ INIT_WORK(&buf->wake_readers, NULL, NULL);
+ } else {
+ cancel_delayed_work(&buf->wake_readers);
+ flush_scheduled_work();
}
atomic_set(&buf->subbufs_produced, 0);
@@ -171,8 +175,6 @@ static inline void __relay_reset(struct rchan_buf *buf, int init)
buf->offset = buf->chan->cb->subbuf_start(buf, buf->data, 0, NULL);
buf->commit[0] = buf->offset;
-
- INIT_WORK(&buf->wake_readers, NULL, NULL);
}
/**
@@ -238,6 +240,8 @@ static inline void relay_close_buf(struct rchan_buf *buf)
{
buf->finalized = 1;
buf->chan->cb = &default_channel_callbacks;
+ cancel_delayed_work(&buf->wake_readers);
+ flush_scheduled_work();
kref_put(&buf->kref, relay_remove_buf);
}