A fast usermode x86 and x86-64 emulator for Arm64 Linux
Go to file
Alyssa Rosenzweig 0a6e875329 InstCountCI: add nontrivial gpr cmpxchg cases
cmpxchg handles rax specially, so cmpxchg with dest=rax is a special case. test
also the general case.

Signed-off-by: Alyssa Rosenzweig <alyssa@rosenzweig.io>
2024-01-12 11:50:43 -04:00
.github Removes IRLoader, unittests, and public interface 2023-12-25 07:00:29 -08:00
CI unittests: Add test thunk library 2023-09-18 16:53:35 +02:00
CMakeFiles CMake: Fix pkg version extraction 2023-07-13 16:01:14 -07:00
CPack CPack: Add an ldconfig trigger 2021-11-21 10:38:56 -08:00
Data AppConfig: Removes Steam config 2023-10-01 08:46:53 -07:00
docs Docs: Update for release FEX-2312 2023-12-03 17:59:59 -08:00
External Merge pull request #3354 from Sonicadvance1/uprev_kernel_2 2024-01-03 14:25:13 -08:00
FEXCore Merge pull request #3339 from Sonicadvance1/pass_thread_unaligned_fault_handler 2024-01-04 18:20:37 -08:00
FEXHeaderUtils FEXCore: Moves BitUtils to FHU 2023-12-25 06:38:51 -08:00
include Adds Config.h generated file 2021-03-23 19:12:18 -07:00
Scripts Scripts: More changes to InstallFEX script 2023-12-06 23:50:43 -08:00
Source Merge pull request #3339 from Sonicadvance1/pass_thread_unaligned_fault_handler 2024-01-04 18:20:37 -08:00
ThunkLibs Thunks: Build fix for clang versions older than 15 2023-12-26 16:02:08 +01:00
unittests InstCountCI: add nontrivial gpr cmpxchg cases 2024-01-12 11:50:43 -04:00
.gitignore Add pidfd_open syscall helpers 2022-07-15 13:44:07 +08:00
.gitmodules Externals: Update xbyak to v7.02 and switch away from fork 2023-12-21 01:52:05 -08:00
CMakeLists.txt FEX: Only pass CPU tunables to FEXCore and FEXLoader 2023-11-08 05:50:33 -08:00
CMakeSettings.json
CODE_OF_CONDUCT.md New domain. 2022-09-02 10:43:07 -07:00
Dockerfile Removes more libnuma references 2021-06-12 18:28:08 -07:00
LICENSE
Readme.md New domain. 2022-09-02 10:43:07 -07:00
toolchain_mingw.cmake CMake: Add mingw toolchain file 2023-08-18 04:31:41 -07:00
toolchain_x86_32.cmake Thunks: Add support for building with clang 2022-10-09 23:07:30 -07:00
toolchain_x86_64.cmake Thunks: Add support for building with clang 2022-10-09 23:07:30 -07:00

中文

FEX - Fast x86 emulation frontend

FEX allows you to run x86 and x86-64 binaries on an AArch64 host, similar to qemu-user and box86. It has native support for a rootfs overlay, so you don't need to chroot, as well as some thunklibs so it can forward things like GL to the host. FEX presents a Linux 5.0 interface to the guest, and supports both AArch64 and x86-64 as hosts. FEX is very much work in progress, so expect things to change.

Quick start guide

For Ubuntu 20.04, 21.04, 21.10, 22.04

Execute the following command in the terminal to install FEX through a PPA.

curl --silent https://raw.githubusercontent.com/FEX-Emu/FEX/main/Scripts/InstallFEX.py --output /tmp/InstallFEX.py && python3 /tmp/InstallFEX.py && rm /tmp/InstallFEX.py

This command will walk you through installing FEX through a PPA, and downloading a RootFS for use with FEX.

Ubuntu PPA is updated with our monthly releases.

For everyone else

Please see Building FEX.

Getting Started

FEX has been tested to build and run on ARMv8.0, ARMv8.1+, and x86-64(AVX or newer) hardware. ARMv7 and older x86 hardware will not work. Expected operating system usage is Linux. FEX has been tested with Ubuntu 20.04, 20.10, and 21.04. Also Arch Linux.

On AArch64 hosts the user MUST have an x86-64 RootFS Creating a RootFS.

Navigating the Source

See the Source Outline for more information.

Building FEX

Follow the guide on the official FEX-Emu Wiki here.

RootFS generation

AArch64 hosts require a rootfs for running applications. Follow the guide on the wiki page for seeing how to set up the rootfs from scratch https://wiki.fex-emu.com/index.php/Development:Setting_up_RootFS

FEX diagram