From: yuangongji Date: Sat, 29 Feb 2020 09:47:47 +0000 (+0800) Subject: increase segment refcnt only if evbuffer_add_file_segment() succeeds X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=114b3836755f1e526e658b248464465136bd87b8;p=libevent increase segment refcnt only if evbuffer_add_file_segment() succeeds --- diff --git a/buffer.c b/buffer.c index 51c56d79..bcb246f6 100644 --- a/buffer.c +++ b/buffer.c @@ -3226,7 +3226,6 @@ evbuffer_add_file_segment(struct evbuffer *buf, } } } - ++seg->refcnt; EVLOCK_UNLOCK(seg->lock, 0); if (buf->freeze_end) @@ -3290,6 +3289,9 @@ evbuffer_add_file_segment(struct evbuffer *buf, chain->off = length; } + EVLOCK_LOCK(seg->lock, 0); + ++seg->refcnt; + EVLOCK_UNLOCK(seg->lock, 0); extra->segment = seg; buf->n_add_for_cb += length; evbuffer_chain_insert(buf, chain); @@ -3316,7 +3318,7 @@ evbuffer_add_file(struct evbuffer *buf, int fd, ev_off_t offset, ev_off_t length if (!seg) return -1; r = evbuffer_add_file_segment(buf, seg, 0, length); - if (r == -1) + if (r == 0) evbuffer_file_segment_free(seg); return r; }