diff options
-rw-r--r-- | libthreads/Makefile | 242 |
1 files changed, 25 insertions, 217 deletions
diff --git a/libthreads/Makefile b/libthreads/Makefile index be9346f3..bff8ed15 100644 --- a/libthreads/Makefile +++ b/libthreads/Makefile @@ -1,226 +1,34 @@ -# -# Mach Operating System -# Copyright (c) 1991,1990,1989 Carnegie Mellon University -# All Rights Reserved. -# -# Permission to use, copy, modify and distribute this software and its -# documentation is hereby granted, provided that both the copyright -# notice and this permission notice appear in all copies of the -# software, derivative works or modified versions, and any portions -# thereof, and that both notices appear in supporting documentation. -# -# CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" -# CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR -# ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. -# -# Carnegie Mellon requests users of this software to return to -# -# Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU -# School of Computer Science -# Carnegie Mellon University -# Pittsburgh PA 15213-3890 -# -# any improvements or extensions that they make and grant Carnegie Mellon -# the rights to redistribute these changes. -# -# -# HISTORY -# $Log: Makefile,v $ -# Revision 2.18 91/12/10 16:33:11 jsb -# New files from Intel -# [91/12/10 16:19:40 jsb] -# -# Revision 2.17 91/09/04 11:29:10 jsb -# Use cc860 for i860. -# [91/09/04 11:23:25 jsb] -# -# From Intel SSD: Added I860_CPP for i860 support. -# [91/09/02 08:57:36 jsb] -# -# Revision 2.16 91/08/24 12:32:09 af -# Added MACHINE_CFLAGS switch to support the -Wf,-XNk150 flag for -# mips string space. Apparently "danner/n3" is enough longer than -# "dbg" to exhaust string space. -# [91/08/21 danner] -# Added better cpp technology to deal with gcc limitations. -# Currently only an issue on luna88k. -# [91/07/26 danner] -# Made use of -ES vs. -E machine dependent, as luna88k does not -# like -ES. -# [91/07/19 danner] -# -# Revision 2.15.2.2 91/08/21 17:23:08 danner -# Added MACHINE_CFLAGS switch to support the -Wf,-XNk150 flag for -# mips string space. Apparently "danner/n3" is enough longer than -# "dbg" to exhaust string space. -# [91/08/21 danner] -# -# Revision 2.15.2.1 91/08/19 13:49:22 danner -# Added better cpp technology to deal with gcc limitations. -# Currently only an issue on luna88k. -# [91/07/26 danner] -# Made use of -ES vs. -E machine dependent, as luna88k does not -# like -ES. -# [91/07/19 danner] -# -# Revision 2.15 91/07/31 18:32:16 dbg -# Directly compile C files if INLINE is null (depends -# on the machine). -# Remove IBMRT-dependent fiddling for malloc. -# [91/07/30 17:32:13 dbg] -# -# Revision 2.14 91/05/14 17:55:53 mrt -# Correcting copyright -# -# Revision 2.13 91/02/14 14:19:15 mrt -# Added new Mach copyright -# [91/02/13 12:41:48 mrt] -# -# Revision 2.12 90/11/05 14:36:32 rpd -# Change MACHINE to TARGET_MACHINE. -# [90/10/29 rwd] -# -# Revision 2.11 90/09/09 14:34:39 rpd -# Remove call.o -# [90/08/24 rwd] -# -# Revision 2.10 90/06/02 15:13:30 rpd -# Compile with -DMACH_IPC_COMPAT=0. -# [90/03/26 23:29:39 rpd] -# -# Revision 2.9 90/05/29 18:40:08 rwd -# Fix PMAX_ASFLAGS. -# [90/05/22 rwd] -# -# Revision 2.8 90/05/03 15:54:28 dbg -# Use -ES switch to preprocess assembler files. -# Not all machines' 'cc' can directly assemble .s files. -# [90/04/23 dbg] -# -# Revision 2.7 90/01/19 14:36:46 rwd -# Added call.o -# [90/01/03 rwd] -# -# Revision 2.6 89/12/08 19:53:01 rwd -# Use ASFLAGS for assembler, the mips one wants to know which -# optimization level the C code was compiled at. -# [89/12/06 af] -# -# Changed CFLAGS to remove -g and add -O -# [89/10/24 rwd] -# Worked over for new merged coroutine-thread version. Removed -# task version. -# [89/10/24 rwd] -# -# +CPPFLAGS = -nostdinc -I. -I/usr1/gnu/DIST/include +CFLAGS = -g -O +CPP = /usr1/gnu/DIST/lib/gcc-cpp +AS = as +AR = ar +RANLIB = ranlib +CC = gcc -LIB = libthreads.a +VPATH=.:i386 -COMMONFLAGS = -I. -DMACH_IPC_COMPAT=0 -COPTS = -MD $(COMMONFLAGS) $(PROFILE) -CPPFLAGS = ${COPTS} -CPPSWITCH = -ES -DEFAULT_CPP = $(CC) $(CPPSWITCH) $(CPPFLAGS) +OBJS = cprocs.o cthreads.o malloc.o \ + mig_support.o stack.o sync.o \ + thread.o lock.o csw.o -PMAX_CFLAGS = -Wf,-XNk150 -PMAX_ASFLAGS= -O -nocpp +all: libthreads.a -LUNA88K_CPP = cpp ${COPTS} - -I860_CPP = /lib/cpp ${COPTS} -I860_CC = cc860 -I860_AS = as860 -I860_AR = ar860 -I860_RANLIB = ranlib860 - -CFLAGS = ${${TARGET_MACHINE}_CFLAGS} -O ${COPTS} -ASFLAGS = ${${TARGET_MACHINE}_ASFLAGS} -NCPP = $($(TARGET_MACHINE)_CPP?$($(TARGET_MACHINE)_CPP):$(DEFAULT_CPP) -CC = $($(TARGET_MACHINE)_CC?$($(TARGET_MACHINE)_CC):cc) -AS = $($(TARGET_MACHINE)_AS?$($(TARGET_MACHINE)_AS):as) -AR = $($(TARGET_MACHINE)_AR?$($(TARGET_MACHINE)_AR):ar) -RANLIB = $($(TARGET_MACHINE)_RANLIB?$($(TARGET_MACHINE)_RANLIB):ranlib) - -I = -c -d -v - -# Use the following definition to enable inline expansion. -#VAX_INLINE = awk -f cthread_inline.awk -#SUN3_INLINE = awk -f cthread_inline.awk - -INLINE = ${${TARGET_MACHINE}_INLINE} - -INLINE_C_RULE = \ - $(CC) $(CFLAGS) -S $*.c && \ - $(MV) $*.s $*.S && \ - $(INLINE) $*.S > $*.s && \ - $(AS) $(ASFLAGS) -o $@ $*.s && \ - $(RM) $(RMFLAGS) $*.s $*.S - -NORMAL_C_RULE = \ - $(CC) $(CFLAGS) -c -o $@ $*.c - -C_RULE = ${${TARGET_MACHINE}_INLINE?${INLINE_C_RULE}:${NORMAL_C_RULE}} - -.SUFFIXES: .c .o - -.c.o: - ${C_RULE} - -SRCS = cprocs.c cthreads.c malloc.c \ - mig_support.c stack.c sync.c \ - machine/thread.c - -OBJS = $(LIB)(cprocs.o) $(LIB)(cthreads.o) $(LIB)(malloc.o) \ - $(LIB)(mig_support.o) $(LIB)(stack.o) $(LIB)(sync.o) \ - $(LIB)(thread.o) $(LIB)(lock.o) $(LIB)(csw.o) - -lib: $(LIB) - -include: machine ckdir - mach_install $I cthreads.h $(DSTBASE)/include - -machine: - -if [ -d machine ]; then true; else ln -s $(machine) machine; fi +install: all + cp libthreads.a /usr1/gnu/DIST/lib/libthreads.a + ranlib /usr1/gnu/DIST/lib/libthreads.a clean: - $(RM) $(RMFLAGS) machine lib*.a Makedep* a.out core errs \ - *.d *.s *.S *.o *.BAK *.CKP */*.BAK */*.CKP - -# -# Get inline expansion file before we do anything else. -# -.INIT: cthread_inline.awk - -cthread_inline.awk: machine/cthread_inline.awk - -if [ -f $@ ]; then chmod 644 $@; else true; fi - cp -p machine/$@ $@ - -# The following are the "generic" rules, -# parameterized by LIB, IMPL, and PROFILE. - -$(LIB): $(OBJS) - $(AR) r$(ARFLAGS) $(LIB) $? - $(RANLIB) $(LIB) - $(RM) $(RMFLAGS) $? -# Avoid complaints from md in case Makedep doesn't exist yet. - touch Makedep - md -m Makedep -d *.d -# Massage dependency file to reflect object files within library. - cp Makedep Makedep.BAK - sed 's/^[^ #$$]*\.o/$$(LIB)(&)/' < Makedep.BAK > Makedep - rm Makedep.BAK - -$(LIB)(thread.o): machine/thread.c - $(CC) $(CFLAGS) -c machine/thread.c + rm -f lib*.a Makedep* a.out core errs \ + *.d *.s *.S *.o *.BAK *.CKP */*.BAK */*.CKP -$(LIB)(lock.o): machine/lock.s - $(NCPP)machine/lock.s > $*.as - $(AS) $(ASFLAGS) -o $@ $*.as - $(RM) $(RMFLAGS) $*.as +libthreads.a: $(OBJS) + rm -f $@ + $(AR) crv $@ $(OBJS) + $(RANLIB) $@ -$(LIB)(csw.o): machine/csw.s - $(NCPP) machine/csw.s > $*.as - $(AS) $(ASFLAGS) -o $@ $*.as - $(RM) $(RMFLAGS) $*.as +%.o: %.s + $(CPP) $(CPPFLAGS) $< > $*.as + $(AS) -o $@ $*.as + rm -f $*.as --include Makedep |