fix logging talloc ctx: add osmo_init_logging2()

Deprecate osmo_init_logging() for the benefit of adding an explicit talloc
context argument to new function osmo_init_logging2().  Pass a ctx to
log_init() instead of hardcoded NULL.

Before now, *all* of our code uses a NULL ctx for logging, which amounts to
talloc "leaks" hit by address sanitizer builds on newer gcc (e.g. gcc 7.3.0 on
debian 9).

This commit helps fixing "leaks" detected in e.g. osmo-bsc unit tests by a
sanitize build with gcc (Debian 7.3.0-12) 7.3.0.

Change-Id: I216837780e9405fdaec8059c63d10699c695b360
This commit is contained in:
Neels Hofmeyr 2018-03-05 15:46:38 +01:00
parent d65f3ea18e
commit 3d8b47fc5c
2 changed files with 11 additions and 2 deletions

View File

@ -1,5 +1,7 @@
#pragma once
#include <osmocom/core/defs.h>
/*!
* \file application.h
* Routines for helping with the osmocom application setup.
@ -15,6 +17,8 @@ struct log_target;
extern struct log_target *osmo_stderr_target;
void osmo_init_ignore_signals(void);
int osmo_init_logging(const struct log_info *);
int osmo_init_logging(const struct log_info *)
OSMO_DEPRECATED("use osmo_init_logging2() instead to avoid a NULL talloc ctx");
int osmo_init_logging2(void *ctx, const struct log_info *log_info);
int osmo_daemonize(void);

View File

@ -113,6 +113,11 @@ void osmo_init_ignore_signals(void)
* creates the default (stderr) logging target.
*/
int osmo_init_logging(const struct log_info *log_info)
{
return osmo_init_logging2(NULL, log_info);
}
int osmo_init_logging2(void *ctx, const struct log_info *log_info)
{
static int logging_initialized = 0;
@ -120,7 +125,7 @@ int osmo_init_logging(const struct log_info *log_info)
return -EEXIST;
logging_initialized = 1;
log_init(log_info, NULL);
log_init(log_info, ctx);
osmo_stderr_target = log_target_create_stderr();
if (!osmo_stderr_target)
return -1;