From: Nick Mathewson Date: Wed, 6 Sep 2017 13:30:50 +0000 (-0400) Subject: Add a zero-copy buffer move implementation. X-Git-Tag: tor-0.3.3.1-alpha~268^2~3 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=095e15f8ac8216cd945b85c159b461d8cd0697a3;p=thirdparty%2Ftor.git Add a zero-copy buffer move implementation. --- diff --git a/src/common/buffers.c b/src/common/buffers.c index d7c4e4d8c3..d1725cf1a1 100644 --- a/src/common/buffers.c +++ b/src/common/buffers.c @@ -838,6 +838,28 @@ buf_move_to_buf(buf_t *buf_out, buf_t *buf_in, size_t *buf_flushlen) return (int)cp; } +/** Moves all data from buf_in to buf_out, without copying. + */ +void +buf_move_all(buf_t *buf_out, buf_t *buf_in) +{ + tor_assert(buf_out); + if (!buf_in) + return; + + if (buf_out->head == NULL) { + buf_out->head = buf_in->head; + buf_out->tail = buf_in->tail; + } else { + buf_out->tail->next = buf_in->head; + buf_out->tail = buf_in->tail; + } + + buf_out->datalen += buf_in->datalen; + buf_in->head = buf_in->tail = NULL; + buf_in->datalen = 0; +} + /** Internal structure: represents a position in a buffer. */ typedef struct buf_pos_t { const chunk_t *chunk; /**< Which chunk are we pointing to? */ diff --git a/src/common/buffers.h b/src/common/buffers.h index b05c5b13d4..56ba7c77ba 100644 --- a/src/common/buffers.h +++ b/src/common/buffers.h @@ -51,6 +51,7 @@ void buf_add_vprintf(buf_t *buf, const char *format, va_list args) int buf_add_compress(buf_t *buf, struct tor_compress_state_t *state, const char *data, size_t data_len, int done); int buf_move_to_buf(buf_t *buf_out, buf_t *buf_in, size_t *buf_flushlen); +void buf_move_all(buf_t *buf_out, buf_t *buf_in); void buf_peek(const buf_t *buf, char *string, size_t string_len); void buf_drain(buf_t *buf, size_t n); int buf_get_bytes(buf_t *buf, char *string, size_t string_len);