From: "Richard W.M. Jones" <rich@annexia.org>
To: Alain Frisch <alain@frisch.fr>
Cc: caml-list@inria.fr
Subject: Re: [Caml-list] Native dynlink and reloading modules
Date: Thu, 22 Mar 2012 16:42:33 +0000 [thread overview]
Message-ID: <20120322164233.GB21740@annexia.org> (raw)
In-Reply-To: <4F6B206D.6030103@frisch.fr>
On Thu, Mar 22, 2012 at 01:51:57PM +0100, Alain Frisch wrote:
> On 03/22/2012 12:47 PM, Richard W.M. Jones wrote:
> >
> >I'm a bit surprised to find that native dynlink doesn't work in the
> >same way as bytecode dynlink in respect to reloading the same module.
> >(See attached test program)
> >
> >In bytecode dynlink, reloading (ie. Dynlink.loadfile) the same module
> >causes the new module code to override the old module code:
> >
> > $ ./dynlink_test
> > testing bytecode ...
> > a
> > b
> >
> >But in native dynlink, the new module is silently discarded and the
> >old code appears to run:
> >
> > $ ./dynlink_test
> > testing native ...
> > a
> > a
> >
> >I would classify this as a bug, but I'm not quite sure what is
> >expected to happen. Is there some other way to override a module as
> >in bytecode?
>
> natdynlink currenlty depends on the OS dynamic linker, we cannot
> control the semantics so precisely (you can try loadfile_private,
> but I'm not sure it would solve your issue).
This is all a bit, umm, unexpected.
Stepping back, the problem I'm trying to solve is how to reload a
configuration-like file into a daemon without restarting the daemon.
The "configuration-like file" is the whenjobs jobs script[1], and the
daemon is the whenjobs daemon[2].
Any ideas on how best to go about this? Note that the whenjobs jobs
script is intentionally a Turing-complete OCaml program, so converting
it to another format is probably not going to be practical.
Rich.
[1] examples:
http://git.annexia.org/?p=whenjobs.git;a=blob;f=tests/jobs/t201_ocaml_set_variable.ml;hb=HEAD
http://people.redhat.com/~rjones/whenjobs/whenjobs.txt
[2] http://git.annexia.org/?p=whenjobs.git;a=blob;f=daemon/daemon.ml;h=bc4f51a2f1177e5be2692a233d7f2b850f9a55bc;hb=HEAD#l293
--
Richard Jones
Red Hat
next prev parent reply other threads:[~2012-03-22 16:42 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-03-22 11:47 Richard W.M. Jones
2012-03-22 12:51 ` Alain Frisch
2012-03-22 16:42 ` Richard W.M. Jones [this message]
2012-03-22 17:14 ` Pierre Chambart
2012-03-22 20:12 ` Richard W.M. Jones
2012-03-31 18:40 ` Richard W.M. Jones
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=20120322164233.GB21740@annexia.org \
--to=rich@annexia.org \
--cc=alain@frisch.fr \
--cc=caml-list@inria.fr \
/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