X-Git-Url: https://git.liburcu.org/?a=blobdiff_plain;f=libust%2Frelay.h;h=630c4eacc5ebd3e43995d93eb06920b7719a98dc;hb=9160b4e4541d3a6010e4e671ee5deb3ea89f4211;hp=7d582a8802e13c70cced7ea3e1bfbbe93e56c005;hpb=769d015768372ce7f68ff12bbc55aa339c3a6bcd;p=ust.git diff --git a/libust/relay.h b/libust/relay.h index 7d582a8..630c4ea 100644 --- a/libust/relay.h +++ b/libust/relay.h @@ -21,9 +21,11 @@ //ust// #include //ust// #include //ust// #include -#include "kref.h" +#include +#include //#include "list.h" #include "channels.h" +#include "buffer.h" /* Needs a _much_ better name... */ #define FIX_SIZE(x) ((((x) - 1) & PAGE_MASK) + PAGE_SIZE) @@ -290,13 +292,16 @@ static inline int ltt_relay_write(struct rchan_buf *buf, size_t offset, //ust// _ltt_relay_write(buf, offset, src, len, page, pagecpy); //ust// return len; - size_t cpy; - cpy = min_t(size_t, len, buf->buf_size - offset); - ltt_relay_do_copy(buf->buf_data + offset, src, cpy); + size_t buf_offset = BUFFER_OFFSET(offset, buf->chan); + + assert(buf_offset < buf->chan->subbuf_size*buf->chan->n_subbufs); + + cpy = min_t(size_t, len, buf->buf_size - buf_offset); + ltt_relay_do_copy(buf->buf_data + buf_offset, src, cpy); if (unlikely(len != cpy)) - _ltt_relay_write(buf, offset, src, len, cpy); + _ltt_relay_write(buf, buf_offset, src, len, cpy); return len; } @@ -366,4 +371,6 @@ int ltt_do_get_subbuf(struct rchan_buf *buf, struct ltt_channel_buf_struct *ltt_ int ltt_do_put_subbuf(struct rchan_buf *buf, struct ltt_channel_buf_struct *ltt_buf, u32 uconsumed_old); +void init_ustrelay_transport(void); + #endif /* _LINUX_LTT_RELAY_H */