Merge pull request #4840 from kumpera/unaligned-access
[mono.git] / mcs / class / corlib / Makefile
1 thisdir = class/corlib
2 SUBDIRS =
3 include ../../build/rules.make
4 export __SECURITY_BOOTSTRAP_DB=$(topdir)/class/corlib
5
6 LIBRARY = corlib.dll
7 LIBRARY_NAME = mscorlib.dll
8
9 LIB_MCS_FLAGS = $(REFERENCE_SOURCES_FLAGS) $(RESOURCE_FILES:%=-resource:%)
10
11 #LIBRARY_USE_INTERMEDIATE_FILE = yes
12
13 ifeq (2, $(FRAMEWORK_VERSION_MAJOR))
14 LIB_MCS_FLAGS += -runtimemetadataversion:v4.0.30319
15 else
16 ifeq (4, $(FRAMEWORK_VERSION_MAJOR))
17 LIB_MCS_FLAGS += -runtimemetadataversion:v4.0.30319
18 else
19 $(error Unknown framework version)
20 endif
21 endif
22
23 ifeq ($(PROFILE),build)
24 CSC_RUNTIME_FLAGS=--profile=aot:output=$(topdir)/class/lib/$(PROFILE)/csc.$(LIBRARY).aotprofile
25 endif
26
27 RESOURCE_STRINGS = ../referencesource/mscorlib/mscorlib.txt
28
29 RESX_RESOURCE_STRING = \
30         ../../../external/corert/src/System.Private.CoreLib/src/Resources/Strings.resx \
31         ../../../external/corefx/src/System.Collections.Concurrent/src/Resources/Strings.resx
32
33 LIBRARY_COMPILE = $(BOOT_COMPILE)
34 LIBRARY_INSTALL_DIR = $(mono_libdir)/mono/$(FRAMEWORK_VERSION)
35
36 RESOURCE_FILES = \
37         resources/charinfo.nlp \
38         resources/collation.core.bin \
39         resources/collation.tailoring.bin \
40         resources/collation.cjkCHS.bin \
41         resources/collation.cjkCHT.bin \
42         resources/collation.cjkJA.bin \
43         resources/collation.cjkKO.bin \
44         resources/collation.cjkKOlv2.bin \
45         LinkerDescriptor/mscorlib.xml
46
47 REFERENCE_SOURCES_FLAGS = -d:FEATURE_PAL,GENERICS_WORK,FEATURE_LIST_PREDICATES,FEATURE_SERIALIZATION,FEATURE_ASCII,FEATURE_LATIN1,FEATURE_UTF7,FEATURE_UTF32,MONO_HYBRID_ENCODING_SUPPORT,FEATURE_ASYNC_IO,NEW_EXPERIMENTAL_ASYNC_IO,FEATURE_UTF32,FEATURE_EXCEPTIONDISPATCHINFO,FEATURE_CORRUPTING_EXCEPTIONS,FEATURE_EXCEPTION_NOTIFICATIONS,FEATURE_STRONGNAME_MIGRATION,FEATURE_USE_LCID,FEATURE_FUSION,FEATURE_CRYPTO,FEATURE_X509_SECURESTRINGS,FEATURE_SYNCHRONIZATIONCONTEXT,FEATURE_SYNCHRONIZATIONCONTEXT_WAIT,HAS_CORLIB_CONTRACTS
48
49 ifndef MOBILE_PROFILE
50 REFERENCE_SOURCES_FLAGS += -d:FEATURE_MACL
51 endif
52
53 ifndef AOT_FRIENDLY_PROFILE
54 REFERENCE_SOURCES_FLAGS += -d:FEATURE_REMOTING,MONO_COM,FEATURE_COMINTEROP,FEATURE_ROLE_BASED_SECURITY
55 endif
56
57 ifndef NO_THREAD_ABORT
58 REFERENCE_SOURCES_FLAGS += -d:MONO_FEATURE_THREAD_ABORT
59 TEST_MCS_FLAGS += -d:MONO_FEATURE_THREAD_ABORT
60 endif
61
62 ifndef NO_THREAD_SUSPEND_RESUME
63 REFERENCE_SOURCES_FLAGS += -d:MONO_FEATURE_THREAD_SUSPEND_RESUME
64 TEST_MCS_FLAGS += -d:MONO_FEATURE_THREAD_SUSPEND_RESUME
65 endif
66
67 ifndef NO_MULTIPLE_APPDOMAINS
68 REFERENCE_SOURCES_FLAGS += -d:MONO_FEATURE_MULTIPLE_APPDOMAINS
69 TEST_MCS_FLAGS += -d:MONO_FEATURE_MULTIPLE_APPDOMAINS
70 endif
71
72 ifndef NO_CONSOLE
73 LIB_MCS_FLAGS += -d:MONO_FEATURE_CONSOLE
74 endif
75
76 ifdef MONO_FEATURE_APPLETLS
77 LIB_MCS_FLAGS += -d:MONO_FEATURE_APPLETLS
78 endif
79
80 ifdef ONLY_APPLETLS
81 LIB_MCS_FLAGS += -d:ONLY_APPLETLS
82 endif
83
84 ifdef MONO_FEATURE_APPLE_X509
85 LIB_MCS_FLAGS += -d:MONO_FEATURE_APPLE_X509
86 endif
87
88 WARNING_ABOUT_DISABLED_WARNING=1635
89 LOCAL_MCS_FLAGS = -unsafe -nostdlib -nowarn:612,618,$(WARNING_ABOUT_DISABLED_WARNING) -d:INSIDE_CORLIB,MONO_CULTURE_DATA -d:LIBC $(REFERENCE_SOURCES_FLAGS)
90 DEFAULT_REFERENCES =
91
92 TEST_LIB_REFS = System.Core System
93
94 ifndef AOT_FRIENDLY_PROFILE
95 ifneq ($(PROFILE),testing_aot_hybrid)
96 TEST_LIB_REFS += Mono.Posix
97 endif
98 endif
99
100 # System.IO/DirectoryInfoTest.cs needs Mono.Posix
101 TEST_MCS_FLAGS += -debug -nowarn:168,219,618,672 -unsafe \
102                                  -define:MONO_DATACONVERTER_STATIC_METHODS $(TEST_RESX_RESOURCES:%=-resource:%)
103
104
105 CC_PROFILE := $(filter monotouch% xammac, $(PROFILE))
106 ifdef CC_PROFILE
107
108 BUILT_SOURCES = \
109         CommonCrypto/MD5CryptoServiceProvider.g.cs      \
110         CommonCrypto/SHA256Managed.g.cs \
111         CommonCrypto/RC2CryptoServiceProvider.g.cs \
112         CommonCrypto/SHA384Managed.g.cs \
113         CommonCrypto/DESCryptoServiceProvider.g.cs \
114         CommonCrypto/SHA1CryptoServiceProvider.g.cs     \
115         CommonCrypto/SHA512Managed.g.cs \
116         CommonCrypto/MD2Managed.g.cs \
117         CommonCrypto/SHA1Managed.g.cs \
118         CommonCrypto/TripleDESCryptoServiceProvider.g.cs \
119         CommonCrypto/MD4Managed.g.cs
120
121 CommonCrypto/%.g.cs:
122         $(MAKE) -C CommonCrypto
123
124 endif
125
126 EXTRA_DISTFILES = \
127         Test/resources/MyResources.resources    \
128         Test/resources/MyResources.de.resources \
129         Test/resources/Empty.resources          \
130         Test/resources/AFile.txt                \
131         Test/resources/StreamTest.resources     \
132         Test/resources/StreamTest.ja.resources  \
133         Test/resources/bug81759.resources       \
134         Test/resources/415628.bin               \
135         Test/resources/Fergie.GED               \
136         Test/resources/culture-*.cs             \
137         $(RESOURCE_FILES) \
138         $(TEST_RESOURCES:.resources=.resx)
139
140 TEST_RESX_RESOURCES = \
141         Test/resources/Resources.resources
142
143 TEST_RESX_RESOURCES_SATELITE = \
144         Test/resources/Resources.es-ES.resources \
145         Test/resources/Resources.nn-NO.resources \
146
147 CLEAN_FILES += $(TEST_RESX_RESOURCES)
148
149 include $(topdir)/build/library.make
150
151 $(TEST_RESX_RESOURCES) $(TEST_RESX_RESOURCES_SATELITE): %.resources: %.resx
152         $(RESGEN) $< || cp $@.prebuilt $@
153
154 TEST_RESOURCES = $(TEST_RESX_RESOURCES) $(TEST_RESX_RESOURCES_SATELITE)
155
156 satellite_assembly1 = es-ES/$(patsubst %.dll,%.resources.dll,$(test_lib))
157 satellite_assembly2 = nn-NO/$(patsubst %.dll,%.resources.dll,$(test_lib))
158
159 $(test_lib): $(TEST_RESOURCES) $(satellite_assembly1) $(satellite_assembly2) 
160
161 $(satellite_assembly1): Test/resources/culture-es-ES.cs Test/resources/Resources.es-ES.resources
162         @mkdir -p es-ES
163         $(CSCOMPILE) -target:library -r:$(topdir)/class/lib/$(PROFILE)/mscorlib.dll Test/resources/culture-es-ES.cs -resource:Test/resources/Resources.es-ES.resources -out:$@
164
165 $(satellite_assembly2): Test/resources/culture-nn-NO.cs Test/resources/Resources.nn-NO.resources
166         @mkdir -p nn-NO
167         $(CSCOMPILE) -target:library -r:$(topdir)/class/lib/$(PROFILE)/mscorlib.dll Test/resources/culture-nn-NO.cs -resource:Test/resources/Resources.nn-NO.resources -out:$@
168
169 vtsdir = Test/System.Runtime.Serialization.Formatters.Binary/VersionTolerantSerialization
170 vtslibs = \
171         $(vtsdir)/$(PROFILE)_TestLib/1.0/Address.dll \
172         $(vtsdir)/$(PROFILE)_TestLib/2.0/Address.dll \
173         $(vtsdir)/$(PROFILE)_TestLib/3.0/Address.dll \
174         $(vtsdir)/$(PROFILE)_TestLib/4.0/Address.dll \
175         $(vtsdir)/$(PROFILE)_TestLib/5.0/Address.dll \
176         $(vtsdir)/$(PROFILE)_TestLib/6.0/Address.dll
177
178 test-vts: $(vtslibs) $(vtsdir)/$(PROFILE)_TestLib/BinarySerializationOverVersions.exe
179
180 $(vtsdir)/$(PROFILE)_TestLib/%/Address.dll: $(vtsdir)/VersionTolerantSerializationTestLib/%/Address.cs
181         @mkdir -p $(dir $@)
182         $(CSCOMPILE) -target:library -warn:0 -r:$(topdir)/class/lib/$(PROFILE)/mscorlib.dll -out:$@ $^
183
184 $(vtsdir)/$(PROFILE)_TestLib/BinarySerializationOverVersions.exe: $(vtsdir)/BinarySerializationOverVersions.cs $(vtsdir)/$(PROFILE)_TestLib/1.0/Address.dll $(test_nunit_dep)
185         $(CSCOMPILE) $(test_nunit_ref) -warn:0 \
186                 -r:$(vtsdir)/$(PROFILE)_TestLib/1.0/Address.dll \
187                 -r:$(topdir)/class/lib/$(PROFILE)/mscorlib.dll \
188                 -r:$(topdir)/class/lib/$(PROFILE)/System.dll \
189                 $(vtsdir)/BinarySerializationOverVersions.cs -out:$@
190         @cp $(vtsdir)/$(PROFILE)_TestLib/1.0/Address.dll $(vtsdir)/$(PROFILE)_TestLib
191
192 # Need to define TEST_MONO_PATH to an absolute dir since the test is ran from a subdir
193 TEST_MONO_PATH=$(PWD)/../lib/$(PROFILE)
194
195 run-test-vts: test-vts
196         @echo Running vts tests...
197         PATH="$(TEST_RUNTIME_WRAPPERS_PATH):$(PATH)" $(TEST_RUNTIME) $(RUNTIME_FLAGS) $(TEST_HARNESS) $(NOSHADOW_FLAG) \
198                 $(vtsdir)/$(PROFILE)_TestLib/BinarySerializationOverVersions.exe
199
200 ifdef NO_TEST
201 NO_VTS_TEST = yes
202 endif
203
204 ifndef NO_VTS_TEST
205 test: test-vts
206 run-test: run-test-vts
207 else
208 test:
209 run-test:
210 endif
211
212 EXTRA_DISTFILES += \
213         $(vtsdir)/VersionTolerantSerializationTestLib/1.0/Address.cs \
214         $(vtsdir)/VersionTolerantSerializationTestLib/2.0/Address.cs \
215         $(vtsdir)/VersionTolerantSerializationTestLib/3.0/Address.cs \
216         $(vtsdir)/VersionTolerantSerializationTestLib/4.0/Address.cs \
217         $(vtsdir)/VersionTolerantSerializationTestLib/5.0/Address.cs \
218         $(vtsdir)/VersionTolerantSerializationTestLib/6.0/Address.cs \
219         $(vtsdir)/BinarySerializationOverVersions.cs
220
221 #
222 # Android TimeZoneInfo testing....
223 #
224
225 TMP_FILE1=tzi1.tmp
226 TMP_FILE2=tzi2.tmp
227
228 # Remove some code that is protected so we don't have to include all the corlib files.
229 tzi.exe:System/AndroidPlatform.cs $(wildcard System/TimeZone*.cs) ../../build/common/Consts.cs ../../build/common/Locale.cs ../Mono.Options/Mono.Options/Options.cs
230         trap "rm -f $(TMP_FILE1) $(TMP_FILE2)" EXIT INT QUIT TERM && \
231         sed 's/Environment\.GetResourceString/string.Format/g' ../referencesource/mscorlib/system/timezoneinfo.cs > $(TMP_FILE1) && \
232         sed 's/StringBuilder\.DefaultCapacity/100/g' ../referencesource/mscorlib/system/text/stringbuildercache.cs > $(TMP_FILE2) && \
233         $(MCS) /debug+ /out:$@ -unsafe -nowarn:612,618 -d:INSIDE_CORLIB,MONO_CULTURE_DATA -d:LIBC $(REFERENCE_SOURCES_FLAGS) "/d:SELF_TEST;NET_1_1;NET_2_0;MOBILE;NET_3_5;NET_4_0;NET_4_5;MONO;DISABLE_CAS_USE;MOBILE;MOBILE_DYNAMIC;MONODROID;ANDROID" $^ $(TMP_FILE1) $(TMP_FILE2)
234
235 android-pull-tzdb:
236         mkdir -p android/tzdb/usr/share/zoneinfo
237         mkdir -p android/tzdb/misc/zoneinfo/zoneinfo
238         android_root=`adb shell echo '$$ANDROID_ROOT' | tr -d "\r"` ; \
239         android_data=`adb shell echo '$$ANDROID_DATA' | tr -d "\r"` ; \
240         adb $(ADB_TARGET) pull $$android_root/usr/share/zoneinfo    android/tzdb/usr/share/zoneinfo || true ; \
241         adb $(ADB_TARGET) pull $$android_data/misc/zoneinfo/tzdata  android/tzdb/misc/zoneinfo || true
242
243 android-dump-tzdata: tzi.exe android-pull-tzdb
244         export
245         __XA_OVERRIDE_TIMEZONE_ID__=America/New_York ANDROID_ROOT="`pwd`/android/tzdb" ANDROID_DATA="`pwd`/android/tzdb" $(TEST_RUNTIME) tzi.exe -o android/tzdata