about summary refs log tree commit diff
path: root/db
diff options
context:
space:
mode:
Diffstat (limited to 'db')
-rw-r--r--db/Makefile15
1 files changed, 14 insertions, 1 deletions
diff --git a/db/Makefile b/db/Makefile
index 4df6f886b9..f8626e17ec 100644
--- a/db/Makefile
+++ b/db/Makefile
@@ -50,10 +50,23 @@ CFLAGS-hash_func.c := -Wno-unused
 # The db code outsmarts the compiler frequently.
 override CFLAGS += -Wno-uninitialized
 
+# We are in an ugly situation here.  The library is called libdb1 but the
+# SONAME for compatibility reasons should be libdb.  Therefore we duplicate
+# shared library generating rule here.
+
 # Depend on libc.so so a DT_NEEDED is generated in the shared objects.
 # This ensures they will load libc.so for needed symbols if loaded by
 # a statically-linked program that hasn't already loaded it.
-$(objpfx)libdb1.so: $(common-objpfx)libc.so
+$(objpfx)libdb1.so: $(objpfx)libdb1_pic.a $(+preinit) $(+postinit) $(+interp) \
+		    $(common-objpfx)libc.so
+	$(LINK.o) -shared -o $@ $(sysdep-LDFLAGS) $(config-LDFLAGS)  \
+		  -B$(csu-objpfx) $(load-map-file) \
+		  -Wl,-soname=lib$(libprefix)db.so$($(@F)-version) \
+		  $(LDFLAGS.so) $(LDFLAGS-$(@F:lib%.so=%).so) \
+		  -L$(subst :, -L,$(rpath-link)) -Wl,-rpath-link=$(rpath-link)\
+		  -Wl,--whole-archive \
+		  $(filter-out $(map-file) $(+preinit) $(+postinit),$^) \
+		  $(no-whole-archive) $(LDLIBS-$(@F:lib%.so=%).so)
 
 #subdir_install: $(inst_libdir)/libndbm.a
 #$(inst_libdir)/libndbm.a: $(inst_libdir)/libdb1.a $(+force)