Commit 708353a1 authored by KIU Shueng Chuan's avatar KIU Shueng Chuan

advance refcnt only if it was used

parent c05a475b
......@@ -132,9 +132,14 @@ namespace zmq
bufsize = new_size;
}
zmq::atomic_counter_t* create_refcnt ()
zmq::atomic_counter_t* provide_refcnt ()
{
return msg_refcnt++;
return msg_refcnt;
}
void advance_refcnt ()
{
msg_refcnt++;
}
private:
......
......@@ -63,11 +63,12 @@ int zmq::raw_decoder_t::decode (const uint8_t *data_, size_t size_,
int rc = in_progress.init ((unsigned char*)data_, size_,
shared_message_memory_allocator::call_dec_ref,
allocator.buffer(),
allocator.create_refcnt() );
allocator.provide_refcnt() );
// if the buffer serves as memory for a zero-copy message, release it
// and allocate a new buffer in get_buffer for the next decode
if (in_progress.is_zcmsg()) {
allocator.advance_refcnt();
allocator.release();
}
......
......@@ -129,11 +129,12 @@ int zmq::v2_decoder_t::size_ready(uint64_t msg_size, unsigned char const* read_p
// if the message will be a large message, pass a valid refcnt memory location as well
rc = in_progress.init( (unsigned char*)read_pos, msg_size,
shared_message_memory_allocator::call_dec_ref, buffer(),
create_refcnt() );
provide_refcnt() );
// For small messages, data has been copied and refcount does not have to be increased
if (in_progress.is_zcmsg())
{
advance_refcnt();
inc_ref();
}
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment