diff --git a/CMakeLists.txt b/CMakeLists.txt
new file mode 100644
index 000000000..49a9a1138
--- /dev/null
+++ b/CMakeLists.txt
@@ -0,0 +1,313 @@
+cmake_minimum_required(VERSION 3.5.0 FATAL_ERROR)
+
+set(TNAME reicast)
+
+project(${TNAME})
+
+enable_language(ASM)
+
+set(DEBUG_CMAKE ON)
+
+set(CMAKE_VERBOSE_MAKEFILE ON)
+set(CMAKE_INCLUDE_CURRENT_DIR ON)
+
+
+## built-in cmake modules #
+#
+#include(CheckIncludeFiles)
+#include(CheckFunctionExists)
+#include(CheckCSourceCompiles)
+
+#set(CMAKE_BINARY_DIR ${CMAKE_CURRENT_BINARY_DIR}/bin)
+#set(LIBRARY_OUTPUT_PATH ${CMAKE_CURRENT_BINARY_DIR})
+#set(EXECUTABLE_OUTPUT_PATH ${CMAKE_CURRENT_BINARY_DIR})
+
+
+
+set(reicast_root_path "${CMAKE_CURRENT_SOURCE_DIR}")
+set(reicast_core_path "${reicast_root_path}/core")
+set(reicast_shell_path "${reicast_root_path}/shell")
+
+include_directories ("${reicast_core_path}")
+
+list(APPEND CMAKE_MODULE_PATH "${reicast_shell_path}/cmake")
+
+
+include(GetGitRevisionDescription)
+git_describe(GIT_VERSION --tags)
+configure_file(${reicast_core_path}/version.h.in ${reicast_core_path}/version.h @ONLY)
+
+
+
+
+## reicast build modules #
+#
+
+set(reicast_SRCS "")
+
+include(config) # configure build settings, must be first
+
+
+
+### libdreamcast.cmake #########################################################################
+
+set(d_core ${reicast_core_path})
+
+file(GLOB_RECURSE hw_SRCS ${d_core}/hw/*.cpp ${d_core}/hw/*.h)
+
+file(GLOB cfg_SRCS ${d_core}/cfg/*.cpp ${d_core}/cfg/*.h)
+file(GLOB rend_SRCS ${d_core}/rend/*.cpp ${d_core}/rend/*.h)
+file(GLOB input_SRCS ${d_core}/input/*.cpp ${d_core}/input/*.h)
+file(GLOB reios_SRCS ${d_core}/reios/*.cpp ${d_core}/reios/*.h)
+file(GLOB imgread_SRCS ${d_core}/imgread/*.cpp ${d_core}/imgread/*.h)
+file(GLOB profiler_SRCS ${d_core}/profiler/*.cpp ${d_core}/profiler/*.h)
+file(GLOB archive_SRCS ${d_core}/archive/*.cpp ${d_core}/archive/*.h)
+
+#### option(rend)
+file(GLOB gl4_SRCS ${d_core}/rend/gl4/*.cpp ${d_core}/rend/gl4/*.h)
+file(GLOB gles_SRCS ${d_core}/rend/gles/*.cpp ${d_core}/rend/gles/*.h)
+
+set(core_SRCS
+ ${hw_SRCS}
+ ${cfg_SRCS}
+ ${rend_SRCS}
+ ${gl4_SRCS}
+ ${gles_SRCS}
+ ${input_SRCS}
+ ${reios_SRCS}
+ ${imgread_SRCS}
+ ${profiler_SRCS}
+# ${archive_SRCS}
+ ${d_core}/archive/archive.cpp ${d_core}/archive/archive.h
+ ${d_core}/nullDC.cpp
+ ${d_core}/stdclass.cpp
+ ${d_core}/dispframe.cpp
+ ${d_core}/serialize.cpp
+)
+
+
+if(${FEAT_SHREC} EQUAL ${DYNAREC_JIT})
+#
+ if(${HOST_CPU} EQUAL ${CPU_X86})
+ list(APPEND core_SRCS
+ ${d_core}/rec-x86/rec_x86_driver.cpp
+ ${d_core}/rec-x86/rec_x86_il.cpp
+ ${d_core}/rec-x86/rec_x86_asm.cpp # change for linux , rec_lin86_asm.S
+ ${d_core}/rec-x86/rec_x86_ngen.h
+ )
+ elseif(${HOST_CPU} EQUAL ${CPU_ARM})
+ list(APPEND core_SRCS
+ ${d_core}/rec-ARM/ngen_arm.S
+ ${d_core}/rec-ARM/rec_arm.cpp
+ )
+ elseif(${HOST_CPU} EQUAL ${CPU_X64})
+
+ ### FIXME: asm with cmake ninja+VC
+ if(${BUILD_COMPILER} EQUAL ${COMPILER_VC})
+ list(APPEND core_SRCS ${d_core}/rec-x64/msvc.asm)
+ endif()
+
+ list(APPEND core_SRCS ${d_core}/rec-x64/rec_x64.cpp ${d_core}/rec-x64/x64_regalloc.h)
+
+ elseif(${HOST_CPU} EQUAL ${CPU_A64})
+ list(APPEND core_SRCS ${d_core}/rec-ARM64/rec_arm64.cpp ${d_core}/rec-ARM64/arm64_regalloc.h)
+
+ else()
+ message(" FEAT_SHREC==DYNAREC_JIT && HOST_CPU Unknown Default add arch or disable rec if not avail.")
+ error()
+ endif()
+#
+elseif(${FEAT_SHREC} EQUAL ${DYNAREC_CPP})
+ list(APPEND core_SRCS ${d_core}/rec-cpp/rec_cpp.cpp)
+endif()
+
+add_definitions(/DFEAT_HAS_SOFTREND=0)
+
+
+### deps.cmake #################################################################################
+
+set(d_deps ${reicast_core_path}/deps)
+include_directories ("${d_deps}")
+include_directories ("${d_deps}/picotcp/include")
+include_directories ("${d_deps}/picotcp/modules")
+
+file(GLOB xbyak_H ${d_deps}/xbyak/*.h) # include headers into cmake target/project view
+
+file(GLOB chdr_SRCS ${d_deps}/chdr/*.c)
+file(GLOB lzma_SRCS ${d_deps}/lzma/*.c)
+file(GLOB lz_SRCS ${d_deps}/zlib/*.c)
+file(GLOB lzip_SRCS ${d_deps}/libzip/*.c)
+file(GLOB lpng_SRCS ${d_deps}/libpng/*.c)
+file(GLOB lelf_SRCS ${d_deps}/libelf/el*.cpp)
+file(GLOB crypt_SRCS ${d_deps}/crypto/*.cpp)
+file(GLOB imgui_SRCS ${d_deps}/imgui/*.cpp)
+file(GLOB lws_SRCS ${d_deps}/libwebsocket/*.c)
+
+file(GLOB picoModS ${d_deps}/picotcp/modules/*.c)
+file(GLOB picoStkS ${d_deps}/picotcp/stack/*.c)
+set(pico_SRCS ${picoModS} ${picoStkS})
+
+set(deps_SRCS
+ ${lz_SRCS}
+# ${lzip_SRCS}
+# ${lzma_SRCS}
+# ${pico_SRCS}
+ ${lpng_SRCS}
+ ${lelf_SRCS}
+ ${chdr_SRCS}
+ ${crypt_SRCS}
+ ${imgui_SRCS}
+ ${d_deps}/xbrz/xbrz.cpp
+ ${d_deps}/dirent/dirent.c
+ ${d_deps}/xxhash/xxhash.c
+ ${d_deps}/chdpsr/cdipsr.cpp # sigh, this dir is named chdpsr for some reason ...
+ ${d_deps}/coreio/coreio.cpp
+# ${d_deps}/ifaddrs/ifaddrs.c
+ ${xbyak_H}
+)
+
+
+
+### libosd.cmake ################################################################################
+
+
+set(d_aout ${reicast_core_path}/oslib)
+
+include_directories ("${d_core}/khronos")
+
+## I really should just glob all of the dirs and ;shrug; if guards don't do it all ##
+
+set(osd_SRCS "")
+
+list(APPEND osd_SRCS ${d_aout}/audiostream.cpp)
+
+if (${HOST_OS} EQUAL ${OS_WINDOWS})
+
+ list(APPEND osd_SRCS ${d_core}/windows/winmain.cpp)
+ list(APPEND osd_SRCS ${d_aout}/audiobackend_directsound.cpp)
+
+
+ link_libraries(Dsound.lib winmm.lib)
+
+
+elseif (${HOST_OS} EQUAL ${OS_LINUX} OR ${HOST_OS} EQUAL ${OS_ANDROID})
+
+ list(APPEND osd_SRCS
+ ${d_core}/linux/common.cpp
+ ${d_core}/linux/context.cpp
+ ${d_core}/linux/nixprof/nixprof.cpp
+
+ ${d_aout}/audiobackend_oss.cpp # add option
+ ) # todo: configure linux audio lib options
+
+ if(NOT ANDROID)
+ list(APPEND osd_SRCS
+ ${d_core}/linux-dist/x11.cpp
+ ${d_core}/linux-dist/main.cpp
+ ${d_core}/linux-dist/evdev.cpp)
+
+ add_definitions(-DSUPPORT_X11) ## don't use GLES ?
+ link_libraries(X11)
+ else()
+ list(APPEND osd_SRCS
+ .//android-studio/reicast/src/main/jni/src/Android.cpp
+ .//android-studio/reicast/src/main/jni/src/utils.cpp
+ # .//android-studio/reicast/src/main/jni/src/XperiaPlay.c
+ )
+ endif() # ANDROID
+
+ add_definitions(-DGLES -DUSE_EVDEV)
+
+ link_libraries(pthread dl rt asound Xext GLESv2 EGL)
+
+elseif(${HOST_OS} EQUAL ${OS_DARWIN})
+#
+ list(APPEND objc_SRCS
+ ./shell/apple/emulator-osx/emulator-osx/osx-main.mm
+ ./shell/apple/emulator-osx/emulator-osx/AppDelegate.swift
+ ./shell/apple/emulator-osx/emulator-osx/EmuGLView.swift
+ )
+
+ set_source_files_properties(${objc_SRCS} PROPERTIES COMPILE_FLAGS "-x objective-c++")
+
+ list(APPEND osd_SRCS ${objc_SRCS}
+ ${d_osd}/linux/common.cpp
+ ${d_osd}/linux/context.cpp
+ ${d_osd}/audiobackend/audiobackend_coreaudio.cpp
+ # if NOT USE_SWIFT / ObjC
+ #${d_osd}/apple/osx_osd.cpp
+ )
+
+else()
+#
+ message("OS Unhandled")
+ error()
+#
+endif()
+
+
+
+
+
+set(reicast_SRCS ${core_SRCS} ${deps_SRCS} ${osd_SRCS})
+
+add_executable(${TNAME}${binSuffix} ${reicast_SRCS} ${deps_SRCS})
+
+
+
+
+
+if(APPLE)
+ enable_language(Swift)
+ set_property(TARGET ${TNAME} PROPERTY XCODE_ATTRIBUTE_SWIFT_OBJC_BRIDGING_HEADER "./shell/apple/emulator-osx/emulator-osx/emulator-osx-Bridging-Header.h")
+
+ target_link_libraries(${TNAME}
+# "-framework Cocoa"
+# "-framework AppKit"
+ "-framework CoreData"
+ "-framework CoreAudio"
+ "-framework AudioUnit"
+ "-framework AudioToolbox"
+ "-framework Foundation"
+)
+
+#### OSX Notes, when not using xcode you have to make app bundle, edit plist and copy, convert MainMenu.xib to nib and copy,
+#null@devpc:~$ /Users/null/Documents/projects/reicast-emulator/bin/RelWithDebInfo/Reicast.app/Contents/MacOS/reicast ; exit;
+#2019-03-18 14:28:44.842 reicast[11468:131797] Unknown class _TtC12emulator_osx9EmuGLView in Interface Builder file at path /Users/null/Documents/projects/reicast-emulator/bin/RelWithDebInfo/Reicast.app/Contents/Resources/MainMenu.nib.
+#2019-03-18 14:28:44.842 reicast[11468:131797] Unknown class _TtC12emulator_osx11AppDelegate in Interface Builder file at path /Users/null/Documents/projects/reicast-emulator/bin/RelWithDebInfo/Reicast.app/Contents/Resources/MainMenu.nib.
+#2019-03-18 14:28:44.860 reicast[11468:131797] Failed to connect (window) outlet from (NSObject) to (NSWindow): missing setter or instance variable
+#
+
+endif() #APPLE
+
+
+if(DEBUG_CMAKE)
+ message(" ------------------------------------------------")
+ message(" - HOST_OS: ${HOST_OS} - HOST_CPU: ${HOST_CPU} ")
+ message(" - host_os: ${host_os} - host_arch: ${host_arch} ")
+ message(" ------------------------------------------------")
+ message(" C Flags: ${CMAKE_C_FLAGS} ")
+ message(" CXX Flags: ${CMAKE_CXX_FLAGS} ")
+ message(" LINK_DIRS: ${LINK_DIRECTORIES}")
+ message("LINK_FLAGS: ${CMAKE_EXE_LINKER_FLAGS}")
+ message(" ------------------------------------------------\n")
+endif()
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/CMakeSettings.json b/CMakeSettings.json
new file mode 100644
index 000000000..8ddfb307d
--- /dev/null
+++ b/CMakeSettings.json
@@ -0,0 +1,216 @@
+{
+ "environments": [
+ {
+ "environment": "toolchain.generic",
+ "TOOLCHAIN_FILE": "ps4sdk.cmake"
+ }
+ ],
+ "configurations": [
+ {
+ "name": "win-x86-Debug",
+ "generator": "Ninja",
+ "description": "TemplateDescription_Localize_x86Debug",
+ "configurationType": "Debug",
+ "inheritEnvironments": [
+ "msvc_x86"
+ ],
+ "buildRoot": "${projectDir}\\build\\${name}",
+ "installRoot": "${projectDir}\\build\\${name}\\install",
+ "cmakeCommandArgs": "",
+ "buildCommandArgs": "-v",
+ "ctestCommandArgs": ""
+ },
+ {
+ "name": "win-x86-Release",
+ "generator": "Ninja",
+ "description": "TemplateDescription_Localize_x86Release",
+ "configurationType": "RelWithDebInfo",
+ "inheritEnvironments": [
+ "msvc_x86"
+ ],
+ "buildRoot": "${projectDir}\\build\\${name}",
+ "installRoot": "${projectDir}\\build\\${name}\\install",
+ "cmakeCommandArgs": "",
+ "buildCommandArgs": "-v",
+ "ctestCommandArgs": ""
+ },
+ {
+ "name": "win-x64-Debug",
+ "generator": "Ninja",
+ "description": "TemplateDescription_Localize_x64Debug",
+ "configurationType": "Debug",
+ "inheritEnvironments": [
+ "msvc_x64_x64"
+ ],
+ "buildRoot": "${projectDir}\\build\\${name}",
+ "installRoot": "${projectDir}\\build\\${name}\\install",
+ "cmakeCommandArgs": "-DNINJA=1",
+ "buildCommandArgs": "-v",
+ "ctestCommandArgs": ""
+ },
+ {
+ "name": "win-x64-Release",
+ "generator": "Ninja",
+ "description": "TemplateDescription_Localize_x64Release",
+ "configurationType": "RelWithDebInfo",
+ "inheritEnvironments": [
+ "msvc_x64_x64"
+ ],
+ "buildRoot": "${projectDir}\\build\\${name}",
+ "installRoot": "${projectDir}\\build\\${name}\\install",
+ "cmakeCommandArgs": "-DNINJA=1",
+ "buildCommandArgs": "-v",
+ "ctestCommandArgs": ""
+ },
+ {
+ "name": "win-x64-Clang-RelWithDebInfo",
+ "generator": "Ninja",
+ "description": "TemplateDescription_Localize_x64Release",
+ "configurationType": "RelWithDebInfo",
+ "inheritEnvironments": [
+ "msvc_x64_x64"
+ ],
+ "buildRoot": "${projectDir}\\build\\${name}",
+ "installRoot": "${projectDir}\\build\\${name}\\install",
+ "cmakeCommandArgs": "",
+ "buildCommandArgs": "-v",
+ "ctestCommandArgs": "",
+ "variables": [
+ {
+ "name": "CMAKE_C_COMPILER",
+ "value": "clang-cl.exe"
+ },
+ {
+ "name": "CMAKE_CXX_COMPILER",
+ "value": "clang-cl.exe"
+ }
+ ]
+ },
+ {
+ "name": "PS4 SDK",
+ "generator": "Ninja",
+ "description": "TemplateDescription_Localize_PS4SDK",
+ "configurationType": "RelWithDebInfo",
+ "inheritEnvironments": [
+ "toolchain.generic"
+ ],
+ "buildRoot": "${projectDir}\\build\\${name}",
+ "installRoot": "${projectDir}\\build\\${name}\\install",
+ "cmakeCommandArgs": "-DCMAKE_TOOLCHAIN_FILE=${projectDir}\\cmake\\ps4sdk.cmake",
+ "buildCommandArgs": "-v",
+ "ctestCommandArgs": ""
+ },
+ {
+ "name": "NSW SDK",
+ "generator": "Ninja",
+ "description": "TemplateDescription_Localize_PS4SDK",
+ "configurationType": "RelWithDebInfo",
+ "inheritEnvironments": [
+ "toolchain.generic"
+ ],
+ "buildRoot": "${projectDir}\\build\\${name}",
+ "installRoot": "${projectDir}\\build\\${name}\\install",
+ "cmakeCommandArgs": "-DCMAKE_TOOLCHAIN_FILE=${projectDir}\\cmake\\devkitA64.cmake",
+ "buildCommandArgs": "-v",
+ "ctestCommandArgs": ""
+ },
+ {
+ "name": "uwp-x64-Release",
+ "generator": "Visual Studio 15 2017 Win64",
+ "description": "TemplateDescription_Localize_x64Release",
+ "configurationType": "RelWithDebInfo",
+ "inheritEnvironments": [
+ "msvc_x64_x64"
+ ],
+ "buildRoot": "${projectDir}\\build\\${name}",
+ "installRoot": "${projectDir}\\build\\${name}\\install",
+ "cmakeCommandArgs": "-DCMAKE_SYSTEM_NAME=WindowsStore -DCMAKE_SYSTEM_VERSION=10",
+ "buildCommandArgs": "",
+ "ctestCommandArgs": ""
+ },
+ {
+ "name": "win-x64-MSBuild-Release",
+ "generator": "Visual Studio 15 2017 Win64",
+ "description": "TemplateDescription_Localize_x64Release",
+ "configurationType": "RelWithDebInfo",
+ "inheritEnvironments": [
+ "msvc_x64_x64"
+ ],
+ "buildRoot": "${projectDir}\\build\\${name}",
+ "installRoot": "${projectDir}\\build\\${name}\\install",
+ "cmakeCommandArgs": "",
+ "buildCommandArgs": "",
+ "ctestCommandArgs": ""
+ },
+ {
+ "environments": [
+ {
+ "MINGW64_ROOT": "C:\\msys64\\mingw64",
+ "BIN_ROOT": "${env.MINGW64_ROOT}\\bin",
+ "FLAVOR": "x86_64-w64-mingw32",
+ "TOOLSET_VERSION": "7.3.0",
+ "PATH": "${env.MINGW64_ROOT}\\bin;${env.MINGW64_ROOT}\\..\\usr\\local\\bin;${env.MINGW64_ROOT}\\..\\usr\\bin;${env.MINGW64_ROOT}\\..\\bin;${env.PATH}",
+ "INCLUDE": "${env.INCLUDE};${env.MINGW64_ROOT}\\include\\c++\\${env.TOOLSET_VERSION};${env.MINGW64_ROOT}\\include\\c++\\${env.TOOLSET_VERSION}\\tr1;${env.MINGW64_ROOT}\\include\\c++\\${env.TOOLSET_VERSION}\\${env.FLAVOR}",
+ "environment": "mingw_64"
+ }
+ ],
+ "name": "Mingw64-Release",
+ "generator": "Ninja",
+ "configurationType": "RelWithDebInfo",
+ "inheritEnvironments": [
+ "mingw_64"
+ ],
+ "buildRoot": "${projectDir}\\build\\${name}",
+ "installRoot": "${projectDir}\\build\\${name}\\install",
+ "cmakeCommandArgs": "",
+ "buildCommandArgs": "-v",
+ "ctestCommandArgs": "",
+ "intelliSenseMode": "linux-gcc-x64",
+ "variables": [
+ {
+ "name": "CMAKE_C_COMPILER",
+ "value": "${env.BIN_ROOT}\\gcc.exe"
+ },
+ {
+ "name": "CMAKE_CXX_COMPILER",
+ "value": "${env.BIN_ROOT}\\g++.exe"
+ }
+ ]
+ },
+ {
+ "environments": [
+ {
+ "MINGW64_ROOT": "C:\\msys64\\mingw64",
+ "BIN_ROOT": "${env.MINGW64_ROOT}\\bin",
+ "FLAVOR": "x86_64-w64-mingw32",
+ "TOOLSET_VERSION": "7.3.0",
+ "PATH": "${env.MINGW64_ROOT}\\bin;${env.MINGW64_ROOT}\\..\\usr\\local\\bin;${env.MINGW64_ROOT}\\..\\usr\\bin;${env.MINGW64_ROOT}\\..\\bin;${env.PATH}",
+ "INCLUDE": "${env.INCLUDE};${env.MINGW64_ROOT}\\include\\c++\\${env.TOOLSET_VERSION};${env.MINGW64_ROOT}\\include\\c++\\${env.TOOLSET_VERSION}\\tr1;${env.MINGW64_ROOT}\\include\\c++\\${env.TOOLSET_VERSION}\\${env.FLAVOR}",
+ "environment": "mingw_64"
+ }
+ ],
+ "name": "Mingw64-Debug",
+ "generator": "Ninja",
+ "configurationType": "Debug",
+ "inheritEnvironments": [
+ "mingw_64"
+ ],
+ "buildRoot": "${projectDir}\\build\\${name}",
+ "installRoot": "${projectDir}\\build\\${name}\\install",
+ "cmakeCommandArgs": "",
+ "buildCommandArgs": "-v",
+ "ctestCommandArgs": "",
+ "intelliSenseMode": "linux-gcc-x64",
+ "variables": [
+ {
+ "name": "CMAKE_C_COMPILER",
+ "value": "${env.BIN_ROOT}\\gcc.exe"
+ },
+ {
+ "name": "CMAKE_CXX_COMPILER",
+ "value": "${env.BIN_ROOT}\\g++.exe"
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/core/build.h b/core/build.h
index a9a9777dd..4dc84a222 100755
--- a/core/build.h
+++ b/core/build.h
@@ -127,10 +127,18 @@
#define DC_PLATFORM_AURORA 6 /* Needs to be done, Uses newer 300 mhz sh4 + 150 mhz pvr mbx SoC */
+
//HOST_OS
#define OS_WINDOWS 0x10000001
#define OS_LINUX 0x10000002
#define OS_DARWIN 0x10000003
+#define OS_IOS 0x10000004
+#define OS_ANDROID 0x10000005
+
+#define OS_UWP 0x10000011
+#define OS_NSW_HOS 0x80000001
+#define OS_PS4_BSD 0x80000002
+
//HOST_CPU
#define CPU_X86 0x20000001
@@ -138,11 +146,16 @@
#define CPU_MIPS 0x20000003
#define CPU_X64 0x20000004
#define CPU_GENERIC 0x20000005 //used for pnacl, emscripten, etc
-#define CPU_ARM64 0x20000006
+#define CPU_PPC 0x20000006
+#define CPU_PPC64 0x20000007
+#define CPU_A64 0x20000008
+#define CPU_MIPS64 0x20000009
//BUILD_COMPILER
-#define COMPILER_VC 0x30000001
-#define COMPILER_GCC 0x30000002
+#define COMPILER_VC 0x30000001
+#define COMPILER_GCC 0x30000002
+#define COMPILER_CLANG 0x30000002
+#define COMPILER_INTEL 0x30000002
//FEAT_SHREC, FEAT_AREC, FEAT_DSPREC
#define DYNAREC_NONE 0x40000001
@@ -152,6 +165,8 @@
//automatic
+#ifndef CMAKE_BUILD
+
#if defined(_WIN32) && !defined(TARGET_WIN86) && !defined(TARGET_WIN64)
#if !defined(_M_AMD64) && !defined(__x86_64__)
#define TARGET_WIN86
@@ -233,6 +248,8 @@
#define FEAT_DSPREC DYNAREC_NONE
#endif
+#endif // !CMAKE_BUILD
+
#if defined(TARGET_NO_NIXPROF)
#define FEAT_HAS_NIXPROF 0
@@ -295,6 +312,19 @@
#error Dont use HOST_NO_AREC
#endif
+
+// Compiler Related
+
+#if BUILD_COMPILER!=COMPILER_VC
+#define ATTR_USED __attribute__((used))
+#define ATTR_UNUSED __attribute__((used))
+#else
+#define ATTR_USED
+#define ATTR_UNUSED
+#endif
+
+
+
// TARGET PLATFORM
#define RAM_SIZE_MAX (32*1024*1024)
diff --git a/core/hw/modem/dns.cpp b/core/hw/modem/dns.cpp
index 1dc7f46c8..1f1b3283e 100644
--- a/core/hw/modem/dns.cpp
+++ b/core/hw/modem/dns.cpp
@@ -18,6 +18,9 @@
You should have received a copy of the GNU General Public License
along with reicast. If not, see .
*/
+#include "types.h"
+
+#if BUILD_COMPILER!=COMPILER_VC && (BUILD_COMPILER!=COMPILER_CLANG || !WIN32)
#include
#include
@@ -145,3 +148,5 @@ char *read_name(char *reader, char *buffer, int *count)
return name;
}
+
+#endif // BUILD_COMPILER!=COMPILER_VC
\ No newline at end of file
diff --git a/core/hw/sh4/dyna/blockmanager.h b/core/hw/sh4/dyna/blockmanager.h
index 5c11af77f..e21fb3dee 100644
--- a/core/hw/sh4/dyna/blockmanager.h
+++ b/core/hw/sh4/dyna/blockmanager.h
@@ -86,10 +86,7 @@ void bm_WriteBlockMap(const string& file);
DynarecCodeEntryPtr DYNACALL bm_GetCode(u32 addr);
extern "C" {
-#ifndef _MSC_VER
-__attribute__((used))
-#endif
- DynarecCodeEntryPtr DYNACALL bm_GetCode2(u32 addr);
+ATTR_USED DynarecCodeEntryPtr DYNACALL bm_GetCode2(u32 addr);
}
RuntimeBlockInfo* bm_GetBlock(void* dynarec_code);
diff --git a/core/hw/sh4/sh4_interpreter.h b/core/hw/sh4/sh4_interpreter.h
index 8d827af84..8a22caa83 100644
--- a/core/hw/sh4/sh4_interpreter.h
+++ b/core/hw/sh4/sh4_interpreter.h
@@ -61,9 +61,7 @@ void ExecuteDelayslot_RTE();
extern "C" {
int UpdateSystem();
-#ifndef _MSC_VER
-__attribute__((used))
-#endif
- int UpdateSystem_INTC();
+
+ATTR_USED int UpdateSystem_INTC();
}
diff --git a/core/hw/sh4/sh4_sched.cpp b/core/hw/sh4/sh4_sched.cpp
index baeef15a8..65b8af0c7 100755
--- a/core/hw/sh4/sh4_sched.cpp
+++ b/core/hw/sh4/sh4_sched.cpp
@@ -25,15 +25,15 @@ u64 sh4_sched_ffb;
u32 sh4_sched_intr;
-vector list;
+vector sch_list; // using list as external inside a macro confuses clang and msc
int sh4_sched_next_id=-1;
u32 sh4_sched_remaining(int id, u32 reference)
{
- if (list[id].end != -1)
+ if (sch_list[id].end != -1)
{
- return list[id].end - reference;
+ return sch_list[id].end - reference;
}
else
{
@@ -51,7 +51,7 @@ void sh4_sched_ffts()
u32 diff=-1;
int slot=-1;
- for (size_t i=0;i= 0 && cycles <= SH4_MAIN_CLOCK));
- list[id].start=sh4_sched_now();
+ sch_list[id].start=sh4_sched_now();
if (cycles == -1) {
- list[id].end = -1;
+ sch_list[id].end = -1;
}
else
{
- list[id].end = list[id].start + cycles;
- if (list[id].end == -1)
- list[id].end++;
+ sch_list[id].end = sch_list[id].start + cycles;
+ if (sch_list[id].end == -1)
+ sch_list[id].end++;
}
sh4_sched_ffts();
@@ -120,10 +120,10 @@ void sh4_sched_request(int id, int cycles)
int sh4_sched_elapsed(int id)
{
- if (list[id].end!=-1)
+ if (sch_list[id].end!=-1)
{
- int rv=sh4_sched_now()-list[id].start;
- list[id].start=sh4_sched_now();
+ int rv=sh4_sched_now()-sch_list[id].start;
+ sch_list[id].start=sh4_sched_now();
return rv;
}
else
@@ -132,12 +132,12 @@ int sh4_sched_elapsed(int id)
void handle_cb(int id)
{
- int remain=list[id].end-list[id].start;
+ int remain=sch_list[id].end-sch_list[id].start;
int elapsd=sh4_sched_elapsed(id);
int jitter=elapsd-remain;
- list[id].end=-1;
- int re_sch=list[id].cb(list[id].tag,remain,jitter);
+ sch_list[id].end=-1;
+ int re_sch=sch_list[id].cb(sch_list[id].tag,remain,jitter);
if (re_sch > 0)
sh4_sched_request(id, max(0, re_sch - jitter));
@@ -156,7 +156,7 @@ void sh4_sched_tick(int cycles)
sh4_sched_intr++;
if (sh4_sched_next_id!=-1)
{
- for (int i=0;i= 0 || remaining == -1);
diff --git a/core/rend/gl4/gltex.cpp b/core/rend/gl4/gltex.cpp
index 85a0b9430..52aba888e 100644
--- a/core/rend/gl4/gltex.cpp
+++ b/core/rend/gl4/gltex.cpp
@@ -1,5 +1,5 @@
#include "gl4.h"
-#include "glcache.h"
+#include "../gles/glcache.h"
GLuint gl4BindRTT(u32 addy, u32 fbw, u32 fbh, u32 channels, u32 fmt)
{
diff --git a/core/rend/gui.cpp b/core/rend/gui.cpp
index e3fde42f4..a530f5b5c 100644
--- a/core/rend/gui.cpp
+++ b/core/rend/gui.cpp
@@ -39,7 +39,8 @@
#include "linux-dist/main.h" // FIXME for kcode[]
#include "gui_util.h"
#include "gui_android.h"
-#include "version/version.h"
+
+#include "version.h"
#include "oslib/audiostream.h"
diff --git a/core/serialize.cpp b/core/serialize.cpp
index f040744a4..9d28fd068 100644
--- a/core/serialize.cpp
+++ b/core/serialize.cpp
@@ -441,7 +441,7 @@ extern u32 old_dn;
//./core/hw/sh4/sh4_sched.o
extern u64 sh4_sched_ffb;
extern u32 sh4_sched_intr;
-extern vector list;
+extern vector sch_list;
//extern int sh4_sched_next_id;
@@ -975,8 +975,6 @@ bool dc_serialize(void **data, unsigned int *total_size)
REICAST_S(decoded_srimask);
-
-
//default to nommu_full
i = 3 ;
if ( do_sqw_nommu == &do_sqw_nommu_area_3)
@@ -1008,48 +1006,49 @@ bool dc_serialize(void **data, unsigned int *total_size)
//extern vector list;
- REICAST_S(list[aica_schid].tag) ;
- REICAST_S(list[aica_schid].start) ;
- REICAST_S(list[aica_schid].end) ;
- REICAST_S(list[rtc_schid].tag) ;
- REICAST_S(list[rtc_schid].start) ;
- REICAST_S(list[rtc_schid].end) ;
+ REICAST_S(sch_list[aica_schid].tag) ;
+ REICAST_S(sch_list[aica_schid].start) ;
+ REICAST_S(sch_list[aica_schid].end) ;
- REICAST_S(list[gdrom_schid].tag) ;
- REICAST_S(list[gdrom_schid].start) ;
- REICAST_S(list[gdrom_schid].end) ;
+ REICAST_S(sch_list[rtc_schid].tag) ;
+ REICAST_S(sch_list[rtc_schid].start) ;
+ REICAST_S(sch_list[rtc_schid].end) ;
- REICAST_S(list[maple_schid].tag) ;
- REICAST_S(list[maple_schid].start) ;
- REICAST_S(list[maple_schid].end) ;
+ REICAST_S(sch_list[gdrom_schid].tag) ;
+ REICAST_S(sch_list[gdrom_schid].start) ;
+ REICAST_S(sch_list[gdrom_schid].end) ;
- REICAST_S(list[dma_sched_id].tag) ;
- REICAST_S(list[dma_sched_id].start) ;
- REICAST_S(list[dma_sched_id].end) ;
+ REICAST_S(sch_list[maple_schid].tag) ;
+ REICAST_S(sch_list[maple_schid].start) ;
+ REICAST_S(sch_list[maple_schid].end) ;
+
+ REICAST_S(sch_list[dma_sched_id].tag) ;
+ REICAST_S(sch_list[dma_sched_id].start) ;
+ REICAST_S(sch_list[dma_sched_id].end) ;
for (int i = 0; i < 3; i++)
{
- REICAST_S(list[tmu_sched[i]].tag) ;
- REICAST_S(list[tmu_sched[i]].start) ;
- REICAST_S(list[tmu_sched[i]].end) ;
+ REICAST_S(sch_list[tmu_sched[i]].tag) ;
+ REICAST_S(sch_list[tmu_sched[i]].start) ;
+ REICAST_S(sch_list[tmu_sched[i]].end) ;
}
- REICAST_S(list[render_end_schid].tag) ;
- REICAST_S(list[render_end_schid].start) ;
- REICAST_S(list[render_end_schid].end) ;
+ REICAST_S(sch_list[render_end_schid].tag) ;
+ REICAST_S(sch_list[render_end_schid].start) ;
+ REICAST_S(sch_list[render_end_schid].end) ;
- REICAST_S(list[vblank_schid].tag) ;
- REICAST_S(list[vblank_schid].start) ;
- REICAST_S(list[vblank_schid].end) ;
+ REICAST_S(sch_list[vblank_schid].tag) ;
+ REICAST_S(sch_list[vblank_schid].start) ;
+ REICAST_S(sch_list[vblank_schid].end) ;
- REICAST_S(list[time_sync].tag) ;
- REICAST_S(list[time_sync].start) ;
- REICAST_S(list[time_sync].end) ;
+ REICAST_S(sch_list[time_sync].tag) ;
+ REICAST_S(sch_list[time_sync].start) ;
+ REICAST_S(sch_list[time_sync].end) ;
- REICAST_S(list[modem_sched].tag) ;
- REICAST_S(list[modem_sched].start) ;
- REICAST_S(list[modem_sched].end) ;
+ REICAST_S(sch_list[modem_sched].tag) ;
+ REICAST_S(sch_list[modem_sched].start) ;
+ REICAST_S(sch_list[modem_sched].end) ;
@@ -1408,50 +1407,50 @@ static bool dc_unserialize_libretro(void **data, unsigned int *total_size)
REICAST_US(sh4_sched_ffb);
REICAST_US(sh4_sched_intr);
- //extern vector list;
+ //extern vector sch_list;
- REICAST_US(list[aica_schid].tag) ;
- REICAST_US(list[aica_schid].start) ;
- REICAST_US(list[aica_schid].end) ;
+ REICAST_US(sch_list[aica_schid].tag) ;
+ REICAST_US(sch_list[aica_schid].start) ;
+ REICAST_US(sch_list[aica_schid].end) ;
- REICAST_US(list[rtc_schid].tag) ;
- REICAST_US(list[rtc_schid].start) ;
- REICAST_US(list[rtc_schid].end) ;
+ REICAST_US(sch_list[rtc_schid].tag) ;
+ REICAST_US(sch_list[rtc_schid].start) ;
+ REICAST_US(sch_list[rtc_schid].end) ;
- REICAST_US(list[gdrom_schid].tag) ;
- REICAST_US(list[gdrom_schid].start) ;
- REICAST_US(list[gdrom_schid].end) ;
+ REICAST_US(sch_list[gdrom_schid].tag) ;
+ REICAST_US(sch_list[gdrom_schid].start) ;
+ REICAST_US(sch_list[gdrom_schid].end) ;
- REICAST_US(list[maple_schid].tag) ;
- REICAST_US(list[maple_schid].start) ;
- REICAST_US(list[maple_schid].end) ;
+ REICAST_US(sch_list[maple_schid].tag) ;
+ REICAST_US(sch_list[maple_schid].start) ;
+ REICAST_US(sch_list[maple_schid].end) ;
- REICAST_US(list[dma_sched_id].tag) ;
- REICAST_US(list[dma_sched_id].start) ;
- REICAST_US(list[dma_sched_id].end) ;
+ REICAST_US(sch_list[dma_sched_id].tag) ;
+ REICAST_US(sch_list[dma_sched_id].start) ;
+ REICAST_US(sch_list[dma_sched_id].end) ;
for (int i = 0; i < 3; i++)
{
- REICAST_US(list[tmu_sched[i]].tag) ;
- REICAST_US(list[tmu_sched[i]].start) ;
- REICAST_US(list[tmu_sched[i]].end) ;
+ REICAST_US(sch_list[tmu_sched[i]].tag) ;
+ REICAST_US(sch_list[tmu_sched[i]].start) ;
+ REICAST_US(sch_list[tmu_sched[i]].end) ;
}
- REICAST_US(list[render_end_schid].tag) ;
- REICAST_US(list[render_end_schid].start) ;
- REICAST_US(list[render_end_schid].end) ;
+ REICAST_US(sch_list[render_end_schid].tag) ;
+ REICAST_US(sch_list[render_end_schid].start) ;
+ REICAST_US(sch_list[render_end_schid].end) ;
- REICAST_US(list[vblank_schid].tag) ;
- REICAST_US(list[vblank_schid].start) ;
- REICAST_US(list[vblank_schid].end) ;
+ REICAST_US(sch_list[vblank_schid].tag) ;
+ REICAST_US(sch_list[vblank_schid].start) ;
+ REICAST_US(sch_list[vblank_schid].end) ;
- REICAST_US(list[time_sync].tag) ;
- REICAST_US(list[time_sync].start) ;
- REICAST_US(list[time_sync].end) ;
+ REICAST_US(sch_list[time_sync].tag) ;
+ REICAST_US(sch_list[time_sync].start) ;
+ REICAST_US(sch_list[time_sync].end) ;
- REICAST_US(list[modem_sched].tag) ;
- REICAST_US(list[modem_sched].start) ;
- REICAST_US(list[modem_sched].end) ;
+ REICAST_US(sch_list[modem_sched].tag) ;
+ REICAST_US(sch_list[modem_sched].start) ;
+ REICAST_US(sch_list[modem_sched].end) ;
@@ -1800,48 +1799,48 @@ bool dc_unserialize(void **data, unsigned int *total_size)
//extern vector list;
- REICAST_US(list[aica_schid].tag) ;
- REICAST_US(list[aica_schid].start) ;
- REICAST_US(list[aica_schid].end) ;
+ REICAST_US(sch_list[aica_schid].tag) ;
+ REICAST_US(sch_list[aica_schid].start) ;
+ REICAST_US(sch_list[aica_schid].end) ;
- REICAST_US(list[rtc_schid].tag) ;
- REICAST_US(list[rtc_schid].start) ;
- REICAST_US(list[rtc_schid].end) ;
+ REICAST_US(sch_list[rtc_schid].tag) ;
+ REICAST_US(sch_list[rtc_schid].start) ;
+ REICAST_US(sch_list[rtc_schid].end) ;
- REICAST_US(list[gdrom_schid].tag) ;
- REICAST_US(list[gdrom_schid].start) ;
- REICAST_US(list[gdrom_schid].end) ;
+ REICAST_US(sch_list[gdrom_schid].tag) ;
+ REICAST_US(sch_list[gdrom_schid].start) ;
+ REICAST_US(sch_list[gdrom_schid].end) ;
- REICAST_US(list[maple_schid].tag) ;
- REICAST_US(list[maple_schid].start) ;
- REICAST_US(list[maple_schid].end) ;
+ REICAST_US(sch_list[maple_schid].tag) ;
+ REICAST_US(sch_list[maple_schid].start) ;
+ REICAST_US(sch_list[maple_schid].end) ;
- REICAST_US(list[dma_sched_id].tag) ;
- REICAST_US(list[dma_sched_id].start) ;
- REICAST_US(list[dma_sched_id].end) ;
+ REICAST_US(sch_list[dma_sched_id].tag) ;
+ REICAST_US(sch_list[dma_sched_id].start) ;
+ REICAST_US(sch_list[dma_sched_id].end) ;
for (int i = 0; i < 3; i++)
{
- REICAST_US(list[tmu_sched[i]].tag) ;
- REICAST_US(list[tmu_sched[i]].start) ;
- REICAST_US(list[tmu_sched[i]].end) ;
+ REICAST_US(sch_list[tmu_sched[i]].tag) ;
+ REICAST_US(sch_list[tmu_sched[i]].start) ;
+ REICAST_US(sch_list[tmu_sched[i]].end) ;
}
- REICAST_US(list[render_end_schid].tag) ;
- REICAST_US(list[render_end_schid].start) ;
- REICAST_US(list[render_end_schid].end) ;
+ REICAST_US(sch_list[render_end_schid].tag) ;
+ REICAST_US(sch_list[render_end_schid].start) ;
+ REICAST_US(sch_list[render_end_schid].end) ;
- REICAST_US(list[vblank_schid].tag) ;
- REICAST_US(list[vblank_schid].start) ;
- REICAST_US(list[vblank_schid].end) ;
+ REICAST_US(sch_list[vblank_schid].tag) ;
+ REICAST_US(sch_list[vblank_schid].start) ;
+ REICAST_US(sch_list[vblank_schid].end) ;
- REICAST_US(list[time_sync].tag) ;
- REICAST_US(list[time_sync].start) ;
- REICAST_US(list[time_sync].end) ;
+ REICAST_US(sch_list[time_sync].tag) ;
+ REICAST_US(sch_list[time_sync].start) ;
+ REICAST_US(sch_list[time_sync].end) ;
- REICAST_US(list[modem_sched].tag) ;
- REICAST_US(list[modem_sched].start) ;
- REICAST_US(list[modem_sched].end) ;
+ REICAST_US(sch_list[modem_sched].tag) ;
+ REICAST_US(sch_list[modem_sched].start) ;
+ REICAST_US(sch_list[modem_sched].end) ;
diff --git a/core/stdclass.cpp b/core/stdclass.cpp
index 59bf1e94a..f9acec72f 100644
--- a/core/stdclass.cpp
+++ b/core/stdclass.cpp
@@ -5,12 +5,10 @@
#include "types.h"
#include "cfg/cfg.h"
-#ifdef WIN32
-#include
-#endif
-#if BUILD_COMPILER==COMPILER_VC
+#if BUILD_COMPILER==COMPILER_VC || (WIN32 && BUILD_COMPILER==COMPILER_CLANG)
#include
+ #include
#define access _access
#define R_OK 4
#else
diff --git a/core/types.h b/core/types.h
index 4d9369127..4f3fb23b8 100644
--- a/core/types.h
+++ b/core/types.h
@@ -385,9 +385,9 @@ using namespace std;
#include "stdclass.h"
#ifndef RELEASE
-#define EMUERROR(format, ...) printf("Error in %s:%s:%d: " format "\n", \
- strlen(__FILE__) <= 20 ? __FILE__ : __FILE__ + strlen(__FILE__) - 20, \
- __FUNCTION__, __LINE__, ##__VA_ARGS__)
+#define EMUERROR(format, ...) printf("Error in %20s:%s:%d: " format "\n", \
+ __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__)
+//strlen(__FILE__) <= 20 ? __FILE__ : __FILE__ + strlen(__FILE__) - 20,
#else
#define EMUERROR(format, ...)
#endif
@@ -521,7 +521,7 @@ typedef union
#if COMPILER_VC==BUILD_COMPILER
#pragma warning( disable : 4127 4996 /*4244*/)
#else
-#define stricmp strcasecmp
+#define stricmp _stricmp // ISO , was strcasecmp
#endif
#ifndef STRIP_TEXT
diff --git a/core/version.h.in b/core/version.h.in
new file mode 100644
index 000000000..81a831a05
--- /dev/null
+++ b/core/version.h.in
@@ -0,0 +1,8 @@
+/*
+ * reicast: version.h
+ */
+#pragma once
+
+#define REICAST_VERSION "@GIT_VERSION@"
+#define GIT_HASH "@GIT_HASH@"
+#define BUILD_DATE __DATE__
\ No newline at end of file
diff --git a/core/windows/winmain.cpp b/core/windows/winmain.cpp
index 3aa5a4a51..7e269a90d 100644
--- a/core/windows/winmain.cpp
+++ b/core/windows/winmain.cpp
@@ -673,7 +673,7 @@ int CALLBACK WinMain(HINSTANCE hInstance,HINSTANCE hPrevInstance,LPSTR lpCmdLine
#ifdef _WIN64
AddVectoredExceptionHandler(1, ExeptionHandler);
#else
- SetUnhandledExceptionFilter(&ExeptionHandler);
+ SetUnhandledExceptionFilter((LPTOP_LEVEL_EXCEPTION_FILTER)&ExeptionHandler);
#endif
#ifndef __GNUC__
__try
diff --git a/shell/cmake/GetGitRevisionDescription.cmake b/shell/cmake/GetGitRevisionDescription.cmake
new file mode 100644
index 000000000..8ab03bc5f
--- /dev/null
+++ b/shell/cmake/GetGitRevisionDescription.cmake
@@ -0,0 +1,168 @@
+# - Returns a version string from Git
+#
+# These functions force a re-configure on each git commit so that you can
+# trust the values of the variables in your build system.
+#
+# get_git_head_revision( [ ...])
+#
+# Returns the refspec and sha hash of the current head revision
+#
+# git_describe( [ ...])
+#
+# Returns the results of git describe on the source tree, and adjusting
+# the output so that it tests false if an error occurs.
+#
+# git_get_exact_tag( [ ...])
+#
+# Returns the results of git describe --exact-match on the source tree,
+# and adjusting the output so that it tests false if there was no exact
+# matching tag.
+#
+# git_local_changes()
+#
+# Returns either "CLEAN" or "DIRTY" with respect to uncommitted changes.
+# Uses the return code of "git diff-index --quiet HEAD --".
+# Does not regard untracked files.
+#
+# Requires CMake 2.6 or newer (uses the 'function' command)
+#
+# Original Author:
+# 2009-2010 Ryan Pavlik
+# http://academic.cleardefinition.com
+# Iowa State University HCI Graduate Program/VRAC
+#
+# Copyright Iowa State University 2009-2010.
+# Distributed under the Boost Software License, Version 1.0.
+# (See accompanying file LICENSE_1_0.txt or copy at
+# http://www.boost.org/LICENSE_1_0.txt)
+
+if(__get_git_revision_description)
+ return()
+endif()
+set(__get_git_revision_description YES)
+
+# We must run the following at "include" time, not at function call time,
+# to find the path to this module rather than the path to a calling list file
+get_filename_component(_gitdescmoddir ${CMAKE_CURRENT_LIST_FILE} PATH)
+
+function(get_git_head_revision _refspecvar _hashvar)
+ set(GIT_PARENT_DIR "${CMAKE_CURRENT_SOURCE_DIR}")
+ set(GIT_DIR "${GIT_PARENT_DIR}/.git")
+ while(NOT EXISTS "${GIT_DIR}") # .git dir not found, search parent directories
+ set(GIT_PREVIOUS_PARENT "${GIT_PARENT_DIR}")
+ get_filename_component(GIT_PARENT_DIR ${GIT_PARENT_DIR} PATH)
+ if(GIT_PARENT_DIR STREQUAL GIT_PREVIOUS_PARENT)
+ # We have reached the root directory, we are not in git
+ set(${_refspecvar} "GITDIR-NOTFOUND" PARENT_SCOPE)
+ set(${_hashvar} "GITDIR-NOTFOUND" PARENT_SCOPE)
+ return()
+ endif()
+ set(GIT_DIR "${GIT_PARENT_DIR}/.git")
+ endwhile()
+ # check if this is a submodule
+ if(NOT IS_DIRECTORY ${GIT_DIR})
+ file(READ ${GIT_DIR} submodule)
+ string(REGEX REPLACE "gitdir: (.*)\n$" "\\1" GIT_DIR_RELATIVE ${submodule})
+ get_filename_component(SUBMODULE_DIR ${GIT_DIR} PATH)
+ get_filename_component(GIT_DIR ${SUBMODULE_DIR}/${GIT_DIR_RELATIVE} ABSOLUTE)
+ endif()
+ set(GIT_DATA "${CMAKE_CURRENT_BINARY_DIR}/CMakeFiles/git-data")
+ if(NOT EXISTS "${GIT_DATA}")
+ file(MAKE_DIRECTORY "${GIT_DATA}")
+ endif()
+
+ if(NOT EXISTS "${GIT_DIR}/HEAD")
+ return()
+ endif()
+ set(HEAD_FILE "${GIT_DATA}/HEAD")
+ configure_file("${GIT_DIR}/HEAD" "${HEAD_FILE}" COPYONLY)
+
+ configure_file("${_gitdescmoddir}/GetGitRevisionDescription.cmake.in"
+ "${GIT_DATA}/grabRef.cmake"
+ @ONLY)
+ include("${GIT_DATA}/grabRef.cmake")
+
+ set(${_refspecvar} "${HEAD_REF}" PARENT_SCOPE)
+ set(${_hashvar} "${HEAD_HASH}" PARENT_SCOPE)
+endfunction()
+
+function(git_describe _var)
+ if(NOT GIT_FOUND)
+ find_package(Git QUIET)
+ endif()
+ get_git_head_revision(refspec hash)
+ if(NOT GIT_FOUND)
+ set(${_var} "GIT-NOTFOUND" PARENT_SCOPE)
+ return()
+ endif()
+ if(NOT hash)
+ set(${_var} "HEAD-HASH-NOTFOUND" PARENT_SCOPE)
+ return()
+ endif()
+
+ # TODO sanitize
+ #if((${ARGN}" MATCHES "&&") OR
+ # (ARGN MATCHES "||") OR
+ # (ARGN MATCHES "\\;"))
+ # message("Please report the following error to the project!")
+ # message(FATAL_ERROR "Looks like someone's doing something nefarious with git_describe! Passed arguments ${ARGN}")
+ #endif()
+
+ #message(STATUS "Arguments to execute_process: ${ARGN}")
+
+ execute_process(COMMAND
+ "${GIT_EXECUTABLE}"
+ describe
+ ${hash}
+ ${ARGN}
+ WORKING_DIRECTORY
+ "${CMAKE_CURRENT_SOURCE_DIR}"
+ RESULT_VARIABLE
+ res
+ OUTPUT_VARIABLE
+ out
+ ERROR_QUIET
+ OUTPUT_STRIP_TRAILING_WHITESPACE)
+ if(NOT res EQUAL 0)
+ set(out "${out}-${res}-NOTFOUND")
+ endif()
+
+ set(${_var} "${out}" PARENT_SCOPE)
+endfunction()
+
+function(git_get_exact_tag _var)
+ git_describe(out --exact-match ${ARGN})
+ set(${_var} "${out}" PARENT_SCOPE)
+endfunction()
+
+function(git_local_changes _var)
+ if(NOT GIT_FOUND)
+ find_package(Git QUIET)
+ endif()
+ get_git_head_revision(refspec hash)
+ if(NOT GIT_FOUND)
+ set(${_var} "GIT-NOTFOUND" PARENT_SCOPE)
+ return()
+ endif()
+ if(NOT hash)
+ set(${_var} "HEAD-HASH-NOTFOUND" PARENT_SCOPE)
+ return()
+ endif()
+
+ execute_process(COMMAND
+ "${GIT_EXECUTABLE}"
+ diff-index --quiet HEAD --
+ WORKING_DIRECTORY
+ "${CMAKE_CURRENT_SOURCE_DIR}"
+ RESULT_VARIABLE
+ res
+ OUTPUT_VARIABLE
+ out
+ ERROR_QUIET
+ OUTPUT_STRIP_TRAILING_WHITESPACE)
+ if(res EQUAL 0)
+ set(${_var} "CLEAN" PARENT_SCOPE)
+ else()
+ set(${_var} "DIRTY" PARENT_SCOPE)
+ endif()
+endfunction()
diff --git a/shell/cmake/GetGitRevisionDescription.cmake.in b/shell/cmake/GetGitRevisionDescription.cmake.in
new file mode 100644
index 000000000..6d8b708ef
--- /dev/null
+++ b/shell/cmake/GetGitRevisionDescription.cmake.in
@@ -0,0 +1,41 @@
+#
+# Internal file for GetGitRevisionDescription.cmake
+#
+# Requires CMake 2.6 or newer (uses the 'function' command)
+#
+# Original Author:
+# 2009-2010 Ryan Pavlik
+# http://academic.cleardefinition.com
+# Iowa State University HCI Graduate Program/VRAC
+#
+# Copyright Iowa State University 2009-2010.
+# Distributed under the Boost Software License, Version 1.0.
+# (See accompanying file LICENSE_1_0.txt or copy at
+# http://www.boost.org/LICENSE_1_0.txt)
+
+set(HEAD_HASH)
+
+file(READ "@HEAD_FILE@" HEAD_CONTENTS LIMIT 1024)
+
+string(STRIP "${HEAD_CONTENTS}" HEAD_CONTENTS)
+if(HEAD_CONTENTS MATCHES "ref")
+ # named branch
+ string(REPLACE "ref: " "" HEAD_REF "${HEAD_CONTENTS}")
+ if(EXISTS "@GIT_DIR@/${HEAD_REF}")
+ configure_file("@GIT_DIR@/${HEAD_REF}" "@GIT_DATA@/head-ref" COPYONLY)
+ else()
+ configure_file("@GIT_DIR@/packed-refs" "@GIT_DATA@/packed-refs" COPYONLY)
+ file(READ "@GIT_DATA@/packed-refs" PACKED_REFS)
+ if(${PACKED_REFS} MATCHES "([0-9a-z]*) ${HEAD_REF}")
+ set(HEAD_HASH "${CMAKE_MATCH_1}")
+ endif()
+ endif()
+else()
+ # detached HEAD
+ configure_file("@GIT_DIR@/HEAD" "@GIT_DATA@/head-ref" COPYONLY)
+endif()
+
+if(NOT HEAD_HASH)
+ file(READ "@GIT_DATA@/head-ref" HEAD_HASH LIMIT 1024)
+ string(STRIP "${HEAD_HASH}" HEAD_HASH)
+endif()
diff --git a/shell/cmake/android.cmake b/shell/cmake/android.cmake
new file mode 100644
index 000000000..366fcb043
--- /dev/null
+++ b/shell/cmake/android.cmake
@@ -0,0 +1,101 @@
+## android.cmake
+#
+
+
+
+function(TestPathNDK ndkPath)
+#
+ file(TO_CMAKE_PATH "${ndkPath}" testPath)
+
+ if(NOT NDK AND EXISTS "${testPath}")
+ if(EXISTS "${testPath}/ndk-bundle")
+ set(NDK ${testPath}/ndk-bundle PARENT_SCOPE)
+ elseif(EXISTS "${testPath}/sysroot")
+ set(NDK ${testPath} PARENT_SCOPE)
+ endif()
+ endif()
+#
+endfunction(TestPathNDK)
+
+
+TestPathNDK("$ENV{ANDROID_HOME}")
+TestPathNDK("$ENV{NDK}")
+TestPathNDK("$ENV{NDK_ROOT}")
+
+if(NOT NDK)
+ message("Failed to find NDK !")
+endif()
+
+
+
+
+
+
+### option for ARM || ARM64 ? HOST isn't useful it's a cross ...
+
+#set(CMAKE_SYSTEM_PROCESSOR aarch64)
+
+
+
+set(CMAKE_SYSTEM_NAME Android)
+set(CMAKE_SYSTEM_VERSION 22) # API level
+
+set(CMAKE_ANDROID_NDK ${NDK})
+set(CMAKE_ANDROID_ARCH_ABI armeabi-v7a) #arm64-v8a , armeabi-v7a , armeabi
+set(CMAKE_ANDROID_STL_TYPE c++_static) #gnustl_static libc++ will allow C++17, if you use _shared you must include in apk !
+set(CMAKE_ANDROID_NDK_TOOLCHAIN_VERSION clang)
+
+
+#arm $TOOLCHAIN/ arm-linux-androideabi /lib/
+#arm64 $TOOLCHAIN/ aarch64-linux-android /lib/
+#x86 $TOOLCHAIN/ i686-linux-android /lib/
+#x86_64 $TOOLCHAIN/ x86_64-linux-android /lib/
+
+
+
+#include(${NDK}/build/cmake/android.toolchain.cmake)
+
+
+set(ANDROID ON)
+
+add_definitions(-D_ANDROID -DANDROID)
+add_definitions(-DANDROID_STL=c++_static)
+
+
+add_definitions(-DTARGET_ANDROID)
+
+add_definitions(-DGLES)
+
+
+
+
+
+## FML
+
+#[[
+CMAKE_ANDROID_ANT_ADDITIONAL_OPTIONS
+CMAKE_ANDROID_API
+CMAKE_ANDROID_API_MIN
+CMAKE_ANDROID_ARCH
+CMAKE_ANDROID_ARCH_ABI
+CMAKE_ANDROID_ARM_MODE
+CMAKE_ANDROID_ARM_NEON
+CMAKE_ANDROID_ASSETS_DIRECTORIES
+CMAKE_ANDROID_GUI
+CMAKE_ANDROID_JAR_DEPENDENCIES
+CMAKE_ANDROID_JAR_DIRECTORIES
+CMAKE_ANDROID_JAVA_SOURCE_DIR
+CMAKE_ANDROID_NATIVE_LIB_DEPENDENCIES
+CMAKE_ANDROID_NATIVE_LIB_DIRECTORIES
+CMAKE_ANDROID_NDK
+CMAKE_ANDROID_NDK_DEPRECATED_HEADERS
+CMAKE_ANDROID_NDK_TOOLCHAIN_HOST_TAG
+CMAKE_ANDROID_NDK_TOOLCHAIN_VERSION
+CMAKE_ANDROID_PROCESS_MAX
+CMAKE_ANDROID_PROGUARD
+CMAKE_ANDROID_PROGUARD_CONFIG_PATH
+CMAKE_ANDROID_SECURE_PROPS_PATH
+CMAKE_ANDROID_SKIP_ANT_STEP
+CMAKE_ANDROID_STANDALONE_TOOLCHAIN
+CMAKE_ANDROID_STL_TYPE
+#]]
diff --git a/shell/cmake/config.cmake b/shell/cmake/config.cmake
new file mode 100644
index 000000000..aa0c67d40
--- /dev/null
+++ b/shell/cmake/config.cmake
@@ -0,0 +1,481 @@
+## config module
+#
+# get luserx0 to doc this shit or something, vars in all caps are to be exported as defs if they aren't in build.h already
+# handle options for FEAT per platform, so rec isn't built for targets w.o one...
+# *TODO* fix Android for build system in emu too, OS_LINUX is hardly fitting: prob works better as PLATFORM_ANDROID_{S,N}DK or something
+# *TODO* setup git version like it's done in VS/make and configure header so --version works still
+# *TODO* lots of other shit to improve build, add enabling/disabling libs/features, setting 3rd party libs as either built in static, dynamic or shared/system
+#
+#
+
+
+set(ZBUILD Off)
+
+
+
+set(BUILD_LIBS OFF) ## Scope:Local If set will build libs { dreamcast, osd, ... }
+set(BUILD_LIB_TYPE STATIC) ## Scope:Local If BUILD_LIBS is set, will use this as type of lib to use { STATIC, SHARED, MODULE (plugin) } *TODO*
+set(BUILD_SHARED_LIBS OFF) ## Scope:CMAKE If type is not specified in add_library, use SHARED
+
+
+
+
+## Build flags ##
+#
+
+set(DC_PLATFORM_MASK 7) # Z: Uh, not a bitset
+set(DC_PLATFORM_DREAMCAST 0) # /* Works, for the most part */
+set(DC_PLATFORM_DEV_UNIT 1) # /* This is missing hardware */
+set(DC_PLATFORM_NAOMI 2) # /* Works, for the most part */
+set(DC_PLATFORM_NAOMI2 3) # /* Needs to be done, 2xsh4 + 2xpvr + custom TNL */
+set(DC_PLATFORM_ATOMISWAVE 4) # /* Needs to be done, DC-like hardware with possibly more ram */
+set(DC_PLATFORM_HIKARU 5) # /* Needs to be done, 2xsh4, 2x aica , custom vpu */
+set(DC_PLATFORM_AURORA 6) # /* Needs to be done, Uses newer 300 mhz sh4 + 150 mhz pvr mbx SoC */
+
+
+
+set(OS_WINDOWS 0x10000001) # HOST_OS
+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_UWP 0x10000011)
+set(OS_NSW_HOS 0x80000001)
+set(OS_PS4_BSD 0x80000002)
+
+
+
+set(CPU_X86 0x20000001) # HOST_CPU
+set(CPU_X64 0x20000004)
+set(CPU_ARM 0x20000002)
+set(CPU_A64 0x20000008)
+set(CPU_MIPS 0x20000003)
+set(CPU_MIPS64 0x20000009)
+set(CPU_PPC 0x20000006)
+set(CPU_PPC64 0x20000007)
+set(CPU_GENERIC 0x20000005) # used for pnacl, emscripten, etc
+
+set(DYNAREC_NONE 0x40000001) # FEAT_SHREC, FEAT_AREC, FEAT_DSPREC
+set(DYNAREC_JIT 0x40000002)
+set(DYNAREC_CPP 0x40000003)
+
+set(COMPILER_VC 0x30000001) # BUILD_COMPILER
+set(COMPILER_GCC 0x30000002)
+set(COMPILER_CLANG 0x30000002)
+set(COMPILER_INTEL 0x30000002)
+
+
+
+
+
+
+
+## These default to host, but are used for cross so make sure not to contaminate
+#
+# CMAKE_SYSTEM ${CMAKE_SYSTEM_NAME}-${CMAKE_SYSTEM_VERSION}.
+# CMAKE_SYSTEM_NAME CMAKE_HOST_SYSTEM_NAME uname -s Linux, Windows, and Darwin
+# CMAKE_SYSTEM_VERSION CMAKE_HOST_SYSTEM_VERSION uname -r
+# CMAKE_SYSTEM_PROCESSOR CMAKE_HOST_SYSTEM_PROCESSOR uname -p
+#
+#
+#
+# BOOL: CMAKE_HOST_UNIX CMAKE_HOST_WIN32 CMAKE_HOST_APPLE
+#
+#
+# CMAKE_LIBRARY_ARCHITECTURE CMAKE__LIBRARY_ARCHITECTURE /lib/
+#
+#
+
+
+
+
+## strings are used to append to path/file names, and to filter multiple possibilities down to one
+# AMD64/x86_64:x64, i*86:x86, ppc/powerpc[64][b|l]e:ppc[64] etc
+#
+if("${CMAKE_SYSTEM_PROCESSOR}" STREQUAL "i686") # todo: check MATCHES "i.86" ?
+ set(host_arch "x86")
+ set(HOST_CPU ${CPU_X86})
+#
+elseif(("${CMAKE_SYSTEM_PROCESSOR}" STREQUAL "AMD64") OR
+ ("${CMAKE_SYSTEM_PROCESSOR}" STREQUAL "x86_64"))
+ set(host_arch "x64")
+ set(HOST_CPU ${CPU_X64})
+#
+elseif("${CMAKE_SYSTEM_PROCESSOR}" MATCHES "aarch64")
+ set(host_arch "arm64")
+ set(HOST_CPU ${CPU_A64})
+#
+elseif("${CMAKE_SYSTEM_PROCESSOR}" MATCHES "arm")
+ set(host_arch "arm")
+ set(HOST_CPU ${CPU_ARM})
+#
+elseif("${CMAKE_SYSTEM_PROCESSOR}" MATCHES "ppc64")
+ set(host_arch "ppc64")
+ set(HOST_CPU ${CPU_PPC64})
+#
+elseif("${CMAKE_SYSTEM_PROCESSOR}" MATCHES "ppc") # has to be done after ppc64 obv
+ set(host_arch "ppc")
+ set(HOST_CPU ${CPU_PPC})
+#
+elseif("${CMAKE_SYSTEM_PROCESSOR}" MATCHES "mips64") # todo: check , r* names?
+ set(host_arch "mips64")
+ set(HOST_CPU ${CPU_MIPS64})
+#
+elseif("${CMAKE_SYSTEM_PROCESSOR}" MATCHES "mips") # todo: check , r* names?
+ set(host_arch "mips")
+ set(HOST_CPU ${CPU_MIPS})
+#
+else()
+ message("Warning: Unknown Host System Processor: \"${CMAKE_SYSTEM_PROCESSOR}\"")
+ set(host_arch "${CMAKE_SYSTEM_PROCESSOR}")
+ set(HOST_CPU ${CPU_GENERIC})
+endif()
+
+
+
+
+string(TOLOWER ${CMAKE_SYSTEM_NAME} host_os)
+
+#message(" - testing cmake host_os: \"${host_os}\"")
+
+## HOST_* is not TARGET_* ;; change ndc-e internal naming it's wrong , then change this ;;
+
+if("android" STREQUAL "${host_os}" OR ANDROID)
+ set(HOST_OS ${OS_LINUX}) # *FIXME* we might have to keep as OS_LINUX or add to full cleanup list :|
+
+elseif("windowsstore" STREQUAL "${host_os}")
+ set(HOST_OS ${OS_UWP})
+ set(HOST_CPU ${CPU_X64})
+
+elseif(CMAKE_HOST_WIN32)
+ set(HOST_OS ${OS_WINDOWS})
+
+elseif(CMAKE_HOST_APPLE)
+
+ if("${host_arch}" MATCHES "arm")
+ set(HOST_OS ${OS_IOS})
+ set(TARGET_IOS On)
+ add_definitions(-DTARGET_IPHONE -DTARGET_IOS)
+ else()
+ set(HOST_OS ${OS_DARWIN}) # todo ios check, check compiler/arch?
+ set(TARGET_OSX On)
+ add_definitions(-DTARGET_OSX)
+ endif()
+
+elseif(CMAKE_HOST_UNIX) # GP UNIX MUST BE AFTER OTHER UNIX'ish options such as APPLE , it matches both
+
+ set(HOST_OS ${OS_LINUX}) # todo android check, just check android vars?
+endif()
+
+
+
+#option(TARGET_NO_REC BOOL "")
+#option(TARGET_NO_AREC BOOL "")
+#option(TARGET_NO_JIT BOOL "")
+
+
+
+## Dynarec avail on x86,x64,arm and aarch64 in arm.32 compat
+#
+if((${HOST_CPU} EQUAL ${CPU_X86}) OR (${HOST_CPU} EQUAL ${CPU_X64}) OR
+ (${HOST_CPU} EQUAL ${CPU_ARM}) OR (${HOST_CPU} EQUAL ${CPU_A64}))
+#
+ message("Dynarec Features Available")
+
+ set(FEAT_SHREC ${DYNAREC_JIT})
+ set(FEAT_AREC ${DYNAREC_NONE})
+ set(FEAT_DSPREC ${DYNAREC_NONE})
+#
+else()
+ set(FEAT_SHREC ${DYNAREC_CPP})
+ set(FEAT_AREC ${DYNAREC_NONE})
+ set(FEAT_DSPREC ${DYNAREC_NONE})
+endif()
+
+## Handle TARGET_* to FEAT_ *FIXME* stupid use one or the other and propogate : part of build cleanup , TARGET_ will only be for platform specifics and FEAT_ as OPTIONS
+#
+if(TARGET_NO_REC)
+ set(FEAT_SHREC ${DYNAREC_NONE})
+ set(FEAT_AREC ${DYNAREC_NONE})
+ set(FEAT_DSPREC ${DYNAREC_NONE})
+endif()
+
+if(TARGET_NO_AREC)
+ set(FEAT_SHREC ${DYNAREC_JIT})
+ set(FEAT_AREC ${DYNAREC_NONE})
+ set(FEAT_DSPREC ${DYNAREC_NONE})
+endif()
+
+if(TARGET_NO_JIT)
+ set(FEAT_SHREC ${DYNAREC_CPP})
+ set(FEAT_AREC ${DYNAREC_NONE})
+ set(FEAT_DSPREC ${DYNAREC_NONE})
+endif()
+
+
+
+
+
+######## Looks like something to delete, but if we're going to handle options here and NOT in libosd/lib* #########
+
+# FindNativeCompilers()
+## options BUILD_COMPILER { GCC, Clang, Intel, RealView? }
+
+
+#set(CMAKE_C_COMPILER clang)
+#set(CMAKE_C_COMPILER_TARGET ${triple})
+#set(CMAKE_CXX_COMPILER clang++)
+#set(CMAKE_CXX_COMPILER_TARGET ${triple})
+
+
+
+if(${HOST_OS} EQUAL ${OS_LINUX})
+# option SUPPORT_X11
+# option FEAT_HAS_NIXPROF
+# option EMSCripten
+endif()
+
+if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC")
+#
+ set(BUILD_COMPILER ${COMPILER_VC})
+ message("MSVC Platform: ${CMAKE_VS_PLATFORM_NAME}")
+ message("MSVC Toolset: ${CMAKE_VS_PLATFORM_TOOLSET}")
+
+
+ add_definitions(/D_CRT_SECURE_NO_WARNINGS /D_CRT_SECURE_CPP_OVERLOAD_STANDARD_NAMES=1)
+
+ if("${HOST_OS}" STREQUAL "${OS_UWP}")
+ set(_CXX_FLAGS "/ZW ")
+ set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} /AppContainer")
+ endif()
+#
+elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
+ set(BUILD_COMPILER ${COMPILER_GCC})
+#
+elseif("${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang") # AppleClang ffs
+ set(BUILD_COMPILER ${COMPILER_CLANG})
+#
+elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Intel")
+ set(BUILD_COMPILER ${COMPILER_INTEL})
+#
+else()
+ message("Unknown Compiler: ${CMAKE_CXX_COMPILER_ID}")
+endif()
+
+
+
+
+## Setup some common flags
+#
+if ((${BUILD_COMPILER} EQUAL ${COMPILER_VC}) OR
+ (${BUILD_COMPILER} EQUAL ${COMPILER_CLANG} AND ${HOST_OS} EQUAL ${OS_WINDOWS}))
+
+ if((${HOST_CPU} EQUAL ${CPU_X64}) AND (${FEAT_SHREC} EQUAL ${DYNAREC_JIT})) # AND NOT "${NINJA}" STREQUAL "")
+ set(FEAT_SHREC ${DYNAREC_CPP})
+ message("---x64 rec disabled for VC x64 via NINJA")
+ endif()
+
+ add_definitions(/D_CRT_SECURE_NO_WARNINGS /D_CRT_SECURE_CPP_OVERLOAD_STANDARD_NAMES=1)
+
+if(${BUILD_COMPILER} EQUAL ${COMPILER_CLANG})
+ add_definitions(/DXBYAK_NO_OP_NAMES /DTARGET_NO_OPENMP) #*FIXME* check openmp on clang-cl
+ remove_definitions(/U_HAS_STD_BYTE)
+ set(_CXX_FLAGS "/std:c++14") # /U_HAS_STD_BYTE not working, have to use c++14 not 17 :|
+ set(_C_FLAGS "-Wno-unused-function -Wno-unused-variable")
+endif()
+
+
+elseif ((${BUILD_COMPILER} EQUAL ${COMPILER_GCC}) OR
+ (${BUILD_COMPILER} EQUAL ${COMPILER_CLANG})) # AND NOT ${HOST_OS} EQUAL ${OS_WINDOWS}))
+
+
+ set(_C_FLAGS "-fno-operator-names") # or add_definitions(/DXBYAK_NO_OP_NAMES)
+
+
+ if(USE_32B OR TARGET_LINUX_X86)
+ set(_C_FLAGS "${_C_FLAGS} -m32")
+ endif()
+
+ if((${HOST_CPU} EQUAL ${CPU_X86}) OR (${HOST_CPU} EQUAL ${CPU_X64}))
+ set(_C_FLAGS "${_C_FLAGS} -msse4")
+
+ if(NOT CMAKE_HOST_APPLE)
+ set(_C_FLAGS "${_C_FLAGS} -fopenmp")
+ endif()
+ endif() # X86 family
+
+
+ set(_CXX_FLAGS "${_CXX_FLAGS} -std=c++17 -fcxx-exceptions") ## xbyak needs exceptions
+
+
+endif()
+
+
+set(_CXX_FLAGS "${_CXX_FLAGS} ${_C_FLAGS}")
+
+
+
+set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${_C_FLAGS}")
+set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${_CXX_FLAGS}")
+
+
+
+#if defined(TARGET_NAOMI)
+ #define DC_PLATFORM DC_PLATFORM_NAOMI
+ #undef TARGET_NAOMI
+#endif
+
+
+
+#if defined(TARGET_NO_NIXPROF)
+#define FEAT_HAS_NIXPROF 0
+#endif
+
+#if defined(TARGET_NO_COREIO_HTTP)
+#define FEAT_HAS_COREIO_HTTP 0
+#endif
+
+#if defined(TARGET_SOFTREND) # need -fopenmp
+ #define FEAT_HAS_SOFTREND 1
+#endif
+
+
+if (TARGET_NSW) # -DCMAKE_TOOLCHAIN_FILE=./cmake/devkitA64.cmake -DTARGET_NSW=ON
+ set(HOST_OS ${OS_NSW_HOS})
+
+ message(" DEVKITA64: ${DEVKITA64} ")
+ message("HOST_OS ${HOST_OS}")
+
+ add_definitions(-D__SWITCH__ -DGLES -DMESA_EGL_NO_X11_HEADERS)
+ add_definitions(-DTARGET_NO_THREADS -DTARGET_NO_EXCEPTIONS -DTARGET_NO_NIXPROF)
+ add_definitions(-DTARGET_NO_COREIO_HTTP -DTARGET_NO_WEBUI -UTARGET_SOFTREND)
+ add_definitions(-D_GLIBCXX_USE_C99_MATH_TR1 -D_LDBL_EQ_DBL)
+
+endif()
+
+if (TARGET_PS4) # -DCMAKE_TOOLCHAIN_FILE=./cmake/{ps4sdk,clang_scei}.cmake -DTARGET_PS4=ON
+ set(HOST_OS ${OS_PS4_BSD})
+ message("HOST_OS ${HOST_OS}")
+
+
+ add_definitions(-DPS4 -DTARGET_PS4 -DTARGET_BSD -D__ORBIS__ -DGLES -DMESA_EGL_NO_X11_HEADERS) ## last needed for __unix__ on eglplatform.h
+ add_definitions(-DTARGET_NO_THREADS -DTARGET_NO_EXCEPTIONS -DTARGET_NO_NIXPROF)
+ add_definitions(-DTARGET_NO_COREIO_HTTP -DTARGET_NO_WEBUI -UTARGET_SOFTREND)
+
+
+ message("*******FIXME******** LARGE PAGES !!")
+endif()
+
+
+
+if(ZBUILD)
+ set(DEBUG_CMAKE ON)
+ add_definitions(-D_Z_) # Get rid of some warnings and internal dev testing
+
+ if(NOT TARGET_PS4 AND NOT TARGET_NSW AND
+ NOT TARGET_OSX AND NOT TARGET_IOS )
+ set(USE_QT ON)
+ endif()
+endif()
+
+
+
+# configure options for osd/ui
+# osd_default, osd_qt
+# ui_default, ui_sdl, ui_qt
+# USE_NATIVE , USE_SDL , USE_QT -- these (can) define multiple
+
+option(USE_QT False "Use Qt5 for UI and support OS Deps.")
+
+
+
+
+#option TARGET_NO_WEBUI
+
+
+
+
+
+#option(BUILD_TESTS "Build tests" OFF) # todo: luserx0 this is your arena, you want tests add em
+
+
+add_definitions(-DCMAKE_BUILD)
+
+
+
+
+add_definitions(-DHOST_OS=${HOST_OS})
+add_definitions(-DHOST_CPU=${HOST_CPU})
+
+add_definitions(-DFEAT_AREC=${FEAT_AREC})
+add_definitions(-DFEAT_SHREC=${FEAT_SHREC})
+add_definitions(-DFEAT_DSPREC=${FEAT_DSPREC})
+
+add_definitions(-DBUILD_COMPILER=${BUILD_COMPILER})
+
+add_definitions(-DTARGET_NO_WEBUI)
+add_definitions(-DDEF_CONSOLE)
+
+
+set(RE_CMAKE_CONFIGURED 1)
+#add_definitions(-D=${})
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+### These were for internal testing, don't use ###
+#
+function(CpuIs CpuType Res)
+ set(${Res} OFF PARENT_SCOPE)
+ if (${HOST_CPU} EQUAL ${CpuType})
+ set(${Res} ON PARENT_SCOPE)
+ endif()
+endfunction()
+
+macro(CpuIsX86 res)
+ CpuIs(CPU_X86 ${res})
+endmacro()
+
+macro(CpuIsX64 res)
+ CpuIs(CPU_X64 ${res})
+endmacro()
+
+macro(CpuIsARM res)
+ CpuIs(CPU_ARM ${res})
+endmacro()
+
+macro(CpuIsA64 res)
+ CpuIs(CPU_A64 ${res})
+endmacro()
+
+macro(CpuIsPPC res)
+ CpuIs(CPU_PPC ${res})
+endmacro()
+
+macro(CpuIsPPC64 res)
+ CpuIs(CPU_PPC64 ${res})
+endmacro()
+
+macro(CpuIsMIPS res)
+ CpuIs(CPU_MIPS ${res})
+endmacro()
+
+macro(CpuIsMIPS64 res)
+ CpuIs(CPU_MIPS64 ${res})
+endmacro()
+
+
+
+
+
diff --git a/shell/cmake/devkitA64.cmake b/shell/cmake/devkitA64.cmake
new file mode 100644
index 000000000..3eb80ff24
--- /dev/null
+++ b/shell/cmake/devkitA64.cmake
@@ -0,0 +1,41 @@
+## devkitA64.cmake - devkitpro A64 cross-compile
+#
+set(CMAKE_SYSTEM_NAME Linux) # this one is important // Add Platform/switch to use this name ...
+set(CMAKE_SYSTEM_PROCESSOR aarch64)
+
+set(CMAKE_SYSTEM_VERSION 1) # this one not so much
+
+
+set(DEVKITPRO $ENV{DEVKITPRO})
+set(DEVKITA64 $ENV{DEVKITA64})
+
+
+if ("" STREQUAL "${DEVKITPRO}")
+ set(DEVKITA64 "/opt/devkitpro")
+endif()
+
+if ("" STREQUAL "${DEVKITA64}")
+ set(DEVKITA64 ${DEVKITPRO}/devkitA64)
+endif()
+
+
+## specify the cross compiler
+#
+set(CMAKE_C_COMPILER ${DEVKITA64}/bin/aarch64-none-elf-gcc)
+set(CMAKE_CXX_COMPILER ${DEVKITA64}/bin/aarch64-none-elf-g++)
+
+
+set(CMAKE_FIND_ROOT_PATH ${DEVKITA64}) # where is the target environment
+
+set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) # search for programs in the build host directories
+set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) # for libraries and headers in the target directories
+set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
+
+
+
+
+include_directories(${DEVKITPRO}/libnx/include)
+
+
+
+set(TARGET_NSW ON)
diff --git a/shell/cmake/ps4sdk.cmake b/shell/cmake/ps4sdk.cmake
new file mode 100644
index 000000000..d8cac168f
--- /dev/null
+++ b/shell/cmake/ps4sdk.cmake
@@ -0,0 +1,130 @@
+## ps4sdk.cmake - devkitpro A64 cross-compile
+#
+set(CMAKE_SYSTEM_NAME FreeBSD) # this one is important
+set(CMAKE_SYSTEM_PROCESSOR x86_64)
+set(CMAKE_SYSTEM_VERSION 9) # this one not so much
+
+
+
+
+set(TARGET_PS4 ON)
+set(TARGET_BSD ON)
+
+
+
+### This shit is very WIP ###
+#
+## TODO: Check for
+
+
+set(PS4SDK $ENV{PS4SDK})
+set(SCESDK $ENV{SCESDK})
+
+set(USE_SCE ON)
+set(PS4_PKG ON)
+
+if(PS4_PKG)
+ add_definitions(-DPS4_PKG)
+endif()
+
+
+
+if ("" STREQUAL "${PS4SDK}")
+ if ("Windows" STREQUAL "${CMAKE_HOST_SYSTEM_NAME}")
+ set(PS4SDK "C:/Dev/SDK/PS4")
+ else()
+ set(PS4SDK "/opt/ps4")
+ endif()
+endif()
+
+
+
+set(TAUON_SDK ${PS4SDK}/tauon)
+
+
+
+if(USE_SCE)
+#
+ set(PS4SDK ${PS4SDK}/SCE/PS4SDK)
+
+ set(PS4HOST ${PS4SDK}/host_tools)
+ set(PS4TARGET ${PS4SDK}/target)
+
+ set(toolPrefix "orbis-")
+ set(toolSuffix ".exe")
+
+ set(CMAKE_C_COMPILER ${PS4HOST}/bin/${toolPrefix}clang${toolSuffix})
+ set(CMAKE_CXX_COMPILER ${PS4HOST}/bin/${toolPrefix}clang++${toolSuffix})
+
+ set(CMAKE_FIND_ROOT_PATH ${PS4TARGET}) # where is the target environment
+
+
+
+ set (PS4_inc_dirs
+ ${TAUON_SDK}/include
+ ${PS4TARGET}/include
+ ${PS4TARGET}/include_common
+ )
+
+# set (PS4_link_dirs
+# "${PS4TARGET}/lib"
+# "${PS4TARGET}/tauon/lib"
+# )
+
+
+#LDFLAGS += -L $(TAUON_SDK_DIR)/lib -L $(SCE_ORBIS_SDK_DIR)/target/lib
+ set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -s -Wl,--addressing=non-aslr,--strip-unused-data ")
+ set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -L ${TAUON_SDK}/lib -L ${PS4TARGET}/lib")
+
+ message("CMAKE_EXE_LINKER_FLAGS ${CMAKE_EXE_LINKER_FLAGS}")
+#
+else()
+#
+ set(triple "x86_64-scei-ps4")
+
+ set(CMAKE_C_COMPILER_TARGET ${triple})
+ set(CMAKE_CXX_COMPILER_TARGET ${triple})
+
+ set(CMAKE_C_COMPILER clang)
+ set(CMAKE_CXX_COMPILER clang++)
+
+
+ set (PS4_inc_dirs
+ ${TAUON_SDK}/include
+
+ ${PS4SDK}/include
+ ${PS4SDK}/tauon/include
+ )
+
+# set (PS4_link_dirs
+# "${PS4SDK}/lib"
+# "${PS4SDK}/tauon/lib"
+# )
+
+
+ set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -s -Wl,--addressing=non-aslr,--strip-unused-data -L${TAUON_SDK}/lib")
+#
+endif()
+
+
+
+
+set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) # search for programs in the build host directories
+set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY BOTH) # for libraries and headers in the target directories
+set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE BOTH)
+
+
+include_directories(${PS4_inc_dirs})
+
+
+
+
+ ### Add a helper to add libSce PREFIX and [_tau]*_stub[_weak]*.a SUFFIX
+ #
+link_libraries(
+ kernel_tau_stub_weak SceSysmodule_tau_stub_weak SceSystemService_stub_weak SceSystemService_tau_stub_weak SceShellCoreUtil_tau_stub_weak ScePigletv2VSH_tau_stub_weak kernel_util
+ ScePad_stub_weak SceNet_stub_weak SceCommonDialog_stub_weak ScePosix_stub_weak
+)
+
+
+
diff --git a/shell/reicast.vcxproj b/shell/reicast.vcxproj
index 2f10bff9e..3d10f789a 100644
--- a/shell/reicast.vcxproj
+++ b/shell/reicast.vcxproj
@@ -574,7 +574,7 @@
Win32Proj
reicast
reicast
- 10.0.17134.0
+ 10.0.17763.0