First working mips code
[cacao.git] / Makefile
index ab19725eac7dd26b2038363f2b0d990fda063f4e..a769fe0c2a8e920e74f881327434ccc260d137ca 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -9,7 +9,7 @@
 # Authors: Reinhard Grafl      EMAIL: cacao@complang.tuwien.ac.at
 #          Andreas  Krall      EMAIL: cacao@complang.tuwien.ac.at
 #
-# Last Change: 1998/10/30
+# Last Change: $Id: Makefile 92 1998-11-25 11:48:50Z phil $
 #
 #
 # ATTENTION: This version of the makefile only works with gmake.
@@ -23,7 +23,7 @@
 ################################################################################
 
 VERSION_MAJOR = 0
-VERSION_MINOR = 30
+VERSION_MINOR = 31
 VERSION_POSTFIX = 
 
 VERSION_STRING=$(VERSION_MAJOR).$(VERSION_MINOR)$(VERSION_POSTFIX)
@@ -31,8 +31,8 @@ VERSION_STRING=$(VERSION_MAJOR).$(VERSION_MINOR)$(VERSION_POSTFIX)
 ##################### generation of the excutable ##############################
 
 # Enabling/disabling thread support
-USE_THREADS = YES
-#USE_THREADS = NO
+USE_THREADS = YES
+USE_THREADS = NO
 
 ifeq ($(USE_THREADS),YES)
 THREAD_OBJ = threads/threads.a
@@ -43,24 +43,38 @@ THREAD_CFLAGS =
 endif
 
 #CC = cc
-#CFLAGS = -g -mieee -Wall $(THREAD_CFLAGS)
-#CFLAGS = -mieee -O3 -Wall $(THREAD_CFLAGS)
+#ARCHFLAGS = 
+#CFLAGS = -g -mieee -Wall $(THREAD_CFLAGS) $(ARCHFLAGS)
+#CFLAGS = -mieee -O3 -Wall $(THREAD_CFLAGS) $(ARCHFLAGS)
+#LFLAGS = -lm
 
 CC = cc
-#CFLAGS = -g3 -ieee $(THREAD_CFLAGS)
-CFLAGS = -O3 -ieee $(THREAD_CFLAGS)
+ARCHFLAGS = 
+#CFLAGS = -g -ieee $(THREAD_CFLAGS) $(ARCHFLAGS)
+#CFLAGS = -O6 -g -pg -ieee $(THREAD_CFLAGS) $(ARCHFLAGS)
+CFLAGS = -O2 -g -ieee -fno-inline $(THREAD_CFLAGS) $(ARCHFLAGS)
+#CFLAGS = -O6 -ieee $(THREAD_CFLAGS) $(ARCHFLAGS)
+#CFLAGS = -O3 -ieee $(THREAD_CFLAGS) $(ARCHFLAGS)
+LFLAGS = -lm
+
+# IRIX 6.5 MIPSPro 7.2.1
+#CC = cc
+#ARCHFLAGS = -DDONT_MMAP
+#CFLAGS = -g $(THREAD_CFLAGS) -DMAP_ANONYMOUS=0 -woff 1048,1110,1164,1515 $(ARCHFLAGS)
+#CFLAGS = -O2 -OPT:Olimit=0 $(THREAD_CFLAGS) -DMAP_ANONYMOUS=0 $(ARCHFLAGS)
+#LFLAGS = -lm -lelfutil
 
-OBJ = main.o tables.o loader.o compiler.o newcomp.o builtin.o asmpart.o \
+OBJ = main.o tables.o loader.o compiler.o jit.o builtin.o asmpart.o \
        toolbox/toolbox.a native.o $(THREAD_OBJ) mm/mm.o
 OBJH = headers.o tables.o loader.o builtin.o toolbox/toolbox.a $(THREAD_OBJ) \
-        mm/mm.o
+mm/mm.o
 
 cacao: $(OBJ)
-       $(CC) $(CFLAGS) -o cacao $(OBJ) -lm
+       $(CC) $(CFLAGS) -o cacao $(OBJ) $(LFLAGS)
 cacaoh: $(OBJH)
-       $(CC) $(CFLAGS) -o cacaoh $(OBJH) -lm
+       $(CC) $(CFLAGS) -o cacaoh $(OBJH) $(LFLAGS)
 
-main.o: main.c global.h tables.h compiler.h ncomp/ncomp.h loader.h \
+main.o: main.c global.h tables.h loader.h jit.h compiler.h \
         asmpart.h builtin.h native.h
 
 headers.o:  headers.c global.h tables.h loader.h
@@ -70,8 +84,8 @@ loader.o:   loader.c global.h loader.h tables.h native.h asmpart.h
 compiler.o: builtin.h compiler.h global.h loader.h tables.h native.h \
             asmpart.h compiler.c comp/*.c sysdep/gen.c sysdep/disass.c
 
-newcomp.o:  builtin.h ncomp/ncomp.h global.h loader.h tables.h native.h \
-            asmpart.h ncomp/ncompdef.h ncomp/*.c sysdep/ngen.h sysdep/ngen.c sysdep/disass.c
+jit.o:  builtin.h jit.h global.h loader.h tables.h native.h asmpart.h \
+            jit/jitdef.h jit/*.c sysdep/ngen.h sysdep/ngen.c sysdep/disass.c
 
 builtin.o: builtin.c global.h loader.h builtin.h tables.h sysdep/native-math.h
 
@@ -84,15 +98,15 @@ global.h: sysdep/types.h toolbox/*.h
        touch global.h
 
 toolbox/toolbox.a: toolbox/*.c toolbox/*.h
-       cd toolbox; make toolbox.a "CFLAGS=$(CFLAGS)" "CC=$(CC)" 
+       cd toolbox; $(MAKE) toolbox.a "CFLAGS=$(CFLAGS)" "CC=$(CC)" 
 
 ifeq ($(USE_THREADS),YES)
 threads/threads.a: threads/*.c threads/*.h sysdep/threads.h
-       cd threads; make threads.a "USE_THREADS=$(USE_THREADS)" "CFLAGS=$(CFLAGS)" "CC=$(CC)" 
+       cd threads; $(MAKE) threads.a "USE_THREADS=$(USE_THREADS)" "CFLAGS=$(CFLAGS)" "CC=$(CC)" 
 endif
 
 mm/mm.o: mm/*.[ch] mm/Makefile
-       cd mm; make mm.o "USE_THREADS=$(USE_THREADS)" "CFLAGS=$(CFLAGS)" "CC=$(CC)"
+       cd mm; $(MAKE) mm.o "USE_THREADS=$(USE_THREADS)" "CFLAGS=$(CFLAGS)" "CC=$(CC)"
 
 asmpart.o: sysdep/asmpart.c sysdep/offsets.h
        rm -f asmpart.s
@@ -106,15 +120,35 @@ asmpart.o: sysdep/asmpart.c sysdep/offsets.h
 clean:
        rm -f *.o cacao cacaoh cacao.tgz nativetable.hh nativetypes.hh \
              core tst/core
-       cd toolbox; make clean
-       cd threads; make clean
-       cd mm; make clean
+       cd toolbox; $(MAKE) clean
+       cd threads; $(MAKE) clean
+       cd mm; $(MAKE) clean
+
+
+### DISTRIBUTION TARGETS ###
+
+DISTRIBUTION_FILES = \
+Makefile \
+*/Makefile \
+README \
+COPYRIGHT \
+tst/*.java \
+doc/*.doc \
+html/*.html \
+*.[ch] \
+comp/*.[ch] \
+jit/*.[ch] \
+alpha/*.doc \
+alpha/*.[ch] \
+nat/*.[ch] \
+toolbox/*.[ch] \
+threads/*.[ch] \
+mm/*.[ch] \
+# sparc/*.[ch]
 
 tar:
        rm -f cacao.tgz cacao.tar
-       tar -cvf cacao.tar Makefile */Makefile README COPYRIGHT tst/*.java \
-           doc/*.doc html/*.html *.[ch] comp/*.[ch] ncomp/*.[ch] alpha/*.doc alpha/*.[ch] \
-           nat/*.[ch] toolbox/*.[ch] threads/*.[ch] # sparc/*.[ch]
+       tar -cvf cacao.tar $(DISTRIBUTION_FILES)
        ls -l cacao.tar
        gzip -9 cacao.tar
        mv cacao.tar.gz cacao.tgz
@@ -123,10 +157,7 @@ tar:
 dist:
        rm -rf cacao-$(VERSION_STRING).tar.gz cacao-$(VERSION_STRING);
        ( mkdir cacao-$(VERSION_STRING); \
-#        tar -cf cacao-$(VERSION_STRING).tar -T FILES; \
-         tar -cvf cacao-$(VERSION_STRING).tar Makefile */Makefile README COPYRIGHT \
-           tst/*.java doc/*.doc html/*.html *.[ch] comp/*.[ch] ncomp/*.[ch] \
-           alpha/*.doc alpha/*.[ch] nat/*.[ch] toolbox/*.[ch] threads/*.[ch]; \
+         tar -cvf cacao-$(VERSION_STRING).tar $(DISTRIBUTION_FILES); \
          cd cacao-$(VERSION_STRING); \
          tar -xf ../cacao-$(VERSION_STRING).tar; \
          cd ..; \
@@ -143,15 +174,21 @@ config-alpha:
        ln -s alpha sysdep
        rm -f threads/sysdep
        ln -s ../sysdep threads/sysdep
-       make clean
+       $(MAKE) clean
 
 config-sparc:
        rm -f sysdep
        ln -s sparc sysdep
        rm -f threads/sysdep
        ln -s ../sysdep threads/sysdep
-       make clean
+       $(MAKE) clean
 
+config-mips:
+       rm -f sysdep
+       ln -s mips sysdep
+       rm -f threads/sysdep
+       ln -s ../sysdep threads/sysdep
+       $(MAKE) clean
 
 
 ##################### generation of NATIVE - header files ######################
@@ -181,5 +218,3 @@ sysdep/offsets.h nativetypes.hh nativetable.hh : cacaoh
 \
        java.util.Properties \
        java.util.Date
-       
-       
\ No newline at end of file