aboutsummaryrefslogtreecommitdiff
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.zip
glibc-96f873b9215ea1a75e2b17c055fe5c6ad32e10d6.tar.gz
glibc-96f873b9215ea1a75e2b17c055fe5c6ad32e10d6.tar.bz2
* 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 959da90..3518c90 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 434f8b2..48a4a95 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 2d33edc..c40e9b2 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)".