git: afa8682087b5 - main - emulators/reicast: fix i386 build
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Thu, 30 Jun 2022 05:37:24 UTC
The branch main has been updated by fernape: URL: https://cgit.FreeBSD.org/ports/commit/?id=afa8682087b52fbd98ed5faa421f713d7e3b89f2 commit afa8682087b52fbd98ed5faa421f713d7e3b89f2 Author: Timothy Beyer <beyert@cs.ucr.edu> AuthorDate: 2022-06-29 05:32:33 +0000 Commit: Fernando Apesteguía <fernape@FreeBSD.org> CommitDate: 2022-06-30 05:34:25 +0000 emulators/reicast: fix i386 build PR: 264218 Reported by: beyert@cs.ucr.edu (maintainer) --- emulators/reicast/Makefile | 18 +++- emulators/reicast/distinfo | 4 +- emulators/reicast/files/patch-CMakeLists.txt | 88 +++++++++++++++- emulators/reicast/files/patch-libswirl_build.h | 10 ++ .../files/patch-libswirl_deps_intrin_intrin__x86.h | 14 +++ .../files/patch-libswirl_deps_lua_luaconf.h | 14 +++ ...patch-libswirl_hw_arm7_arm7__jit__virt__x86.cpp | 114 +++++++++++++++++++++ .../files/patch-libswirl_hw_sh4_dyna_driver.cpp | 11 ++ ...h-libswirl_jit_backend_x86_rec__x86__driver.cpp | 11 ++ .../reicast/files/patch-libswirl_libswirl.cpp | 11 ++ .../files/patch-libswirl_linux-dist_main.cpp | 33 +++++- .../reicast/files/patch-libswirl_linux_common.cpp | 27 ++++- .../files/patch-libswirl_linux_nixprof_nixprof.cpp | 48 +++++++++ .../reicast/files/patch-reicast_cmake_config.cmake | 22 +++- 14 files changed, 407 insertions(+), 18 deletions(-) diff --git a/emulators/reicast/Makefile b/emulators/reicast/Makefile index d6a317efb18f..9dff00af7f80 100644 --- a/emulators/reicast/Makefile +++ b/emulators/reicast/Makefile @@ -2,6 +2,7 @@ PORTNAME= reicast PORTVERSION= 0.20201231 +PORTREVISION= 1 CATEGORIES= emulators games MAINTAINER= beyert@cs.ucr.edu @@ -18,7 +19,10 @@ LIB_DEPENDS= libao.so:audio/libao \ libpulse.so:audio/pulseaudio \ libudev.so:devel/libudev-devd -USES= cmake compiler gl xorg +USES= cmake compiler gl xorg + +.include <bsd.port.options.mk> + USE_GCC= yes USE_LDCONFIG= yes CMAKE_ARGS= -DOPENGL_EGL_INCLUDE_DIR:PATH=${LOCALBASE}/include/EGL \ @@ -26,13 +30,17 @@ CMAKE_ARGS= -DOPENGL_EGL_INCLUDE_DIR:PATH=${LOCALBASE}/include/EGL \ -DOPENGL_INCLUDE_DIR:PATH=${LOCALBASE}/include/GL \ -DOPENGL_opengl_LIBRARY:PATH=${LOCALBASE}/lib/libGL.so +.if ${ARCH} == i386 +USE_BINUTILS= yes +CXXFLAGS+= -DSIMPLELINK +.endif + USE_GITHUB= yes -GH_ACCOUNT= reicast -GH_PROJECT= reicast-emulator -GH_TAGNAME= 0bd6ea3 +GH_TUPLE= reicast:reicast-emulator:0bd6ea3 \ + yuikns:intrin:ae63327:intrin/libswirl/deps/intrin USE_XORG= ice sm x11 xext -USE_GL= egl gbm gl +USE_GL= egl gbm gl PLIST_FILES= bin/reicast diff --git a/emulators/reicast/distinfo b/emulators/reicast/distinfo index 9ade18ae5b8a..9aa5d391dc06 100644 --- a/emulators/reicast/distinfo +++ b/emulators/reicast/distinfo @@ -1,3 +1,5 @@ -TIMESTAMP = 1623465538 +TIMESTAMP = 1653194932 SHA256 (reicast-reicast-emulator-0.20201231-0bd6ea3_GH0.tar.gz) = a30e67754c28029e16cf2eb3d3878906888178e308800139e64e8e29533bc679 SIZE (reicast-reicast-emulator-0.20201231-0bd6ea3_GH0.tar.gz) = 6467649 +SHA256 (yuikns-intrin-ae63327_GH0.tar.gz) = 744aca1c35a28b25d85202ddb14379be70defae303ca1667aa7448ef4a7ee17e +SIZE (yuikns-intrin-ae63327_GH0.tar.gz) = 12533 diff --git a/emulators/reicast/files/patch-CMakeLists.txt b/emulators/reicast/files/patch-CMakeLists.txt index 5532f40fde80..ce7313b51ea7 100644 --- a/emulators/reicast/files/patch-CMakeLists.txt +++ b/emulators/reicast/files/patch-CMakeLists.txt @@ -1,6 +1,90 @@ ---- CMakeLists.txt.orig 2020-08-21 20:26:50 UTC +--- CMakeLists.txt.orig 2020-10-18 11:22:48 UTC +++ CMakeLists.txt -@@ -431,6 +431,8 @@ if(${HOST_OS} EQUAL ${OS_DARWIN}) +@@ -100,20 +100,29 @@ set(core_SRCS + ${d_core}/serialize.cpp + ) + +-if(${BUILD_COMPILER} EQUAL ${COMPILER_GCC} OR (${BUILD_COMPILER} EQUAL ${COMPILER_CLANG} AND ${HOST_OS} EQUAL ${OS_DARWIN})) # TODO: Test with Clang on other platforms ++if(${BUILD_COMPILER} EQUAL ${COMPILER_GCC} OR (${BUILD_COMPILER} EQUAL ${COMPILER_CLANG} AND (${HOST_OS} EQUAL ${OS_DARWIN} OR ${HOST_OS} EQUAL ${OS_FREEBSD}))) + list(APPEND core_SRCS ${archive_SRCS}) + endif() + + if(${FEAT_SHREC} EQUAL ${DYNAREC_JIT}) + + if(${HOST_CPU} EQUAL ${CPU_X86}) +- list(APPEND core_SRCS +- ${d_core}/jit/backend/x86/rec_x86_driver.cpp +- ${d_core}/jit/backend/x86/rec_x86_asm.cpp # change for linux , rec_lin86_asm.S +- ${d_core}/jit/backend/x86/rec_x86_ngen.h +- +- ${d_core}/jit/emitter/x86/x86_emitter.cpp +- ) ++ if (${HOST_OS} EQUAL ${OS_LINUX} OR (${HOST_OS} EQUAL ${OS_FREEBSD})) ++ list(APPEND core_SRCS ++ ${d_core}/jit/backend/x86/rec_x86_driver.cpp ++ ${d_core}/jit/backend/x86/rec_lin86_asm.S ++ ${d_core}/jit/backend/x86/rec_x86_asm.cpp ++ ${d_core}/jit/backend/x86/rec_x86_ngen.h ++ ${d_core}/jit/emitter/x86/x86_emitter.cpp ++ ) ++ else() ++ list(APPEND core_SRCS ++ ${d_core}/jit/backend/x86/rec_x86_driver.cpp ++ ${d_core}/jit/backend/x86/rec_x86_asm.cpp ++ ${d_core}/jit/backend/x86/rec_x86_ngen.h ++ ${d_core}/jit/emitter/x86/x86_emitter.cpp ++ ) ++ endif() + elseif(${HOST_CPU} EQUAL ${CPU_ARM}) + list(APPEND core_SRCS + ${d_core}/rec-ARM/ngen_arm.S +@@ -139,6 +148,8 @@ add_definitions(/DFEAT_HAS_SOFTREND=1) + + if(${HOST_OS} EQUAL ${OS_LINUX}) + add_definitions(-DLUA_USE_LINUX) ++elseif(${HOST_OS} EQUAL ${OS_FREEBSD}) ++ add_definitions(-DLUA_USE_FREEBSD) + endif() + + ### deps.cmake ################################################################################# +@@ -149,6 +160,7 @@ set(gpl_deps ${reicast_core_path}/gpl/deps) + include_directories ("${d_deps}") + include_directories ("${gpl_deps}/picotcp/include") + include_directories ("${gpl_deps}/picotcp/modules") ++include_directories ("${d_deps}/intrin") + + file(GLOB xbyak_H ${d_deps}/xbyak/*.h) # include headers into cmake target/project view + +@@ -185,8 +197,8 @@ set(deps_SRCS + ${d_deps}/coreio/coreio.cpp + ${xbyak_H} + ) +- +-if(${BUILD_COMPILER} EQUAL ${COMPILER_GCC} OR (${BUILD_COMPILER} EQUAL ${COMPILER_CLANG} AND ${HOST_OS} EQUAL ${OS_DARWIN})) # TODO: Test with Clang on other platforms ++ ++if(${BUILD_COMPILER} EQUAL ${COMPILER_GCC} OR (${BUILD_COMPILER} EQUAL ${COMPILER_CLANG} AND (${HOST_OS} EQUAL ${OS_DARWIN} OR ${HOST_OS} EQUAL ${OS_FREEBSD}))) + list(APPEND deps_SRCS + ${lzip_SRCS} + ${lzma_SRCS} +@@ -228,7 +240,7 @@ if (${HOST_OS} EQUAL ${OS_WINDOWS}) + list(APPEND osd_SRCS ${d_core}/oslib/windows/threading.cpp) + list(APPEND osd_SRCS ${d_aout}/audiobackend_directsound.cpp) + link_libraries(dsound.lib winmm.lib xinput.lib wsock32.lib opengl32.lib) +-elseif (${HOST_OS} EQUAL ${OS_LINUX} OR ${HOST_OS} EQUAL ${OS_ANDROID}) ++elseif (${HOST_OS} EQUAL ${OS_LINUX} OR ${HOST_OS} EQUAL ${OS_ANDROID} OR ${OS_FREEBSD}) + + list(APPEND osd_SRCS + ${d_core}/linux-dist/main.cpp +@@ -294,7 +306,7 @@ endif() + + target_compile_features(${TNAME}${binSuffix} PRIVATE cxx_std_14) + +-if(${HOST_OS} EQUAL ${OS_LINUX}) ++if(${HOST_OS} EQUAL ${OS_LINUX} OR ${HOST_OS} EQUAL ${OS_FREEBSD}) + # needed for opentty + target_link_libraries(${TNAME} -lutil) + +@@ -431,6 +443,8 @@ if(${HOST_OS} EQUAL ${OS_DARWIN}) endif() diff --git a/emulators/reicast/files/patch-libswirl_build.h b/emulators/reicast/files/patch-libswirl_build.h new file mode 100644 index 000000000000..05dcf62fbcae --- /dev/null +++ b/emulators/reicast/files/patch-libswirl_build.h @@ -0,0 +1,10 @@ +--- libswirl/build.h.orig 2020-10-18 11:22:48 UTC ++++ libswirl/build.h +@@ -139,6 +139,7 @@ + #define OS_DARWIN 0x10000003 + #define OS_IOS 0x10000004 + #define OS_ANDROID 0x10000005 ++#define OS_FREEBSD 0x10000006 + + #define OS_UWP 0x10000011 + #define OS_NSW_HOS 0x80000001 diff --git a/emulators/reicast/files/patch-libswirl_deps_intrin_intrin__x86.h b/emulators/reicast/files/patch-libswirl_deps_intrin_intrin__x86.h new file mode 100644 index 000000000000..2fa6fb7bbf00 --- /dev/null +++ b/emulators/reicast/files/patch-libswirl_deps_intrin_intrin__x86.h @@ -0,0 +1,14 @@ +--- libswirl/deps/intrin/intrin_x86.h.orig 2018-11-26 23:44:32 UTC ++++ libswirl/deps/intrin/intrin_x86.h +@@ -896,9 +896,11 @@ static __inline__ __attribute__((always_inline)) unsig + #endif // !HAS_BUILTIN(__rdtsc) + + /*** Interrupts ***/ ++/* + static __inline__ __attribute__((always_inline)) void __debugbreak(void) { + __asm__("int $3"); + } ++*/ + + static __inline__ __attribute__((always_inline)) void __int2c(void) { + __asm__("int $0x2c"); diff --git a/emulators/reicast/files/patch-libswirl_deps_lua_luaconf.h b/emulators/reicast/files/patch-libswirl_deps_lua_luaconf.h new file mode 100644 index 000000000000..c4dd21b707b4 --- /dev/null +++ b/emulators/reicast/files/patch-libswirl_deps_lua_luaconf.h @@ -0,0 +1,14 @@ +--- libswirl/deps/lua/luaconf.h.orig 2020-10-18 11:22:48 UTC ++++ libswirl/deps/lua/luaconf.h +@@ -64,6 +64,11 @@ + #define LUA_USE_READLINE /* needs some extra libraries */ + #endif + ++#if defined(LUA_USE_FREEBSD) ++#define LUA_USE_POSIX ++#define LUA_USE_DLOPEN /* FreeBSD does not need -ldl */ ++#define LUA_USE_READLINE /* needs an extra library: -lreadline */ ++#endif + + #if defined(LUA_USE_MACOSX) + #define LUA_USE_POSIX diff --git a/emulators/reicast/files/patch-libswirl_hw_arm7_arm7__jit__virt__x86.cpp b/emulators/reicast/files/patch-libswirl_hw_arm7_arm7__jit__virt__x86.cpp new file mode 100644 index 000000000000..9331c26f4d49 --- /dev/null +++ b/emulators/reicast/files/patch-libswirl_hw_arm7_arm7__jit__virt__x86.cpp @@ -0,0 +1,114 @@ +--- libswirl/hw/arm7/arm7_jit_virt_x86.cpp.orig 2020-10-18 11:22:48 UTC ++++ libswirl/hw/arm7/arm7_jit_virt_x86.cpp +@@ -11,8 +11,101 @@ + + #if HOST_CPU == CPU_X86 && FEAT_AREC == DYNAREC_JIT + +-#if HOST_OS == OS_LINUX || HOST_OS == OS_DARWIN ++#if HOST_OS == OS_LINUX || HOST_OS == OS_DARWIN || HOST_OS == OS_FREEBSD + #include <sys/mman.h> ++ ++#define DP_R_ROFC (OP_READ_FLAGS_S|OP_READ_REG_1) //Reads reg1, op2, flags if S ++#define DP_R_ROF (OP_READ_FLAGS|OP_READ_REG_1) //Reads reg1, op2, flags (ADC & co) ++#define DP_R_OFC (OP_READ_FLAGS_S) //Reads op2, flags if S ++ ++#define DP_W_RFC (OP_WRITE_FLAGS_S|OP_WRITE_REG) //Writes reg, and flags if S ++#define DP_W_F (OP_WRITE_FLAGS) //Writes only flags, always (S=1) ++ ++struct ArmDPOP { ++ u32 key; ++ u32 mask; ++ u32 flags; ++}; ++ ++vector<ArmDPOP> ops; ++ ++void AddDPOP(u32 subcd, u32 rflags, u32 wflags) { ++ ArmDPOP op; ++ ++ u32 key = subcd << 21; ++ u32 mask = (15 << 21) | (7 << 25); ++ ++ op.flags = rflags | wflags; ++ ++ if (wflags == DP_W_F) { ++ //also match S bit for opcodes that must write to flags (CMP & co) ++ mask |= 1 << 20; ++ key |= 1 << 20; ++ } ++ ++ //ISR form (bit 25=0, bit 4 = 0) ++ op.key = key; ++ op.mask = mask | (1 << 4); ++ ops.push_back(op); ++ ++ //RSR form (bit 25=0, bit 4 = 1, bit 7=0) ++ op.key = key | (1 << 4); ++ op.mask = mask | (1 << 4) | (1 << 7); ++ ops.push_back(op); ++ ++ //imm8r4 form (bit 25=1) ++ op.key = key | (1 << 25); ++ op.mask = mask; ++ ops.push_back(op); ++} ++ ++void InitHash() { ++ /* ++ COND | 00 I OP1 S Rn Rd OPER2 -- Data opcode, PSR xfer ++ Data processing opcodes ++ */ ++ ++ //AND 0000 Rn, OPER2, {Flags} Rd, {Flags} ++ //EOR 0001 Rn, OPER2, {Flags} Rd, {Flags} ++ //SUB 0010 Rn, OPER2, {Flags} Rd, {Flags} ++ //RSB 0011 Rn, OPER2, {Flags} Rd, {Flags} ++ //ADD 0100 Rn, OPER2, {Flags} Rd, {Flags} ++ //ORR 1100 Rn, OPER2, {Flags} Rd, {Flags} ++ //BIC 1110 Rn, OPER2, {Flags} Rd, {Flags} ++ AddDPOP(0, DP_R_ROFC, DP_W_RFC); ++ AddDPOP(1, DP_R_ROFC, DP_W_RFC); ++ AddDPOP(2, DP_R_ROFC, DP_W_RFC); ++ AddDPOP(3, DP_R_ROFC, DP_W_RFC); ++ AddDPOP(4, DP_R_ROFC, DP_W_RFC); ++ AddDPOP(12, DP_R_ROFC, DP_W_RFC); ++ AddDPOP(14, DP_R_ROFC, DP_W_RFC); ++ ++ //ADC 0101 Rn, OPER2, Flags Rd, {Flags} ++ //SBC 0110 Rn, OPER2, Flags Rd, {Flags} ++ //RSC 0111 Rn, OPER2, Flags Rd, {Flags} ++ AddDPOP(5, DP_R_ROF, DP_W_RFC); ++ AddDPOP(6, DP_R_ROF, DP_W_RFC); ++ AddDPOP(7, DP_R_ROF, DP_W_RFC); ++ ++ //TST 1000 S=1 Rn, OPER2, Flags Flags ++ //TEQ 1001 S=1 Rn, OPER2, Flags Flags ++ AddDPOP(8, DP_R_ROF, DP_W_F); ++ AddDPOP(9, DP_R_ROF, DP_W_F); ++ ++ //CMP 1010 S=1 Rn, OPER2 Flags ++ //CMN 1011 S=1 Rn, OPER2 Flags ++ AddDPOP(10, DP_R_ROF, DP_W_F); ++ AddDPOP(11, DP_R_ROF, DP_W_F); ++ ++ //MOV 1101 OPER2, {Flags} Rd, {Flags} ++ //MVN 1111 OPER2, {Flags} Rd, {Flags} ++ AddDPOP(13, DP_R_OFC, DP_W_RFC); ++ AddDPOP(15, DP_R_OFC, DP_W_RFC); ++} ++ ++void armt_init() { ++ InitHash(); ++} + #endif + #if HOST_OS == OS_WINDOWS + #include <Windows.h> +@@ -55,6 +148,8 @@ u8 ARM7_TCB[ICacheSize + 4096] __attribute__((section( + + #elif HOST_OS==OS_DARWIN + u8 ARM7_TCB[ICacheSize + 4096] __attribute__((section("__TEXT, .text"))); ++#elif HOST_OS==OS_FREEBSD ++u8 ARM7_TCB[ICacheSize + 4096] __attribute__((section(".text"))); + #else + #error ARM7_TCB ALLOC + #endif diff --git a/emulators/reicast/files/patch-libswirl_hw_sh4_dyna_driver.cpp b/emulators/reicast/files/patch-libswirl_hw_sh4_dyna_driver.cpp new file mode 100644 index 000000000000..5f2f011e9bd9 --- /dev/null +++ b/emulators/reicast/files/patch-libswirl_hw_sh4_dyna_driver.cpp @@ -0,0 +1,11 @@ +--- libswirl/hw/sh4/dyna/driver.cpp.orig 2020-10-18 11:22:48 UTC ++++ libswirl/hw/sh4/dyna/driver.cpp +@@ -31,7 +31,7 @@ + u8 SH4_TCB[CODE_SIZE+4096] + #if HOST_OS == OS_WINDOWS || FEAT_SHREC != DYNAREC_JIT + ; +-#elif HOST_OS == OS_LINUX ++#elif HOST_OS == OS_LINUX || HOST_OS == OS_FREEBSD + __attribute__((section(".text"))); + #elif HOST_OS==OS_DARWIN + __attribute__((section("__TEXT,.text"))); diff --git a/emulators/reicast/files/patch-libswirl_jit_backend_x86_rec__x86__driver.cpp b/emulators/reicast/files/patch-libswirl_jit_backend_x86_rec__x86__driver.cpp new file mode 100644 index 000000000000..42595057c452 --- /dev/null +++ b/emulators/reicast/files/patch-libswirl_jit_backend_x86_rec__x86__driver.cpp @@ -0,0 +1,11 @@ +--- libswirl/jit/backend/x86/rec_x86_driver.cpp.orig 2020-10-18 11:22:48 UTC ++++ libswirl/jit/backend/x86/rec_x86_driver.cpp +@@ -852,7 +852,7 @@ struct X86NGenBackend : NGenBackend + + addr=retadr-5; + +- #if HOST_OS == OS_LINUX ++ #if HOST_OS == OS_LINUX || HOST_OS == OS_FREEBSD + ctx->esp += 4; + //restore the addr from eax to ecx so it's valid again + ctx->ecx = ctx->eax; diff --git a/emulators/reicast/files/patch-libswirl_libswirl.cpp b/emulators/reicast/files/patch-libswirl_libswirl.cpp new file mode 100644 index 000000000000..608bdab016dc --- /dev/null +++ b/emulators/reicast/files/patch-libswirl_libswirl.cpp @@ -0,0 +1,11 @@ +--- libswirl/libswirl.cpp.orig 2020-10-18 11:22:48 UTC ++++ libswirl/libswirl.cpp +@@ -95,7 +95,7 @@ int64_t get_time_usec(void) + if (!QueryPerformanceCounter(&count)) + return 0; + return count.QuadPart * 1000000 / freq.QuadPart; +-#elif defined(_POSIX_MONOTONIC_CLOCK) || defined(__QNX__) || defined(ANDROID) || defined(__MACH__) || HOST_OS==OS_LINUX ++#elif defined(_POSIX_MONOTONIC_CLOCK) || defined(__QNX__) || defined(ANDROID) || defined(__MACH__) || HOST_OS==OS_LINUX || HOST_OS==OS_FREEBSD + struct timespec tv = { 0 }; + if (clock_gettime(CLOCK_MONOTONIC, &tv) < 0) + return 0; diff --git a/emulators/reicast/files/patch-libswirl_linux-dist_main.cpp b/emulators/reicast/files/patch-libswirl_linux-dist_main.cpp index a0e4638bf5b9..c510f8e9a419 100644 --- a/emulators/reicast/files/patch-libswirl_linux-dist_main.cpp +++ b/emulators/reicast/files/patch-libswirl_linux-dist_main.cpp @@ -1,10 +1,37 @@ ---- libswirl/linux-dist/main.cpp.orig 2020-08-21 20:26:50 UTC +--- libswirl/linux-dist/main.cpp.orig 2020-10-18 11:22:48 UTC +++ libswirl/linux-dist/main.cpp -@@ -22,7 +22,6 @@ +@@ -7,7 +7,7 @@ + #include "types.h" + #include "cfg/cfg.h" + +-#if HOST_OS==OS_LINUX ++#if HOST_OS==OS_LINUX || HOST_OS==OS_FREEBSD + #include <poll.h> + #include <termios.h> + //#include <curses.h> +@@ -22,7 +22,9 @@ #include "hw/sh4/dyna/blockmanager.h" #include "hw/maple/maple_cfg.h" #include <unistd.h> --#include <pty.h> ++#if HOST_OS==OS_LINUX + #include <pty.h> ++#endif #include "libswirl.h" #include "hw/pvr/Renderer_if.h" +@@ -539,6 +541,7 @@ int main(int argc, wchar* argv[]) + + int get_mic_data(u8* buffer) { return 0; } + ++#if HOST_OS == OS_LINUX + void os_DebugBreak() + { + #if !defined(TARGET_EMSCRIPTEN) +@@ -548,6 +551,7 @@ void os_DebugBreak() + exit(-1); + #endif + } ++#endif + + + diff --git a/emulators/reicast/files/patch-libswirl_linux_common.cpp b/emulators/reicast/files/patch-libswirl_linux_common.cpp index 147dd36e4224..686feaf0e9c7 100644 --- a/emulators/reicast/files/patch-libswirl_linux_common.cpp +++ b/emulators/reicast/files/patch-libswirl_linux_common.cpp @@ -1,6 +1,23 @@ ---- libswirl/linux/common.cpp.orig 2020-08-21 20:26:50 UTC +--- libswirl/linux/common.cpp.orig 2020-10-18 11:22:48 UTC +++ libswirl/linux/common.cpp -@@ -22,6 +22,12 @@ +@@ -9,7 +9,7 @@ + + #include <pthread.h> + +-#if HOST_OS==OS_LINUX || HOST_OS == OS_DARWIN ++#if HOST_OS==OS_LINUX || HOST_OS == OS_DARWIN || HOST_OS == OS_FREEBSD + + #if HOST_OS == OS_DARWIN + #define _XOPEN_SOURCE 1 +@@ -17,11 +17,20 @@ + #include <TargetConditionals.h> + #include <dlfcn.h> + #include <util.h> ++#elif HOST_OS == OS_FREEBSD ++ #include <dlfcn.h> ++ #include <libutil.h> + #endif + #if FEAT_HAS_SERIAL_TTY #include <sys/stat.h> #if HOST_OS == OS_DARWIN #import <util.h> @@ -13,7 +30,7 @@ #else #include <pty.h> #endif -@@ -33,7 +39,7 @@ +@@ -33,7 +42,7 @@ #include <sys/param.h> #include <sys/mman.h> #include <sys/time.h> @@ -22,7 +39,7 @@ #include <sys/personality.h> #include <dlfcn.h> #endif -@@ -294,7 +300,7 @@ void enable_runfast() +@@ -294,7 +303,7 @@ void enable_runfast() } void linux_fix_personality() { @@ -31,7 +48,7 @@ printf("Personality: %08X\n", personality(0xFFFFFFFF)); personality(~READ_IMPLIES_EXEC & personality(0xFFFFFFFF)); printf("Updated personality: %08X\n", personality(0xFFFFFFFF)); -@@ -302,7 +308,7 @@ void linux_fix_personality() { +@@ -302,7 +311,7 @@ void linux_fix_personality() { } void linux_rpi2_init() { diff --git a/emulators/reicast/files/patch-libswirl_linux_nixprof_nixprof.cpp b/emulators/reicast/files/patch-libswirl_linux_nixprof_nixprof.cpp new file mode 100644 index 000000000000..51560366fe24 --- /dev/null +++ b/emulators/reicast/files/patch-libswirl_linux_nixprof_nixprof.cpp @@ -0,0 +1,48 @@ +--- libswirl/linux/nixprof/nixprof.cpp.orig 2020-10-18 11:22:48 UTC ++++ libswirl/linux/nixprof/nixprof.cpp +@@ -13,6 +13,7 @@ + + #include <stdio.h> + #include <stdlib.h> ++#include <thread> + #include <pthread.h> + #include <unistd.h> + #include <pthread.h> +@@ -56,7 +57,7 @@ + + static int tick_count=0; + static pthread_t proft; +-static pthread_t thread[2]; ++static pthread_t thread_[2]; + static void* prof_address[2]; + static u32 prof_wait; + +@@ -76,8 +77,8 @@ void prof_handler (int sn, siginfo_t * si, void *ctxr) + context_from_segfault(&ctx); + + int thd=-1; +- if (pthread_self()==thread[0]) thd=0; +- else if (pthread_self()==thread[1]) thd=1; ++ if (pthread_self()==thread_[0]) thd=0; ++ else if (pthread_self()==thread_[1]) thd=1; + else return; + + prof_address[thd] = (void*)ctx.pc; +@@ -94,7 +95,7 @@ void install_prof_handler(int id) + act.sa_flags = SA_SIGINFO | SA_RESTART; + sigaction(SIGPROF, &act, &segv_oact); + +- thread[id]=pthread_self(); ++ thread_[id]=pthread_self(); + } + + static void prof_head(FILE* out, const char* type, const char* name) +@@ -299,7 +300,7 @@ static void* profiler_main(void *ptr) + { + tick_count++; + // printf("Sending SIGPROF %08X %08X\n",thread[0],thread[1]); +- for (int i = 0; i < 2; i++) pthread_kill(thread[i], SIGPROF); ++ for (int i = 0; i < 2; i++) pthread_kill(thread_[i], SIGPROF); + // printf("Sent SIGPROF\n"); + usleep(prof_wait); + // fwrite(&prof_address[0],1,sizeof(prof_address[0])*2,prof_out); diff --git a/emulators/reicast/files/patch-reicast_cmake_config.cmake b/emulators/reicast/files/patch-reicast_cmake_config.cmake index 4fa4fed8b020..a8fc926abacc 100644 --- a/emulators/reicast/files/patch-reicast_cmake_config.cmake +++ b/emulators/reicast/files/patch-reicast_cmake_config.cmake @@ -1,6 +1,14 @@ ---- reicast/cmake/config.cmake.orig 2020-08-21 20:26:50 UTC +--- reicast/cmake/config.cmake.orig 2020-10-18 11:22:48 UTC +++ reicast/cmake/config.cmake -@@ -106,11 +106,13 @@ endif() +@@ -39,6 +39,7 @@ set(OS_LINUX 0x10000002) + set(OS_DARWIN 0x10000003) + set(OS_IOS 0x10000004) # todo: iOS != OS_DARWIN + set(OS_ANDROID 0x10000005) # todo: should be SYSTEM_ANDROID but ! OS_LINUX ++set(OS_FREEBSD 0x10000006) + + set(OS_UWP 0x10000011) + set(OS_NSW_HOS 0x80000001) +@@ -106,11 +107,13 @@ endif() # AMD64/x86_64:x64, i*86:x86, ppc/powerpc[64][b|l]e:ppc[64] etc # if(("${CMAKE_SYSTEM_PROCESSOR}" STREQUAL "i686") OR @@ -14,3 +22,13 @@ ("${CMAKE_SYSTEM_PROCESSOR}" STREQUAL "x86_64") OR ("${CMAKE_SYSTEM_PROCESSOR}" STREQUAL "x64")) set(host_arch "x64") +@@ -164,6 +167,9 @@ elseif("windowsstore" STREQUAL "${host_os}") + + elseif(CMAKE_HOST_WIN32) + set(HOST_OS ${OS_WINDOWS}) ++ ++elseif("freebsd" STREQUAL "${host_os}") ++ set(HOST_OS ${OS_FREEBSD}) + + elseif(CMAKE_HOST_APPLE) +