aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/msgpack_rpc/channel.c
diff options
context:
space:
mode:
authorbfredl <bjorn.linse@gmail.com>2022-08-23 10:36:46 +0200
committerbfredl <bjorn.linse@gmail.com>2022-08-24 14:22:26 +0200
commitbcf5ee328e228d5a536b4de2069a79234f9f3e9e (patch)
treece25e8627bb00363deb6919561400fa1807ebf47 /src/nvim/msgpack_rpc/channel.c
parentc0d60526541a3cf977ae623471ae4a347b492af1 (diff)
downloadrneovim-bcf5ee328e228d5a536b4de2069a79234f9f3e9e.tar.gz
rneovim-bcf5ee328e228d5a536b4de2069a79234f9f3e9e.tar.bz2
rneovim-bcf5ee328e228d5a536b4de2069a79234f9f3e9e.zip
refactor(arena): use a shared block freelist
This is both simpler in client code and more effective (always reuse block hottest in cache)
Diffstat (limited to 'src/nvim/msgpack_rpc/channel.c')
-rw-r--r--src/nvim/msgpack_rpc/channel.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/src/nvim/msgpack_rpc/channel.c b/src/nvim/msgpack_rpc/channel.c
index 66fd79c692..f00c62f766 100644
--- a/src/nvim/msgpack_rpc/channel.c
+++ b/src/nvim/msgpack_rpc/channel.c
@@ -158,7 +158,7 @@ Object rpc_send_call(uint64_t id, const char *method_name, Array args, ArenaMem
}
// frame.result was allocated in an arena
- arena_mem_free(frame.result_mem, &rpc->unpacker->reuse_blk);
+ arena_mem_free(frame.result_mem);
frame.result_mem = NULL;
}
@@ -244,7 +244,7 @@ static void parse_msgpack(Channel *channel)
ui_client_event_raw_line(p->grid_line_event);
} else if (p->ui_handler.fn != NULL && p->result.type == kObjectTypeArray) {
p->ui_handler.fn(p->result.data.array);
- arena_mem_free(arena_finish(&p->arena), &p->reuse_blk);
+ arena_mem_free(arena_finish(&p->arena));
}
} else if (p->type == kMessageTypeResponse) {
ChannelCallFrame *frame = kv_last(channel->rpc.call_stack);
@@ -295,7 +295,7 @@ static void handle_request(Channel *channel, Unpacker *p, Array args)
if (!p->handler.fn) {
send_error(channel, p->type, p->request_id, p->unpack_error.msg);
api_clear_error(&p->unpack_error);
- arena_mem_free(arena_finish(&p->arena), &p->reuse_blk);
+ arena_mem_free(arena_finish(&p->arena));
return;
}
@@ -364,7 +364,7 @@ static void request_event(void **argv)
free_ret:
// e->args (and possibly result) are allocated in an arena
- arena_mem_free(arena_finish(&e->used_mem), &channel->rpc.unpacker->reuse_blk);
+ arena_mem_free(arena_finish(&e->used_mem));
channel_decref(channel);
xfree(e);
api_clear_error(&error);