Skip to content

Latest commit

 

History

History
127 lines (91 loc) · 5.46 KB

compiling.md

File metadata and controls

127 lines (91 loc) · 5.46 KB

Compiling with Native AOT

Please consult documentation for instructions how to compile and publish application.

The rest of this document covers advanced topics only.

Using daily builds

For using daily builds, you need to make sure the nuget.config file for your project contains the following package sources under the <packageSources> element:

<add key="dotnet9" value="https://pkgs.dev.azure.com/dnceng/public/_packaging/dotnet9/nuget/v3/index.json" />
<add key="nuget" value="https://api.nuget.org/v3/index.json" />

If your project has no nuget.config file, it may be created by running

> dotnet new nugetconfig

from the project's root directory. New package sources must be added after the <clear /> element if you decide to keep it.

Once you have added the package sources, add a reference to the ILCompiler package either by running

> dotnet add package Microsoft.DotNet.ILCompiler -v 9.0.0-*

or by adding the following element to the project file:

<ItemGroup>
  <PackageReference Include="Microsoft.DotNet.ILCompiler" Version="9.0.0-*" />
</ItemGroup>

Adding an explicit package reference to Microsoft.DotNet.ILCompiler will generate warning when publishing and it can run into version errors. When possible, use the default Microsoft.DotNet.ILCompiler version to publish a native AOT application.

Cross-architecture compilation

Native AOT toolchain allows targeting ARM64 on an x64 host and vice versa for both Windows and Linux. Cross-OS compilation, such as targeting Linux on a Windows host, is not supported.

The target architecture can be specified using -r or --arch options of the dotnet publish command. For example, the following command produces Windows Arm64 binary on a Windows x64 host machine:

> dotnet publish -r win-arm64

The cross-architecture compilation requires native build tools for the target platform to be installed and configured correctly. On Linux, you may need to follow cross-building instructions to create your own sysroot directory and specify path to it using the SysRoot property.

See Building native AOT apps in containers for a streamlined path to establishing a Linux cross-compilation environments.

Using daily builds with cross-architecture compilation

For using daily builds according to the instructions above, in addition to the Microsoft.DotNet.ILCompiler package reference, also add the runtime.win-x64.Microsoft.DotNet.ILCompiler package reference to get the x64-hosted compiler:

<PackageReference Include="Microsoft.DotNet.ILCompiler; runtime.win-x64.Microsoft.DotNet.ILCompiler" Version="9.0.0-alpha.1.23456.7" />

Replace 9.0.0-alpha.1.23456.7 with the latest version from the dotnet9 feed. Note that it is important to use the same version for both packages to avoid potential hard-to-debug issues. After adding the package reference, you may publish for win-arm64 as usual:

> dotnet publish -r win-arm64

Similarly, to target linux-arm64 on a Linux x64 host, in addition to the Microsoft.DotNet.ILCompiler package reference, also add the runtime.linux-x64.Microsoft.DotNet.ILCompiler package reference to get the x64-hosted compiler:

<PackageReference Include="Microsoft.DotNet.ILCompiler; runtime.linux-x64.Microsoft.DotNet.ILCompiler" Version="9.0.0-alpha.1.23456.7" />

Using statically linked ICU

This feature can statically link libicu libraries (such as libicui18n.a) into your applications at build time. NativeAOT binaries built with this feature can run even when libicu libraries are not installed.

You can use this feature by adding the StaticICULinking property to your project file as follows:

<PropertyGroup>
  <StaticICULinking>true</StaticICULinking>
</PropertyGroup>

This feature is only supported on Linux. This feature is not supported when crosscompiling.

License (Unicode): https://github.com/unicode-org/icu/blob/main/icu4c/LICENSE

Prerequisites

Ubuntu

apt install libicu-dev cmake

Alpine

apk add cmake icu-static icu-dev

Using statically linked OpenSSL

This feature can statically link OpenSSL libraries (such as libssl.a and libcrypto.a) into your applications at build time. NativeAOT binaries built with this feature can run even when OpenSSL libraries are not installed. WARNING: This is scenario for advanced users, please use with extreme caution. Incorrect usage of this feature, can cause security vulnerabilities in your product

You can use this feature by adding the StaticOpenSslLinking property to your project file as follows:

<PropertyGroup>
  <StaticOpenSslLinking>true</StaticOpenSslLinking>
</PropertyGroup>

This feature is only supported on Linux. This feature is not supported when crosscompiling.

License for OpenSSL v3+ (Apache v2.0): https://github.com/openssl/openssl/blob/master/LICENSE.txt License for OpenSSL releases prior to v3 (dual OpenSSL and SSLeay license): https://www.openssl.org/source/license-openssl-ssleay.txt

Prerequisites

Ubuntu

apt install libssl-dev cmake

Alpine

apk add cmake openssl-dev openssl-libs-static

NixOS

NativeAOT uses native executable ilc pulled from nuget, which has special requirements. Docs can be found at https://nixos.wiki/wiki/DotNET#NativeAOT