# HG changeset patch # User youngs # Date 1024956025 0 # Node ID beddd25fe24a15f28c265aa0dfdeb2fe3b07976e # Parent f809bc97829a1303044b7c75212646bb0329cd91 [xemacs-hg @ 2002-06-24 22:00:17 by youngs] 2002-06-17 Jerry James * emodules.texi (Loading other Modules): Describe why we do not use RTLD_GLOBAL. 2002-06-17 Jerry James * sysdll.c: Remove RTLD_GLOBAL initialization. * sysdll.c (dll_open): Do not use RTLD_GLOBAL. diff -r f809bc97829a -r beddd25fe24a man/ChangeLog --- a/man/ChangeLog Mon Jun 24 10:01:22 2002 +0000 +++ b/man/ChangeLog Mon Jun 24 22:00:25 2002 +0000 @@ -1,3 +1,8 @@ +2002-06-17 Jerry James + + * emodules.texi (Loading other Modules): Describe why we do not + use RTLD_GLOBAL. + 2002-06-20 Adrian Aichner * xemacs/mule.texi (Language Environments): Typo fix suggested by diff -r f809bc97829a -r beddd25fe24a man/emodules.texi --- a/man/emodules.texi Mon Jun 24 10:01:22 2002 +0000 +++ b/man/emodules.texi Mon Jun 24 22:00:25 2002 +0000 @@ -483,6 +483,20 @@ then their parents will also fail to load. This does not include previous successful calls to @code{emodules_load} at the top level. +@strong{Warning:} Modules are @emph{not} loaded with the +@code{RTLD_GLOBAL} flag. The practical upshot is that individual +modules do not have access to each other's C symbols. One module cannot +make a C function call to a function defined in another module, nor can +it read or set a C variable in another module. All interaction between +modules must, therefore, take place at the Lisp level. This is by +design. Other projects have attempted to use @code{RTLD_GLOBAL}, only +to find that spurious symbol name clashes were the result. Helper +functions often have simple names, increasing the probability of such a +clash. If you really need to share symbols between modules, create a +shared library containing those symbols, and link your modules with +that library. Otherwise, interactions between modules must take place +via Lisp function calls and Lisp variables accesses. + @node Using ellcc, Defining Functions, Anatomy of a Module, Top @chapter Using @code{ellcc} @cindex @code{ellcc} diff -r f809bc97829a -r beddd25fe24a src/ChangeLog --- a/src/ChangeLog Mon Jun 24 10:01:22 2002 +0000 +++ b/src/ChangeLog Mon Jun 24 22:00:25 2002 +0000 @@ -1,3 +1,8 @@ +2002-06-17 Jerry James + + * sysdll.c: Remove RTLD_GLOBAL initialization. + * sysdll.c (dll_open): Do not use RTLD_GLOBAL. + 2002-06-24 Mike Sperber * search.c (skip_chars): Fix a crash if NILP(lim). diff -r f809bc97829a -r beddd25fe24a src/sysdll.c --- a/src/sysdll.c Mon Jun 24 10:01:22 2002 +0000 +++ b/src/sysdll.c Mon Jun 24 22:00:25 2002 +0000 @@ -38,10 +38,6 @@ # define RTLD_LAZY 1 #endif /* RTLD_LAZY isn't defined under FreeBSD - ick */ -#ifndef RTLD_GLOBAL -# define RTLD_GLOBAL 0 -#endif - #ifndef RTLD_NOW # define RTLD_NOW 2 #endif @@ -55,7 +51,7 @@ dll_handle dll_open (const char *fname) { - return (dll_handle) dlopen (fname, RTLD_NOW | RTLD_GLOBAL); + return (dll_handle) dlopen (fname, RTLD_NOW); } int