svn commit: trunk/uClibc/libpthread/linuxthreads: sysdeps sysdeps/sh64

psm at uclibc.org psm at uclibc.org
Thu Sep 29 20:15:31 UTC 2005


Author: psm
Date: 2005-09-29 13:15:28 -0700 (Thu, 29 Sep 2005)
New Revision: 11698

Log:
Similarly to libm, remove recursion from linuxthreads. Now only libc.a and libc.so are rebuilt again if make is run a second time.

Removed:
   trunk/uClibc/libpthread/linuxthreads/sysdeps/Makefile
   trunk/uClibc/libpthread/linuxthreads/sysdeps/sh64/Makefile

Modified:
   trunk/uClibc/libpthread/linuxthreads/Makefile


Changeset:
Modified: trunk/uClibc/libpthread/linuxthreads/Makefile
===================================================================
--- trunk/uClibc/libpthread/linuxthreads/Makefile	2005-09-29 19:14:58 UTC (rev 11697)
+++ trunk/uClibc/libpthread/linuxthreads/Makefile	2005-09-29 20:15:28 UTC (rev 11698)
@@ -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 @@
             -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 @@
 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 @@
 
 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 @@
 	$(STRIPTOOL) -x -R .note -R .comment $*.o
 endif
 
-clean: subdirs_clean
-	$(RM) *.o *~ core
+$(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
 
-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
-
-.PHONY: dummy
+clean:
+	$(RM) *.o sysdeps/*/*.o *~ core

Deleted: trunk/uClibc/libpthread/linuxthreads/sysdeps/Makefile
===================================================================
--- trunk/uClibc/libpthread/linuxthreads/sysdeps/Makefile	2005-09-29 19:14:58 UTC (rev 11697)
+++ trunk/uClibc/libpthread/linuxthreads/sysdeps/Makefile	2005-09-29 20:15:28 UTC (rev 11698)
@@ -1,49 +0,0 @@
-# Makefile for uClibc's pthread library
-#
-# Copyright (C) 2003 Paul Mundt <lethal at linux-sh.org>
-#
-# This program is free software; you can redistribute it and/or modify it under
-# the terms of the GNU Library General Public License as published by the Free
-# Software Foundation; either version 2 of the License, or (at your option) any
-# later version.
-#
-# This program is distributed in the hope that it will be useful, but WITHOUT
-# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
-# FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more
-# details.
-#
-# You should have received a copy of the GNU Library General Public License
-# along with this program; if not, write to the Free Software Foundation, Inc.,
-# 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
-# Makefile for uClibc
-
-TOPDIR=../../../
-include $(TOPDIR)Rules.mak
-
-# Generally most TARGET_ARCHs aren't going to want a make rule here as they
-# can generally just inline directly into the upper-level pt-machine.c. As
-# such, we offer this capability for platforms that either can't get away
-# with the inlining, or need to be able to do builds here for other reasons. 
-
-DIRS =
-
-ifeq ($(TARGET_ARCH),sh64)
-	DIRS += $(TARGET_ARCH)
-endif
-
-all: subdirs
-
-clean: subdirs_clean
-	$(RM) *~ core
-
-subdirs: $(patsubst %, _dir_%, $(DIRS))
-subdirs_clean: $(patsubst %, _dirclean_%, $(DIRS))
-
-$(patsubst %, _dir_%, $(DIRS)) : dummy
-	$(MAKE) -C $(patsubst _dir_%, %, $@)
-
-$(patsubst %, _dirclean_%, $(DIRS)) : dummy
-	$(MAKE) -C $(patsubst _dirclean_%, %, $@) clean
-
-.PHONY: dummy subdirs
-

Deleted: trunk/uClibc/libpthread/linuxthreads/sysdeps/sh64/Makefile
===================================================================
--- trunk/uClibc/libpthread/linuxthreads/sysdeps/sh64/Makefile	2005-09-29 19:14:58 UTC (rev 11697)
+++ trunk/uClibc/libpthread/linuxthreads/sysdeps/sh64/Makefile	2005-09-29 20:15:28 UTC (rev 11698)
@@ -1,43 +0,0 @@
-# Makefile for uClibc's sh64 pthread backend
-#
-# Copyright (C) 2003 Paul Mundt <lethal at linux-sh.org>
-#
-# This program is free software; you can redistribute it and/or modify it under
-# the terms of the GNU Library General Public License as published by the Free
-# Software Foundation; either version 2 of the License, or (at your option) any
-# later version.
-#
-# This program is distributed in the hope that it will be useful, but WITHOUT
-# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
-# FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more
-# details.
-#
-# You should have received a copy of the GNU Library General Public License
-# along with this program; if not, write to the Free Software Foundation, Inc.,
-# 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
-
-TOPDIR=../../../../
-include $(TOPDIR)Rules.mak
-
-CFLAGS+=$(SSP_ALL_CFLAGS)
-
-# We need to build as SHcompact for tas..
-CFLAGS := $(subst 32media,compact,$(CFLAGS))
-
-LIB_NAME=libpthread
-AR_LIB_NAME=$(TOPDIR)lib/$(LIB_NAME).a
-
-CSRC = pt-machine.c
-OBJS = $(patsubst %.c,%.o, $(CSRC))
-
-all: add_to_archive
-
-add_to_archive: $(OBJS)
-	$(AR) $(ARFLAGS) $(AR_LIB_NAME) $(OBJS)
-
-$(OBJS): %.o : %.c
-	$(CC) $(CFLAGS) -c $< -o $@
-	$(STRIPTOOL) -x -R .note -R .comment $*.o
-
-clean:
-	$(RM) *.o *~ core




More information about the uClibc-cvs mailing list