diff options
author | Stephen Gallagher <sgallagh@redhat.com> | 2009-06-19 11:09:33 -0400 |
---|---|---|
committer | Stephen Gallagher <sgallagh@redhat.com> | 2009-06-19 11:58:10 -0400 |
commit | 673c2ce9b3371241de872b2bd206f732485888cb (patch) | |
tree | 0bfc814d55de2f240e88b110a8adf72a40c7f8f0 | |
parent | a8f3c276d5f408d39b2474f62e1f80cc97e5a2b0 (diff) | |
download | sssd-673c2ce9b3371241de872b2bd206f732485888cb.tar.gz sssd-673c2ce9b3371241de872b2bd206f732485888cb.tar.bz2 sssd-673c2ce9b3371241de872b2bd206f732485888cb.zip |
Fix segfault in update_monitor_config
We were stealing the memory context of only the first value in
the linked-list of domains (and also services). This patch adds a
memory context to hold the lists so that can be stolen along with
all of the entries.
-rw-r--r-- | server/confdb/confdb.c | 4 | ||||
-rw-r--r-- | server/monitor/monitor.c | 34 |
2 files changed, 30 insertions, 8 deletions
diff --git a/server/confdb/confdb.c b/server/confdb/confdb.c index 8eefcfb6..8b8dc746 100644 --- a/server/confdb/confdb.c +++ b/server/confdb/confdb.c @@ -709,6 +709,10 @@ int confdb_get_domain(struct confdb_ctx *cdb, } domain = talloc_zero(mem_ctx, struct sss_domain_info); + if (!domain) { + ret = ENOMEM; + goto done; + } tmp = ldb_msg_find_attr_as_string(res->msgs[0], "cn", NULL); if (!tmp) { diff --git a/server/monitor/monitor.c b/server/monitor/monitor.c index 906d1579..e4fca25a 100644 --- a/server/monitor/monitor.c +++ b/server/monitor/monitor.c @@ -84,7 +84,9 @@ struct mt_svc { struct mt_ctx { struct tevent_context *ev; struct confdb_ctx *cdb; + TALLOC_CTX *domain_ctx; /* Memory context for domain list */ struct sss_domain_info *domains; + TALLOC_CTX *service_ctx; /* Memory context for services */ char **services; struct mt_svc *svc_list; struct sbus_srv_ctx *sbus_srv; @@ -619,8 +621,13 @@ int get_monitor_config(struct mt_ctx *ctx) return ret; } - ret = confdb_get_string_as_list(ctx->cdb, ctx, SERVICE_CONF_ENTRY, - "activeServices", &ctx->services); + ctx->service_ctx = talloc_new(ctx); + if(!ctx->service_ctx) { + return ENOMEM; + } + ret = confdb_get_string_as_list(ctx->cdb, ctx->service_ctx, + SERVICE_CONF_ENTRY, "activeServices", + &ctx->services); if (ret != EOK) { DEBUG(0, ("No services configured!\n")); return EINVAL; @@ -631,7 +638,11 @@ int get_monitor_config(struct mt_ctx *ctx) return ret; } - ret = confdb_get_domains(ctx->cdb, ctx, &ctx->domains); + ctx->domain_ctx = talloc_new(ctx); + if(!ctx->domain_ctx) { + return ENOMEM; + } + ret = confdb_get_domains(ctx->cdb, ctx->domain_ctx, &ctx->domains); if (ret != EOK) { DEBUG(2, ("No domains configured. LOCAL should always exist!\n")); return ret; @@ -861,7 +872,12 @@ static int update_monitor_config(struct mt_ctx *ctx) struct mt_svc *cur_svc; struct mt_svc *new_svc; struct sss_domain_info *dom, *new_dom; - struct mt_ctx *new_config = talloc_zero(NULL, struct mt_ctx); + struct mt_ctx *new_config; + + new_config = talloc_zero(NULL, struct mt_ctx); + if(!new_config) { + return ENOMEM; + } new_config->ev = ctx->ev; new_config->cdb = ctx->cdb; @@ -953,8 +969,9 @@ static int update_monitor_config(struct mt_ctx *ctx) } /* Replace the old service list with the new one */ - talloc_free(ctx->services); - ctx->services = talloc_steal(ctx, new_config->services); + talloc_free(ctx->service_ctx); + ctx->service_ctx = talloc_steal(ctx, new_config->service_ctx); + ctx->services = new_config->services; /* Compare data providers */ /* Have any providers been disabled? */ @@ -1040,8 +1057,9 @@ static int update_monitor_config(struct mt_ctx *ctx) } /* Replace the old domain list with the new one */ - talloc_free(ctx->domains); - ctx->domains = talloc_steal(ctx, new_config->domains); + talloc_free(ctx->domain_ctx); + ctx->domain_ctx = talloc_steal(ctx, new_config->domain_ctx); + ctx->domains = new_config->domains; /* Signal all services to reload their configuration */ for(cur_svc = ctx->svc_list; cur_svc; cur_svc = cur_svc->next) { |