Kotlin/Native supported targets and hosts
This document describes which targets and hosts are supported by the Kotlin/Native compiler.
Target tiers
The Kotlin/Native compiler supports a number of different targets, though the level of support for them varies. To clarify these levels, we've broken up the targets into several tiers depending on how well the compiler supports them.
Mind the following terms used in tier tables:
Gradle target name is a target name that is used in the Kotlin Multiplatform Gradle plugin to enable the target.
Target triple is a target name according to the
<architecture>-<vendor>-<system>-<abi>structure that is commonly used by compilers.Running tests indicates out-of-the-box support for running tests in Gradle and IDE.
This is only available on a native host for the specific target. For example, you can run
macosX64andiosX64tests only on the macOS x86-64 host.
Tier 1
The target is regularly tested on CI to be able to compile and run.
We provide a source and binary compatibility between compiler releases.
Gradle target name | Target triple | Running tests | Description |
|---|---|---|---|
Apple macOS hosts only: | |||
|
| ✅ | Apple macOS on Apple Silicon platforms |
|
| ✅ | Apple iOS simulator on Apple Silicon platforms |
|
| Apple iOS and iPadOS on ARM64 platforms |
Tier 2
The target is regularly tested on CI to be able to compile but may not be automatically tested to be able to run.
We're doing our best to provide source and binary compatibility between compiler releases.
Gradle target name | Target triple | Running tests | Description |
|---|---|---|---|
|
| ✅ | Linux on x86_64 platforms |
|
| Linux on ARM64 platforms | |
Apple macOS hosts only: | |||
|
| ✅ | Apple macOS on x86_64 platforms |
|
| ✅ | Apple iOS simulator on x86-64 platforms |
|
| ✅ | Apple watchOS simulator on Apple Silicon platforms |
|
| ✅ | Apple watchOS 64-bit simulator on x86_64 platforms |
|
| Apple watchOS on ARM32 platforms | |
|
| Apple watchOS on ARM64 platforms with ILP32 | |
|
| ✅ | Apple tvOS simulator on Apple Silicon platforms |
|
| ✅ | Apple tvOS simulator on x86_64 platforms |
|
| Apple tvOS on ARM64 platforms |
Tier 3
The target is not guaranteed to be tested on CI.
We can't promise a source and binary compatibility between different compiler releases, though such changes for these targets are quite rare.
Gradle target name | Target triple | Running tests | Description |
|---|---|---|---|
|
| Android NDK on ARM32 platforms | |
|
| Android NDK on ARM64 platforms | |
|
| Android NDK on x86 platforms | |
|
| Android NDK on x86_64 platforms | |
|
| ✅ | 64-bit Windows 10 and later using MinGW compatibility layer |
Apple macOS hosts only: | |||
|
| Apple watchOS on ARM64 platforms |
For library authors
We don't recommend library authors to test more targets or provide stricter guarantees than the Kotlin/Native compiler does. You can use the following approach when considering support for native targets:
Support all the targets from tiers 1, 2, and 3.
Regularly test targets from tiers 1 and 2 that support running tests out of the box.
The Kotlin team uses this approach in the official Kotlin libraries, for example, kotlinx.coroutines and kotlinx.serialization.
Hosts
The Kotlin/Native compiler supports the following hosts:
Host OS | Building final binaries | Producing |
|---|---|---|
macOS on Apple silicon (ARM64) | Any supported target | Any supported target |
macOS on Intel chips (x86_64) | Any supported target | Any supported target |
Linux with x86_64 architecture | Any supported target, except for Apple targets | Any supported target, Apple targets only without cinterop dependencies |
Windows (MinGW toolchain) with x86_64 architecture | Any supported target, except for Apple targets | Any supported target, Apple targets only without cinterop dependencies |
Building final binaries
To produce final binaries, you can compile for supported targets only on supported hosts. For example, you cannot do it on FreeBSD or on a Linux machine running on the ARM64 architecture.
Building final binaries for Apple targets on Linux and Windows is also not possible.
Producing .klib artifacts
Generally, Kotlin/Native allows any supported host to produce .klib artifacts for supported targets.
However, artifact production for Apple targets still has some limitations on Linux and Windows. If your project uses cinterop dependencies (including CocoaPods), you must use a macOS host.
For example, you can produce a .klib for macosArm64 target on a Windows machine running on the x86_64 architecture only if there are no cinterop dependencies.