1
0
Fork 0
mirror of https://github.com/utmapp/UTM.git synced 2026-05-14 06:41:59 -04:00
Virtual machines for iOS and macOS https://getutm.app
  • Swift 84.3%
  • Objective-C 11.6%
  • Shell 2.6%
  • C 0.9%
  • Python 0.6%
Find a file
2026-05-03 14:30:24 -07:00
.github ci: make Xcode path configurable via HOST_XCODE_PATH variable 2026-05-03 19:49:33 +02:00
Configuration use single VZVirtioSoundDeviceConfiguration for Apple VM audio 2026-05-03 22:29:34 +02:00
Documentation Update translations for zh-Hans & zh-HK (#7345) 2025-08-18 16:04:14 -07:00
Icons Added Pisi linux logo (#7618) 2026-02-24 09:33:46 -08:00
Intents intents: properly fix LNPerformActionErrorCodeActionNotFound 2026-01-03 09:12:09 -08:00
JailbreakInterposer interposer: disable for simulator builds 2021-05-17 21:19:01 -07:00
patches build: update virglrenderer (again) 2026-05-03 05:38:23 -07:00
Platform data: prevent duplicate VMs from appearing 2026-05-03 14:11:00 -07:00
QEMUHelper Update translations for Korean (ko) (#6995) 2025-04-07 18:20:42 -07:00
QEMULauncher Polish localization updates 2024-03-31 20:03:49 -07:00
Remote remote(client): improve flow when local network access is denied 2025-04-07 08:58:52 -07:00
Renderer project: refactored CocoaSpice into package 2022-02-08 14:41:17 -08:00
Scripting Refactor same function to improve device matching 2026-05-03 23:15:38 +02:00
scripts build: remove minver hack for building ANGLE for iOS 2026-02-24 13:57:45 -08:00
Services scripting: fix "update registry" for AVM backend 2026-05-03 11:03:55 -07:00
UTM.xcodeproj CocoaSpice: re-introduce hack to reduce latency 2026-02-27 14:56:03 -08:00
utmctl utmctl: add version command 2025-08-17 20:22:16 -07:00
zh-Hans.lproj Add more translations for zh-hans 2023-09-12 09:04:13 +08:00
zh-Hant.lproj l10n: zh-TW: update translation 2023-08-10 17:23:00 +08:00
zh-HK.lproj Import localization for zh-hk 2023-09-12 08:52:50 +08:00
.gitignore project: move code signing config to external file 2021-04-26 20:15:41 -07:00
Build.xcconfig project: bumped version 2026-05-03 14:30:24 -07:00
CodeSigning.xcconfig.sample project: configure manual signing for iOS 2025-07-04 19:30:21 -07:00
CONTRIBUTING.md docs: add CONTRIBUTING.md 2026-02-21 14:00:44 -08:00
LICENSE UTM: implemented main view and configuration views 2019-04-12 09:40:30 -07:00
README.bn.md readme: update build badge 2024-11-24 20:15:07 -08:00
README.cz.md readme: update build badge 2024-11-24 20:15:07 -08:00
README.es.md readme: update build badge 2024-11-24 20:15:07 -08:00
README.fr.md readme: update build badge 2024-11-24 20:15:07 -08:00
README.ja.md readme: update build badge 2024-11-24 20:15:07 -08:00
README.ko.md Update translations for Korean (ko) (#6995) 2025-04-07 18:20:42 -07:00
README.md readme: update build badge 2024-11-24 20:15:07 -08:00
README.pl-PL.md readme: update build badge 2024-11-24 20:15:07 -08:00
README.ru.md readme: update build badge 2024-11-24 20:15:07 -08:00
README.uk.md readme: update build badge 2024-11-24 20:15:07 -08:00
README.zh-Hans.md Update translations for zh-Hans & zh-HK (#7430) 2026-01-02 16:42:10 -08:00
README.zh-Hant.md readme: update build badge 2024-11-24 20:15:07 -08:00
README.zh-HK.md Update translations for zh-Hans & zh-HK (#7430) 2026-01-02 16:42:10 -08:00
screen.png Update screenshot in README.md 2022-06-23 12:45:27 +02:00
screenmac.png Add image of UTM running on macOS 2022-06-22 18:35:21 -06:00

UTM

Build

It is possible to invent a single machine which can be used to compute any computable sequence.

-- Alan Turing, 1936

UTM is a full featured system emulator and virtual machine host for iOS and macOS. It is based off of QEMU. In short, it allows you to run Windows, Linux, and more on your Mac, iPhone, and iPad. More information at https://getutm.app/ and https://mac.getutm.app/

UTM running on an iPhone
UTM running on a MacBook

Features

  • Full system emulation (MMU, devices, etc) using QEMU
  • 30+ processors supported including x86_64, ARM64, and RISC-V
  • VGA graphics mode using SPICE and QXL
  • Text terminal mode
  • USB devices
  • JIT based acceleration using QEMU TCG
  • Frontend designed from scratch for macOS 11 and iOS 11+ using the latest and greatest APIs
  • Create, manage, run VMs directly from your device

Additional macOS Features

  • Hardware accelerated virtualization using Hypervisor.framework and QEMU
  • Boot macOS guests with Virtualization.framework on macOS 12+

UTM SE

UTM/QEMU requires dynamic code generation (JIT) for maximum performance. JIT on iOS devices require either a jailbroken device, or one of the various workarounds found for specific versions of iOS (see "Install" for more details).

UTM SE ("slow edition") uses a threaded interpreter which performs better than a traditional interpreter but still slower than JIT. This technique is similar to what iSH does for dynamic execution. As a result, UTM SE does not require jailbreaking or any JIT workarounds and can be sideloaded as a regular app.

To optimize for size and build times, only the following architectures are included in UTM SE: ARM, PPC, RISC-V, and x86 (all with both 32-bit and 64-bit variants).

Install

UTM (SE) for iOS: https://getutm.app/install/

UTM is also available for macOS: https://mac.getutm.app/

Development

macOS Development

iOS Development

  • iSH: emulates a usermode Linux terminal interface for running x86 Linux applications on iOS
  • a-shell: packages common Unix commands and utilities built natively for iOS and accessible through a terminal interface

License

UTM is distributed under the permissive Apache 2.0 license. However, it uses several (L)GPL components. Most are dynamically linked but the gstreamer plugins are statically linked and parts of the code are taken from qemu. Please be aware of this if you intend on redistributing this application.

Some icons made by Freepik from www.flaticon.com.

Additionally, UTM frontend depends on the following MIT/BSD License components:

Continuous integration hosting is provided by MacStadium

MacStadium logo