High-level emulator for iOS 3 and earlier's iPhone apps.
touchHLE is a high-level emulator designed to run iPhone OS apps, specifically targeting games from the early days of iOS. It operates by implementing system frameworks such as Foundation, UIKit, OpenGL ES, and OpenAL, allowing apps to run without simulating hardware.
Key Features:
Runs on modern desktop operating systems (Windows, macOS) and Android.
Supports input methods including mouse/trackpad, game controllers, and real touch.
Provides simulated accelerometer input options using game controllers or device sensors.
Utilizes a community-driven app compatibility database for tracking supported apps.
Audience & Benefit: Ideal for users interested in running early iOS games, enabling access to these titles on modern devices without the need for physical iPhones or iPod touches.
README
touchHLE: high-level emulator for iPhone OS apps
touchHLE is a high-level emulator for iPhone OS apps. It runs on modern desktop operating systems and Android, and is written in Rust.
touchHLE's high-level emulation (HLE) approach differs from low-level emulation (LLE) in that it does not directly simulate the iPhone/iPod touch hardware. Instead of running iPhone OS inside emulation, touchHLE itself takes the place of iPhone OS and provides its own implementations of the system frameworks (Foundation, UIKit, OpenGL ES, OpenAL, etc). The only code the emulated CPU executes is the app binary and a handful of libraries.
The goal of this project is to run games from the early days of iOS:
Currently: iPhone and iPod touch apps for iPhone OS 2.x and iPhone OS 3.0.
Longer term: iPhone OS 3.1, iPad apps (iPhone OS 3.2), iOS 4.x, …
This does not mean that all apps for these OS versions work. The vast majority of iPhone OS 2.x and iPhone OS 3.x apps do not currently work in touchHLE, and the ones that do work are generally games (support for other apps isn't a priority: it's more complex and less fun). This improves gradually over time with contributions from various developers. The touchHLE app compatibility database tracks which apps work in touchHLE; it is a crowdsourced effort to which anyone can contribute. We don't take requests, so please do not ask us to support your favourite game.
If you're curious about the history and motivation behind the project, you might want to read the original announcement. For an introduction to some of the technical details, check out touchHLE in depth.
**Check out the website for downloads, FAQ, social media, and more:**👉 👈
Important disclaimer
This project is not affiliated with or endorsed by Apple Inc in any way. iPhone, iOS, iPod, iPod touch and iPad are trademarks of Apple Inc in the United States and other countries.
Only use touchHLE to emulate software you have obtained legally.
Platform support
Officially supported: x64 Windows, x64 macOS and AArch64 Android.
If you're an Apple Silicon Mac user, the x64 build reportedly works in Rosetta.
Probably works, but you must build it yourself: AArch64 macOS, x64 Linux, AArch64 Linux.
Never?: other architectures.
Input methods:
For simulated touch input, there are four options:
Mouse/trackpad input (tap/hold/drag by pressing the left mouse button)
Virtual cursor using a game controller (move the cursor with the right analog stick , and tap/hold/drag by pressing the stick or the right shoulder button)
Mapping of game controller buttons (see the description of --button-to-touch= in OPTIONS_HELP.txt)
Real touch input, if you're on a device that has a touch screen
For simulated accelerometer input, there are three options:
Tilt control simulation using the left analog stick of a game controller
Tilt control simulation using a mouse (hold down the right mouse button)
Real accelerometer input, if you are using a phone, tablet or some other device with a built-in accelerometer (TODO: support game controllers with accelerometers)
Development status
This project has been in development since December 2022. This was originally hikari_no_yume's full-time passion project. Since its release in February 2023, a number of other volunteers have also contributed in their free time, and this is no longer a single-person project. There's only been a handful of releases so far and no promises can be made about the future. Please be patient.
In general, the supported functionality is defined by the supported apps: most contributors are interested in getting a particular game working, and contribute support for whichever missing features are needed for that game. Consequently, the completeness varies a lot between APIs, e.g. UIKit is easily the most hacky and incomplete of the large frameworks that have been implemented, because most games don't use very much of its functionality, whereas the OpenGL ES and OpenAL implementations are probably complete enough to cover a large number of early apps, because games make heavy use of these.
Usage
First obtain touchHLE, either a binary release or by building it yourself (see the next section).
You'll then need an app that you can run. The app compatibility database is a good guide for which versions of which apps are known to work, but bear in mind that it may contain outdated or inaccurate information. Note that the app binary must be decrypted to be usable.
There's a few ways you can run an app in touchHLE.
Special Android notes
Windows, Mac and Linux users can skip this section.
On Android, only the graphical user interface (app picker) is available. Therefore, you must put your “.ipa” files or “.app” bundles inside the “touchHLE_apps” directory. Note that you can only do that once you have run touchHLE at least once.
If you tap the “File manager” button in touchHLE, this should open some sort of file manager. You might also be able to find touchHLE in your device's file manager app (often called “Files”, or sometimes “Downloads”), alongside cloud storage services. There are some limitations on what kinds of operations are possible. The files in this location are stored on your device. Warning: on some devices, the “File manager” button will open a file manager, but it will crash when actually doing file operations (this is probably a bug in Android, we have not been able to debug it). If this happens to you, clear that file manager from your recent apps list and try to navigate to your device's file manager app directly instead, rather than via the touchHLE UI.
If you have an older version of Android, you may be able to directly access touchHLE's files by browsing to /sdcard/Android/data/org.touchhle.android/files/touchHLE_apps. Note that the /sdcard directory is usually not on the SD card.
You may be able to use ADB. If you're unfamiliar with ADB, try using (in Google Chrome or another browser with WebUSB) with your device connected over USB. touchHLE's files can be found in “sdcard” > “Android” > “data” > “org.touchhle.android” > “files” > “touchHLE_apps”.
Graphical user interface
touchHLE has a built-in app picker. If you put your .ipa files and .app bundles in the touchHLE_apps directory, they will show up in the app picker when you run touchHLE.
To configure the options, you can edit the touchHLE_options.txt file. To get a list of options, look in the OPTIONS_HELP.txt file.
Command-line user interface
This section does not apply on Android.
You can see the command-line usage by passing the --help flag.
If you're a Windows user and unfamiliar with the command line, these instructions may help you get started:
Move the .ipa file or .app bundle to the same folder as touchHLE.exe.
Hold the Shift key and right-click on the empty space in the folder window.
Click “Open with PowerShell”.
Type .\touchHLE.exe "YourAppNameHere.ipa" (or .app as appropriate) and press Enter. If you want to specify options, add a space after the app name (outside the quotes) and then type the options, separated by spaces.
Other stuff
Any data saved by the app (e.g. saved games) are stored in the touchHLE_sandbox folder.
If the emulator crashes almost immediately while running a known-working version of a game, please check whether you have any overlays turned on like the Steam overlay, Discord overlay, RivaTuner Statistics Server, etc. Sadly, as useful as these tools are, they work by injecting themselves into other apps or games and don't always clean up after themselves, so they can break touchHLE… it's not our fault. 😢 Currently only RivaTuner Statistics Server is known to be a problem. If you find another overlay that doesn't work, please tell us about it.
Building and contributing
See the CONTRIBUTING.md file in the git repo if you want to contribute. If you just want build touchHLE, look at dev-docs/building.md.
The source code of touchHLE itself (not its dependencies) is licensed under the Mozilla Public License, version 2.0.
Due to license compatibility concerns, binaries are under the GNU General Public License version 3 or later.
For a best effort listing of all licenses of dependencies, build touchHLE and pass the --copyright flag when running it, or click the “Copyright info” button in the app picker.
Please note that different licensing terms apply to the bundled dynamic libraries (in touchHLE_dylibs/) and fonts (in touchHLE_fonts/). Please consult the respective directories for more information.
Thanks
We stand on the shoulders of giants. Thank you to:
Everyone who has contributed to the project or supported any of its contributors financially.
The various people out there who've documented the iPhone OS platform, officially or otherwise. Much of this documentation is linked to within this codebase!
The iOS hacking/jailbreaking community.
The Free Software Foundation, for making libgcc and libstdc++ copyleft and therefore saving this project from ABI hell.
The National Security Agency of the United States of America, for Ghidra.
GerritForge for providing free Gerrit hosting to the general public, including us.