summaryrefslogtreecommitdiff
path: root/src/backend/port/dynloader/sco.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/sco.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/sco.h')
-rw-r--r--src/backend/port/dynloader/sco.h24
1 files changed, 17 insertions, 7 deletions
diff --git a/src/backend/port/dynloader/sco.h b/src/backend/port/dynloader/sco.h
index 171c9e4c4d2..dccca881f2b 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 */