On Thu, Nov 13, 2025 at 6:05 PM Markus Volk via lists.openembedded.org
<[email protected]> wrote:

> Fex is a fast usermode x86 and x86-64 emulator for Arm64 Linux
> It is used by 'valve' to run windows games on snapdragon
>
> Compilation requires TOOLCHAIN = "clang"
>
> Signed-off-by: Markus Volk <[email protected]>
> ---
>  meta-oe/recipes-devtools/fex/fex_2511.bb | 58 ++++++++++++++++++++++++
>  1 file changed, 58 insertions(+)
>  create mode 100644 meta-oe/recipes-devtools/fex/fex_2511.bb
>
> diff --git a/meta-oe/recipes-devtools/fex/fex_2511.bb
> b/meta-oe/recipes-devtools/fex/fex_2511.bb
> new file mode 100644
> index 0000000000..295df8e814
> --- /dev/null
> +++ b/meta-oe/recipes-devtools/fex/fex_2511.bb
> @@ -0,0 +1,58 @@
> +SUMMARY = "A fast usermode x86 and x86-64 emulator for Arm64 Linux"
> +HOMEPAGE = "https://github.com/FEX-Emu/FEX";
> +LICENSE = "MIT & BSL-1.0 & BSD-2-Clause"
> +LIC_FILES_CHKSUM = "file://LICENSE;md5=70d20d502833c35d6d5a4f0ef5d9efcc"
> +LIC_FILES_CHKSUM +=
> "file://External/range-v3/LICENSE.txt;md5=5dc23d5193abaedb6e42f05650004624"
> +LIC_FILES_CHKSUM +=
> "file://External/xxhash/LICENSE;md5=13be6b481ff5616f77dda971191bb29b"
> +
> +COMPATIBLE_HOST = "aarch64.*-linux"
> +
> +REQUIRED_DISTRO_FEATURES = "ld-is-lld"
> +
>

You. can just add LDFLAGS += "-fuse-ld=lld" instead of demanding the distro
feature
that will make it work with wider variety of distro settings, not many OE
distros default to LLD yet.


> +SRC_URI = " \
> +       git://
> github.com/FEX-Emu/FEX.git;name=fex;protocol=https;nobranch=1;tag=FEX-${PV}
> <http://github.com/FEX-Emu/FEX.git;name=fex;protocol=https;nobranch=1;tag=FEX-$%7BPV%7D>
> \
> +       git://
> github.com/Sonicadvance1/cpp-optparse.git;name=cpp-optparse;subdir=${S}/Source/Common/cpp-optparse;protocol=https;nobranch=1
> <http://github.com/Sonicadvance1/cpp-optparse.git;name=cpp-optparse;subdir=$%7BS%7D/Source/Common/cpp-optparse;protocol=https;nobranch=1>
> \
> +       git://
> github.com/FEX-Emu/drm-headers.git;name=fex-drm;subdir=${S}/External/drm-headers;protocol=https;nobranch=1
> <http://github.com/FEX-Emu/drm-headers.git;name=fex-drm;subdir=$%7BS%7D/External/drm-headers;protocol=https;nobranch=1>
> \
> +       git://
> github.com/Cyan4973/xxHash.git;name=xxhash;subdir=${S}/External/xxhash;protocol=https;nobranch=1
> <http://github.com/Cyan4973/xxHash.git;name=xxhash;subdir=$%7BS%7D/External/xxhash;protocol=https;nobranch=1>
> \
> +       git://
> github.com/FEX-Emu/jemalloc.git;name=jemalloc;subdir=${S}/External/jemalloc;protocol=https;nobranch=1
> <http://github.com/FEX-Emu/jemalloc.git;name=jemalloc;subdir=$%7BS%7D/External/jemalloc;protocol=https;nobranch=1>
> \
> +       git://
> github.com/FEX-Emu/jemalloc.git;name=jemalloc-glibc;subdir=${S}/External/jemalloc_glibc;protocol=https;nobranch=1
> <http://github.com/FEX-Emu/jemalloc.git;name=jemalloc-glibc;subdir=$%7BS%7D/External/jemalloc_glibc;protocol=https;nobranch=1>
> \
> +       git://
> github.com/ericniebler/range-v3.git;name=range-v3;subdir=${S}/External/range-v3;protocol=https;nobranch=1
> <http://github.com/ericniebler/range-v3.git;name=range-v3;subdir=$%7BS%7D/External/range-v3;protocol=https;nobranch=1>
> \
> +       git://
> github.com/FEX-Emu/robin-map.git;name=robin-map;subdir=${S}/External/robin-map;protocol=https;nobranch=1
> <http://github.com/FEX-Emu/robin-map.git;name=robin-map;subdir=$%7BS%7D/External/robin-map;protocol=https;nobranch=1>
> \
> +"
> +
> +SRCREV_FORMAT = "fex"
> +SRCREV_fex = "663fd5a98befbf7a0ac585627de15c662715a731"
> +SRCREV_cpp-optparse = "9f94388a339fcbb0bc95c17768eb786c85988f6e"
> +SRCREV_fex-drm = "3e49836995c1dcb3df709440ad2f270b569c6a5f"
> +SRCREV_xxhash = "e626a72bc2321cd320e953a0ccf1584cad60f363"
> +SRCREV_jemalloc = "ce24593018ca5d5af7e5661ceda9744e02b59f8f"
> +SRCREV_jemalloc-glibc = "8436195ad5e1bc347d9b39743af3d29abee59f06"
> +SRCREV_robin-map = "d5683d9f1891e5b04e3e3b2192b5349dc8d814ea"
> +SRCREV_range-v3 = "ca1388fb9da8e69314dda222dc7b139ca84e092f"
> +
> +DEPENDS = " \
> +    catch2 \
> +    fmt \
> +    libdrm  \
> +    nasm-native \
> +    vulkan-headers \
> +"
> +
> +PACKAGECONFIG = ""
> +PACKAGECONFIG[qt] = "-DBUILD_FEXCONFIG=ON,-DBUILD_FEXCONFIG=OFF,qtbase
> qttools-native qtquick3d"
> +
> +EXTRA_OECMAKE += " \
> +       -DBUILD_TESTING=OFF \
> +       -DENABLE_VIXL_DISASSEMBLER=OFF \
> +       -DENABLE_VIXL_SIMULATOR=OFF \
> +       -DCMAKE_EXE_LINKER_FLAGS_INIT="-fuse-ld=lld" \
> +       -DCMAKE_MODULE_LINKER_FLAGS_INIT="-fuse-ld=lld" \
> +       -DCMAKE_SHARED_LINKER_FLAGS_INIT="-fuse-ld=lld" \
> +       -DDATA_DIRECTORY=${datadir} \
> +       -DQT_HOST_PATH:PATH=${RECIPE_SYSROOT_NATIVE}${prefix_native} \
> +"
> +
> +inherit cmake ccache pkgconfig features_check
> +
> +FILES:${PN} += "${datadir} ${libdir}/binfmt.d ${libdir}/libFEXCore.so"
> +FILES:${PN}-dev = "${includedir}"
> --
> 2.51.0
>
>
> 
>
>
-=-=-=-=-=-=-=-=-=-=-=-
Links: You receive all messages sent to this group.
View/Reply Online (#121665): 
https://lists.openembedded.org/g/openembedded-devel/message/121665
Mute This Topic: https://lists.openembedded.org/mt/116286410/21656
Group Owner: [email protected]
Unsubscribe: https://lists.openembedded.org/g/openembedded-devel/unsub 
[[email protected]]
-=-=-=-=-=-=-=-=-=-=-=-

Reply via email to