summaryrefslogtreecommitdiff
path: root/libpthread/linuxthreads/Makefile
diff options
context:
space:
mode:
authorPeter S. Mazinger <ps.m@gmx.net>2005-09-29 20:15:28 +0000
committerPeter S. Mazinger <ps.m@gmx.net>2005-09-29 20:15:28 +0000
commitb0d66c53896602904a66405d781820f1cdfc0a95 (patch)
tree5fd408d711a72605ca8b8450d1a63a15a6021875 /libpthread/linuxthreads/Makefile
parent17df0bf5cda8b2ba2532a3fcb46c38e7f9e5e690 (diff)
Similarly to libm, remove recursion from linuxthreads. Now only libc.a and libc.so are rebuilt again if make is run a second time.
Diffstat (limited to 'libpthread/linuxthreads/Makefile')
-rw-r--r--libpthread/linuxthreads/Makefile46
1 files changed, 22 insertions, 24 deletions
diff --git a/libpthread/linuxthreads/Makefile b/libpthread/linuxthreads/Makefile
index 2d20d2351..f9148fadd 100644
--- a/libpthread/linuxthreads/Makefile
+++ b/libpthread/linuxthreads/Makefile
@@ -20,11 +20,6 @@
TOPDIR=../../
include $(TOPDIR)Rules.mak
-# As long as there is only one subdir, we don't
-# have to worry about race conditions with multiple
-# $(AR)'s in subdirs running on linuxthreads.a.
-DIRS = sysdeps
-
CFLAGS+=$(SSP_ALL_CFLAGS)
#This stuff will not compile without at least -O1
@@ -39,6 +34,12 @@ SYSDEPINC = -I$(PTDIR)sysdeps/pthread \
-I$(TOPDIR)libc/sysdeps/linux/$(TARGET_ARCH)
CFLAGS += $(SYSDEPINC)
+ARCH_CFLAGS = $(CFLAGS)
+ifeq ($(strip $(TARGET_ARCH)),sh64)
+# We need to build as SHcompact for tas..
+ARCH_CFLAGS := $(subst 32media,compact,$(ARCH_CFLAGS))
+endif
+
ifeq ($(strip $(UCLIBC_CTOR_DTOR)),y)
SHARED_START_FILES = $(TOPDIR)lib/crti.o $(LIBGCC_DIR)crtbeginS.o
SHARED_END_FILES = $(LIBGCC_DIR)crtendS.o $(TOPDIR)lib/crtn.o
@@ -49,6 +50,9 @@ AR_LIB_NAME=$(TOPDIR)lib/$(LIB_NAME).a
SO_LIB_NAME=$(TOPDIR)lib/$(LIB_NAME).so
SO_FULL_NAME=$(LIB_NAME)-$(MAJOR_VERSION).$(MINOR_VERSION).$(SUBLEVEL).so
+ARCH_CSRC=$(wildcard sysdeps/$(TARGET_ARCH)/*.c)
+ARCH_OBJS=$(patsubst %.c,%.o, $(ARCH_CSRC))
+
CSRC = $(wildcard *.c)
ifneq ($(strip $(UCLIBC_HAS_XLOCALE)),y)
CSRC := $(filter-out locale.c,$(CSRC))
@@ -56,22 +60,19 @@ endif
OBJS=$(patsubst %.c,%.o, $(CSRC))
-# We need to make sure that we put all the top-level $(OBJS) into
-# our archive before executing subdirs. That way, when $(AR) is
-# run in the subdirs, it'll bump the generic top-level objects
-# out of our archive in favor of the machine-specific ones.
ifeq ($(strip $(HAVE_SHARED)),y)
all: $(SO_LIB_NAME)
else
-all: subdirs
+all: $(AR_LIB_NAME)
endif
-$(AR_LIB_NAME): $(OBJS)
+$(AR_LIB_NAME): $(OBJS) $(ARCH_OBJS)
$(INSTALL) -d $(TOPDIR)lib
$(RM) $(AR_LIB_NAME)
$(AR) $(ARFLAGS) $(AR_LIB_NAME) $(OBJS)
+ $(AR) $(ARFLAGS) $(AR_LIB_NAME) $(ARCH_OBJS)
-$(SO_LIB_NAME): subdirs
+$(SO_LIB_NAME): $(AR_LIB_NAME)
$(RM) $(TOPDIR)lib/$(SO_FULL_NAME) $(SO_LIB_NAME).$(MAJOR_VERSION) $(SO_LIB_NAME)
$(LD) $(LDFLAGS_NOSTRIP) -soname=$(LIB_NAME).so.$(MAJOR_VERSION) \
-o $(TOPDIR)lib/$(SO_FULL_NAME) $(SHARED_START_FILES) --whole-archive $(AR_LIB_NAME) \
@@ -88,16 +89,13 @@ else
$(STRIPTOOL) -x -R .note -R .comment $*.o
endif
-clean: subdirs_clean
- $(RM) *.o *~ core
-
-subdirs: $(patsubst %, _dir_%, $(DIRS))
-subdirs_clean: $(patsubst %, _dirclean_%, $(DIRS))
-
-$(patsubst %, _dir_%, $(DIRS)): $(AR_LIB_NAME)
- $(MAKE) -C $(patsubst _dir_%, %, $@)
-
-$(patsubst %, _dirclean_%, $(DIRS)): dummy
- $(MAKE) -C $(patsubst _dirclean_%, %, $@) clean
+$(ARCH_OBJS): %.o : %.c
+ $(CC) $(ARCH_CFLAGS) -c $< -o $@
+ifeq ($(strip $(PTHREADS_DEBUG_SUPPORT)),y)
+ $(STRIPTOOL) -X --strip-debug -R .note -R .comment $*.o
+else
+ $(STRIPTOOL) -x -R .note -R .comment $*.o
+endif
-.PHONY: dummy
+clean:
+ $(RM) *.o sysdeps/*/*.o *~ core