X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mono%2Fmini%2FMakefile.am.in;h=28fb9ee5b8d2fdbc6a19ed9ea8541ad4814c313b;hb=HEAD;hp=59888bbc64dc722b2d29ab611d8a06f6ee1a6d7b;hpb=6025544e01621474c7c7e1acb08bcfa66704e8db;p=mono.git diff --git a/mono/mini/Makefile.am.in b/mono/mini/Makefile.am.in index 59888bbc64d..28fb9ee5b8d 100755 --- a/mono/mini/Makefile.am.in +++ b/mono/mini/Makefile.am.in @@ -10,8 +10,13 @@ PLATFORM_PATH_SEPARATOR=: endif # This is needed for automake dependency generation +if SUPPORT_NULLGC +libgc_libs= +libgc_static_libs= +else libgc_libs=$(monodir)/libgc/libmonogc.la libgc_static_libs=$(monodir)/libgc/libmonogc-static.la +endif boehm_libs= \ $(monodir)/mono/metadata/libmonoruntime.la \ @@ -37,13 +42,22 @@ sgen_static_libs = \ $(monodir)/mono/utils/libmonoutils.la \ $(GLIB_LIBS) $(LIBICONV) +if FULL_AOT_TESTS +# if the tests are going to run with framework assemblies compiled with +# -d:MOBILE, tell the runtime to remap framework assemblies using the mobile +# runtime info +MOBILE_RUNTIME_ARG=--runtime=mobile +else +MOBILE_RUNTIME_ARG= +endif + CLASS=$(mcs_topdir)/class/lib/$(DEFAULT_PROFILE) RUNTIME_EXECUTABLE = $(if $(BOEHM),$(top_builddir)/mono/mini/mono-boehm,$(top_builddir)/runtime/mono-wrapper) -MINI_RUNTIME = MONO_PATH=$(CLASS) $(RUNTIME_EXECUTABLE) +MINI_RUNTIME = MONO_PATH=$(CLASS) $(RUNTIME_EXECUTABLE) $(MOBILE_RUNTIME_ARG) TOOLS_RUNTIME = MONO_PATH=$(mcs_topdir)/class/lib/build $(top_builddir)/runtime/mono-wrapper -INTERPRETER_RUNTIME = $(MINI_RUNTIME) --interpreter +INTERP_RUNTIME = $(MINI_RUNTIME) --interpreter RUNTIME_AOTCHECK = MONO_PATH="$(CLASS)$(PLATFORM_PATH_SEPARATOR)." $(RUNTIME_EXECUTABLE) MCS = CSC_SDK_PATH_DISABLED= $(TOOLS_RUNTIME) $(CSC) -unsafe -nowarn:0162 -nologo -noconfig -r:$(CLASS)/mscorlib.dll -r:$(CLASS)/System.dll -r:$(CLASS)/System.Core.dll @@ -73,7 +87,7 @@ monobinldflags=$(export_ldflags) $(extra_runtime_ldflags) if HOST_WIN32 libmonoldflags=-no-undefined -avoid-version -Wl,--kill-at $(monoldflags) else -if PLATFORM_ANDROID +if HOST_ANDROID libmonoldflags= -avoid-version $(monoldflags) else libmonoldflags=$(monoldflags) -version-info 1:0:0 @@ -154,7 +168,7 @@ if LOADED_LLVM lib_LTLIBRARIES += libmono-llvm.la libmono_llvm_la_SOURCES = mini-llvm.c mini-llvm-cpp.cpp llvm-jit.cpp libmono_llvm_la_LIBADD = $(GLIB_LIBS) $(LLVM_LIBS) $(LLVM_LDFLAGS) -if PLATFORM_DARWIN +if HOST_DARWIN libmono_llvm_la_LDFLAGS=-Wl,-undefined -Wl,suppress -Wl,-flat_namespace else libmono_llvm_la_LIBADD += $(top_builddir)/mono/mini/libmonoboehm-$(API_VER).la $(boehm_libs) @@ -298,6 +312,12 @@ genmdesc_LDADD = \ $(GLIB_LIBS) \ $(LIBICONV) +wasm_sources = \ + mini-wasm.c \ + mini-wasm.h \ + exceptions-wasm.c \ + tramp-wasm.c + x86_sources = \ mini-x86.c \ mini-x86.h \ @@ -357,19 +377,14 @@ s390x_sources = \ exceptions-s390x.c \ tramp-s390x.c -ia64_sources = \ - mini-ia64.c \ - mini-ia64.h \ - exceptions-ia64.c \ - tramp-ia64.c - darwin_sources = \ mini-darwin.c windows_sources = \ mini-windows.c \ mini-windows.h \ - mini-windows-dllmain.c + mini-windows-dllmain.c \ + mini-windows-dlldac.c posix_sources = \ mini-posix.c @@ -388,15 +403,18 @@ endif endif if ENABLE_INTERPRETER -interpreter_sources = \ - interpreter/hacks.h \ - interpreter/interp.h \ - interpreter/interp-internals.h \ - interpreter/interp.c \ - interpreter/mintops.h \ - interpreter/mintops.def \ - interpreter/mintops.c \ - interpreter/transform.c +interp_sources = \ + interp/hacks.h \ + interp/interp.h \ + interp/interp-internals.h \ + interp/interp.c \ + interp/mintops.h \ + interp/mintops.def \ + interp/mintops.c \ + interp/transform.c +else +interp_sources = \ + interp/interp-stubs.c endif if ENABLE_LLVM @@ -444,6 +462,7 @@ common_sources = \ aot-compiler.h \ aot-compiler.c \ aot-runtime.c \ + aot-runtime-wasm.c \ graph.c \ mini-codegen.c \ mini-exceptions.c \ @@ -475,12 +494,15 @@ common_sources = \ llvm-runtime.h \ type-checking.c \ lldb.h \ - lldb.c + lldb.c \ + memory-access.c \ + mini-profiler.c test_sources = \ basic-calls.cs \ basic-long.cs \ bench.cs \ + builtin-types.cs \ objects.cs \ arrays.cs \ basic-float.cs \ @@ -496,17 +518,17 @@ test_sources = \ basic-vectors.cs \ aot-tests.cs \ gc-test.cs \ - gshared.cs - -if NACL_CODEGEN -test_sources += nacl.cs -endif + gshared.cs \ + unaligned.cs \ + MemoryIntrinsics.il \ + mixed.cs regtests_UNIVERSAL = \ basic.exe \ basic-float.exe \ basic-long.exe \ basic-calls.exe \ + builtin-types.exe \ objects.exe \ arrays.exe \ basic-math.exe \ @@ -515,27 +537,22 @@ regtests_UNIVERSAL = \ devirtualization.exe \ generics.exe \ basic-simd.exe \ + unaligned.exe \ basic-vectors.exe -if NACL_CODEGEN -regtests_UNIVERSAL += nacl.exe -endif - regtests_DISABLED = if FULL_AOT_TESTS -regtests_DISABLED += +regtests_DISABLED += builtin-types.exe endif regtests = $(filter-out $(regtests_DISABLED),$(regtests_UNIVERSAL)) -iregtests = \ - basic.exe \ - basic-float.exe \ - basic-long.exe \ - basic-calls.exe \ - generics.exe \ - objects.exe +if WASM +arch_sources = $(wasm_sources) +arch_built=cpu-wasm.h +arch_define=__wasm__ +endif if X86 arch_sources = $(x86_sources) @@ -600,29 +617,23 @@ arch_built=cpu-s390x.h arch_define=__s390__ endif -if IA64 -arch_sources = $(ia64_sources) -arch_built = cpu-ia64.h -arch_define=__ia64__ -endif - if HOST_WIN32 os_sources = $(windows_sources) monobin_platform_ldflags= endif -if PLATFORM_SIGPOSIX +if HOST_SIGPOSIX os_sources = $(posix_sources) monobin_platform_ldflags= endif -if PLATFORM_DARWIN +if HOST_DARWIN os_sources = $(darwin_sources) $(posix_sources) #monobin_platform_ldflags=-sectcreate __TEXT __info_plist $(top_srcdir)/mono/mini/Info.plist -framework CoreFoundation -framework Foundation monobin_platform_ldflags=-framework CoreFoundation -framework Foundation endif -libmini_la_SOURCES = $(common_sources) $(llvm_sources) $(llvm_runtime_sources) $(interpreter_sources) $(arch_sources) $(os_sources) +libmini_la_SOURCES = $(common_sources) $(llvm_sources) $(llvm_runtime_sources) $(interp_sources) $(arch_sources) $(os_sources) libmini_la_CFLAGS = $(mono_CFLAGS) libmonoboehm_2_0_la_SOURCES = @@ -648,7 +659,7 @@ libmonoincludedir = $(includedir)/mono-$(API_VER)/mono/jit libmonoinclude_HEADERS = jit.h -CSFLAGS = -unsafe -nowarn:0219,0169,0414,0649 +CSFLAGS = -unsafe -nowarn:0219,0169,0414,0649,0618 basic-simd.exe: basic-simd.cs TestDriver.dll $(MCS) -out:$@ $(CSFLAGS) $< -r:TestDriver.dll -r:$(CLASS)/Mono.Simd.dll @@ -656,12 +667,18 @@ basic-simd.exe: basic-simd.cs TestDriver.dll basic-vectors.exe: basic-vectors.cs TestDriver.dll $(MCS) -out:$@ $(CSFLAGS) $< -r:TestDriver.dll -r:$(CLASS)/System.Numerics.dll -r:$(CLASS)/System.Numerics.Vectors.dll +builtin-types.exe: builtin-types.cs TestDriver.dll + $(MCS) -out:$@ $(CSFLAGS) -define:ARCH_$(shell echo $$((8 * $(SIZEOF_VOID_P)))) $< -r:TestDriver.dll + nacl.exe: nacl.cs TestDriver.dll $(MCS) -out:$@ $(CSFLAGS) $< -r:TestDriver.dll -r:$(CLASS)/Mono.Simd.dll generics.exe: generics.cs TestDriver.dll generics-variant-types.dll $(MCS) -out:$@ $(CSFLAGS) $< -r:TestDriver.dll -r:generics-variant-types.dll -r:$(CLASS)/System.Core.dll +unaligned.exe: unaligned.cs TestDriver.dll MemoryIntrinsics.dll + $(MCS) -out:$@ $(CSFLAGS) $< -r:TestDriver.dll -r:MemoryIntrinsics.dll + %.exe: %.cs TestDriver.dll $(MCS) -out:$@ $(CSFLAGS) $< -r:TestDriver.dll @@ -674,26 +691,29 @@ TestDriver.dll: $(srcdir)/TestDriver.cs $(srcdir)/TestHelpers.cs generics-variant-types.dll: generics-variant-types.il $(ILASM) -dll -output=$@ $< -if NACL_CODEGEN -GENMDESC_OPTS=--nacl -else !NACL_CODEGEN +MemoryIntrinsics.dll: MemoryIntrinsics.il + $(ILASM) -dll -output=$@ $< + GENMDESC_OPTS= -endif !NACL_CODEGEN # 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 $(srcdir)/genmdesc.pl $(arch_define) $(srcdir) $(GENMDESC_OPTS) -else !CROSS_COMPILING -if NACL_CODEGEN +else +if WASM GENMDESC_PRG=perl $(srcdir)/genmdesc.pl $(arch_define) $(srcdir) $(GENMDESC_OPTS) else GENMDESC_PRG=./genmdesc $(GENMDESC_OPTS) endif endif !CROSS_COMPILING +cpu-wasm.h: cpu-wasm.md genmdesc$(EXEEXT) + $(GENMDESC_PRG) cpu-wasm.h wasm_desc $(srcdir)/cpu-wasm.md + cpu-x86.h: cpu-x86.md genmdesc$(EXEEXT) $(GENMDESC_PRG) cpu-x86.h x86_desc $(srcdir)/cpu-x86.md @@ -718,9 +738,6 @@ cpu-sparc.h: cpu-sparc.md genmdesc$(EXEEXT) cpu-s390x.h: cpu-s390x.md genmdesc$(EXEEXT) $(GENMDESC_PRG) cpu-s390x.h s390x_cpu_desc $(srcdir)/cpu-s390x.md -cpu-ia64.h: cpu-ia64.md genmdesc$(EXEEXT) - $(GENMDESC_PRG) cpu-ia64.h ia64_desc $(srcdir)/cpu-ia64.md - cpu-mips.h: cpu-mips.md genmdesc$(EXEEXT) $(GENMDESC_PRG) cpu-mips.h mips_desc $(srcdir)/cpu-mips.md @@ -746,8 +763,11 @@ rcheck-nunit: mono $(regtests) rcheck: mono $(regtests) $(MINI_RUNTIME) --regression $(regtests) -richeck: mono $(iregtests) - $(INTERPRETER_RUNTIME) --regression $(iregtests) +richeck: mono $(regtests) + $(INTERP_RUNTIME) --regression $(regtests) + +mixedcheck: mono mixed.exe + $(MINI_RUNTIME) --interp=jit=JitClass mixed.exe if ARM check-seq-points: @@ -778,6 +798,7 @@ gsharedvtcheck: $(MAKE) fullaotcheck GSHAREDVT=1 fullaot_regtests = $(regtests) aot-tests.exe $(if $(GSHAREDVT),gshared.exe) +fullaot_testing_deps = generics-variant-types.dll TestDriver.dll MemoryIntrinsics.dll FULLAOT_LIBS_UNIVERSAL = \ mscorlib.dll \ @@ -803,19 +824,20 @@ FULLAOT_LIBS_DISABLED += \ System.Configuration.dll endif + FULLAOT_LIBS = $(filter-out $(FULLAOT_LIBS_DISABLED),$(FULLAOT_LIBS_UNIVERSAL)) FULLAOT_TMP_DIR=$(top_builddir)/mono/mini/fullaot-tmp # This currently only works on amd64/arm -fullaotcheck: $(mono) $(fullaot_regtests) +fullaotcheck: $(mono) $(fullaot_regtests) $(fullaot_testing_deps) rm -rf $(FULLAOT_TMP_DIR) mkdir $(FULLAOT_TMP_DIR) $(MAKE) fullaot-libs AOT_FLAGS="full,$(MONO_FULLAOT_ADDITIONAL_ARGS)$(INVARIANT_AOT_OPTIONS)" GSHAREDVT=$(GSHAREDVT) - cp $(regtests) $(fullaot_regtests) generics-variant-types.dll TestDriver.dll $(FULLAOT_TMP_DIR)/ - MONO_PATH=$(FULLAOT_TMP_DIR) $(top_builddir)/runtime/mono-wrapper $(LLVM_AOT_RUNTIME_OPTS) $(GSHAREDVT_RUNTIME_OPTS) --aot="full,$(MONO_FULLAOT_ADDITIONAL_ARGS)$(INVARIANT_AOT_OPTIONS)" $(FULLAOT_TMP_DIR)/{generics-variant-types.dll,TestDriver.dll,*.exe} || exit 1 + cp $(regtests) $(fullaot_regtests) $(fullaot_testing_deps) $(FULLAOT_TMP_DIR)/ + MONO_PATH=$(FULLAOT_TMP_DIR) $(top_builddir)/runtime/mono-wrapper $(MOBILE_RUNTIME_ARG) $(LLVM_AOT_RUNTIME_OPTS) $(GSHAREDVT_RUNTIME_OPTS) --aot="full,$(MONO_FULLAOT_ADDITIONAL_ARGS)$(INVARIANT_AOT_OPTIONS)" $(FULLAOT_TMP_DIR)/{*.dll,*.exe} || exit 1 ln -s $(if $(MONO_EXECUTABLE),$(MONO_EXECUTABLE),$$PWD/mono) $(FULLAOT_TMP_DIR)/ - for i in $(fullaot_regtests); do echo $$i; MONO_PATH=$(FULLAOT_TMP_DIR) $(top_builddir)/runtime/mono-wrapper --full-aot $(FULLAOT_TMP_DIR)/$$i --exclude '!FULLAOT' $(ARCH_FULLAOT_EXCLUDE) || exit 1; done + for i in $(fullaot_regtests); do echo $$i; MONO_PATH=$(FULLAOT_TMP_DIR) $(top_builddir)/runtime/mono-wrapper $(MOBILE_RUNTIME_ARG) --full-aot $(FULLAOT_TMP_DIR)/$$i --exclude '!FULLAOT' $(ARCH_FULLAOT_EXCLUDE) || exit 1; done # This can run in parallel fullaot-libs: $(patsubst %,fullaot-tmp/%.dylib,$(FULLAOT_LIBS)) @@ -823,7 +845,7 @@ fullaot-libs: $(patsubst %,fullaot-tmp/%.dylib,$(FULLAOT_LIBS)) fullaot-tmp/%.dylib: $(CLASS)/% cp $(CLASS)/$* fullaot-tmp/ mkdir fullaot-tmp/$*-tmp - MONO_PATH="fullaot-tmp/$(PLATFORM_PATH_SEPARATOR)$(CLASS)" $(top_builddir)/runtime/mono-wrapper $(if $(GSHAREDVT),-O=gsharedvt) --aot=$(AOT_FLAGS),temp-path=fullaot-tmp/$*-tmp fullaot-tmp/$* + MONO_PATH="fullaot-tmp/$(PLATFORM_PATH_SEPARATOR)$(CLASS)" $(top_builddir)/runtime/mono-wrapper $(MOBILE_RUNTIME_ARG) $(if $(GSHAREDVT),-O=gsharedvt) --aot=$(AOT_FLAGS),temp-path=fullaot-tmp/$*-tmp fullaot-tmp/$* rm -rf fullaot-tmp/$*-tmp llvmfullaotcheck: @@ -835,10 +857,10 @@ llvmonlycheck: mono $(llvmonly_regtests) rm -rf fullaot-tmp mkdir fullaot-tmp $(MAKE) fullaot-libs AOT_FLAGS="llvmonly,$(MONO_FULLAOT_ADDITIONAL_ARGS)$(INVARIANT_AOT_OPTIONS)" - cp $(llvmonly_regtests) generics-variant-types.dll TestDriver.dll fullaot-tmp/ - MONO_PATH=fullaot-tmp $(top_builddir)/runtime/mono-wrapper --aot=llvmonly fullaot-tmp/{generics-variant-types.dll,TestDriver.dll,*.exe} || exit 1 + cp $(llvmonly_regtests) $(fullaot_testing_deps) fullaot-tmp/ + MONO_PATH=fullaot-tmp $(top_builddir)/runtime/mono-wrapper $(MOBILE_RUNTIME_ARG) --aot=llvmonly fullaot-tmp/{*.dll,*.exe} || exit 1 ln -s $$PWD/mono fullaot-tmp/ - for i in $(llvmonly_regtests); do echo $$i; MONO_PATH=fullaot-tmp $(top_builddir)/runtime/mono-wrapper --llvmonly fullaot-tmp/$$i --exclude '!BITCODE' || exit 1; done + for i in $(llvmonly_regtests); do echo $$i; MONO_PATH=fullaot-tmp $(top_builddir)/runtime/mono-wrapper $(MOBILE_RUNTIME_ARG) --llvmonly fullaot-tmp/$$i --exclude '!BITCODE' || exit 1; done gccheck: gc-test.exe MONO_GC_PARAMS=stack-mark=precise MONO_GC_DEBUG=clear-at-gc ./mono-sgen gc-test.exe @@ -881,6 +903,7 @@ EXTRA_DIST = TestDriver.cs \ TestHelpers.cs \ genmdesc.pl \ $(test_sources) \ + $(wasm_sources) cpu-wasm.md \ $(x86_sources) cpu-x86.md \ $(amd64_sources) cpu-amd64.md \ $(ppc_sources) cpu-ppc.md cpu-ppc64.md \ @@ -889,7 +912,6 @@ EXTRA_DIST = TestDriver.cs \ $(mips_sources) cpu-mips.md \ $(sparc_sources) cpu-sparc.md \ $(s390x_sources) cpu-s390x.md \ - $(ia64_sources) cpu-ia64.md \ $(windows_sources) \ $(darwin_sources) Info.plist \ $(posix_sources) \