package YourModule;
require DynaLoader;
@ISA = qw(... DynaLoader ...);
bootstrap YourModule;
This module defines the standard Perl interface to the dynamic linking
mechanisms available on many platforms. A common theme throughout the
module system is that
using
a module should be easy, even if the
module itself (or the installation of the module) is more complicated as
a result. This applies particularly to the DynaLoader. To use it in
your own module, all you need are the incantations listed above in the
synopsis. This will work whether YourModule is statically or
dynamically linked into Perl. (This is a
Configure
option for each
module.) The
bootstrap()
method will either
call YourModule's bootstrap routine directly if YourModule is statically
linked into Perl, or if not, YourModule will inherit the
bootstrap()
method from DynaLoader, which will do everything necessary to load in your module, and then call YourModule's
bootstrap()
method for you, as
if it were there all the time and you called it yourself. Piece of cake,
of the have-it-and-eat-it-too variety.
The rest of this description talks about the DynaLoader from the
viewpoint of someone who wants to extend the DynaLoader module to a new
architecture. The
Configure
process selects which kind of dynamic
loading to use by choosing to link in one of several C implementations,
which must be linked into
perl
statically. (This is unlike other
C extensions, which provide a single implementation, which may be linked
in either statically or dynamically.)
The DynaLoader is designed to be a very simple, high-level interface that
is sufficiently general to cover the requirements of SunOS, HP-UX,
NeXT, Linux, VMS, Win-32, and other platforms. By itself, though,
DynaLoader is practically useless for accessing non-Perl libraries
because it provides almost no Perl-to-C "glue". There is, for example,
no mechanism for calling a C library function or supplying its arguments
in any sort of portable form. This job is delegated to the other
extension modules that you may load in by using DynaLoader.
Variables:
@dl_library_path
@dl_resolve_using
@dl_require_symbols
$dl_debug
Subroutines:
bootstrap($modulename);
@filepaths = dl_findfile(@names);
$filepath = dl_expandspec($spec);
$libref = dl_load_file($filename);
$symref = dl_find_symbol($libref, $symbol);
@symbols = dl_undef_symbols();
dl_install_xsub($name, $symref [, $filename]);
$message = dl_error;
The
bootstrap()
and
dl_findfile()
routines
are standard across all platforms, and so are defined in
DynaLoader.pm
. The rest of the functions are supplied by
the particular
.xs
file that supplies the implementation
for the platform. (You can examine the existing implementations in the
ext/DynaLoader/
*
.xs
files in the Perl
source directory. You should also read
DynaLoader.pm
, of
course.) These implementations may also tweak the default values of the
variables listed below.
-
@dl_library_path
-
The default list of directories in which
dl_findfile()
will
search for libraries. Directories are searched in the order they are
given in this array variable, beginning with subscript 0.
@dl_library_path
is initialized to hold the list of "normal"
directories (
/usr/lib
and so on) determined by the Perl installation
script,
Configure
, and given by
$Config{'libpth'}
. This
is to ensure portability across a wide range of platforms.
@dl_library_path
should also be initialized with any other directories
that can be determined from the environment at run-time (such as
LD_LIBRARY_PATH
for SunOS).
After initialization,
@dl_library_path
can be manipulated by an
application using
push
and
unshift
before calling
dl_findfile()
.
unshift
can be used to add directories to the front of the search order
either to save search time or to override standard libraries with the same
name.
The load function that
dl_load_file()
calls might require an absolute
pathname. The
dl_findfile()
function and
@dl_library_path
can be used to search for and return the absolute pathname for the
library/object that you wish to load.
-
@dl_resolve_using
-
A list of additional libraries or other shared objects that can be
used to resolve any undefined symbols that might be generated by a
later call to
dl_load_file()
.
This is only required on some platforms that do not handle dependent
libraries automatically. For example, the Socket extension shared library
(
auto/Socket/Socket.so
) contains references to many socket functions
that need to be resolved when it's loaded. Most platforms will
automatically know where to find the "dependent" library (for example,
/usr/lib/libsocket.so
). A few platforms
need to be told the location
of the dependent library explicitly. Use
@dl_resolve_using
for this.
Example:
@dl_resolve_using = dl_findfile('-lsocket');
-
@dl_require_symbols
-
A list of one or more symbol names that are in the library/object file
to be dynamically loaded. This is only required on some platforms.
-
dl_error
-
$message = dl_error();
Error message text from the last failed DynaLoader function. Note that, similar
to
errno
in UNIX, a successful function call does not reset
this message. Implementations should detect the error as soon as it occurs in
any of the other functions and save the corresponding message for later
retrieval. This will avoid problems on some platforms (such as SunOS) where the
error message is very temporary (see, for example,
dlerror
(3)).
-
$dl_debug
-
Internal debugging messages are enabled when
$dl_debug
is set
true. Currently, setting
$dl_debug
only affects the Perl side
of the DynaLoader. These messages should help an application
developer to resolve any DynaLoader usage problems.
$dl_debug
is set to
$ENV{'PERL_DL_DEBUG'}
if defined.
For the DynaLoader developer and porter there is a similar debugging
variable added to the C code (see
dlutils.c
) and enabled if Perl was
built with the
-DDEBUGGING
flag. This can also be set via the
PERL_DL_DEBUG
environment variable. Set to 1 for minimal information or
higher for more.
-
dl_findfile
-
@filepaths = dl_findfile(@names)
Determines the full paths (including file suffix) of one or more loadable files,
given their generic names and optionally one or more directories. Searches
directories in
@dl_library_path
by default and returns an
empty list if no files were found. Names can be specified in a variety of
platform-independent forms. Any names in the form
-lname
are
converted into
libname.
*, where .* is an appropriate suffix
for the platform. If a name does not already have a suitable prefix or suffix,
then the corresponding file will be sought by trying prefix and suffix
combinations appropriate to the platform:
$name.o
,
lib$name.
* and
$name
. If any
directories are included in
@names
, they are searched before
@dl_library_path
. Directories may be specified as
-Ldir
. Any other names are treated as filenames to be
searched for.
Using arguments of the form
-Ldir
and
-lname
is recommended. Example:
@dl_resolve_using = dl_findfile(qw(-L/usr/5lib -lposix));
-
dl_expandspec
-
$filepath = dl_expandspec($spec)
Some unusual systems such as VMS require special filename handling in order to
deal with symbolic names for files (that is, VMS's Logical Names). To support
these systems a
dl_expandspec()
function can be implemented
either in the
dl_
*
.xs
file or code can
be added to the autoloadable
dl_expandspec()
function in
DynaLoader.pm
.
-
dl_load_file
-
$libref = dl_load_file($filename)
Dynamically load
$filename
, which must be the path to a shared object
or library. An opaque "library reference" is returned as a handle for
the loaded object.
dl_load_file()
returns the undefined value on error.
(On systems that provide a handle for the loaded object such as SunOS
and HP-UX, the returned handle will be
$libref
. On other systems
$libref
will typically be
$filename
or a pointer to a
buffer containing
$filename
.
The application should not examine or alter
$libref
in any way.)
Below are some of the functions that do the real work. Such functions
should use the current values of
@dl_require_symbols
and
@dl_resolve_using
if required.
SunOS: dlopen($filename)
HP-UX: shl_load($filename)
Linux: dld_create_reference(@dl_require_symbols); dld_link($filename)
NeXT: rld_load($filename, @dl_resolve_using)
VMS: lib$find_image_symbol($filename, $dl_require_symbols[0])
-
dl_find_symbol
-
$symref = dl_find_symbol($libref, $symbol)
Returns the address of the symbol
$symbol
, or the undefined value
if not found. If the
target system has separate functions to search for symbols of different
types, then
dl_find_symbol()
should search for function symbols first
and then search for other types.
The exact manner in which the address is returned in
$symref
is not
currently defined. The only initial requirement is that
$symref
can
be passed to, and understood by,
dl_install_xsub()
. Here are some
current implementations:
SunOS: dlsym($libref, $symbol)
HP-UX: shl_findsym($libref, $symbol)
Linux: dld_get_func($symbol) and/or dld_get_symbol($symbol)
NeXT: rld_lookup("_$symbol")
VMS: lib$find_image_symbol($libref, $symbol)
-
dl_undef_symbols
-
@symbols = dl_undef_symbols()
Returns a list of symbol names which remain undefined after
dl_load_file()
. It returns
()
if these
names are not known. Don't worry if your platform does not provide a mechanism
for this. Most platforms do not need it and hence do not provide it; they just
return an empty list.
-
dl_install_xsub
-
dl_install_xsub($perl_name, $symref [, $filename])
Creates a new Perl external subroutine named
$perl_name
using
$symref
as a pointer to the function that implements the routine.
This is simply a direct call to
newXSUB()
. It returns a reference to
the installed function.
The
$filename
parameter is used by Perl to identify the source file for
the function if required by
die
,
caller
, or the debugger. If
$filename
is not defined, then
DynaLoader
will be used.
-
bootstrap()
-
bootstrap($module);
This is the normal entry point for automatic dynamic loading in Perl.
It performs the following actions:
-
Locates an
auto/$module
directory by searching
@INC
-
Uses
dl_findfile()
to determine the filename to load
-
Sets
@dl_require_symbols
to
("boot_$module")
-
Executes an
auto/$module/$module.bs
file if it exists
(typically used to add to
@dl_resolve_using
any files that
are required to load the module on the current platform)
-
Calls
dl_load_file()
to load the file
-
Calls
dl_undef_symbols()
and warns if any symbols are undefined
-
Calls
dl_find_symbol()
for
"boot_$module"
-
Calls
dl_install_xsub()
to install it as
${module}::bootstrap
-
Calls
&{"${module}::bootstrap"}
to bootstrap the module (actually
it uses the function reference returned by
dl_install_xsub()
for speed)
|