From: Xavier Leroy <Xavier.Leroy@inria.fr>
To: yminsky@cs.cornell.edu
Cc: Caml Mailing List <caml-list@inria.fr>
Subject: Re: [Caml-list] Unix.localtime not threadsafe?
Date: Sat, 03 Sep 2005 09:54:20 +0200 [thread overview]
Message-ID: <431956AC.1050008@inria.fr> (raw)
In-Reply-To: <891bd339050902103460db1a55@mail.gmail.com>
> 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.
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.
> 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.
- Xavier Leroy
next prev parent reply other threads:[~2005-09-03 7:54 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 ` Xavier Leroy [this message]
2005-09-03 11:14 ` [Caml-list] " Yaron Minsky
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=431956AC.1050008@inria.fr \
--to=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