From 121a0fbc47cdb4d2b44c7850e26126051e066186 Mon Sep 17 00:00:00 2001 From: SingleAccretion Date: Thu, 5 Dec 2024 19:48:59 +0300 Subject: [PATCH 1/3] Add WasmComponentTypeWit --- .../BuildIntegration/Microsoft.NETCore.Native.targets | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/coreclr/nativeaot/BuildIntegration/Microsoft.NETCore.Native.targets b/src/coreclr/nativeaot/BuildIntegration/Microsoft.NETCore.Native.targets index 6418e84d3b3..03585d580f0 100644 --- a/src/coreclr/nativeaot/BuildIntegration/Microsoft.NETCore.Native.targets +++ b/src/coreclr/nativeaot/BuildIntegration/Microsoft.NETCore.Native.targets @@ -548,7 +548,7 @@ The .NET Foundation licenses this file to you under the MIT license. - <_WasiComponentImports Include="$(IlcFrameworkNativePath)*.wit" /> + @@ -566,7 +566,7 @@ The .NET Foundation licenses this file to you under the MIT license. - + From 20a5288ff6c13ec9371b74889bd2f78e4902b07c Mon Sep 17 00:00:00 2001 From: SingleAccretion Date: Thu, 5 Dec 2024 19:51:10 +0300 Subject: [PATCH 2/3] Actually enable the SharedLibrary project --- .../SmokeTests/SharedLibrary/SharedLibrary.cs | 38 ++++--------------- .../SharedLibrary/SharedLibrary.csproj | 5 +-- 2 files changed, 8 insertions(+), 35 deletions(-) diff --git a/src/tests/nativeaot/SmokeTests/SharedLibrary/SharedLibrary.cs b/src/tests/nativeaot/SmokeTests/SharedLibrary/SharedLibrary.cs index 9db2c3a3cf5..f949690b1a2 100644 --- a/src/tests/nativeaot/SmokeTests/SharedLibrary/SharedLibrary.cs +++ b/src/tests/nativeaot/SmokeTests/SharedLibrary/SharedLibrary.cs @@ -147,29 +147,16 @@ public static int DoCheckSimpleGCCollect() } [UnmanagedCallersOnly(EntryPoint = "test-http")] - public static unsafe void wasmExportTestHttp(int p0) + public static unsafe void TestHttp(int port) { - TestHttp((((ushort)p0))); - } - - public static void TestHttp(ushort port) - { - var stopwatch = new Stopwatch(); - stopwatch.Start(); - - var task = TestHttpAsync(port); - while (!task.IsCompleted) - { - WasiEventLoop.DispatchWasiEventLoop(); - } - var exception = task.Exception; - if (exception is not null) - { - throw exception; - } + [UnsafeAccessor(UnsafeAccessorKind.StaticMethod, Name = "PollWasiEventLoopUntilResolvedVoid")] + static extern void PollWasiEventLoopUntilResolvedVoid(Thread t, Task task); + Stopwatch stopwatch = Stopwatch.StartNew(); + PollWasiEventLoopUntilResolvedVoid(null, TestHttpAsync((ushort)port)); stopwatch.Stop(); - // Verify that `WasiEventLoop.DispatchWasiEventLoop` returned + + // Verify that `PollWasiEventLoopUntilResolvedVoid` returned // promptly once the main task finished, even if there were other // tasks (e.g. the default 100 second HttpClient timeout) still in // progress. @@ -239,15 +226,4 @@ private static async Task TestHttpAsync(ushort port) Trace.Assert(stopwatch.ElapsedMilliseconds < 1000); } } - - internal static class WasiEventLoop - { - internal static void DispatchWasiEventLoop() - { - CallDispatchWasiEventLoop((Thread)null!); - - [UnsafeAccessor(UnsafeAccessorKind.StaticMethod, Name = "DispatchWasiEventLoop")] - static extern void CallDispatchWasiEventLoop(Thread t); - } - } } diff --git a/src/tests/nativeaot/SmokeTests/SharedLibrary/SharedLibrary.csproj b/src/tests/nativeaot/SmokeTests/SharedLibrary/SharedLibrary.csproj index 34f2b527c56..f2f1f6389c1 100644 --- a/src/tests/nativeaot/SmokeTests/SharedLibrary/SharedLibrary.csproj +++ b/src/tests/nativeaot/SmokeTests/SharedLibrary/SharedLibrary.csproj @@ -13,9 +13,6 @@ true - - true - false @@ -66,6 +63,6 @@ cp SharedLibraryDriver$(NativeExtension) native/SharedLibrary$(NativeExtension) - + From cf52c0afc4dc374eb2f5e512e6243bc8d7cab48f Mon Sep 17 00:00:00 2001 From: SingleAccretion Date: Thu, 5 Dec 2024 19:59:17 +0300 Subject: [PATCH 3/3] Documentation --- docs/using-nativeaot/compiling.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/docs/using-nativeaot/compiling.md b/docs/using-nativeaot/compiling.md index 2c5fdf484e6..46057c16996 100644 --- a/docs/using-nativeaot/compiling.md +++ b/docs/using-nativeaot/compiling.md @@ -71,6 +71,8 @@ Another large contributor to the size is globalization support (ICU data and cod Additionally, NativeAOT-LLVM supports the following properties: - `WasmHtmlTemplate`: specifies path to the HTML template within which the WASM application will be embedded. An example of a minimal template can be found in the Emscripten repo: https://github.com/emscripten-core/emscripten/blob/main/src/shell_minimal.html +And item groups: +- `WasmComponentTypeWit`: WIT files that will be passed to the linker to define the imports and exports ('world') of the application as a component. ## WebAssembly native libraries