From 7085fcc8d66267429fc6734be4ff0c563b9ff50a Mon Sep 17 00:00:00 2001 From: Jeffrey Pfau Date: Wed, 10 Jun 2015 22:15:11 -0700 Subject: [PATCH] Fix FreeBSD build --- Source/Core/Common/FileUtil.cpp | 2 +- Source/Core/Common/MemoryUtil.cpp | 8 ++++++-- Source/Core/Common/Thread.cpp | 10 ++++++++-- Source/Core/Core/HW/EXI_DeviceEthernet.h | 2 +- Source/Core/Core/IPC_HLE/WII_Socket.h | 2 +- Source/Core/DolphinWX/CMakeLists.txt | 6 +++++- Source/Core/VideoBackends/OGL/CMakeLists.txt | 4 +++- Source/Core/VideoCommon/DriverDetails.cpp | 2 ++ Source/Core/VideoCommon/DriverDetails.h | 1 + 9 files changed, 28 insertions(+), 9 deletions(-) diff --git a/Source/Core/Common/FileUtil.cpp b/Source/Core/Common/FileUtil.cpp index 925e3f1ed3..4709c011b2 100644 --- a/Source/Core/Common/FileUtil.cpp +++ b/Source/Core/Common/FileUtil.cpp @@ -42,7 +42,7 @@ #define S_ISDIR(m) (((m)&S_IFMT) == S_IFDIR) #endif -#ifdef BSD4_4 +#if defined BSD4_4 || defined __FreeBSD__ #define stat64 stat #define fstat64 fstat #endif diff --git a/Source/Core/Common/MemoryUtil.cpp b/Source/Core/Common/MemoryUtil.cpp index 510b258b09..c2befe56a6 100644 --- a/Source/Core/Common/MemoryUtil.cpp +++ b/Source/Core/Common/MemoryUtil.cpp @@ -20,7 +20,7 @@ #include #include #include -#ifdef __APPLE__ +#if defined __APPLE__ || defined __FreeBSD__ #include #else #include @@ -256,11 +256,15 @@ size_t MemPhysical() memInfo.dwLength = sizeof(MEMORYSTATUSEX); GlobalMemoryStatusEx(&memInfo); return memInfo.ullTotalPhys; -#elif defined(__APPLE__) +#elif defined __APPLE__ || defined __FreeBSD__ int mib[2]; size_t physical_memory; mib[0] = CTL_HW; +#ifdef __APPLE__ mib[1] = HW_MEMSIZE; +#elif defined __FreeBSD__ + mib[1] = HW_REALMEM; +#endif size_t length = sizeof(size_t); sysctl(mib, 2, &physical_memory, &length, NULL, 0); return physical_memory; diff --git a/Source/Core/Common/Thread.cpp b/Source/Core/Common/Thread.cpp index fb091ee2a7..1e60fbb29f 100644 --- a/Source/Core/Common/Thread.cpp +++ b/Source/Core/Common/Thread.cpp @@ -8,7 +8,7 @@ #ifdef __APPLE__ #include -#elif defined BSD4_4 +#elif defined BSD4_4 || defined __FreeBSD__ #include #endif @@ -94,8 +94,12 @@ void SetThreadAffinity(std::thread::native_handle_type thread, u32 mask) #ifdef __APPLE__ thread_policy_set(pthread_mach_thread_np(thread), THREAD_AFFINITY_POLICY, (integer_t *)&mask, 1); -#elif (defined __linux__ || defined BSD4_4) && !(defined ANDROID) +#elif (defined __linux__ || defined BSD4_4 || defined __FreeBSD__) && !(defined ANDROID) +#ifdef __FreeBSD__ + cpuset_t cpu_set; +#else cpu_set_t cpu_set; +#endif CPU_ZERO(&cpu_set); for (int i = 0; i != sizeof(mask) * 8; ++i) @@ -125,6 +129,8 @@ void SetCurrentThreadName(const char* szThreadName) { #ifdef __APPLE__ pthread_setname_np(szThreadName); +#elif defined __FreeBSD__ + pthread_set_name_np(pthread_self(), szThreadName); #else pthread_setname_np(pthread_self(), szThreadName); #endif diff --git a/Source/Core/Core/HW/EXI_DeviceEthernet.h b/Source/Core/Core/HW/EXI_DeviceEthernet.h index db5e92bc43..465bf40893 100644 --- a/Source/Core/Core/HW/EXI_DeviceEthernet.h +++ b/Source/Core/Core/HW/EXI_DeviceEthernet.h @@ -327,7 +327,7 @@ public: DWORD mMtu; OVERLAPPED mReadOverlapped; static VOID CALLBACK ReadWaitCallback(PVOID lpParameter, BOOLEAN TimerFired); -#elif defined(__linux__) || defined(__APPLE__) +#elif defined(__linux__) || defined(__APPLE__) || defined(__FreeBSD__) int fd; std::thread readThread; std::atomic readEnabled; diff --git a/Source/Core/Core/IPC_HLE/WII_Socket.h b/Source/Core/Core/IPC_HLE/WII_Socket.h index a38d1bb60d..edbb6ee60d 100644 --- a/Source/Core/Core/IPC_HLE/WII_Socket.h +++ b/Source/Core/Core/IPC_HLE/WII_Socket.h @@ -15,7 +15,7 @@ typedef pollfd pollfd_t; #define MALLOC(x) HeapAlloc(GetProcessHeap(), 0, (x)) #define FREE(x) HeapFree(GetProcessHeap(), 0, (x)) -#elif defined(__linux__) or defined(__APPLE__) +#elif defined(__linux__) or defined(__APPLE__) or defined(__FreeBSD__) #include #include #include diff --git a/Source/Core/DolphinWX/CMakeLists.txt b/Source/Core/DolphinWX/CMakeLists.txt index f378716dd2..d9cdb9bd9b 100644 --- a/Source/Core/DolphinWX/CMakeLists.txt +++ b/Source/Core/DolphinWX/CMakeLists.txt @@ -64,7 +64,11 @@ if(USE_X11) set(NOGUI_SRCS ${NOGUI_SRCS} X11Utils.cpp) endif() -set(WXLIBS ${wxWidgets_LIBRARIES} dl) +set(WXLIBS ${wxWidgets_LIBRARIES}) + +if(NOT CMAKE_SYSTEM_NAME MATCHES FreeBSD) + set(WXLIBS ${WXLIBS} dl) +endif() list(APPEND LIBS core uicommon) diff --git a/Source/Core/VideoBackends/OGL/CMakeLists.txt b/Source/Core/VideoBackends/OGL/CMakeLists.txt index 85964a3185..b4ece69de1 100644 --- a/Source/Core/VideoBackends/OGL/CMakeLists.txt +++ b/Source/Core/VideoBackends/OGL/CMakeLists.txt @@ -45,8 +45,10 @@ set(LIBS ${LIBS} videocommon SOIL common - dl ${X11_LIBRARIES}) +if(NOT CMAKE_SYSTEM_NAME MATCHES FreeBSD) + set(LIBS ${LIBS} dl) +endif() if(USE_EGL) set(LIBS ${LIBS} EGL) endif() diff --git a/Source/Core/VideoCommon/DriverDetails.cpp b/Source/Core/VideoCommon/DriverDetails.cpp index aa2e34d184..d3b1883cb3 100644 --- a/Source/Core/VideoCommon/DriverDetails.cpp +++ b/Source/Core/VideoCommon/DriverDetails.cpp @@ -30,6 +30,8 @@ namespace DriverDetails const u32 m_os = OS_ALL | OS_OSX; #elif __linux__ const u32 m_os = OS_ALL | OS_LINUX; +#elif __FreeBSD__ + const u32 m_os = OS_ALL | OS_FREEBSD; #endif static Vendor m_vendor = VENDOR_UNKNOWN; diff --git a/Source/Core/VideoCommon/DriverDetails.h b/Source/Core/VideoCommon/DriverDetails.h index 86fc2b04b6..cdc5026dc2 100644 --- a/Source/Core/VideoCommon/DriverDetails.h +++ b/Source/Core/VideoCommon/DriverDetails.h @@ -14,6 +14,7 @@ namespace DriverDetails OS_LINUX = (1 << 2), OS_OSX = (1 << 3), OS_ANDROID = (1 << 4), + OS_FREEBSD = (1 << 5), }; // Enum of known vendors // Tegra and Nvidia are separated out due to such substantial differences