.github | ||
docs | ||
LLVMprivateGenerator | ||
pkgbuilds | ||
src | ||
system | ||
tests | ||
x64lib | ||
.gitignore | ||
.travis.yml | ||
cmake_uninstall.cmake.in | ||
CMakeLists.txt | ||
LICENSE | ||
postinst | ||
rebuild_wrappers.py | ||
runTest.cmake |
box64
Linux Userspace x86_64 Emulator with a twist
Box64 lets you run x86_64 Linux programs (such as games) on non-x86_64 Linux systems, like ARM (host system needs to be 64-bit little-endian).
You can find many more Box64 video on YouTube in the MicroLinux, Pi Labs or The Byteman channels.
Because Box64 uses the native versions of some "system" libraries, like libc, libm, SDL, and OpenGL, it's easy to integrate and use with most applications, and performance can be surprisingly high in many cases. Take a look at thoses bench analysis for an example here.
Box64 integrates a DynaRec (dynamic recompiler) for the ARM64 platform, providing a speed boost between 5 to 10 times faster than using only the interpreter. Some high level information on how the DynaRec works can be found here.
Some x64 internal opcodes use parts of "Realmode X86 Emulator Library", see x64primop.c for copyright details
Logo and Icon made by @grayduck, thanks!
Usage
There are a few environment variables to control the behaviour of Box64.
See here all the environment variables and what they do.
Note: Box64's Dynarec uses a mechanism with Memory Protection and a SegFault signal handler to handle JIT code. In simpler terms, if you want to use GDB to debug a running program that use JIT'd code (like mono/Unity3D), you will still have many "normal" segfaults triggering. It is suggested to use something like handle SIGSEGV nostop
in GDB to not stop at each segfault, and maybe put a breakpoint inside my_memprotectionhandler
in signals.c
if you want to trap SegFaults.
Compiling/Installation
Compilation instructions can be found here
Version history/Change log
The change log is available here
Notes about 32-bit platforms
Because Box64 works by directly translating function calls from x86_64 to host system, the host system (the one Box64 is running on) needs to have 64-bit libraries. Box64 doesn't include any 64-bit <-> 32-bit translation.
So understand that box64 will only runs 64-bit linux binaries. For 32-bit binaries, you need box86 (with all the multiarch or proot trickery it imply on 64-bit OS). Note that many installer (mojo setup based) will fall back to "x86" when detecting ARM64 OS, and so will try to use box86 for the setup, even if an x86_64 version exist. You can hack your way around with a fake "uname" that return "x86_64" when the argument is "-m"
Notes about Unity game emulation
Running Unity games is a hit or miss for now. Unity uses Mono (which uses signals that are not always emulated in a 100% accurate way).
You should also note that some Unity3D games require OpenGL 3+ which can be tricky to provide on ARM SBC (single-board computers) for now.
So, not all Unity games work and can require a high OpenGL profile, but many actualy works now
Hint: on Pi4, use MESA_GL_VERSION_OVERRIDE=3.2
and with Panfrost use PAN_MESA_DEBUG=gl3
to use higher profile if the game starts then quits before showing anything.
Notes about GTK programs
GTK libraries are not wrapped yet on box64 (contrary to box86). Many games use gtk (setup too), like Unity game for the Screen Selection dialog. While Unity games can run without that dialog (using the default setup), many just can't. For now, you'll need to put the set of gtk x86_64 libraries in the game folder (or some other folder known by box64) to get gtk support. GTK Wrapping is planned on box64.
Notes about Steam
Note that Steam is a hybrid 32-bit / 64-bit. You NEED box86 to run Steam, as the client app is a 32-bit binary. It also uses a 64-bit local server binaries, but like most stuff using libcef/chromium, it's not working correctly on box64 for now. So, no Steam for now on box64.
Notes about Wine
Wine64 is supported on box64. Be aware that 64-bit Wine also includes 32-bit components, to be able to run 32-bit Windows programs. The 32-bit apps will need box86 and will not run without it. On a system where both box64 and box86 are present and working, a wine 64-bit setup can run both 32-bit and 64-bit Windows programs (just use wine
and wine64
respectively)
Notes about Vulkan
Box64 does not wrap Vulkan libraries yet. It's planned, but for now, Vulkan programs will not run on box64.
Final word
I want to thank everyone who has contributed to box64 developpement. There are many ways to contribute: code contribution, financial, hardware and advertisement! So, in no particular order, I want to thank:
- For their major code contribution: rajdakin, mogery
- For their major financial contribution: FlyingFathead, stormchaser3000
- For hardware contribution and LoongArch migration: xiaoji, Deepin Beijing Develop Team
- For their hardware contribution: Radxa, Pine64
- For their continous advertisement of box64 project: salva (microLinux), PILab/TwisterOS team, The Byteman, NicoD, ekianjo (Boilingsteam)
And I also thank the many other people who participated even once in this project.
(If you use Box64 in your project, please don't forget to mention it!)