From ea67da003731c3ac6c37b22568683f29853c8f5c Mon Sep 17 00:00:00 2001 From: Pavel Reichl Date: Thu, 17 Apr 2014 16:52:43 +0000 Subject: NSS: fix memory leak in sysdb_getnetgr MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Reviewed-by: Michal Židek --- src/responder/nss/nsssrv_netgroup.c | 29 +++++++++++++++++++---------- 1 file changed, 19 insertions(+), 10 deletions(-) (limited to 'src') diff --git a/src/responder/nss/nsssrv_netgroup.c b/src/responder/nss/nsssrv_netgroup.c index 0f7f782a2..9906dc858 100644 --- a/src/responder/nss/nsssrv_netgroup.c +++ b/src/responder/nss/nsssrv_netgroup.c @@ -499,7 +499,8 @@ static errno_t lookup_netgr_step(struct setent_step_ctx *step_ctx) dom->case_sensitive); if (!name) { DEBUG(SSSDBG_CRIT_FAILURE, "sss_get_cased_name failed\n"); - return ENOMEM; + ret = ENOMEM; + goto done; } DEBUG(SSSDBG_CONF_SETTINGS, "Requesting info for [%s@%s]\n", @@ -507,12 +508,12 @@ static errno_t lookup_netgr_step(struct setent_step_ctx *step_ctx) if (dom->sysdb == NULL) { DEBUG(SSSDBG_FATAL_FAILURE, "Fatal: Sysdb CTX not found for this domain!\n"); - return EIO; + ret = EIO; + goto done; } /* Look up the netgroup in the cache */ ret = sysdb_getnetgr(step_ctx->dctx, dom, name, &step_ctx->dctx->res); - if (ret == ENOENT) { /* This netgroup was not found in this domain */ if (!step_ctx->dctx->check_provider) { @@ -528,13 +529,15 @@ static errno_t lookup_netgr_step(struct setent_step_ctx *step_ctx) if (ret != EOK) { DEBUG(SSSDBG_CRIT_FAILURE, "Failed to make request to our cache!\n"); - return EIO; + ret = EIO; + goto done; } if (step_ctx->dctx->res->count > 1) { DEBUG(SSSDBG_FATAL_FAILURE, "getnetgr call returned more than one result !?!\n"); - return EMSGSIZE; + ret = EMSGSIZE; + goto done; } ret = get_netgroup_entry(step_ctx->nctx, step_ctx->name, @@ -542,7 +545,7 @@ static errno_t lookup_netgr_step(struct setent_step_ctx *step_ctx) if (ret != EOK) { /* Something really bad happened! */ DEBUG(SSSDBG_FATAL_FAILURE, "Netgroup entry was lost!\n"); - return ret; + goto done; } /* Convert the result to a list of entries */ @@ -569,7 +572,8 @@ static errno_t lookup_netgr_step(struct setent_step_ctx *step_ctx) netgr->ready = true; netgr->found = false; set_netgr_lifetime(step_ctx->nctx->neg_timeout, step_ctx, netgr); - return EIO; + ret = EIO; + goto done; } /* if this is a caching provider (or if we haven't checked the cache @@ -586,7 +590,7 @@ static errno_t lookup_netgr_step(struct setent_step_ctx *step_ctx) /* May return EAGAIN legitimately to indicate that * we need to reenter the mainloop */ - return ret; + goto done; } } @@ -603,7 +607,9 @@ static errno_t lookup_netgr_step(struct setent_step_ctx *step_ctx) } if (lifetime < 10) lifetime = 10; set_netgr_lifetime(lifetime, step_ctx, netgr); - return EOK; + + ret = EOK; + goto done; } /* If we've gotten here, then no domain contained this netgroup */ @@ -619,8 +625,11 @@ static errno_t lookup_netgr_step(struct setent_step_ctx *step_ctx) "create_negcache_netgr failed with: %d:[%s], ignored.\n", ret, sss_strerror(ret)); } + ret = ENOENT; - return ENOENT; +done: + talloc_free(name); + return ret; } static void lookup_netgr_dp_callback(uint16_t err_maj, uint32_t err_min, -- cgit