$(GLIB_LIBS) \
$(libgc_static_libs)
-CLASS1=$(mcs_topdir)/class/lib/default
-CLASS2=$(mcs_topdir)/class/lib/net_2_0
+CLASS=$(mcs_topdir)/class/lib/net_2_0
-RUNTIME = MONO_PATH=$(CLASS1) $(top_builddir)/runtime/mono-wrapper
-RUNTIME2 = MONO_PATH=$(CLASS2) $(top_builddir)/runtime/mono-wrapper
+RUNTIME = MONO_PATH=$(CLASS) $(top_builddir)/runtime/mono-wrapper
+RUNTIME_AOTCHECK = MONO_PATH=$(CLASS):. $(top_builddir)/runtime/mono-wrapper
-MCS = $(RUNTIME) $(CLASS1)/mcs.exe -unsafe -nowarn:0162
-GMCS = $(RUNTIME2) $(CLASS2)/gmcs.exe -unsafe -nowarn:0162
-ILASM = $(RUNTIME) $(CLASS1)/ilasm.exe
-ILASM2 = $(RUNTIME2) $(CLASS2)/ilasm.exe
+MCS = $(RUNTIME) $(CLASS)/gmcs.exe -unsafe -nowarn:0162
+ILASM = $(RUNTIME) $(CLASS)/ilasm.exe
AM_CFLAGS = \
-I$(top_srcdir) \
endif
if PLATFORM_WIN32
-libmono_la_LDFLAGS=-no-undefined -avoid-version $(monoldflags)
+libmono_la_LDFLAGS=-no-undefined -avoid-version -Wl,--kill-at $(monoldflags)
else
libmono_la_LDFLAGS=$(monoldflags)
endif
mono_SOURCES = \
main.c
+if DTRACE_G_REQUIRED
+LIBMONO_DTRACE_OBJECT = .libs/mono-dtrace.$(OBJEXT)
+if STATIC_MONO
+MONO_DTRACE_OBJECT = mono-dtrace.$(OBJEXT)
+else
+MONO_DTRACE_OBJECT =
+endif
+else
+MONO_DTRACE_OBJECT =
+LIBMONO_DTRACE_OBJECT =
+endif
+
if STATIC_MONO
# Link libmono into mono statically
# This leads to higher performance, especially with TLS
mono_LDADD = \
$(MONO_LIB) \
$(GLIB_LIBS) \
- -lm
+ -lm \
+ $(MONO_DTRACE_OBJECT)
mono_LDFLAGS = \
$(static_flags) -export-dynamic $(monobinldflags)
+if DTRACE_G_REQUIRED
+
+mono-dtrace.$(OBJEXT): $(top_srcdir)/data/mono.d mini.lo $(monodir)/mono/metadata/libmonoruntime-static.la
+ DTRACE="$(DTRACE)" DTRACEFLAGS="$(DTRACEFLAGS)" AR="$(AR)" $(SHELL) $(top_srcdir)/dtrace-prelink.sh \
+ $@ $(top_srcdir)/data/mono.d $(monodir)/mono/metadata/libmonoruntime-static.la mini.lo
+
+.libs/mono-dtrace.$(OBJEXT): $(top_srcdir)/data/mono.d mini.lo $(monodir)/mono/metadata/libmonoruntime.la
+ DTRACE="$(DTRACE)" DTRACEFLAGS="$(DTRACEFLAGS)" AR="$(AR)" $(SHELL) $(top_srcdir)/dtrace-prelink.sh \
+ --pic $@ $(top_srcdir)/data/mono.d $(monodir)/mono/metadata/libmonoruntime.la mini.lo
+
+endif
+
# Create monow.exe, linked for the 'windows' subsystem
if PLATFORM_WIN32
monow_LDADD = $(mono_LDADD)
mini-x86.c \
mini-x86.h \
exceptions-x86.c \
- tramp-x86.c \
- mini-trampolines.c
+ tramp-x86.c
amd64_sources = \
mini-amd64.c \
mini-amd64.h \
exceptions-amd64.c \
- tramp-amd64.c \
- mini-trampolines.c
+ tramp-amd64.c
ppc_sources = \
mini-ppc.c \
mini-sparc.c \
mini-sparc.h \
exceptions-sparc.c \
- tramp-sparc.c \
- mini-trampolines.c
+ tramp-sparc.c
s390_sources = \
mini-s390.c \
mini-ia64.c \
mini-ia64.h \
exceptions-ia64.c \
- tramp-ia64.c \
- mini-trampolines.c
+ tramp-ia64.c
alpha_sources = \
mini-alpha.c \
mini-alpha.h \
exceptions-alpha.c \
- tramp-alpha.c \
- mini-trampolines.c
+ tramp-alpha.c
+
+hppa_sources = \
+ mini-hppa.c \
+ mini-hppa.h \
+ exceptions-hppa.c \
+ tramp-hppa.c
common_sources = \
mini.c \
+ ir-emit.h \
+ method-to-ir.c \
+ decompose.c \
mini.h \
+ version.h \
optflags-def.h \
jit-icalls.h \
jit-icalls.c \
simple-mini-ops.h \
driver.c \
debug-mini.c \
+ debug-mini.h \
linear-scan.c \
aot-compiler.c \
aot-runtime.c \
graph.c \
mini-exceptions.c \
mini-codegen.c \
+ mini-trampolines.c \
declsec.c \
declsec.h \
wapihandles.c \
- branch-opts.c
+ branch-opts.c \
+ generic-sharing.c \
+ ssa2.c \
+ abcremoval2.c \
+ regalloc2.c
test_sources = \
basic-calls.cs \
basic-math.cs \
basic.cs \
exceptions.cs \
- iltests.il \
- test.cs
-
-test_sources2 = generics.2.cs il2tests.2.il
+ devirtualization.cs \
+ iltests.il.in \
+ test.cs \
+ generics.cs \
+ generics-variant-types.il
if MONO_DEBUGGER_SUPPORTED
if AMD64
mono_debugger_arch_sources = mdb-debug-info64.s
else
-if ALPHA
-mono_debugger_arch_sources = mdb-debug-info64.s
-else
+if X86
mono_debugger_arch_sources = mdb-debug-info32.s
endif
endif
mono_debugger_sources =
endif
-regtests=basic.exe arrays.exe basic-float.exe basic-math.exe basic-long.exe objects.exe basic-calls.exe iltests.exe exceptions.exe bench.exe
-regtests2=generics.exe il2tests.exe
+regtests=basic.exe basic-float.exe basic-long.exe basic-calls.exe objects.exe arrays.exe basic-math.exe exceptions.exe iltests.exe devirtualization.exe generics.exe
common_BURGSRC= $(srcdir)/inssel.brg $(srcdir)/inssel-float.brg
if POWERPC
arch_sources = $(ppc_sources)
arch_BURGSRC= $(srcdir)/inssel-long32.brg $(srcdir)/inssel-ppc.brg
-arch_built=cpu-g4.h
+arch_built=cpu-ppc.h
arch_define=__ppc__
endif
arch_define=__alpha__
endif
+if HPPA
+# Only support 32-bit targets for now
+arch_sources = $(hppa_sources)
+arch_BURGSRC = $(srcdir)/inssel-long32.brg $(srcdir)/inssel-hppa.brg
+arch_built = cpu-hppa.h
+arch_define=__hppa__
+endif
+
libmono_la_SOURCES = $(common_sources) $(arch_sources)
+if DISABLE_JIT
+nodist_libmono_la_SOURCES = inssel.h
+else
nodist_libmono_la_SOURCES = inssel.c inssel.h
+endif
libmono_static_la_SOURCES = $(libmono_la_SOURCES)
nodist_libmono_static_la_SOURCES = $(nodist_libmono_la_SOURCES)
libmono_static_la_LDFLAGS = -static
-libmono_static_la_LIBADD = $(static_libs)
+libmono_static_la_LIBADD = $(static_libs) $(MONO_DTRACE_OBJECT)
BURGSRC= $(common_BURGSRC) $(arch_BURGSRC)
libmonoinclude_HEADERS = jit.h
libmono_la_LIBADD = \
- $(libs)
+ $(libs) $(LIBMONO_DTRACE_OBJECT)
-%.exe: %.2.cs TestDriver.dll
- $(GMCS) -out:$@ $< -r:TestDriver.dll
+generics.exe: generics.cs TestDriver.dll generics-variant-types.dll
+ $(MCS) -out:$@ $< -r:TestDriver.dll -r:generics-variant-types.dll
%.exe: %.cs TestDriver.dll
$(MCS) -out:$@ -unsafe $< -r:TestDriver.dll
-%.exe: %.2.il
- $(ILASM2) -output=$@ $<
+iltests.il: iltests.il.in Makefile.am
+ echo '// DO NOT EDIT: This file has been generated from iltests.il.in' > iltests.il
+ cpp -Darch=$(arch_define) < $(srcdir)/iltests.il.in | sed 's/^#.*//' >> iltests.il
%.exe: %.il
$(ILASM) -output=$@ $<
TestDriver.dll: $(srcdir)/TestDriver.cs
$(MCS) -out:$@ -target:library $<
+generics-variant-types.dll: generics-variant-types.il
+ $(ILASM) -dll -output=$@ $<
+
# we don't always use the perl impl because it's an additional
# build dependency for the poor windows users
# $(arch_define) is the preprocessor symbol that enables all the opcodes
# for the specific platform in mini-ops.h
if CROSS_COMPILING
-GENMDESC_PRG=perl genmdesc.pl $(arch_define) $(srcdir)
+GENMDESC_PRG=perl $(srcdir)/genmdesc.pl $(arch_define) $(srcdir)
else !CROSS_COMPILING
GENMDESC_PRG=./genmdesc
endif !CROSS_COMPILING
cpu-amd64.h: cpu-amd64.md genmdesc$(EXEEXT)
$(GENMDESC_PRG) $(srcdir)/cpu-amd64.md cpu-amd64.h amd64_desc
-cpu-g4.h: cpu-g4.md genmdesc$(EXEEXT)
- $(GENMDESC_PRG) $(srcdir)/cpu-g4.md cpu-g4.h ppcg4
+cpu-ppc.h: cpu-ppc.md genmdesc$(EXEEXT)
+ $(GENMDESC_PRG) $(srcdir)/cpu-ppc.md cpu-ppc.h ppcg4
cpu-arm.h: cpu-arm.md genmdesc$(EXEEXT)
$(GENMDESC_PRG) $(srcdir)/cpu-arm.md cpu-arm.h arm_cpu_desc
cpu-alpha.h: cpu-alpha.md genmdesc$(EXEEXT)
$(GENMDESC_PRG) $(srcdir)/cpu-alpha.md cpu-alpha.h alpha_desc
+cpu-hppa.h: cpu-hppa.md genmdesc$(EXEEXT)
+ $(GENMDESC_PRG) $(srcdir)/cpu-hppa.md cpu-hppa.h hppa_desc
+
cpu-mips.h: cpu-mips.md genmdesc$(EXEEXT)
$(GENMDESC_PRG) $(srcdir)/cpu-mips.md cpu-mips.h mips_desc
checktests: $(regtests)
for i in $(regtests); do $(RUNTIME) $$i; done
-checktests2: $(regtests2)
- for i in $(regtests); do $(RUNTIME2) $$i; done
-
-rcheck: mono $(regtests) $(regtests2)
+rcheck: mono $(regtests)
$(RUNTIME) --regression $(regtests)
- $(RUNTIME2) --regression $(regtests2)
aotcheck: mono $(regtests)
- for i in $(regtests); do $(RUNTIME) --aot $$i; done
-# for i in $(regtests2); do $(RUNTIME2) --aot $$i; done
- $(RUNTIME) --regression $(regtests)
-# $(RUNTIME2) --verbose --regression $(regtests2)
+ rm -f *.exe.so
+ $(RUNTIME) --aot $(regtests) || exit 1
+ for i in $(regtests); do $(RUNTIME_AOTCHECK) --regression $$i || exit 1; done
rm -f *.exe.so
bench: mono test.exe
pkgconfigdir = $(libdir)/pkgconfig
if JIT_SUPPORTED
-BUILT_SOURCES= inssel.c inssel.h $(arch_built)
+BUILT_SOURCES = version.h inssel.c inssel.h $(arch_built)
+else
+BUILT_SOURCES = version.h
endif
CLEANFILES= $(BUILT_SOURCES) *.exe *.dll
EXTRA_DIST = $(common_BURGSRC) cprop.c TestDriver.cs ldscript ldscript.mono \
genmdesc.pl \
- $(test_sources) $(test_sources2) \
+ $(test_sources) \
inssel-long.brg inssel-long32.brg \
inssel-softfloat.brg \
$(x86_sources) inssel-x86.brg cpu-x86.md \
$(amd64_sources) inssel-amd64.brg cpu-amd64.md \
- $(ppc_sources) inssel-ppc.brg cpu-g4.md \
+ $(ppc_sources) inssel-ppc.brg cpu-ppc.md \
$(arm_sources) inssel-arm.brg cpu-arm.md \
$(mips_sources) inssel-mips.brg inssel-long32-mips.brg cpu-mips.md \
$(sparc_sources) inssel-sparc.brg cpu-sparc.md \
$(s390_sources) inssel-s390.brg cpu-s390.md \
$(s390x_sources) inssel-s390x.brg cpu-s390x.md \
$(ia64_sources) inssel-ia64.brg cpu-ia64.md \
- $(alpha_sources) inssel-alpha.brg cpu-alpha.md
+ $(alpha_sources) inssel-alpha.brg cpu-alpha.md \
+ $(hppa_sources) inssel-hppa.brg cpu-hppa.md
+
+version.h: Makefile
+ if test -d $(top_srcdir)/.git/svn; then svn_info='git svn info'; fi; \
+ if test -d $(srcdir)/.svn; then svn_info='svn info'; fi; \
+ if test -n "$$svn_info"; then \
+ (cd $(top_srcdir); \
+ LANG=C; export LANG; \
+ branch=`$$svn_info | grep URL | sed -e 's/.*source//' -e 's,mono/?$$,,'`; \
+ version=`$$svn_info | grep Revision | sed 's/.*: //'`; \
+ echo "#define FULL_VERSION \"$$branch r$$version\""; \
+ ); \
+ else \
+ echo "#define FULL_VERSION \"tarball\""; \
+ fi > version.h