Skip to content

Commit

Permalink
pty: fix use-after-free issue when closing a connection (#997)
Browse files Browse the repository at this point in the history
  • Loading branch information
jzw-weride authored Oct 11, 2022
1 parent 3c8dbbb commit 4ca49a1
Showing 1 changed file with 6 additions and 3 deletions.
9 changes: 6 additions & 3 deletions src/pty.c
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,10 @@ static void alloc_cb(uv_handle_t *unused, size_t suggested_size, uv_buf_t *buf)

static void close_cb(uv_handle_t *handle) { free(handle); }

static void async_free_cb(uv_handle_t *handle) {
free((uv_async_t *) handle -> data);
}

pty_buf_t *pty_buf_init(char *base, size_t len) {
pty_buf_t *buf = xmalloc(sizeof(pty_buf_t));
buf->base = xmalloc(len);
Expand Down Expand Up @@ -114,7 +118,6 @@ void process_free(pty_process *process) {
char **p = process->envp;
for (; *p; p++) free(*p);
free(process->envp);
free(process);
}

void pty_pause(pty_process *process) {
Expand Down Expand Up @@ -307,7 +310,7 @@ static void async_cb(uv_async_t *async) {
process->exit_signal = 1;
process->exit_cb(process);

uv_close((uv_handle_t *) async, NULL);
uv_close((uv_handle_t *) async, async_free_cb);
process_free(process);
}

Expand Down Expand Up @@ -420,7 +423,7 @@ static void async_cb(uv_async_t *async) {
pty_process *process = (pty_process *) async->data;
process->exit_cb(process);

uv_close((uv_handle_t *) async, NULL);
uv_close((uv_handle_t *) async, async_free_cb);
process_free(process);
}

Expand Down

0 comments on commit 4ca49a1

Please sign in to comment.