Blame SOURCES/autofs-5.1.0-fix-mem-leak-in-create_client.patch

4d476f
autofs-5.1.0 - fix memory leak in create_client()
4d476f
4d476f
From: Ian Kent <raven@themaw.net>
4d476f
4d476f
In create_client(), if the target host is unreachable the function
4d476f
exists without freeing the addrinfo data returned from getaddrinfo(3).
4d476f
---
4d476f
 CHANGELOG      |    1 +
4d476f
 lib/rpc_subs.c |    4 +++-
4d476f
 2 files changed, 4 insertions(+), 1 deletion(-)
4d476f
4d476f
--- autofs-5.0.7.orig/CHANGELOG
4d476f
+++ autofs-5.0.7/CHANGELOG
4d476f
@@ -148,6 +148,7 @@
4d476f
 - add mutex call return check in defaults.c.
4d476f
 - force disable browse mode for amd format maps.
4d476f
 - fix hosts map options check in lookup_amd_instance().
4d476f
+- fix memory leak in create_client().
4d476f
 
4d476f
 25/07/2012 autofs-5.0.7
4d476f
 =======================
4d476f
--- autofs-5.0.7.orig/lib/rpc_subs.c
4d476f
+++ autofs-5.0.7/lib/rpc_subs.c
4d476f
@@ -719,8 +719,10 @@ static int create_client(struct conn_inf
4d476f
 		ret = rpc_do_create_client(haddr->ai_addr, info, &fd, client);
4d476f
 		if (ret == 0)
4d476f
 			break;
4d476f
-		if (ret == -EHOSTUNREACH)
4d476f
+		if (ret == -EHOSTUNREACH) {
4d476f
+			freeaddrinfo(ai);
4d476f
 			goto out_close;
4d476f
+		}
4d476f
 
4d476f
 		if (!info->client && fd != RPC_ANYSOCK) {
4d476f
 			close(fd);