about summary refs log tree commit diff
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>1995-02-20 10:23:07 +0000
committerRoland McGrath <roland@gnu.org>1995-02-20 10:23:07 +0000
commit96f873b9215ea1a75e2b17c055fe5c6ad32e10d6 (patch)
tree91f62a75db7a944bb19e751077278c75e966f3e3
parent0923c7a543d377bae9da0ad7075c8f9664ae70dc (diff)
downloadglibc-96f873b9215ea1a75e2b17c055fe5c6ad32e10d6.tar.gz
glibc-96f873b9215ea1a75e2b17c055fe5c6ad32e10d6.tar.xz
glibc-96f873b9215ea1a75e2b17c055fe5c6ad32e10d6.zip
* Makeconfig [elf=yes] (+preinit, +postinit): New variables, set
 	to crt[in].o.
	(csu-objpfx): New variable.
	(+link): Use it to find start.o and $(+preinit), $(+postinit).

	* Rules (subdir_lib, all): Depend on objs.
-rw-r--r--ChangeLog7
-rw-r--r--Makeconfig13
-rw-r--r--Rules4
3 files changed, 21 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 959da903a0..3518c907bd 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,12 @@
 Mon Feb 20 04:04:57 1995  Roland McGrath  <roland@duality.gnu.ai.mit.edu>
 
+	* Makeconfig [elf=yes] (+preinit, +postinit): New variables, set
+ 	to crt[in].o.
+	(csu-objpfx): New variable.
+	(+link): Use it to find start.o and $(+preinit), $(+postinit).
+
+	* Rules (subdir_lib, all): Depend on objs.
+
 	* config.h.in [HAVE_ELF || HAVE_GNU_LD]: Define HAVE_WEAK_SYMBOLS.
 
 	* stdlib/strtod.c (PASTE, PASTE1): New helper macros; use these in
diff --git a/Makeconfig b/Makeconfig
index 434f8b2d19..48a4a95ef8 100644
--- a/Makeconfig
+++ b/Makeconfig
@@ -254,11 +254,22 @@ endif
 # Command for linking programs with the C library.
 ifndef +link
 +link = $(CC) -nostdlib $(LDFLAGS) -o $@ \
-	$(common-objpfx)start.o $(^:lib=$(libc.a)) $(gnulib) $(libc.a)
+	$(addprefix $(csu-objpfx),start.o $(+preinit)) \
+	$(^:lib=$(libc.a)) $(gnulib) $(libc.a) \
+	$(addprefix $(csu-objpfx),$(+postinit))
 endif
 ifndef gnulib
 gnulib := -lgcc
 endif
+ifeq ($(elf),yes)
++preinit = crti.o
++postinit = crtn.o
+endif
+ifdef objpfx
+csu-objpfx = $(objpfx)
+else
+csu-objpfx = $(..)csu
+endif
 
 ifndef LD
 LD := ld -X
diff --git a/Rules b/Rules
index 2d33edcbc4..c40e9b2f30 100644
--- a/Rules
+++ b/Rules
@@ -36,7 +36,7 @@ export subdir := $(subdir)
 
 # This is the default target; it makes the library and auxiliary programs.
 .PHONY: all
-all: lib others
+all: objs lib others
 
 ifneq	"$(findstring env,$(origin headers))" ""
 headers :=
@@ -55,7 +55,7 @@ endif
 include ../Makerules
 
 .PHONY: subdir_lib
-subdir_lib: lib-noranlib
+subdir_lib: objs lib-noranlib
 
 # Some subdirs need to install a dummy library.
 # They can use "$(objpfx)libfnord.a: $(dep-dummy-lib); $(make-dummy-lib)".