Skip to content

Commit

Permalink
Use gmtime_r() and localtime_r() instead of non-thread-safe versions.
Browse files Browse the repository at this point in the history
Signed-off-by: Ben Pfaff <[email protected]>
  • Loading branch information
blp committed May 2, 2013
1 parent d515594 commit 9b6937e
Show file tree
Hide file tree
Showing 4 changed files with 14 additions and 10 deletions.
12 changes: 6 additions & 6 deletions lib/dynamic-string.c
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* 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 Down Expand Up @@ -184,21 +184,21 @@ ds_put_printable(struct ds *ds, const char *s, size_t n)
}

/* Writes the current time to 'string' based on 'template'.
* The current time is either localtime or UTC based on 'utc'. */
* The current time is either local time or UTC based on 'utc'. */
void
ds_put_strftime(struct ds *ds, const char *template, bool utc)
{
const struct tm *tm;
struct tm tm;
time_t now = time_wall();
if (utc) {
tm = gmtime(&now);
gmtime_r(&now, &tm);
} else {
tm = localtime(&now);
localtime_r(&now, &tm);
}

for (;;) {
size_t avail = ds->string ? ds->allocated - ds->length + 1 : 0;
size_t used = strftime(&ds->string[ds->length], avail, template, tm);
size_t used = strftime(&ds->string[ds->length], avail, template, &tm);
if (used) {
ds->length += used;
return;
Expand Down
5 changes: 3 additions & 2 deletions lib/table.c
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2009, 2010, 2011, 2012 Nicira, Inc.
* Copyright (c) 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 Down Expand Up @@ -222,7 +222,8 @@ static void
table_format_timestamp__(char *s, size_t size)
{
time_t now = time_wall();
strftime(s, size, "%Y-%m-%d %H:%M:%S", gmtime(&now));
struct tm tm;
strftime(s, size, "%Y-%m-%d %H:%M:%S", gmtime_r(&now, &tm));
}

static void
Expand Down
3 changes: 2 additions & 1 deletion ovsdb/ovsdb-tool.c
Original file line number Diff line number Diff line change
Expand Up @@ -519,9 +519,10 @@ do_show_log(int argc, char *argv[])
date = shash_find_data(json_object(json), "_date");
if (date && date->type == JSON_INTEGER) {
time_t t = json_integer(date);
struct tm tm;
char s[128];

strftime(s, sizeof s, "%Y-%m-%d %H:%M:%S", gmtime(&t));
strftime(s, sizeof s, "%Y-%m-%d %H:%M:%S", gmtime_r(&t, &tm));
printf(" %s", s);
}

Expand Down
4 changes: 3 additions & 1 deletion utilities/ovs-ofctl.c
Original file line number Diff line number Diff line change
Expand Up @@ -1358,9 +1358,11 @@ monitor_vconn(struct vconn *vconn)

if (timestamp) {
time_t now = time_wall();
struct tm tm;
char s[32];

strftime(s, sizeof s, "%Y-%m-%d %H:%M:%S: ", gmtime(&now));
strftime(s, sizeof s, "%Y-%m-%d %H:%M:%S: ",
gmtime_r(&now, &tm));
fputs(s, stderr);
}

Expand Down

0 comments on commit 9b6937e

Please sign in to comment.