From: Qiao Yang Date: Fri, 5 Sep 2008 12:08:09 +0000 (+0200) Subject: Fix a memleak X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=be6f12273f171a3eb1967d2299064e57d737f6a4;p=thirdparty%2Fsamba.git Fix a memleak request.extra_data is not freed if there is no extra_data in response or when there is some error happens in processing. This patch will free the buffer right after processing a request before sending back a response. --- diff --git a/source/winbindd/winbindd.c b/source/winbindd/winbindd.c index f75af64f8f7..44b5415726a 100644 --- a/source/winbindd/winbindd.c +++ b/source/winbindd/winbindd.c @@ -549,7 +549,6 @@ static void response_extra_sent(void *private_data, bool success) return; } - SAFE_FREE(state->request.extra_data.data); SAFE_FREE(state->response.extra_data.data); setup_async_read(&state->fd_event, &state->request, sizeof(uint32), @@ -581,6 +580,8 @@ static void response_main_sent(void *private_data, bool success) static void request_finished(struct winbindd_cli_state *state) { + /* Make sure request.extra_data is freed when finish processing a request */ + SAFE_FREE(state->request.extra_data.data); setup_async_write(&state->fd_event, &state->response, sizeof(state->response), response_main_sent, state); }