caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
* Unix.localtime not threadsafe?
@ 2005-09-02 17:34 Yaron Minsky
  2005-09-03  7:03 ` Bardur Arantsson
  2005-09-03  7:54 ` [Caml-list] " Xavier Leroy
  0 siblings, 2 replies; 5+ messages in thread
From: Yaron Minsky @ 2005-09-02 17:34 UTC (permalink / raw)
  To: Caml Mailing List

I was looking at the Unix.localtime implementation, and it appears to
me that it's not threadsafe.  I'm wondering if anyone can confirm.

First off, the underlying localtime call is definitely not re-entrant.
 The tm data structure is shared among all calls, leading to the
possibility of races.  What I'm not sure of is whether there can be a
race given the locking of the OCaml runtime.  Here's the code from
gmtime.c in the ocaml distribution:

static value alloc_tm(struct tm *tm)
{
  value res;
  res = alloc_small(9, 0);
  Field(res,0) = Val_int(tm->tm_sec);
  Field(res,1) = Val_int(tm->tm_min);
  Field(res,2) = Val_int(tm->tm_hour);
  Field(res,3) = Val_int(tm->tm_mday);
  Field(res,4) = Val_int(tm->tm_mon);
  Field(res,5) = Val_int(tm->tm_year);
  Field(res,6) = Val_int(tm->tm_wday);
  Field(res,7) = Val_int(tm->tm_yday);
  Field(res,8) = tm->tm_isdst ? Val_true : Val_false;
  return res;
}

CAMLprim value unix_localtime(value t)
{
  time_t clock;
  struct tm * tm;
  clock = (time_t) Double_val(t);
  tm = localtime(&clock);
  if (tm == NULL) unix_error(EINVAL, "localtime", Nothing);
  return alloc_tm(tm);
}

If I understand the way ocaml's locking works, another thread could
make a call to localtime where alloc_small is called.  If there are
mixed C threads and Ocaml threads, then a call by the C thread at that
point could muck up the tm data structure before switching back to
OCaml, thus leading to bad data getting into the tm data structure.

So, does this seem like a going bug?  We think we may have encountered
this in the wild, so this may be more than a theoretical bug.

Yaron


^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2005-09-03 11:14 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2005-09-02 17:34 Unix.localtime not threadsafe? Yaron Minsky
2005-09-03  7:03 ` Bardur Arantsson
2005-09-03  7:20   ` [Caml-list] " Florian Weimer
2005-09-03  7:54 ` [Caml-list] " Xavier Leroy
2005-09-03 11:14   ` Yaron Minsky

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).