Follow Techotopia on Twitter

On-line Guides
All Guides
eBook Store
iOS / Android
Linux for Beginners
Office Productivity
Linux Installation
Linux Security
Linux Utilities
Linux Virtualization
Linux Kernel
System/Network Admin
Scripting Languages
Development Tools
Web Development
GUI Toolkits/Desktop
Mail Systems
Eclipse Documentation

How To Guides
General System Admin
Linux Security
Linux Filesystems
Web Servers
Graphics & Desktop
PC Hardware
Problem Solutions
Privacy Policy




Back: libltdl Dependent Libraries
Forward: Portable Library Design
FastBack: Portable Library Design
Up: Using libltdl
FastForward: Portable Library Design
Top: Autoconf, Automake, and Libtool
Contents: Table of Contents
Index: Index
About: About this document

18.2.5 Dynamic Module

Writing a module for use with the libltdl based dynamic module loader is no more involved than before: It must provide the correct entry points, as expected by the simple API I designed -- the `run' entry point described in 17.4 A Simple GNU/Linux Module Loader. Here is such a module, `ltdl-module.c':

#include <stdio.h>
#include <math.h>

#define run ltdl_module_LTX_run

run (const char *argument)
  char *end = NULL;
  long number;
  if (!argument || *argument == '\0')
      fprintf (stderr, "error: invalid argument, \"%s\".\n",
               argument ? argument : "(null)");
      return -1;
  number = strtol (argument, &end, 0);
  if (end && *end != '\0')
      fprintf (stderr, "warning: trailing garbage \"%s\".\n",

  printf ("Square root of %s is %f\n", argument, sqrt (number));

  return 0;

To take full advantage of the new module loader, the module itself must be compiled with Libtool. Otherwise dependent libraries will not have been stored when libltdl tries to load the module on an architecture that doesn't load them natively, or which doesn't have shared libraries at all (see section 18.4 dlpreopen Loading).

$ libtool --mode=compile gcc -c ltdl-module.c
rm -f .libs/ltdl-module.lo
gcc -c ltdl-module.c  -fPIC -DPIC -o .libs/ltdl-module.lo
gcc -c ltdl-module.c -o ltdl-module.o >/dev/null 2>&1
mv -f .libs/ltdl-module.lo ltdl-module.lo
$ libtool --mode=link gcc -g -o -rpath `pwd` \
-no-undefined -module -avoid-version ltdl-module.lo -lm
rm -fr .libs/ .libs/ltdl-module.* .libs/ltdl-module.*
gcc -shared  ltdl-module.lo  -lm -lc  -Wl,-soname \
-Wl, -o .libs/
ar cru .libs/ltdl-module.a  ltdl-module.o
(cd .libs && rm -f && ln -s ../ \

You can see from the interaction below that `ltdl-loader' does not load the math library, `libm', and that the shared part of the Libtool module, `ltdl-module', does have a reference to it. The pseudo-library also has a note of the `libm' dependency so that libltdl will be able to load it even on architectures that can't do it natively:

$ libtool --mode=execute ldd ltdl-loader => /usr/lib/ (0x4001a000) => /lib/ (0x4001f000) => /lib/ (0x40023000)
        /lib/ => /lib/ (0x40000000)
$ ldd .libs/ => /lib/ (0x40008000) => /lib/ (0x40025000)
        /lib/ => /lib/ (0x80000000)
$ fgrep depend
# Libraries that this one depends upon.
dependency_libs=' -lm'

This module is now ready to load from `ltdl-loader':

$ ltdl-loader ltdl-module 9
Square root of 9 is 3.000000
        => 0

This document was generated by Gary V. Vaughan on February, 8 2006 using texi2html

  Published under the terms of the Open Publication License Design by Interspire