diff --git a/src/backend/port/dynloader/README.dlfcn.aix b/src/backend/port/dynloader/README.dlfcn.aix index f64446d49b549bb4fe26eda88c4bb6f9c8ccbd43..e7519086d11d7f42a21514f3c8e4f38aba7810f1 100644 --- a/src/backend/port/dynloader/README.dlfcn.aix +++ b/src/backend/port/dynloader/README.dlfcn.aix @@ -39,8 +39,8 @@ table. If the path does not contain a '/' character, dlopen will search for the module using the LIBPATH environment variable. It returns an opaque handle to the module or NULL on error. The mode parameter can be either RTLD_LAZY (for lazy function binding) or RTLD_NOW for immediate -function binding. The AIX implementation currently does treat RTLD_NOW -the same as RTLD_LAZY. The flag RTLD_GLOBAL might be or'ed into the +function binding. The AIX implementation currently behaves as RTLD_NOW +even if RTLD_LAZY is specified. The flag RTLD_GLOBAL might be or'ed into the mode parameter to allow loaded modules to bind to global variables or functions in other loaded modules loaded by dlopen(). If RTLD_GLOBAL is not specified, only globals from the main part of the executable or diff --git a/src/backend/port/dynloader/aix.h b/src/backend/port/dynloader/aix.h index 69b5881ec48768ec7b98530fff05aec9332fe0fd..3aee79731a220b8646a5e91a8fed62387c2f44ac 100644 --- a/src/backend/port/dynloader/aix.h +++ b/src/backend/port/dynloader/aix.h @@ -1,5 +1,5 @@ /* - * $Id: aix.h,v 1.10 2001/11/08 20:37:52 momjian Exp $ + * $Id: aix.h,v 1.11 2002/02/12 23:39:46 tgl Exp $ * * @(#)dlfcn.h 1.4 revision of 95/04/25 09:36:52 * This is an unpublished work copyright (c) 1992 HELIOS Software GmbH @@ -57,7 +57,7 @@ int dlclose(); #include "utils/dynamic_loader.h" -#define pg_dlopen(f) dlopen((f), RTLD_LAZY | RTLD_GLOBAL) +#define pg_dlopen(f) dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym dlsym #define pg_dlclose dlclose #define pg_dlerror dlerror diff --git a/src/backend/port/dynloader/bsdi.h b/src/backend/port/dynloader/bsdi.h index 1af6d3d3f5a67d35e6f0d3c6ff77ba7c67fb9a6f..29c2e0e854693db5061abec2f8ac2651b13558c8 100644 --- a/src/backend/port/dynloader/bsdi.h +++ b/src/backend/port/dynloader/bsdi.h @@ -1,12 +1,12 @@ /*------------------------------------------------------------------------- * - * Dynamic loader interface for BSD/OS - * + * bsdi.h + * Dynamic loader interface for BSD/OS * * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * port_protos.h,v 1.2 1995/05/25 22:51:03 andrew Exp + * $Id: bsdi.h,v 1.15 2002/02/12 23:39:57 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -19,7 +19,21 @@ #ifdef HAVE_DLOPEN #include <dlfcn.h> -#define pg_dlopen(f) dlopen((f), RTLD_LAZY | RTLD_GLOBAL) + +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif +#ifndef RTLD_GLOBAL +#define RTLD_GLOBAL 0 +#endif + +#define pg_dlopen(f) dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym dlsym #define pg_dlclose dlclose #define pg_dlerror dlerror @@ -32,6 +46,7 @@ do { \ dld_unlink_by_file(handle, 1); \ free(handle); \ } while (0) + #endif /* not HAVE_DLOPEN */ #endif /* PORT_PROTOS_H */ diff --git a/src/backend/port/dynloader/dgux.h b/src/backend/port/dynloader/dgux.h index 2cdde7574f71a6e6b4915373e304e61415a886ae..b53245858a94cbadcb81358b4b5ef8600d960198 100644 --- a/src/backend/port/dynloader/dgux.h +++ b/src/backend/port/dynloader/dgux.h @@ -5,7 +5,7 @@ * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $Id: dgux.h,v 1.13 2001/11/05 17:46:27 momjian Exp $ + * $Id: dgux.h,v 1.14 2002/02/12 23:40:03 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -21,9 +21,22 @@ * this dynamic loader uses the system dynamic loading interface for shared * libraries (ie. dlopen/dlsym/dlclose). The user must specify a shared * library as the file to be dynamically loaded. - * */ -#define pg_dlopen(f) dlopen((f), RTLD_LAZY | RTLD_GLOBAL) + +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif +#ifndef RTLD_GLOBAL +#define RTLD_GLOBAL 0 +#endif + +#define pg_dlopen(f) dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym dlsym #define pg_dlclose dlclose #define pg_dlerror dlerror diff --git a/src/backend/port/dynloader/freebsd.h b/src/backend/port/dynloader/freebsd.h index 4437bff089dd393f9cc8f23c1b69abcd8ff8a17b..065451f8c6e62a798dda519e88d9c30a0586c5f8 100644 --- a/src/backend/port/dynloader/freebsd.h +++ b/src/backend/port/dynloader/freebsd.h @@ -1,13 +1,12 @@ /*------------------------------------------------------------------------- * - * port_protos.h - * port-specific prototypes for NetBSD 1.0 - * + * freebsd.h + * port-specific prototypes for FreeBSD * * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $Id: freebsd.h,v 1.14 2002/02/11 21:38:11 petere Exp $ + * $Id: freebsd.h,v 1.15 2002/02/12 23:40:12 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -21,7 +20,6 @@ #include "utils/dynamic_loader.h" -/* dynloader.c */ /* * Dynamic Loader on NetBSD 1.0. * @@ -35,11 +33,20 @@ * NetBSD (like 1.0, and 1.0A pre June 1995) have no dlerror.) */ +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif #ifndef RTLD_GLOBAL #define RTLD_GLOBAL 0 #endif -#define pg_dlopen(f) BSD44_derived_dlopen((f), RTLD_LAZY | RTLD_GLOBAL) +#define pg_dlopen(f) BSD44_derived_dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym BSD44_derived_dlsym #define pg_dlclose BSD44_derived_dlclose #define pg_dlerror BSD44_derived_dlerror diff --git a/src/backend/port/dynloader/irix5.h b/src/backend/port/dynloader/irix5.h index 87efa317f77f61492ad58f3365d59596bfaf4d6b..2d6dfac8a09c06809ec9ec7b155c566f46f98a69 100644 --- a/src/backend/port/dynloader/irix5.h +++ b/src/backend/port/dynloader/irix5.h @@ -1,13 +1,13 @@ /*------------------------------------------------------------------------- * - * port_protos.h + * irix5.h * port-specific prototypes for Irix 5 * * * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * port_protos.h,v 1.2 1995/03/17 06:40:18 andrew Exp + * $Id: irix5.h,v 1.12 2002/02/12 23:40:24 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -17,16 +17,28 @@ #include <dlfcn.h> #include "utils/dynamic_loader.h" -/* dynloader.c */ /* * Dynamic Loader on SunOS 4. * * this dynamic loader uses the system dynamic loading interface for shared * libraries (ie. dlopen/dlsym/dlclose). The user must specify a shared * library as the file to be dynamically loaded. - * */ -#define pg_dlopen(f) dlopen((f), RTLD_LAZY | RTLD_GLOBAL) + +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif +#ifndef RTLD_GLOBAL +#define RTLD_GLOBAL 0 +#endif + +#define pg_dlopen(f) dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym dlsym #define pg_dlclose dlclose #define pg_dlerror dlerror diff --git a/src/backend/port/dynloader/linux.h b/src/backend/port/dynloader/linux.h index 3db2436597b77f1401a07ec6816dc7316da40dc8..de096c60373b87bb9b12edb9cf143ee98eeab1e7 100644 --- a/src/backend/port/dynloader/linux.h +++ b/src/backend/port/dynloader/linux.h @@ -1,12 +1,13 @@ /*------------------------------------------------------------------------- * - * Dynamic loader interface for Linux + * linux.h + * Port-specific prototypes for Linux * * * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $Id: linux.h,v 1.16 2001/11/05 17:46:27 momjian Exp $ + * $Id: linux.h,v 1.17 2002/02/12 23:40:29 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -35,7 +36,20 @@ do { \ #else /* HAVE_DLOPEN */ -#define pg_dlopen(f) dlopen((f), RTLD_LAZY | RTLD_GLOBAL) +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif +#ifndef RTLD_GLOBAL +#define RTLD_GLOBAL 0 +#endif + +#define pg_dlopen(f) dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym dlsym #define pg_dlclose dlclose #define pg_dlerror dlerror diff --git a/src/backend/port/dynloader/netbsd.h b/src/backend/port/dynloader/netbsd.h index 8310de4db2af8b168fc68393e3957d81d4113af3..e01fd8f333474a2dbe6744b5cbf6c0b5ff92fc7b 100644 --- a/src/backend/port/dynloader/netbsd.h +++ b/src/backend/port/dynloader/netbsd.h @@ -1,13 +1,13 @@ /*------------------------------------------------------------------------- * - * port_protos.h - * port-specific prototypes for NetBSD 1.0 + * netbsd.h + * port-specific prototypes for NetBSD * * * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $Id: netbsd.h,v 1.8 2001/11/05 17:46:27 momjian Exp $ + * $Id: netbsd.h,v 1.9 2002/02/12 23:40:37 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -21,7 +21,6 @@ #include "utils/dynamic_loader.h" -/* dynloader.c */ /* * Dynamic Loader on NetBSD 1.0. * @@ -34,7 +33,21 @@ * begin with an underscore is fairly tricky, and some versions of * NetBSD (like 1.0, and 1.0A pre June 1995) have no dlerror.) */ -#define pg_dlopen(f) BSD44_derived_dlopen((f), RTLD_LAZY | RTLD_GLOBAL) + +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif +#ifndef RTLD_GLOBAL +#define RTLD_GLOBAL 0 +#endif + +#define pg_dlopen(f) BSD44_derived_dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym BSD44_derived_dlsym #define pg_dlclose BSD44_derived_dlclose #define pg_dlerror BSD44_derived_dlerror diff --git a/src/backend/port/dynloader/openbsd.h b/src/backend/port/dynloader/openbsd.h index 644b149b8046ff2102d9942793e670ed23d4a7c6..b68bb9d5873946072b49a1c4da3ad1a077a2544e 100644 --- a/src/backend/port/dynloader/openbsd.h +++ b/src/backend/port/dynloader/openbsd.h @@ -1,11 +1,12 @@ /*------------------------------------------------------------------------- * - * Dynamic loader for OpenBSD + * openbsd.h + * port-specific prototypes for OpenBSD * * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $Id: openbsd.h,v 1.9 2001/11/05 17:46:27 momjian Exp $ + * $Id: openbsd.h,v 1.10 2002/02/12 23:40:40 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -19,7 +20,6 @@ #include "utils/dynamic_loader.h" -/* dynloader.c */ /* * Dynamic Loader on NetBSD 1.0. * @@ -32,7 +32,21 @@ * begin with an underscore is fairly tricky, and some versions of * NetBSD (like 1.0, and 1.0A pre June 1995) have no dlerror.) */ -#define pg_dlopen(f) BSD44_derived_dlopen((f), RTLD_LAZY) + +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif +#ifndef RTLD_GLOBAL +#define RTLD_GLOBAL 0 +#endif + +#define pg_dlopen(f) BSD44_derived_dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym BSD44_derived_dlsym #define pg_dlclose BSD44_derived_dlclose #define pg_dlerror BSD44_derived_dlerror diff --git a/src/backend/port/dynloader/osf.h b/src/backend/port/dynloader/osf.h index f505ad1dff884c5520d3a617b8582654770e8d3f..71028d9b2401c41f7c73e339b59963de0ea0861f 100644 --- a/src/backend/port/dynloader/osf.h +++ b/src/backend/port/dynloader/osf.h @@ -1,13 +1,13 @@ /*------------------------------------------------------------------------- * - * alpha.h + * osf.h * prototypes for OSF/1-specific routines * * * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $Id: osf.h,v 1.7 2001/11/15 16:08:15 petere Exp $ + * $Id: osf.h,v 1.8 2002/02/12 23:40:43 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -18,23 +18,28 @@ #include <dlfcn.h> #include "utils/dynamic_loader.h" -/* dynloader.c */ - /* * Dynamic Loader on Alpha OSF/1.x * * this dynamic loader uses the system dynamic loading interface for shared * libraries (ie. dlopen/dlsym/dlclose). The user must specify a shared * library as the file to be dynamically loaded. - * */ -/* RTLD_GLOBAL is not available in <5.x */ +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif #ifndef RTLD_GLOBAL #define RTLD_GLOBAL 0 #endif -#define pg_dlopen(f) dlopen((f), RTLD_LAZY | RTLD_GLOBAL) +#define pg_dlopen(f) dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym(h, f) ((PGFunction) dlsym(h, f)) #define pg_dlclose(h) dlclose(h) #define pg_dlerror() dlerror() diff --git a/src/backend/port/dynloader/sco.h b/src/backend/port/dynloader/sco.h index 171c9e4c4d201d3375ea6755204f2cd90c27df8a..dccca881f2bbff1be15c4020040304ab8e0f8849 100644 --- a/src/backend/port/dynloader/sco.h +++ b/src/backend/port/dynloader/sco.h @@ -1,13 +1,13 @@ /*------------------------------------------------------------------------- * - * port_protos.h + * sco.h * port-specific prototypes for SCO 3.2v5.2 * * * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $Id: sco.h,v 1.11 2001/11/05 17:46:27 momjian Exp $ + * $Id: sco.h,v 1.12 2002/02/12 23:40:47 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -17,20 +17,30 @@ #include <dlfcn.h> #include "utils/dynamic_loader.h" -/* dynloader.c */ /* * Dynamic Loader on SCO 3.2v5.0.2 * * this dynamic loader uses the system dynamic loading interface for shared * libraries (ie. dlopen/dlsym/dlclose). The user must specify a shared * library as the file to be dynamically loaded. - * */ -#define pg_dlopen(f) dlopen((f), RTLD_LAZY | RTLD_GLOBAL) + +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif +#ifndef RTLD_GLOBAL +#define RTLD_GLOBAL 0 +#endif + +#define pg_dlopen(f) dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym dlsym #define pg_dlclose dlclose #define pg_dlerror dlerror -/* port.c */ - #endif /* PORT_PROTOS_H */ diff --git a/src/backend/port/dynloader/solaris.h b/src/backend/port/dynloader/solaris.h index ddb6b965b95fe8ad27cf4dbbc874b896d5312651..2f0c00e97b6642d09af559d0e98476db287c04c3 100644 --- a/src/backend/port/dynloader/solaris.h +++ b/src/backend/port/dynloader/solaris.h @@ -1,14 +1,38 @@ -/* $Header: /cvsroot/pgsql/src/backend/port/dynloader/solaris.h,v 1.7 2001/11/05 17:46:27 momjian Exp $ */ - -#ifndef DYNLOADER_SOLARIS_H -#define DYNLOADER_SOLARIS_H +/*------------------------------------------------------------------------- + * + * solaris.h + * port-specific prototypes for Solaris + * + * + * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group + * Portions Copyright (c) 1994, Regents of the University of California + * + * $Id: solaris.h,v 1.8 2002/02/12 23:40:53 tgl Exp $ + * + *------------------------------------------------------------------------- + */ +#ifndef PORT_PROTOS_H +#define PORT_PROTOS_H #include <dlfcn.h> #include "utils/dynamic_loader.h" -#define pg_dlopen(f) dlopen((f), RTLD_LAZY | RTLD_GLOBAL) +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif +#ifndef RTLD_GLOBAL +#define RTLD_GLOBAL 0 +#endif + +#define pg_dlopen(f) dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym dlsym #define pg_dlclose dlclose #define pg_dlerror dlerror -#endif /* DYNLOADER_SOLARIS_H */ +#endif /* PORT_PROTOS_H */ diff --git a/src/backend/port/dynloader/sunos4.h b/src/backend/port/dynloader/sunos4.h index 0bd685be7dc06229488ac14b9efad3889c040b86..60d434586a2bfc672757eb9ff7f3e8d59f399cca 100644 --- a/src/backend/port/dynloader/sunos4.h +++ b/src/backend/port/dynloader/sunos4.h @@ -1,13 +1,13 @@ /*------------------------------------------------------------------------- * - * port_protos.h + * sunos4.h * port-specific prototypes for SunOS 4 * * * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $Id: sunos4.h,v 1.12 2001/12/05 02:03:59 ishii Exp $ + * $Id: sunos4.h,v 1.13 2002/02/12 23:40:55 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -17,16 +17,28 @@ #include <dlfcn.h> #include "utils/dynamic_loader.h" -/* dynloader.c */ /* * Dynamic Loader on SunOS 4. * * this dynamic loader uses the system dynamic loading interface for shared * libraries (ie. dlopen/dlsym/dlclose). The user must specify a shared * library as the file to be dynamically loaded. - * */ -#define pg_dlopen(f) dlopen((f),1) + +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif +#ifndef RTLD_GLOBAL +#define RTLD_GLOBAL 0 +#endif + +#define pg_dlopen(f) dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym dlsym #define pg_dlclose dlclose #define pg_dlerror dlerror diff --git a/src/backend/port/dynloader/svr4.h b/src/backend/port/dynloader/svr4.h index 191f81b42e9e37e0cfd657ba0eac160554346e6e..33b36692bf4d6d91481e34850ce21e5b22d4c5b7 100644 --- a/src/backend/port/dynloader/svr4.h +++ b/src/backend/port/dynloader/svr4.h @@ -1,34 +1,46 @@ /*------------------------------------------------------------------------- * - * dynloader.h + * svr4.h * port-specific prototypes for Intel x86/Intel SVR4 * * * Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $Id: svr4.h,v 1.11 2001/11/05 17:46:27 momjian Exp $ + * $Id: svr4.h,v 1.12 2002/02/12 23:41:01 tgl Exp $ * *------------------------------------------------------------------------- */ -#ifndef DYNLOADER_H -#define DYNLOADER_H +#ifndef PORT_PROTOS_H +#define PORT_PROTOS_H #include <dlfcn.h> #include "utils/dynamic_loader.h" -/* dynloader.h */ /* * Dynamic Loader on Intel x86/Intel SVR4. * * this dynamic loader uses the system dynamic loading interface for shared * libraries (ie. dlopen/dlsym/dlclose). The user must specify a shared * library as the file to be dynamically loaded. - * */ -#define pg_dlopen(f) dlopen((f), RTLD_LAZY | RTLD_GLOBAL) + +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif +#ifndef RTLD_GLOBAL +#define RTLD_GLOBAL 0 +#endif + +#define pg_dlopen(f) dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym dlsym #define pg_dlclose dlclose #define pg_dlerror dlerror -#endif /* DYNLOADER_H */ +#endif /* PORT_PROTOS_H */ diff --git a/src/backend/port/dynloader/univel.h b/src/backend/port/dynloader/univel.h index c8a652f733aae08216208802ba86369189f621cb..aef381712d2880527ee634c28c16851d9ba1e8d7 100644 --- a/src/backend/port/dynloader/univel.h +++ b/src/backend/port/dynloader/univel.h @@ -17,16 +17,28 @@ #include <dlfcn.h> #include "utils/dynamic_loader.h" - /* dynloader.c */ /* * Dynamic Loader on Intel x86/Intel SVR4. * * this dynamic loader uses the system dynamic loading interface for shared * libraries (ie. dlopen/dlsym/dlclose). The user must specify a shared * library as the file to be dynamically loaded. - * - */ -#define pg_dlopen(f) dlopen((f), RTLD_LAZY | RTLD_GLOBAL) + */ + +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif +#ifndef RTLD_GLOBAL +#define RTLD_GLOBAL 0 +#endif + +#define pg_dlopen(f) dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym dlsym #define pg_dlclose dlclose #define pg_dlerror dlerror diff --git a/src/backend/port/dynloader/unixware.h b/src/backend/port/dynloader/unixware.h index 691273fdbdcdb7038078e1e44aed8aeab0800f78..2edea13cf87b8b88d5b30b9dc2207d9f91090f0a 100644 --- a/src/backend/port/dynloader/unixware.h +++ b/src/backend/port/dynloader/unixware.h @@ -17,16 +17,28 @@ #include <dlfcn.h> #include "utils/dynamic_loader.h" - /* dynloader.c */ /* * Dynamic Loader on Intel x86/Intel SVR4. * * this dynamic loader uses the system dynamic loading interface for shared * libraries (ie. dlopen/dlsym/dlclose). The user must specify a shared * library as the file to be dynamically loaded. - * - */ -#define pg_dlopen(f) dlopen((f), RTLD_LAZY | RTLD_GLOBAL) + */ + +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif +#ifndef RTLD_GLOBAL +#define RTLD_GLOBAL 0 +#endif + +#define pg_dlopen(f) dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym dlsym #define pg_dlclose dlclose #define pg_dlerror dlerror diff --git a/src/backend/port/dynloader/win.h b/src/backend/port/dynloader/win.h index 01ee8761c7fd973aa9a58f4e37a1c82cfa19b60d..4f76d20f0d74625c300474d12a76ce243db927f3 100644 --- a/src/backend/port/dynloader/win.h +++ b/src/backend/port/dynloader/win.h @@ -17,16 +17,28 @@ #include <dlfcn.h> #include "utils/dynamic_loader.h" - /* dynloader.c */ /* * Dynamic Loader on Intel x86/Windows NT * * this dynamic loader uses the system dynamic loading interface for shared * libraries (ie. dlopen/dlsym/dlclose). The user must specify a shared * library as the file to be dynamically loaded. - * - */ -#define pg_dlopen(f) dlopen((f), RTLD_LAZY | RTLD_GLOBAL) + */ + +/* + * In some older systems, the RTLD_NOW flag isn't defined and the mode + * argument to dlopen must always be 1. The RTLD_GLOBAL flag is wanted + * if available, but it doesn't exist everywhere. + * If it doesn't exist, set it to 0 so it has no effect. + */ +#ifndef RTLD_NOW +#define RTLD_NOW 1 +#endif +#ifndef RTLD_GLOBAL +#define RTLD_GLOBAL 0 +#endif + +#define pg_dlopen(f) dlopen((f), RTLD_NOW | RTLD_GLOBAL) #define pg_dlsym dlsym #define pg_dlclose dlclose #define pg_dlerror dlerror