summaryrefslogtreecommitdiff
path: root/src/backend/port/dynloader/bsdi.h
diff options
context:
space:
mode:
authorTom Lane2002-02-12 23:41:25 +0000
committerTom Lane2002-02-12 23:41:25 +0000
commitfa046b6a92431a91f91a981bb2995e7091552477 (patch)
tree8048a4ce16e41b2d344ed468457d55e3b9989e5f /src/backend/port/dynloader/bsdi.h
parentbaa0bb97b0a6f40993a8e340b55b14c9317f60a1 (diff)
Use RTLD_NOW, not RTLD_LAZY, as binding mode for dlopen() on all platforms.
This restores the Linux behavior to what it was in PG 7.0 and 7.1, and causes other platforms to agree. (Other well-tested platforms like HPUX were doing it this way already.) Per pghackers discussion over the past month or so.
Diffstat (limited to 'src/backend/port/dynloader/bsdi.h')
-rw-r--r--src/backend/port/dynloader/bsdi.h23
1 files changed, 19 insertions, 4 deletions
diff --git a/src/backend/port/dynloader/bsdi.h b/src/backend/port/dynloader/bsdi.h
index 1af6d3d3f5a..29c2e0e8546 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 */