From 25772145172d28c67fc193440d6ce33747d32203 Mon Sep 17 00:00:00 2001 From: Vic Lee Date: Mon, 1 Feb 2010 23:26:10 +0800 Subject: The ssh_message object needs to be freed after processing in channel_accept(). Signed-off-by: Vic Lee Signed-off-by: Andreas Schneider --- libssh/channels.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'libssh') diff --git a/libssh/channels.c b/libssh/channels.c index 2731843c..c10369ee 100644 --- a/libssh/channels.c +++ b/libssh/channels.c @@ -1458,6 +1458,7 @@ static ssh_channel channel_accept(ssh_session session, int channeltype, }; #endif ssh_message msg = NULL; + ssh_channel channel = NULL; struct ssh_iterator *iterator; int t; @@ -1472,7 +1473,9 @@ static ssh_channel channel_accept(ssh_session session, int channeltype, if (ssh_message_type(msg) == SSH_REQUEST_CHANNEL_OPEN && ssh_message_subtype(msg) == channeltype) { ssh_list_remove(session->ssh_message_list, iterator); - return ssh_message_channel_request_open_reply_accept(msg); + channel = ssh_message_channel_request_open_reply_accept(msg); + ssh_message_free(msg); + return channel; } iterator = iterator->next; } -- cgit v1.2.3