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

[wasm] Emscripten 3.1.1 bump #63894

Merged
merged 62 commits into from
Mar 22, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
62 commits
Select commit Hold shift + click to select a range
0a6c904
Initial changes for emscripten 2.0.34
radekdoulik Dec 7, 2021
1c2f989
Use emcc-link.rsp in build targets
radekdoulik Dec 8, 2021
f74d8b9
Use updated docker images
radekdoulik Dec 8, 2021
20f59e5
Fix compiler warnings
Dec 9, 2021
31197d9
Put `--profiling-funcs` to `_EmccLinkFlags`
radekdoulik Dec 9, 2021
2063241
Fix build
radekdoulik Dec 9, 2021
6aed1c5
Add shell to the environment
radekdoulik Dec 13, 2021
1f0048f
Merge remote-tracking branch 'origin/main' into pr-emscripten-34-bump
radekdoulik Dec 21, 2021
17c0117
Merge remote-tracking branch 'remotes/origin/main' into pr-emscripten…
radekdoulik Jan 3, 2022
11e2ce5
Add emcc-link.rsp to PlatformManifestFileEntry
radekdoulik Jan 4, 2022
3eb44cf
Feedback
radekdoulik Jan 7, 2022
c0e4d84
Merge remote-tracking branch 'remotes/origin/main' into pr-emscripten…
radekdoulik Jan 12, 2022
460d09a
Bump emscripten version
radekdoulik Jan 17, 2022
6f7d0c2
Bump llvm package version and use its libclang
radekdoulik Jan 17, 2022
b9c7488
Merge remote-tracking branch 'remotes/origin/main' into pr-emscripten…
radekdoulik Jan 17, 2022
e089ab1
Use newer docker images with emscripten 3.1.1
radekdoulik Jan 19, 2022
1cfd8bb
Merge remote-tracking branch 'remotes/origin/main' into pr-emscripten…
radekdoulik Jan 19, 2022
01c9516
Remove unused variable
radekdoulik Jan 20, 2022
e8a77c9
Merge remote-tracking branch 'remotes/origin/main' into pr-emscripten…
radekdoulik Feb 3, 2022
5076d72
Merge remote-tracking branch 'remotes/origin/main' into pr-emscripten…
radekdoulik Feb 16, 2022
1b81b20
Add note about icu repo
radekdoulik Feb 16, 2022
a7d92fb
Add comment to improve code readability
radekdoulik Feb 16, 2022
5cf57dc
Bump the ICU and emsdk versions
lewing Feb 16, 2022
d810106
Merge branch 'main' into pr-emscripten-311-bump
lewing Feb 16, 2022
d42afa8
disable non-wasm builds
radical Feb 16, 2022
ffe7aa0
disable wasm jobs in runtime, and runtime-staging, as we'll be runnin…
radical Feb 17, 2022
7205be1
Merge remote-tracking branch 'origin/main' into pr-emscripten-311-bump
radical Feb 17, 2022
3b90be5
[wasm] Re-enable tests that were disabled due to the earlier emsdk bump
radical Feb 17, 2022
7b90965
[wasm] Disable nodejs tests
radical Feb 17, 2022
f7c77d9
fix wbt build
radical Feb 17, 2022
5166d90
Update path to node in helix commands.
maraf Feb 17, 2022
1b7a8d1
Merge remote-tracking branch 'origin/main' into pr-emscripten-311-bump
radical Feb 18, 2022
af8bc89
disable non-wasm builds
radical Feb 18, 2022
f80cc5c
Merge remote-tracking branch 'origin/main' into pr-emscripten-311-bump
radical Feb 19, 2022
d792358
Merge remote-tracking branch 'origin/main' into pr-emscripten-311-bump
radical Feb 19, 2022
c18ae32
[wasm] Make emscripten version mismatch an error on CI
radical Feb 19, 2022
6a0fa45
Bump emscripten packages used to preview3, which has emsdk 3.1.1
radical Feb 19, 2022
54dc582
Update emscripten package version in Versions.props tooo
radical Feb 19, 2022
635286c
Re-enable wasm jobs
radical Feb 20, 2022
756f6e5
Merge remote-tracking branch 'origin/main' into pr-emscripten-311-bump
radical Feb 20, 2022
a0c64b2
enable non-wasm jobs
radical Feb 20, 2022
c3046b0
Add more missing exports
radekdoulik Feb 23, 2022
42f9f10
Merge remote-tracking branch 'remotes/origin/main' into pr-emscripten…
radekdoulik Feb 23, 2022
f7e3905
__dl_seterr shouldn't be needed
radekdoulik Feb 23, 2022
0812dbc
Merge remote-tracking branch 'remotes/origin/main' into pr-emscripten…
radekdoulik Mar 1, 2022
c17fb1b
Fix MicrosoftNETCoreRuntimeICUTransportVersion
radekdoulik Mar 11, 2022
721db38
Merge remote-tracking branch 'remotes/origin/main' into pr-emscripten…
radekdoulik Mar 16, 2022
f733732
Put back the 3.1.1 docker images after merge
radekdoulik Mar 16, 2022
c68ce2d
Revert "fix wbt build"
radekdoulik Mar 16, 2022
5305472
Revert "[wasm] Disable nodejs tests"
radekdoulik Mar 16, 2022
b8a0d83
Use newer ICU package, last that still had 3.1.1
radekdoulik Mar 16, 2022
a34230f
Try different helix queue parameter
radekdoulik Mar 16, 2022
e55f6be
Revert "Try different helix queue parameter"
radekdoulik Mar 16, 2022
0b4ad77
Fix helix queue with docker tag
radekdoulik Mar 16, 2022
f96e33a
Merge remote-tracking branch 'remotes/origin/main' into pr-emscripten…
radekdoulik Mar 16, 2022
d9b8aef
Try to set PYTHONPATH for emscripten
radekdoulik Mar 17, 2022
24d8396
[wasm] Do not set _WasmDevel=true for blazor projects
radical Mar 17, 2022
c5a3329
Increase timeout
radekdoulik Mar 17, 2022
18db8a4
Fix WBT tests
radekdoulik Mar 17, 2022
7b33355
Merge branch 'main' into pr-emscripten-311-bump
radical Mar 18, 2022
d37b85e
[wasm] Export more functions
radical Mar 18, 2022
7c9ae48
fix exported function names
radical Mar 18, 2022
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
8 changes: 4 additions & 4 deletions eng/Version.Details.xml
Original file line number Diff line number Diff line change
@@ -1,16 +1,16 @@
<Dependencies>
<ProductDependencies>
<Dependency Name="Microsoft.NETCore.Runtime.ICU.Transport" Version="7.0.0-preview.3.22157.1">
<Dependency Name="Microsoft.NETCore.Runtime.ICU.Transport" Version="7.0.0-preview.3.22121.1">
<Uri>https://github.com/dotnet/icu</Uri>
<Sha>5416401e2e54d6ce9bef7f0c4a5fe25088c42652</Sha>
<Sha>d3c9d26f8e787253536d38504d3ac9e307573bfb</Sha>
</Dependency>
<Dependency Name="System.Net.MsQuic.Transport" Version="7.0.0-alpha.1.22160.2">
<Uri>https://github.com/dotnet/msquic</Uri>
<Sha>4fe73fcad4b0af91cc49fd1f5576f0111f15f6fd</Sha>
</Dependency>
<Dependency Name="Microsoft.NET.Workload.Emscripten.Manifest-7.0.100" Version="7.0.0-preview.3.22167.1">
<Dependency Name="Microsoft.NET.Workload.Emscripten.Manifest-7.0.100" Version="7.0.0-preview.3.22121.1">
<Uri>https://github.com/dotnet/emsdk</Uri>
<Sha>d2be7d0bf644d9608bf8180d706483238d85f13a</Sha>
<Sha>b8e71431b3eaa024afad7886699f8ac6bca2ba01</Sha>
</Dependency>
<Dependency Name="System.ServiceModel.Primitives" Version="4.9.0-rc2.21473.1">
<Uri>https://github.com/dotnet/wcf</Uri>
Expand Down
4 changes: 2 additions & 2 deletions eng/Versions.props
Original file line number Diff line number Diff line change
Expand Up @@ -172,7 +172,7 @@
<MicrosoftNETILLinkTasksVersion>7.0.100-1.22160.1</MicrosoftNETILLinkTasksVersion>
<MicrosoftNETILLinkAnalyzerPackageVersion>$(MicrosoftNETILLinkTasksVersion)</MicrosoftNETILLinkAnalyzerPackageVersion>
<!-- ICU -->
<MicrosoftNETCoreRuntimeICUTransportVersion>7.0.0-preview.3.22157.1</MicrosoftNETCoreRuntimeICUTransportVersion>
<MicrosoftNETCoreRuntimeICUTransportVersion>7.0.0-preview.3.22121.1</MicrosoftNETCoreRuntimeICUTransportVersion>
<!-- MsQuic -->
<SystemNetMsQuicTransportVersion>7.0.0-alpha.1.22160.2</SystemNetMsQuicTransportVersion>
<!-- Mono LLVM -->
Expand All @@ -185,7 +185,7 @@
<runtimeosx1012x64MicrosoftNETCoreRuntimeMonoLLVMSdkVersion>11.1.0-alpha.1.22164.2</runtimeosx1012x64MicrosoftNETCoreRuntimeMonoLLVMSdkVersion>
<runtimeosx1012x64MicrosoftNETCoreRuntimeMonoLLVMToolsVersion>11.1.0-alpha.1.22164.2</runtimeosx1012x64MicrosoftNETCoreRuntimeMonoLLVMToolsVersion>
<!-- emscripten / Node -->
<MicrosoftNETWorkloadEmscriptenManifest70100Version>7.0.0-preview.3.22167.1</MicrosoftNETWorkloadEmscriptenManifest70100Version>
<MicrosoftNETWorkloadEmscriptenManifest70100Version>7.0.0-preview.3.22121.1</MicrosoftNETWorkloadEmscriptenManifest70100Version>
<MicrosoftNETRuntimeEmscriptenVersion>$(MicrosoftNETWorkloadEmscriptenManifest70100Version)</MicrosoftNETRuntimeEmscriptenVersion>
<!-- workloads -->
<SwixPackageVersion>1.1.87-gba258badda</SwixPackageVersion>
Expand Down
2 changes: 1 addition & 1 deletion eng/pipelines/common/platform-matrix.yml
Original file line number Diff line number Diff line change
Expand Up @@ -303,7 +303,7 @@ jobs:
targetRid: browser-wasm
platform: Browser_wasm
container:
image: ubuntu-18.04-webassembly-20210707133424-12f133e
image: ubuntu-18.04-webassembly-20220118141522-180197c
registry: mcr
jobParameters:
hostedOs: Linux
Expand Down
2 changes: 1 addition & 1 deletion eng/pipelines/common/templates/wasm-library-tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ jobs:
testGroup: innerloop
nameSuffix: LibraryTests${{ parameters.nameSuffix }}
buildArgs: -s mono+libs+host+packs+libs.tests -c $(_BuildConfig) /p:ArchiveTests=true /p:BrowserHost=$(_hostedOs) ${{ parameters.runSmokeOnlyArg }} ${{ parameters.extraBuildArgs }}
timeoutInMinutes: 180
timeoutInMinutes: 240
# always run for runtime-wasm builds (triggered manually)
# Always run for rolling builds
# Else run on path changes
Expand Down
2 changes: 1 addition & 1 deletion eng/pipelines/libraries/helix-queues-setup.yml
Original file line number Diff line number Diff line change
Expand Up @@ -182,6 +182,6 @@ jobs:

# WebAssembly windows
- ${{ if eq(parameters.platform, 'Browser_wasm_win') }}:
- (Windows.Server.Core.1909.Amd64.Open)windows.10.amd64.server20h2.open@mcr.microsoft.com/dotnet-buildtools/prereqs:windowsservercore-2004-helix-webassembly-amd64-20210702131541-6837048
- (Windows.Amd64.Server2022.Open)windows.amd64.server2022.open@mcr.microsoft.com/dotnet-buildtools/prereqs:windowsservercore-ltsc2022-helix-webassembly-20220118164817-dc6e6f1

${{ insert }}: ${{ parameters.jobParameters }}
1 change: 1 addition & 0 deletions src/mono/mono/component/debugger-agent.c
Original file line number Diff line number Diff line change
Expand Up @@ -414,6 +414,7 @@ static gboolean buffer_replies;
DebuggerTlsData *tls; \
tls = (DebuggerTlsData *)mono_native_tls_get_value (debugger_tls_id);
#else
/* the thread argument is omitted on wasm, to avoid compiler warning */
#define GET_TLS_DATA_FROM_THREAD(...) \
radekdoulik marked this conversation as resolved.
Show resolved Hide resolved
DebuggerTlsData *tls; \
tls = &debugger_wasm_thread;
Expand Down
1 change: 1 addition & 0 deletions src/mono/wasm/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -188,6 +188,7 @@ Bumping Emscripten version involves these steps:
* update https://github.com/dotnet/runtime/blob/main/src/mono/wasm/emscripten-version.txt
* bump emscripten versions in docker images in https://github.com/dotnet/dotnet-buildtools-prereqs-docker
* bump emscripten in https://github.com/dotnet/emsdk
* bump docker images in https://github.com/dotnet/icu, update emscripten files in eng/patches/
* update version number in docs
* update `Microsoft.NET.Runtime.Emscripten.<emscripten version>.Node.win-x64` package name, version and sha hash in https://github.com/dotnet/runtime/blob/main/eng/Version.Details.xml and in https://github.com/dotnet/runtime/blob/main/eng/Versions.props. the sha is the commit hash in https://github.com/dotnet/emsdk and the package version can be found at https://dev.azure.com/dnceng/public/_packaging?_a=feed&feed=dotnet6
* update packages in the workload manifest https://github.com/dotnet/runtime/blob/main/src/mono/nuget/Microsoft.NET.Workload.Mono.Toolchain.Manifest/WorkloadManifest.json.in
Expand Down
2 changes: 1 addition & 1 deletion src/mono/wasm/build/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -137,7 +137,7 @@ them for the new task assembly.

If encountering build performance issues, you can use the rollup `--perf` option and the typescript compiler `--generateCpuProfile` option to get build profile data, like so:

```../emsdk/node/14.15.5_64bit/bin/npm run rollup --perf -- --perf --environment Configuration:Release,NativeBinDir:./rollup-test-data,ProductVersion:12.3.4```
```../emsdk/node/14.18.2_64bit/bin/npm run rollup --perf -- --perf --environment Configuration:Release,NativeBinDir:./rollup-test-data,ProductVersion:12.3.4```

```node node_modules/typescript/lib/tsc.js --generateCpuProfile dotnet-tsc.cpuprofile -p tsconfig.json ```

Expand Down
1 change: 1 addition & 0 deletions src/mono/wasm/build/WasmApp.Native.targets
Original file line number Diff line number Diff line change
Expand Up @@ -255,6 +255,7 @@
<_WasmNativeFileForLinking Include="@(NativeFileReference)" />

<EmscriptenEnvVars Include="EMSDK_PYTHON=$(EmscriptenPythonToolsPath)python.exe" Condition="'$(OS)' == 'Windows_NT'" />
<EmscriptenEnvVars Include="PYTHONPATH=$(EmscriptenPythonToolsPath)" Condition="'$(OS)' == 'Windows_NT'" />
<EmscriptenEnvVars Include="EM_CACHE=$(WasmCachePath)" Condition="'$(WasmCachePath)' != ''" />
</ItemGroup>

Expand Down
2 changes: 1 addition & 1 deletion src/mono/wasm/emscripten-version.txt
Original file line number Diff line number Diff line change
@@ -1 +1 @@
2.0.23
3.1.1
2 changes: 1 addition & 1 deletion src/mono/wasm/wasm.proj
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,7 @@
<_EmccLinkFlags Include="-s FORCE_FILESYSTEM=1" />
<_EmccLinkFlags Include="-s EXPORTED_RUNTIME_METHODS=&quot;['FS','print','ccall','cwrap','setValue','getValue','UTF8ToString','UTF8ArrayToString','FS_createPath','FS_createDataFile','removeRunDependency','addRunDependency', 'FS_readFile']&quot;" />
<!-- _htons,_ntohs,__get_daylight,__get_timezone,__get_tzname are exported temporarily, until the issue is fixed in emscripten, https://github.com/dotnet/runtime/issues/64724 -->
<_EmccLinkFlags Include="-s EXPORTED_FUNCTIONS=_free,_malloc,_memalign,_memset" Condition="$([MSBuild]::VersionGreaterThan('$(_EmccVersion)', '3.0'))" />
<_EmccLinkFlags Include="-s EXPORTED_FUNCTIONS=_free,_malloc,_memalign,_memset,_htons,_ntohs,__get_daylight,__get_timezone,__get_tzname" Condition="$([MSBuild]::VersionGreaterThan('$(_EmccVersion)', '3.0'))" />
<_EmccLinkFlags Include="-s EXPORTED_FUNCTIONS=_free,_malloc,_htons,_ntohs,__get_daylight,__get_timezone,__get_tzname,_memalign" Condition="$([MSBuild]::VersionLessThan('$(_EmccVersion)', '3.0'))" />
<_EmccLinkFlags Include="--source-map-base http://example.com" />
<_EmccLinkFlags Include="-s STRICT_JS=1" />
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ public void NativeBuild_WithDeployOnBuild_UsedByVS(string config, bool nativeRel
AddItemsPropertiesToProject(projectFile, extraProperties: nativeRelink ? string.Empty : "<RunAOTCompilation>true</RunAOTCompilation>");

// build with -p:DeployOnBuild=true, and that will trigger a publish
(CommandResult res, _) = BuildInternal(id, config, publish: false, "-p:DeployOnBuild=true");
(CommandResult res, _) = BuildInternal(id, config, publish: false, setWasmDevel: false, "-p:DeployOnBuild=true");

var expectedFileType = nativeRelink ? NativeFilesType.Relinked : NativeFilesType.AOT;

Expand Down
8 changes: 4 additions & 4 deletions src/tests/BuildWasmApps/Wasm.Build.Tests/BuildTestBase.cs
Original file line number Diff line number Diff line change
Expand Up @@ -398,7 +398,7 @@ public string CreateBlazorWasmTemplateProject(string id)

protected (CommandResult, string) BlazorBuild(BlazorBuildOptions options, params string[] extraArgs)
{
var res = BuildInternal(options.Id, options.Config, publish: false, extraArgs);
var res = BuildInternal(options.Id, options.Config, publish: false, setWasmDevel: false, extraArgs);
AssertDotNetNativeFiles(options.ExpectedFileType, options.Config, forPublish: false, targetFramework: options.TargetFramework);
AssertBlazorBundle(options.Config, isPublish: false, dotnetWasmFromRuntimePack: options.ExpectedFileType == NativeFilesType.FromRuntimePack);

Expand All @@ -407,7 +407,7 @@ public string CreateBlazorWasmTemplateProject(string id)

protected (CommandResult, string) BlazorPublish(BlazorBuildOptions options, params string[] extraArgs)
{
var res = BuildInternal(options.Id, options.Config, publish: true, extraArgs);
var res = BuildInternal(options.Id, options.Config, publish: true, setWasmDevel: false, extraArgs);
AssertDotNetNativeFiles(options.ExpectedFileType, options.Config, forPublish: true, targetFramework: options.TargetFramework);
AssertBlazorBundle(options.Config, isPublish: true, dotnetWasmFromRuntimePack: options.ExpectedFileType == NativeFilesType.FromRuntimePack);

Expand All @@ -423,7 +423,7 @@ public string CreateBlazorWasmTemplateProject(string id)
return res;
}

protected (CommandResult, string) BuildInternal(string id, string config, bool publish=false, params string[] extraArgs)
protected (CommandResult, string) BuildInternal(string id, string config, bool publish=false, bool setWasmDevel=true, params string[] extraArgs)
{
string label = publish ? "publish" : "build";
Console.WriteLine($"{Environment.NewLine}** {label} **{Environment.NewLine}");
Expand All @@ -435,7 +435,7 @@ public string CreateBlazorWasmTemplateProject(string id)
$"-bl:{logPath}",
$"-p:Configuration={config}",
"-p:BlazorEnableCompression=false",
"-p:_WasmDevel=true"
setWasmDevel ? "-p:_WasmDevel=true" : string.Empty
}.Concat(extraArgs).ToArray();

CommandResult res = new DotNetCommand(s_buildEnv)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ public void BlazorOnlyLinkRebuild(string config)

string objDir = Path.Combine(_projectDir!, "obj", config, DefaultTargetFramework, "wasm");

BlazorBuild(new BlazorBuildOptions(id, config, NativeFilesType.Relinked));
BlazorBuild(new BlazorBuildOptions(id, config, NativeFilesType.Relinked), "-p:EmccLinkOptimizationFlag=-O2");
File.Move(Path.Combine(s_buildEnv.LogRootPath, id, $"{id}-build.binlog"),
Path.Combine(s_buildEnv.LogRootPath, id, $"{id}-build-first.binlog"));

Expand Down