OSDN Git Service

Convert libraries into the BYTECODE_LIBRARY style
authorChris Lattner <sabre@nondot.org>
Fri, 15 Aug 2003 02:20:32 +0000 (02:20 +0000)
committerChris Lattner <sabre@nondot.org>
Fri, 15 Aug 2003 02:20:32 +0000 (02:20 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7858 91177308-0d34-0410-b5e6-96231b3b80d8

runtime/GCCLibraries/crtend/Makefile
runtime/GCCLibraries/libc/Makefile
runtime/GCCLibraries/libgcc/Makefile
runtime/GCCLibraries/libm/Makefile
runtime/GCCLibraries/libmalloc/Makefile
runtime/GCCLibraries/libucb/Makefile
runtime/Makefile
runtime/Makefile.libs [deleted file]
runtime/libdummy/Makefile
runtime/libtrace/Makefile

index 7fa16aa..9bfb9d1 100644 (file)
@@ -1,11 +1,17 @@
 LEVEL = ../../..
-LIBNAME = crtend
+BYTECODE_LIBRARY=1
+DONT_BUILD_RELINKED=1
+LIBRARYNAME=crtend
+
 Source = crtend.c listend.ll
 
 EXPORTED_SYMBOL_LIST = __main,llvm.global_ctors,llvm.global_dtors
 
-include ../Makefile.libs
+include $(LEVEL)/Makefile.common
+
+
+$(LLVMGCCDIR)/bytecode-libs/crtend.o: $(LIBNAME_BC)
+       @cp $< $@
 
-install:: $(DESTLIBNAME)
-       cp $(DESTLIBNAME) $(INSTALL_DIR)/crtend.o
-       rm $(INSTALL_DIR)/libcrtend.bc
+install:: $(LLVMGCCDIR)/bytecode-libs/crtend.o
+       @rm $(LLVMGCCDIR)/bytecode-libs/libcrtend.bc
\ No newline at end of file
index dbe590b..286f2e9 100644 (file)
@@ -1,6 +1,7 @@
 LEVEL = ../../..
+BYTECODE_LIBRARY=1
+DONT_BUILD_RELINKED=1
+LIBRARYNAME=c
 
-LIBNAME = c
-
-include ../Makefile.libs
+include $(LEVEL)/Makefile.common
 
index fd56528..fc97d44 100644 (file)
@@ -1,6 +1,6 @@
 LEVEL = ../../..
+BYTECODE_LIBRARY=1
+DONT_BUILD_RELINKED=1
+LIBRARYNAME=gcc
 
-LIBNAME = gcc
-
-include ../Makefile.libs
-
+include $(LEVEL)/Makefile.common
index f3085de..5b95c6f 100644 (file)
@@ -1,6 +1,7 @@
 LEVEL = ../../..
+BYTECODE_LIBRARY=1
+DONT_BUILD_RELINKED=1
+LIBRARYNAME=m
 
-LIBNAME = m
-
-include ../Makefile.libs
+include $(LEVEL)/Makefile.common
 
index 9d56de0..ab66132 100644 (file)
@@ -1,6 +1,6 @@
 LEVEL = ../../..
+BYTECODE_LIBRARY=1
+DONT_BUILD_RELINKED=1
+LIBRARYNAME=malloc
 
-LIBNAME = malloc
-
-include ../Makefile.libs
-
+include $(LEVEL)/Makefile.common
index 247caea..0eb0e9b 100644 (file)
@@ -1,6 +1,6 @@
 LEVEL = ../../..
+BYTECODE_LIBRARY=1
+DONT_BUILD_RELINKED=1
+LIBRARYNAME=ucb
 
-LIBNAME = ucb
-
-include ../Makefile.libs
-
+include $(LEVEL)/Makefile.common
index 2fad228..6f05ed2 100644 (file)
@@ -1,7 +1,7 @@
 # Libraries Makefile:  Build all subdirectories automatically
 
 LEVEL = ../..
-DIRS  := $(sort $(filter-out Output/, $(filter-out CVS/, $(wildcard */))))
+PARALLEL_DIRS  := $(sort $(filter-out Output/, $(filter-out CVS/, $(wildcard */))))
 
 include ${LEVEL}/Makefile.common
 
diff --git a/runtime/Makefile.libs b/runtime/Makefile.libs
deleted file mode 100644 (file)
index 52766e1..0000000
+++ /dev/null
@@ -1,47 +0,0 @@
-#                          test/Libraries/Makefile.libs
-#
-# This makefile should be used by subdirectories, which are libraries that are
-# to be compiled to llvm bytecode and linked together with a specified name.
-#
-# Variables to be defined before including this makefile:
-#
-# 1. LEVEL - Must be set as per normal semantics: The depth from the top of tree
-# 2. LIBNAME - Name of library to link together.  Forms lib<LIBNAME>.bc
-# 3. EXPORTED_SYMBOL_LIST - If this symbol is defined, it contains a comma
-#    separated list of symbols that are exported by the library.  All other
-#    symbols are marked internal, reducing namespace pollution.
-#
-
-DESTLIBDIR  := $(LEVEL)/test/Libraries/Output
-DESTLIBNAME := $(LEVEL)/test/Libraries/Output/lib$(LIBNAME).bc
-
-all:: $(DESTLIBNAME)
-
-include $(LEVEL)/test/Makefile.tests
-
-# Figure out what object files we want to build...
-LObjs    := $(sort $(addsuffix .bc, $(basename $(Source))))
-LObjects := $(addprefix Output/,$(LObjs))
-
-.PRECIOUS: $(LObjects)
-
-# If the library specified a list of symbols to export, add an internalize pass
-# to the link options.
-ifdef EXPORTED_SYMBOL_LIST
-LLINK_OPTS += -internalize -internalize-public-api-list=$(EXPORTED_SYMBOL_LIST)
-endif
-
-# Standard set of postlink optimizations...
-LLINK_OPTS +=  -inline -globaldce -funcresolve -deadtypeelim -instcombine -simplifycfg
-
-# Link the library, then perform postlink optimization...
-$(DESTLIBNAME): $(DESTLIBDIR)/.dir $(LObjects) $(LLINK) $(LOPT)
-       $(LLINK) -f $(LObjects) $(LDFLAGS) | \
-        $(LOPT) -f -q $(LLINK_OPTS) -o $@
-
-# Install target for libraries: Copy into the gcc install directory.
-#
-INSTALL_DIR := $(LLVMGCCDIR)/bytecode-libs/
-
-install:: $(DESTLIBNAME)
-       cp $(DESTLIBNAME) $(INSTALL_DIR)
index 2b4af85..1f7d590 100644 (file)
@@ -1,4 +1,6 @@
 LEVEL = ../../..
-LIBNAME = dummy
-include ../Makefile.libs
+BYTECODE_LIBRARY=1
+DONT_BUILD_RELINKED=1
+LIBRARYNAME=dummy
 
+include $(LEVEL)/Makefile.common
index b74e037..199dd74 100644 (file)
@@ -1,23 +1,7 @@
 LEVEL = ../../..
+BYTECODE_LIBRARY=1
+#DONT_BUILD_RELINKED=1
+LIBRARYNAME=gcc
 
-LIBNAME = instr
+include $(LEVEL)/Makefile.common
 
-include ../Makefile.libs
-
-## We need the native libraries for libinstr because they are directly
-## linked into the native CBE or LLC code.  That is the only practical
-## way to debug them!
-
-LIBINSTR = ../Output/libinstr.$(ARCH).a
-all:: $(LIBINSTR)
-
-tracelib: tracelib.c
-       g++ -g -DTEST_INSTRLIB $< -o $@
-
-Debug/tracelib.o: tracelib.c Debug/.dir
-       $(CompileC) -g $< -o $@
-
-$(LIBINSTR): Debug/tracelib.o ../Output/.dir
-       ar r $@ $<
-
-tracelib.c: tracelib.h