From: Yaron Minsky <yminsky@gmail.com>
To: Xavier Leroy <Xavier.Leroy@inria.fr>
Cc: Caml Mailing List <caml-list@inria.fr>
Subject: Re: [Caml-list] Unix.localtime not threadsafe?
Date: Sat, 3 Sep 2005 07:14:11 -0400 [thread overview]
Message-ID: <891bd33905090304142aaa2679@mail.gmail.com> (raw)
In-Reply-To: <431956AC.1050008@inria.fr>
On 9/3/05, Xavier Leroy <Xavier.Leroy@inria.fr> wrote:
> > 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.
>
> As others mentioned, the C library implementation of this function
> could use thread-local storage to avoid this particular race. I don't
> think this is guaranteed, though.
Indeed, the man page explicitly states that the function is not
threadsafe. I think this counts as a bug, and I suspect I may have
seen the bug in the wild. It seems like it would be simple and safe
to use localtime_r instead. Should I submit a patch?
> > If I understand the way ocaml's locking works, another thread could
> > make a call to localtime where alloc_small is called.
>
> No, at least not another Caml thread: GC triggered from C code
> (e.g. alloc_small()) cannot cause context switches. So, from a Caml
> standpoint, the call to localtime() and the following allocation of
> its result are atomic.
>
> > 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.
>
> Yes, this is possible in principle if 1- some non-Caml threads call
> localtime(), and 2- the implementation of that function does not use
> thread-local storage.
It's interesting to learn that context switches can't happen on c-land
allocations. That simplifies a lot of things. But the C-interactions
are still possible, so I would still argue for a fix. I'm still quite
unsure if the bug I saw is a result of this race, and realizing that
the race can't be between caml-threads makes me more unsure.
Thanks for the help,
Yaron
prev parent reply other threads:[~2005-09-03 11:14 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2005-09-02 17:34 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 message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=891bd33905090304142aaa2679@mail.gmail.com \
--to=yminsky@gmail.com \
--cc=Xavier.Leroy@inria.fr \
--cc=caml-list@inria.fr \
--cc=yminsky@cs.cornell.edu \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox