Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[mono][infra] Enable runtime tests in fullAOT LLVM mode on linux-x64 #92057

Merged
merged 110 commits into from
Apr 5, 2024
Merged
Show file tree
Hide file tree
Changes from 26 commits
Commits
Show all changes
110 commits
Select commit Hold shift + click to select a range
fd56ecb
Use llvm toolchain instead of binutils on linux
kotlarmilos Sep 14, 2023
870e2d4
Increase job timeouts
kotlarmilos Sep 15, 2023
96c3dd5
Pass docker option to increase memory limit
kotlarmilos Sep 15, 2023
fa12bb3
Pass docker option to increase memory limit
kotlarmilos Sep 15, 2023
133f3a8
Pass docker option to increase memory limit
kotlarmilos Sep 16, 2023
ba0c40e
Test 64g memory limit
kotlarmilos Sep 18, 2023
82bfa05
Add msbuild parallelism limit
kotlarmilos Sep 19, 2023
8eb0cab
Set maxcpucount to 1
kotlarmilos Sep 20, 2023
24628ff
Increase job timeout
kotlarmilos Sep 20, 2023
93ec6c8
Enable aggressive trimming
kotlarmilos Sep 21, 2023
ade75a2
Try using memory swap
kotlarmilos Sep 22, 2023
0345bff
Disable JIT testing group
kotlarmilos Sep 23, 2023
451c85f
Test a subset of runtime tests
kotlarmilos Sep 23, 2023
ec2fe19
Merge branch 'dotnet:main' into bugfix/linux-x64-fullaot-job
kotlarmilos Sep 25, 2023
8f41239
Run only linux-x64 job
kotlarmilos Sep 26, 2023
c188cfa
Try enabling swap from docker container
kotlarmilos Sep 26, 2023
1ef87f2
Enable baseservices tests only
kotlarmilos Sep 27, 2023
b574489
Test baseservices/mono
kotlarmilos Sep 29, 2023
06febc6
Set maxcpucount to 1
kotlarmilos Sep 29, 2023
fbc914c
Test baseservices subset
kotlarmilos Sep 29, 2023
a62f417
Merge branch 'main' into bugfix/linux-x64-fullaot-job
kotlarmilos Oct 2, 2023
0af7018
Disable failing tests
kotlarmilos Oct 2, 2023
a2fe74a
Revert timeout
kotlarmilos Oct 2, 2023
fe59c5a
Fix RuntimeVariant property
kotlarmilos Oct 2, 2023
a7d7d2c
Disable failing tests
kotlarmilos Oct 3, 2023
1d956f0
Add toolchain parameters to the AOT compiler
kotlarmilos Oct 5, 2023
72f1414
Test baseservices/mono tree
kotlarmilos Oct 6, 2023
a4bac46
Revert changes to test the CI
kotlarmilos Oct 7, 2023
e98235d
Merge branch 'dotnet:main' into bugfix/linux-x64-fullaot-job
kotlarmilos Oct 9, 2023
6fc3476
Merge branch 'dotnet:main' into bugfix/linux-x64-fullaot-job
kotlarmilos Oct 19, 2023
9913498
Include System.Private.CoreLib assembly only
kotlarmilos Oct 19, 2023
b61f8ef
Testing only - move the job to the runtime.yml to run on each PR
kotlarmilos Oct 19, 2023
a67303e
Testing only - move the job to the runtime.yml to run on each PR
kotlarmilos Oct 19, 2023
66f0481
Exclude coreroot libs
kotlarmilos Oct 20, 2023
bc13a90
Include System.Private.CoreLib assembly only
kotlarmilos Oct 20, 2023
5af9f34
Merge branch 'dotnet:main' into bugfix/linux-x64-fullaot-job
kotlarmilos Oct 23, 2023
7a1365d
Add swap space to the docker container
kotlarmilos Oct 23, 2023
358ba2a
Pass options to docker container
kotlarmilos Oct 24, 2023
da25b50
Merge branch 'main' of github.com:kotlarmilos/runtime into bugfix/lin…
kotlarmilos Dec 7, 2023
0691089
Merge branch 'dotnet:main' into bugfix/linux-x64-fullaot-job
kotlarmilos Dec 7, 2023
7775dd5
[infra] Utilize linux x64 XL queue
kotlarmilos Dec 7, 2023
5bf0643
[infra] Utilize linux x64 XL queue
kotlarmilos Dec 7, 2023
612fc81
[test] Disable runtime tests
kotlarmilos Dec 7, 2023
c69b705
[test] Disable CI jobs
kotlarmilos Dec 7, 2023
ed8f002
[test] Disable CI jobs
kotlarmilos Dec 7, 2023
bc9c906
[test] Disable CI jobs
kotlarmilos Dec 7, 2023
b43f611
[test] Disable CI jobs
kotlarmilos Dec 7, 2023
936a59a
[test] Test the CI job
kotlarmilos Dec 7, 2023
c20b843
[test] Test the CI job
kotlarmilos Dec 7, 2023
f771c02
[test] Test the CI job
kotlarmilos Dec 7, 2023
fd637c2
[test] Test the CI job
kotlarmilos Dec 7, 2023
2e53492
[test] Test the CI job
kotlarmilos Dec 7, 2023
2f46c1b
[test] Test the CI job
kotlarmilos Dec 7, 2023
db8ca13
[test] Test the CI job
kotlarmilos Dec 7, 2023
31e1c2a
[test] Test the new ubuntu xl queue
kotlarmilos Dec 8, 2023
2405b09
[tests] Try running mini runtime tests
kotlarmilos Dec 11, 2023
0c301ba
[tests] Try running mini runtime tests
kotlarmilos Dec 11, 2023
af288cb
[tests] Try running mini runtime tests
kotlarmilos Dec 11, 2023
c51cdc7
[tests] Try running mini runtime tests
kotlarmilos Dec 11, 2023
d03314f
[tests] Try running mini runtime tests
kotlarmilos Dec 11, 2023
d1be24d
[tests] Try running mini runtime tests
kotlarmilos Dec 11, 2023
abefc4b
[tests] Try running mini runtime tests
kotlarmilos Dec 13, 2023
b4fe13c
[tests] Try running mini runtime tests
kotlarmilos Dec 13, 2023
ca5ea14
[tests] Try running mini runtime tests
kotlarmilos Dec 13, 2023
3b45c90
[tests] Try running mini runtime tests
kotlarmilos Dec 14, 2023
9109cde
[tests] Try running mini runtime tests
kotlarmilos Dec 14, 2023
babcfde
Merge branch 'dotnet:main' into bugfix/linux-x64-fullaot-job
kotlarmilos Dec 27, 2023
57f8366
Enable runtime.yml jobs
kotlarmilos Feb 9, 2024
124b053
Merge branch 'dotnet:main' into bugfix/linux-x64-fullaot-job
kotlarmilos Feb 9, 2024
22b155a
Disable runtime.yml jobs
kotlarmilos Feb 9, 2024
97c2d87
Revert unnecessary changes
kotlarmilos Feb 9, 2024
0304a87
Add missing param
kotlarmilos Feb 9, 2024
cbb9d45
Enable llvm in runtime build
kotlarmilos Feb 9, 2024
4ae294c
[tests] Disable failing tests
kotlarmilos Feb 12, 2024
765f7ad
[tests] Disable failing tests
kotlarmilos Feb 12, 2024
c1fb96e
Merge branch 'dotnet:main' into bugfix/linux-x64-fullaot-job
kotlarmilos Feb 15, 2024
5df1f70
[tests] Disable failing tests
kotlarmilos Feb 16, 2024
0a8baab
Merge branch 'bugfix/linux-x64-fullaot-job' of github.com:kotlarmilos…
kotlarmilos Feb 16, 2024
65cf2ab
[tests] Disable failing tests
kotlarmilos Feb 19, 2024
d967a00
[tests] Disable failing tests
kotlarmilos Feb 19, 2024
9f047ed
Enable arm64 fullAOT llvm job
kotlarmilos Feb 23, 2024
db7ef9d
Enable runtime.yml jobs
kotlarmilos Mar 7, 2024
41e6975
Merge branch 'main' into bugfix/linux-x64-fullaot-job
kotlarmilos Mar 7, 2024
dd9e817
Disable runtime.yml jobs
kotlarmilos Mar 7, 2024
639b73b
Remove arm64 job
kotlarmilos Mar 8, 2024
c32760f
Remove arm64 job
kotlarmilos Mar 8, 2024
acdb941
Revert temporary changes
kotlarmilos Mar 28, 2024
ccdda9d
Merge branch 'main' of github.com:kotlarmilos/runtime into bugfix/lin…
kotlarmilos Mar 28, 2024
55202af
Fix formatting
kotlarmilos Mar 28, 2024
a54c281
Enable llvmfullaot job in extra-platforms pipeline
kotlarmilos Mar 29, 2024
814614a
Exclude Microsoft.DotNet.XUnitExtensions.dll from AOT compilation
kotlarmilos Apr 1, 2024
df9aee8
Run only baseservices subset due to OOM issue
kotlarmilos Apr 1, 2024
36fb292
Limit AOT compilation to maxcpucount:1
kotlarmilos Apr 1, 2024
ba82756
Test all runtime tests
kotlarmilos Apr 1, 2024
58752b8
Update max CPU count for AOT compilation to 2
kotlarmilos Apr 1, 2024
f85c698
Increase job timeout
kotlarmilos Apr 2, 2024
2bdc654
Split tests in several jobs
kotlarmilos Apr 2, 2024
08fea48
Split intrinsics and other tests
kotlarmilos Apr 3, 2024
acbbb8b
Disable failing tests
kotlarmilos Apr 3, 2024
889d510
Split intrinsics and other runtime tests in different jobs
kotlarmilos Apr 3, 2024
ba408d9
Disable failing tests
kotlarmilos Apr 3, 2024
3d16867
Disable failing tests
kotlarmilos Apr 3, 2024
e744c75
Disable failing tests
kotlarmilos Apr 3, 2024
5fa6730
Fix formatting
kotlarmilos Apr 3, 2024
2b58f7a
Move jobs to runtime-llvm.yml
kotlarmilos Apr 4, 2024
c3381cc
Move runtimeVariant to jobParameters
kotlarmilos Apr 4, 2024
7619c51
Update nameSuffix for runtime tests
kotlarmilos Apr 4, 2024
a00899f
Fix llvmot build
kotlarmilos Apr 4, 2024
fb828fe
Remove redundant parameters
kotlarmilos Apr 5, 2024
b449744
Merge branch 'main' into bugfix/linux-x64-fullaot-job
kotlarmilos Apr 5, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -55,16 +55,16 @@ steps:

- ${{ if eq(parameters.archType, 'x64') }}:
- ${{ if eq(parameters.runtimeVariant, 'llvmaot') }}:
- script: $(Build.SourcesDirectory)/src/tests/build$(scriptExt) $(logRootNameArg)MonoAot mono_aot ${{ parameters.buildConfig }} ${{ parameters.archType }}
- script: $(Build.SourcesDirectory)/src/tests/build$(scriptExt) $(logRootNameArg)MonoAot mono_aot ${{ parameters.buildConfig }} ${{ parameters.archType }} /p:RuntimeVariant=llvmaot
displayName: "LLVM AOT compile CoreCLR tests"
target: ${{ coalesce(parameters.llvmAotStepContainer, parameters.container) }}
- ${{ if eq(parameters.runtimeVariant, 'llvmfullaot') }}:
- script: $(Build.SourcesDirectory)/src/tests/build$(scriptExt) $(logRootNameArg)MonoAot mono_fullaot ${{ parameters.buildConfig }} ${{ parameters.archType }}
- script: $(Build.SourcesDirectory)/src/tests/build$(scriptExt) $(logRootNameArg)MonoAot mono_fullaot ${{ parameters.buildConfig }} ${{ parameters.archType }} /p:RuntimeVariant=llvmfullaot -maxcpucount:1
displayName: "LLVM AOT compile CoreCLR tests"
target: ${{ coalesce(parameters.llvmAotStepContainer, parameters.container) }}
- ${{ if eq(parameters.archType, 'arm64') }}:
- ${{ if eq(parameters.runtimeVariant, 'llvmaot') }}:
- script: $(Build.SourcesDirectory)/src/tests/build$(scriptExt) $(logRootNameArg)MonoAot mono_aot ${{ parameters.buildConfig }} ${{ parameters.archType }} $(_monoAotCrossCompileArg) /p:RuntimeVariant=llvmfullaot -maxcpucount:2
- script: $(Build.SourcesDirectory)/src/tests/build$(scriptExt) $(logRootNameArg)MonoAot mono_aot ${{ parameters.buildConfig }} ${{ parameters.archType }} $(_monoAotCrossCompileArg) /p:RuntimeVariant=llvmaot -maxcpucount:2
displayName: "LLVM AOT cross-compile CoreCLR tests"
env:
__MonoToolPrefix: aarch64-linux-gnu-
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -204,7 +204,7 @@ jobs:
runtimeFlavor: mono
platforms:
- linux_x64
- linux_arm64
# - linux_arm64
variables:
- name: timeoutPerTestInMinutes
value: 60
Expand All @@ -216,7 +216,6 @@ jobs:
runtimeVariant: llvmfullaot
buildArgs: -s mono+libs+clr.hosts+clr.iltools -c Release /p:MonoEnableLLVM=true /p:MonoBundleLLVMOptimizer=true
timeoutInMinutes: 300

condition: >-
or(
eq(dependencies.evaluate_paths.outputs['SetPathVars_mono_excluding_wasm.containsChange'], true),
Expand All @@ -228,6 +227,7 @@ jobs:
creator: dotnet-bot
llvmAotStepContainer: linux_x64_llvmaot
testRunNamePrefixSuffix: Mono_Release
testBuildArgs: tree baseservices
extraVariablesTemplates:
- template: /eng/pipelines/common/templates/runtimes/test-variables.yml

Expand Down
35 changes: 30 additions & 5 deletions src/mono/mono/mini/aot-compiler.c
Original file line number Diff line number Diff line change
Expand Up @@ -240,8 +240,11 @@ typedef struct MonoAotOptions {
gboolean allow_errors;
char *tool_prefix;
char *as_prefix;
char *as_name;
char *as_options;
char *ld_flags;
char *ld_name;
char *ld_options;
char *mtriple;
char *llvm_path;
char *temp_path;
Expand Down Expand Up @@ -8881,10 +8884,16 @@ mono_aot_parse_options (const char *aot_options, MonoAotOptions *opts)
opts->tool_prefix = g_strdup (arg + strlen ("tool-prefix="));
} else if (str_begins_with (arg, "as-prefix=")) {
opts->as_prefix = g_strdup (arg + strlen ("as-prefix="));
} else if (str_begins_with (arg, "as-name=")) {
opts->as_name = g_strdup (arg + strlen ("as-name="));
} else if (str_begins_with (arg, "as-options=")) {
opts->as_options = g_strdup (arg + strlen ("as-options="));
} else if (str_begins_with (arg, "ld-flags=")) {
opts->ld_flags = g_strdup (arg + strlen ("ld-flags="));
} else if (str_begins_with (arg, "ld-name=")) {
opts->ld_name = g_strdup (arg + strlen ("ld-name="));
} else if (str_begins_with (arg, "ld-options=")) {
opts->ld_options = g_strdup (arg + strlen ("ld-options="));
} else if (str_begins_with (arg, "soft-debug")) {
opts->soft_debug = TRUE;
// Intentionally undocumented x2-- deprecated
Expand Down Expand Up @@ -13287,8 +13296,16 @@ compile_asm (MonoAotCompile *acfg)
#ifdef TARGET_OSX
g_string_append (acfg->as_args, "-c -x assembler ");
#endif
const char *as_binary_name = acfg->aot_opts.as_name;
if (as_binary_name == NULL) {
as_binary_name = AS_NAME;
}
const char *as_options = acfg->aot_opts.as_options;
if (as_options == NULL) {
as_options = AS_OPTIONS;
}

command = g_strdup_printf ("\"%s%s\" %s %s -o %s %s", as_prefix, AS_NAME, AS_OPTIONS,
command = g_strdup_printf ("\"%s%s\" %s %s -o %s %s", as_prefix, as_binary_name, as_options,
acfg->as_args ? acfg->as_args->str : "",
wrap_path (objfile), wrap_path (acfg->tmpfname));
aot_printf (acfg, "Executing the native assembler: %s\n", command);
Expand All @@ -13299,7 +13316,7 @@ compile_asm (MonoAotCompile *acfg)
}

if (acfg->llvm && !acfg->llvm_owriter) {
command = g_strdup_printf ("\"%s%s\" %s %s -o %s %s", as_prefix, AS_NAME, AS_OPTIONS,
command = g_strdup_printf ("\"%s%s\" %s %s -o %s %s", as_prefix, as_binary_name, as_options,
acfg->as_args ? acfg->as_args->str : "",
wrap_path (acfg->llvm_ofile), wrap_path (acfg->llvm_sfile));
aot_printf (acfg, "Executing the native assembler: %s\n", command);
Expand Down Expand Up @@ -13348,16 +13365,21 @@ compile_asm (MonoAotCompile *acfg)

str = g_string_new ("");
const char *ld_binary_name = acfg->aot_opts.ld_name;

const char *ld_options = acfg->aot_opts.ld_options;
if (ld_options == NULL) {
ld_options = LD_OPTIONS;
}
#if defined(LD_NAME)
if (ld_binary_name == NULL) {
ld_binary_name = LD_NAME;
}
if (acfg->aot_opts.tool_prefix)
g_string_append_printf (str, "\"%s%s\" %s", tool_prefix, ld_binary_name, LD_OPTIONS);
g_string_append_printf (str, "\"%s%s\" %s", tool_prefix, ld_binary_name, ld_options);
else if (acfg->aot_opts.llvm_only)
g_string_append_printf (str, "%s", acfg->aot_opts.clangxx);
else
g_string_append_printf (str, "\"%s%s\" %s", tool_prefix, ld_binary_name, LD_OPTIONS);
g_string_append_printf (str, "\"%s%s\" %s", tool_prefix, ld_binary_name, ld_options);
#else
if (ld_binary_name == NULL) {
ld_binary_name = "ld";
Expand All @@ -13366,7 +13388,7 @@ compile_asm (MonoAotCompile *acfg)
// Default (linux)
if (acfg->aot_opts.tool_prefix)
/* Cross compiling */
g_string_append_printf (str, "\"%s%s\" %s", tool_prefix, ld_binary_name, LD_OPTIONS);
g_string_append_printf (str, "\"%s%s\" %s", tool_prefix, ld_binary_name, ld_options);
else if (acfg->aot_opts.llvm_only)
g_string_append_printf (str, "%s", acfg->aot_opts.clangxx);
else
Expand Down Expand Up @@ -14297,8 +14319,11 @@ aot_opts_free (MonoAotOptions *aot_opts)
g_free (aot_opts->dedup_include);
g_free (aot_opts->tool_prefix);
g_free (aot_opts->as_prefix);
g_free (aot_opts->as_name);
g_free (aot_opts->as_options);
g_free (aot_opts->ld_flags);
g_free (aot_opts->ld_name);
g_free (aot_opts->ld_options);
g_free (aot_opts->mtriple);
g_free (aot_opts->llvm_path);
g_free (aot_opts->temp_path);
Expand Down
7 changes: 7 additions & 0 deletions src/tests/build.proj
Original file line number Diff line number Diff line change
Expand Up @@ -148,6 +148,13 @@
<MonoAotOption Include="llvm-path=$(MonoLlvmPath)" />
<MonoAotOption Condition="'$(__MonoToolPrefix)' != ''" Include="tool-prefix=$(__MonoToolPrefix)" />
</ItemGroup>
<ItemGroup Condition="'$(MonoFullAot)' == 'true' and '$(TargetOS)' == 'linux'">
<MonoAotOption Include="as-name=clang" />
<MonoAotOption Include="as-options='-c -x assembler'" />
<MonoAotOption Include="tool-prefix=''" />
<MonoAotOption Include="ld-name=clang" />
<MonoAotOption Include="ld-options='-fuse-ld=lld'" />
</ItemGroup>
<ItemGroup Condition="'$(TargetArchitecture)' == 'arm64'">
<MonoAotOption Include="mattr=crc" />
<MonoAotOption Include="mattr=crypto" />
Expand Down
15 changes: 15 additions & 0 deletions src/tests/issues.targets
Original file line number Diff line number Diff line change
Expand Up @@ -2592,6 +2592,21 @@
<ItemGroup Condition="'$(RuntimeFlavor)' == 'mono' and ('$(RuntimeVariant)' == 'llvmfullaot' or '$(RuntimeVariant)' == 'llvmaot' or '$(TargetOS)' == 'ios') and '$(TargetArchitecture)' == 'arm64'">
</ItemGroup>

<ItemGroup Condition="'$(RuntimeFlavor)' == 'mono' and '$(RuntimeVariant)' == 'llvmfullaot' and '$(TargetArchitecture)' == 'x64'">
<ExcludeList Include="$(XunitTestBinBase)/baseservices/compilerservices/UnsafeAccessors/UnsafeAccessorsTests/*">
<Issue>https://github.com/dotnet/runtime/issues/92883</Issue>
</ExcludeList>
<ExcludeList Include="$(XunitTestBinBase)/baseservices/TieredCompilation/TieredVtableMethodTests/*">
<Issue>https://github.com/dotnet/runtime/issues/92883</Issue>
</ExcludeList>
<ExcludeList Include="$(XunitTestBinBase)/baseservices/varargs/varargsupport/*">
<Issue>https://github.com/dotnet/runtime/issues/92883</Issue>
</ExcludeList>
<ExcludeList Include="$(XunitTestBinBase)/baseservices/varargs/varargsupport_r/*">
<Issue>https://github.com/dotnet/runtime/issues/92883</Issue>
</ExcludeList>
</ItemGroup>

<ItemGroup Condition="'$(RuntimeFlavor)' == 'mono' and '$(RuntimeVariant)' == 'minijit' and '$(TargetArchitecture)' == 'arm64'">
<ExcludeList Include="$(XunitTestBinBase)/Interop/SuppressGCTransition/SuppressGCTransitionTest/**">
<Issue>https://github.com/dotnet/runtime/issues/82859</Issue>
Expand Down
Loading