From: "Stéphane Glondu" <steph@glondu.net>
To: Romain Bardou <bardou@lri.fr>
Cc: jeremie@dimino.org, OCaml List <caml-list@yquem.inria.fr>
Subject: Re: [Caml-list] Link a .so/.dll dynamically
Date: Thu, 15 Sep 2011 11:20:45 +0200 [thread overview]
Message-ID: <4E71C36D.5030207@glondu.net> (raw)
In-Reply-To: <4E71BC0C.1090607@lri.fr>
On 09/15/2011 10:49 AM, Romain Bardou wrote:
> Thanks, I tried the following combinations (with the bytecode version,
> not the native one):
>
> -cclib -l$(DLLPATH)$(DLLNAME)$(DLLEXT)
> -cclib -L$(DLLPATH) -cclib -l$(DLLNAME)$(DLLEXT)
> -L$(DLLPATH) -cclib -l$(DLLNAME)$(DLLEXT)
> -cclib -l$(DLLPATH)$(DLLNAME)
> -cclib -L$(DLLPATH) -cclib -l$(DLLNAME)
> -L$(DLLPATH) -cclib -l$(DLLNAME)
>
> Where $(DLLPATH) is the full path to my driver, such as /usr/lib/,
> $(DLLNAME) is driver file name without the extension, such as driver,
> and $(DLLEXT) is the extension, such as .so, such that the full .so path
> is /usr/lib/driver.so.
"-l$(DLLNAME)" refers to "lib$(DLLNAME).so". It is to be used with
system shared libraries that use that convention. If you want to link to
something not using this convention, using the full path (without -l/-L)
might work on Linux, but keep in mind that not using lib$(DLLNAME).so
might be on purpose (e.g. to suggest that this .so should be dlopen()-ed
and not ld-linked).
> None of them works; I still get the "undefined symbol" error. The option
> does appear with ocamlobjinfo though. For instance, here is the result
> of ocamlobjinfo on the .cma using the last command:
>
> Extra C object files: -lcryptoki -ldriver
> Extra C options: -L/usr/lib/
> Extra dynamically-loaded libraries: -lcryptoki
>
> Shouldn't the -ldriver option appear in the extra dynamically-loaded
> libraries as well?
Where does cryptoki come from?
> I might try Jeremie's more direct approach if everything else fails.
Actually, I should have read more carefully your first mail... Jeremie's
(and Daniel's) approach are clearly the way to go: write a C stub around
dlopen() once and for all. I was instead thinking about drivers written
in OCaml that were using system shared libraries in my replies.
Cheers,
--
Stéphane
next prev parent reply other threads:[~2011-09-15 9:20 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-09-14 15:00 Romain Bardou
2011-09-14 15:35 ` Benedikt Meurer
[not found] ` <83695D27-A767-438A-B909-6864D1A655FE@googlemail.com>
2011-09-14 15:56 ` Romain Bardou
2011-09-14 15:59 ` Benedikt Meurer
2011-09-14 16:03 ` Romain Bardou
2011-09-14 16:07 ` Jérémie Dimino
2011-09-14 16:07 ` Stéphane Glondu
2011-09-14 16:12 ` Romain Bardou
2011-09-14 16:34 ` Stéphane Glondu
2011-09-14 16:42 ` Romain Bardou
2011-09-14 16:56 ` Stéphane Glondu
2011-09-15 8:49 ` Romain Bardou
2011-09-15 9:20 ` Stéphane Glondu [this message]
2011-09-15 9:23 ` Romain Bardou
2011-09-15 9:05 ` Romain Bardou
2011-09-14 16:15 ` Jérémie Dimino
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=4E71C36D.5030207@glondu.net \
--to=steph@glondu.net \
--cc=bardou@lri.fr \
--cc=caml-list@yquem.inria.fr \
--cc=jeremie@dimino.org \
/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