Skip to content

Commit

Permalink
dirs: Make thread-safe.
Browse files Browse the repository at this point in the history
Signed-off-by: Ben Pfaff <[email protected]>
  • Loading branch information
blp committed Jul 22, 2013
1 parent d3aa371 commit 811d645
Showing 1 changed file with 29 additions and 8 deletions.
37 changes: 29 additions & 8 deletions lib/dirs.c.in
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#line 2 "@srcdir@/lib/dirs.c.in"
/*
* Copyright (c) 2008, 2009, 2010, 2011, 2012 Nicira, Inc.
* Copyright (c) 2008, 2009, 2010, 2011, 2012, 2013 Nicira, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand All @@ -18,59 +18,76 @@
#include <config.h>
#include "dirs.h"
#include <stdlib.h>
#include "ovs-thread.h"
#include "util.h"

struct directory {
const char *value; /* Actual value; NULL if not yet determined. */
const char *default_value; /* Default value. */
const char *var_name; /* Environment variable to override default. */
struct ovsthread_once once; /* Ensures 'value' gets initialized once. */
};

static const char *
get_dir(struct directory *d)
{
if (!d->value) {
if (ovsthread_once_start(&d->once)) {
d->value = getenv(d->var_name);
if (!d->value || !d->value[0]) {
d->value = d->default_value;
}
ovsthread_once_done(&d->once);
}
return d->value;
}

const char *
ovs_sysconfdir(void)
{
static struct directory d = { NULL, @sysconfdir@, "OVS_SYSCONFDIR" };
static struct directory d = {
NULL, @sysconfdir@, "OVS_SYSCONFDIR", OVSTHREAD_ONCE_INITIALIZER
};

return get_dir(&d);
}

const char *
ovs_pkgdatadir(void)
{
static struct directory d = { NULL, @pkgdatadir@, "OVS_PKGDATADIR" };
static struct directory d = {
NULL, @pkgdatadir@, "OVS_PKGDATADIR", OVSTHREAD_ONCE_INITIALIZER
};

return get_dir(&d);
}

const char *
ovs_rundir(void)
{
static struct directory d = { NULL, @RUNDIR@, "OVS_RUNDIR" };
static struct directory d = {
NULL, @RUNDIR@, "OVS_RUNDIR", OVSTHREAD_ONCE_INITIALIZER
};

return get_dir(&d);
}

const char *
ovs_logdir(void)
{
static struct directory d = { NULL, @LOGDIR@, "OVS_LOGDIR" };
static struct directory d = {
NULL, @LOGDIR@, "OVS_LOGDIR", OVSTHREAD_ONCE_INITIALIZER
};

return get_dir(&d);
}

const char *
ovs_dbdir(void)
{
static struct ovsthread_once once = OVSTHREAD_ONCE_INITIALIZER;
static const char *dbdir;
if (!dbdir) {

if (ovsthread_once_start(&once)) {
dbdir = getenv("OVS_DBDIR");
if (!dbdir || !dbdir[0]) {
char *sysconfdir = getenv("OVS_SYSCONFDIR");
Expand All @@ -79,13 +96,17 @@ ovs_dbdir(void)
? xasprintf("%s/openvswitch", sysconfdir)
: @DBDIR@);
}
ovsthread_once_done(&once);
}
return dbdir;
}

const char *
ovs_bindir(void)
{
static struct directory d = { NULL, @bindir@, "OVS_BINDIR" };
static struct directory d = {
NULL, @bindir@, "OVS_BINDIR", OVSTHREAD_ONCE_INITIALIZER
};

return get_dir(&d);
}

0 comments on commit 811d645

Please sign in to comment.