mirror of
				https://github.com/RaySollium99/picodrive.git
				synced 2025-10-26 08:19:38 -04:00 
			
		
		
		
	Merge from libretro/master:46902e0 for repo synchronization
This commit is contained in:
		
							parent
							
								
									9d1ecde692
								
							
						
					
					
						commit
						61d76999d7
					
				
					 74 changed files with 14043 additions and 2094 deletions
				
			
		|  | @ -1,5 +1,12 @@ | |||
| # Makefile for PicoDrive (libretro) | ||||
| 
 | ||||
| SPACE := | ||||
| SPACE := $(SPACE) $(SPACE) | ||||
| BACKSLASH := | ||||
| BACKSLASH := \$(BACKSLASH) | ||||
| filter_out1 = $(filter-out $(firstword $1),$1) | ||||
| filter_out2 = $(call filter_out1,$(call filter_out1,$1)) | ||||
| 
 | ||||
| ifeq ($(platform),) | ||||
| 	platform = unix | ||||
| 	ifeq ($(shell uname -a),) | ||||
|  | @ -19,6 +26,14 @@ AS ?= as | |||
| CC_AS ?= $(CC) | ||||
| CFLAGS ?= | ||||
| 
 | ||||
| #libretro includes | ||||
| CFLAGS += -I platform/libretro/libretro-common/include | ||||
| CFLAGS += -I platform/libretro/libretro-common/include/compat | ||||
| CFLAGS += -I platform/libretro/libretro-common/include/encodings | ||||
| CFLAGS += -I platform/libretro/libretro-common/include/streams | ||||
| CFLAGS += -I platform/libretro/libretro-common/include/string | ||||
| CFLAGS += -I platform/libretro/libretro-common/include/vfs | ||||
| 
 | ||||
| STATIC_LINKING:= 0 | ||||
| TARGET_NAME := picodrive | ||||
| LIBM := -lm | ||||
|  | @ -41,6 +56,9 @@ ifeq ($(platform), unix) | |||
| 	SHARED := -shared | ||||
| 	DONT_COMPILE_IN_ZLIB = 1 | ||||
| 	CFLAGS += -DFAMEC_NO_GOTOS | ||||
| ifneq ($(findstring SunOS,$(shell uname -a)),) | ||||
| 	CC=gcc | ||||
| endif | ||||
| 
 | ||||
| # Portable Linux | ||||
| else ifeq ($(platform), linux-portable) | ||||
|  | @ -60,6 +78,7 @@ else ifeq ($(platform), osx) | |||
| 	fpic := -fPIC | ||||
| 	APPLE := 1 | ||||
| 	ifeq ($(shell uname -p),powerpc) | ||||
| 		CFLAGS += -DHAVE_NO_LANGEXTRA | ||||
| 		CFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__ -DFAMEC_NO_GOTOS | ||||
| 	endif | ||||
| 	OSXVER = `sw_vers -productVersion | cut -d. -f 2` | ||||
|  | @ -94,14 +113,21 @@ else ifneq (,$(findstring ios,$(platform))) | |||
| 	ifeq ($(IOSSDK),) | ||||
| 		IOSSDK := $(shell xcodebuild -version -sdk iphoneos Path) | ||||
| 	endif | ||||
| 	CC = clang -arch armv7 -isysroot $(IOSSDK) | ||||
| 	CXX = clang++ -arch armv7 -isysroot $(IOSSDK) | ||||
| 	CC_AS = perl ./tools/gas-preprocessor.pl $(CC) | ||||
| 	CFLAGS += -mcpu=cortex-a8 -mtune=cortex-a8 -mfpu=neon -marm  | ||||
| 	ASFLAGS += -mcpu=cortex-a8 -mtune=cortex-a8 -mfpu=neon | ||||
| 	ifeq ($(platform),ios-arm64) | ||||
| 	  CC = clang -arch arm64 -isysroot $(IOSSDK) | ||||
| 	  CXX = clang++ -arch arm64 -isysroot $(IOSSDK) | ||||
| 	  CFLAGS += -marm -DARM -D__aarch64__=1  | ||||
| 	else | ||||
| 	  CC = clang -arch armv7 -isysroot $(IOSSDK) | ||||
| 	  CXX = clang++ -arch armv7 -isysroot $(IOSSDK) | ||||
| 	  CC_AS = perl ./tools/gas-preprocessor.pl $(CC) | ||||
| 	  CFLAGS += -mcpu=cortex-a8 -mtune=cortex-a8 -mfpu=neon -marm  | ||||
| 	  ASFLAGS += -mcpu=cortex-a8 -mtune=cortex-a8 -mfpu=neon | ||||
| 	  NO_ARM_ASM = 1 | ||||
| 	endif | ||||
| 	CFLAGS += -DIOS | ||||
| 
 | ||||
| ifeq ($(platform),ios9) | ||||
| ifeq ($(platform),$(filter $(platform),ios9 ios-arm64)) | ||||
| 	CC     += -miphoneos-version-min=8.0 | ||||
| 	CXX    += -miphoneos-version-min=8.0 | ||||
| 	CC_AS  += -miphoneos-version-min=8.0 | ||||
|  | @ -113,6 +139,21 @@ else | |||
| 	CFLAGS += -miphoneos-version-min=5.0 | ||||
| endif | ||||
| 
 | ||||
| # tvOS | ||||
| else ifeq ($(platform), tvos-arm64) | ||||
| 	TARGET := $(TARGET_NAME)_libretro_tvos.dylib | ||||
| 	SHARED := -dynamiclib | ||||
| 	fpic := -fPIC | ||||
| 	APPLE := 1 | ||||
| 	ifeq ($(IOSSDK),) | ||||
| 		IOSSDK := $(shell xcodebuild -version -sdk appletvos Path) | ||||
| 	endif | ||||
| 	CC_AS = perl ./tools/gas-preprocessor.pl $(CC) | ||||
| 	CC = clang -arch arm64 -isysroot $(IOSSDK) | ||||
| 	CXX = clang++ -arch arm64 -isysroot $(IOSSDK) | ||||
| 	CFLAGS += -marm -DARM -D__aarch64__=1  | ||||
| 	CFLAGS += -DIOS | ||||
| 
 | ||||
| # PS3 | ||||
| else ifeq ($(platform), ps3) | ||||
| 	TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||
|  | @ -143,7 +184,7 @@ else ifeq ($(platform), psl1ght) | |||
| 	STATIC_LINKING = 1 | ||||
| 	NO_MMAP = 1 | ||||
| 	DONT_COMPILE_IN_ZLIB = 1 | ||||
| 	 | ||||
| 
 | ||||
| # PSP | ||||
| else ifeq ($(platform), psp1) | ||||
| 	TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||
|  | @ -157,6 +198,21 @@ else ifeq ($(platform), psp1) | |||
| 
 | ||||
| 	asm_render = 1 | ||||
| 
 | ||||
| # PS2 | ||||
| else ifeq ($(platform), ps2) | ||||
| 	TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||
| 	CC = ee-gcc$(EXE_EXT) | ||||
| 	AR = ee-ar$(EXE_EXT) | ||||
| 	CFLAGS += -Wall -DPS2 -DUSE_BGR555 -DFAMEC_NO_GOTOS -DRENDER_GSKIT_PS2 -fsingle-precision-constant | ||||
| 	CFLAGS += -I$(PS2DEV)/gsKit/include -I$(PS2SDK)/ee/include -I$(PS2SDK)/common/include | ||||
| 	CFLAGS += -DHAVE_NO_LANGEXTRA | ||||
| 	STATIC_LINKING = 1 | ||||
| 	NO_MMAP = 1 | ||||
| 	DONT_COMPILE_IN_ZLIB = 1 | ||||
| 
 | ||||
| 	asm_render = 1 | ||||
| 	OBJS += platform/ps2/asm.o | ||||
| 
 | ||||
| # CTR (3DS) | ||||
| else ifeq ($(platform), ctr) | ||||
| 	TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||
|  | @ -171,7 +227,7 @@ else ifeq ($(platform), ctr) | |||
| 	NO_MMAP = 1 | ||||
| 	DONT_COMPILE_IN_ZLIB = 1 | ||||
| 
 | ||||
| 	OBJS +=platform/libretro/3ds/3ds_utils.o | ||||
| 	OBJS += platform/libretro/3ds/3ds_utils.o platform/libretro/3ds/utils.o | ||||
| 
 | ||||
| # Raspberry Pi (original model) Raspbian | ||||
| else ifeq ($(platform), raspberrypi) | ||||
|  | @ -219,6 +275,33 @@ else ifeq ($(platform), wii) | |||
| 	AR = $(DEVKITPPC)/bin/powerpc-eabi-ar$(EXE_EXT) | ||||
| 	CFLAGS += -DGEKKO -DHW_RVL -mrvl -mcpu=750 -meabi -mhard-float -DBLARGG_BIG_ENDIAN=1 -D__ppc__ | ||||
| 
 | ||||
| # Nintendo Wii U | ||||
| else ifeq ($(platform), wiiu) | ||||
| 	TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||
| 	CC = $(DEVKITPPC)/bin/powerpc-eabi-gcc$(EXE_EXT) | ||||
| 	CXX = $(DEVKITPPC)/bin/powerpc-eabi-g++$(EXE_EXT) | ||||
| 	AR = $(DEVKITPPC)/bin/powerpc-eabi-ar$(EXE_EXT) | ||||
| 	COMMONFLAGS += -DGEKKO -DWIIU -DHW_RVL -mwup -mcpu=750 -meabi -mhard-float -D__POWERPC__ -D__ppc__ -DMSB_FIRST -DWORDS_BIGENDIAN=1 -I./deps/include/ | ||||
| 	COMMONFLAGS += -U__INT32_TYPE__ -U __UINT32_TYPE__ -D__INT32_TYPE__=int | ||||
| 
 | ||||
| # Nintendo Switch (libtransistor) | ||||
| else ifeq ($(platform), switch) | ||||
| 	TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||
| 	include $(LIBTRANSISTOR_HOME)/libtransistor.mk | ||||
| 	STATIC_LINKING=1 | ||||
| 	NO_MMAP = 1 | ||||
| 
 | ||||
| # Nintendo Switch (libnx) | ||||
| else ifeq ($(platform), libnx) | ||||
| 	include $(DEVKITPRO)/libnx/switch_rules | ||||
| 	TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||
| 	CFLAGS += -O3 -fomit-frame-pointer -ffast-math -I$(DEVKITPRO)/libnx/include/ -fPIE -Wl,--allow-multiple-definition | ||||
| 	CFLAGS += -specs=$(DEVKITPRO)/libnx/switch.specs | ||||
| 	CFLAGS += -D__SWITCH__ -DHAVE_LIBNX | ||||
| 	CFLAGS += -DARM -D__aarch64__=1 -march=armv8-a -mtune=cortex-a57 -mtp=soft -ffast-math -mcpu=cortex-a57+crc+fp+simd -ffunction-sections | ||||
| 	CFLAGS += -Ifrontend/switch -ftree-vectorize | ||||
| 	STATIC_LINKING=1 | ||||
| 
 | ||||
| # QNX | ||||
| else ifeq ($(platform), qnx) | ||||
| 	TARGET := $(TARGET_NAME)_libretro_$(platform).so | ||||
|  | @ -229,6 +312,78 @@ else ifeq ($(platform), qnx) | |||
| 	ASFLAGS +=  -mcpu=cortex-a9 -mfpu=neon -mfloat-abi=softfp | ||||
| 	ARCH = arm | ||||
| 
 | ||||
| # (armv7 a7, hard point, neon based) ###  | ||||
| # NESC, SNESC, C64 mini  | ||||
| else ifeq ($(platform), classic_armv7_a7) | ||||
| 	TARGET := $(TARGET_NAME)_libretro.so | ||||
| 	fpic := -fPIC | ||||
| 	SHARED := -shared -Wl,--no-undefined,-Bsymbolic | ||||
| 	CFLAGS += -Ofast \ | ||||
| 	-flto=4 -fwhole-program -fuse-linker-plugin \ | ||||
| 	-fdata-sections -ffunction-sections -Wl,--gc-sections \ | ||||
| 	-fno-stack-protector -fno-ident -fomit-frame-pointer \ | ||||
| 	-falign-functions=1 -falign-jumps=1 -falign-loops=1 \ | ||||
| 	-fno-unwind-tables -fno-asynchronous-unwind-tables -fno-unroll-loops \ | ||||
| 	-fmerge-all-constants -fno-math-errno \ | ||||
| 	-marm -mtune=cortex-a7 -mfpu=neon-vfpv4 -mfloat-abi=hard | ||||
| 	CXXFLAGS += $(CFLAGS) | ||||
| 	CPPFLAGS += $(CFLAGS) | ||||
| 	ASFLAGS += $(CFLAGS) | ||||
| 	HAVE_NEON = 1 | ||||
| 	BUILTIN_GPU = neon | ||||
| 	ifeq ($(shell echo `$(CC) -dumpversion` "< 4.9" | bc -l), 1) | ||||
| 	  CFLAGS += -march=armv7-a | ||||
| 	else | ||||
| 	  CFLAGS += -march=armv7ve | ||||
| 	  # If gcc is 5.0 or later | ||||
| 	  ifeq ($(shell echo `$(CC) -dumpversion` ">= 5" | bc -l), 1) | ||||
| 	    LDFLAGS += -static-libgcc -static-libstdc++ | ||||
| 	  endif | ||||
| 	endif | ||||
| 
 | ||||
| # (armv8 a35, hard point, neon based) ### | ||||
| # Playstation Classic | ||||
| else ifeq ($(platform), classic_armv8_a35) | ||||
| 	TARGET := $(TARGET_NAME)_libretro.so | ||||
| 	fpic := -fPIC | ||||
| 	SHARED := -shared -Wl,--no-undefined,-Bsymbolic | ||||
| 	CFLAGS += -Ofast \ | ||||
| 		-flto -fwhole-program -fuse-linker-plugin \ | ||||
| 		-fdata-sections -ffunction-sections -Wl,--gc-sections \ | ||||
| 		-fno-stack-protector -fno-ident -fomit-frame-pointer \ | ||||
| 		-falign-functions=1 -falign-jumps=1 -falign-loops=1 \ | ||||
| 		-fno-unwind-tables -fno-asynchronous-unwind-tables -fno-unroll-loops \ | ||||
| 		-fmerge-all-constants -fno-math-errno -fno-strict-aliasing \ | ||||
| 		-marm -mtune=cortex-a35 -mfpu=neon-fp-armv8 -mfloat-abi=hard | ||||
| 	CXXFLAGS += $(CFLAGS) | ||||
| 	CPPFLAGS += $(CFLAGS) | ||||
| 	ASFLAGS += $(CFLAGS) | ||||
| 	HAVE_NEON = 1 | ||||
| 	BUILTIN_GPU = neon | ||||
| 	CFLAGS += -march=armv8-a | ||||
| 	LDFLAGS += -static-libgcc -static-libstdc++ | ||||
| 
 | ||||
| ####################################### | ||||
| 
 | ||||
| # ARM-64 | ||||
| else ifeq ($(platform), arm64) | ||||
| 	EXT ?= so | ||||
| 	TARGET := $(TARGET_NAME)_libretro.$(EXT) | ||||
| 	ARCH = aarch64 | ||||
| 	fpic := -fPIC | ||||
| 	SHARED := -shared | ||||
| 	DONT_COMPILE_IN_ZLIB = 1 | ||||
| 	CFLAGS += -DFAMEC_NO_GOTOS | ||||
| 
 | ||||
| # AARCH64 generic | ||||
| else ifeq ($(platform), aarch64) | ||||
| 	TARGET := $(TARGET_NAME)_libretro.so | ||||
| 	ARCH = aarch64 | ||||
| 	fpic := -fPIC | ||||
| 	SHARED := -shared | ||||
| 	DONT_COMPILE_IN_ZLIB = 1 | ||||
| 	CFLAGS += -DFAMEC_NO_GOTOS | ||||
| 
 | ||||
| # ARM | ||||
| else ifneq (,$(findstring armv,$(platform))) | ||||
| 	TARGET := $(TARGET_NAME)_libretro.so | ||||
|  | @ -279,7 +434,105 @@ else ifeq ($(platform), gcw0) | |||
| 	fpic := -fPIC | ||||
| 	LIBM := | ||||
| 	DONT_COMPILE_IN_ZLIB = 1 | ||||
| 	CFLAGS += -ffast-math -march=mips32 -mtune=mips32r2 -mhard-float | ||||
| 	CFLAGS += -fomit-frame-pointer -ffast-math -march=mips32 -mtune=mips32r2 -mhard-float | ||||
| 
 | ||||
| # Windows MSVC 2017 all architectures | ||||
| else ifneq (,$(findstring windows_msvc2017,$(platform))) | ||||
| 	NO_GCC := 1 | ||||
| 
 | ||||
| 	PlatformSuffix = $(subst windows_msvc2017_,,$(platform)) | ||||
| 	ifneq (,$(findstring desktop,$(PlatformSuffix))) | ||||
| 		WinPartition = desktop | ||||
| 		MSVC2017CompileFlags = -DWINAPI_FAMILY=WINAPI_FAMILY_DESKTOP_APP -FS | ||||
| 		LDFLAGS += -MANIFEST -LTCG:incremental -NXCOMPAT -DYNAMICBASE -DEBUG -OPT:REF -INCREMENTAL:NO -SUBSYSTEM:WINDOWS -MANIFESTUAC:"level='asInvoker' uiAccess='false'" -OPT:ICF -ERRORREPORT:PROMPT -NOLOGO -TLBID:1 | ||||
| 		LDLIBS += kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib | ||||
| 	else ifneq (,$(findstring uwp,$(PlatformSuffix))) | ||||
| 		WinPartition = uwp | ||||
| 		MSVC2017CompileFlags = -DWINAPI_FAMILY=WINAPI_FAMILY_APP -D_WINDLL -D_UNICODE -DUNICODE -D__WRL_NO_DEFAULT_LIB__ -EHsc -FS | ||||
| 		LDFLAGS += -APPCONTAINER -NXCOMPAT -DYNAMICBASE -MANIFEST:NO -LTCG -OPT:REF -SUBSYSTEM:CONSOLE -MANIFESTUAC:NO -OPT:ICF -ERRORREPORT:PROMPT -NOLOGO -TLBID:1 -DEBUG:FULL -WINMD:NO | ||||
| 		LDLIBS += WindowsApp.lib | ||||
| 	endif | ||||
| 
 | ||||
| 	ARCH = x86_64 | ||||
| 	SHARED := | ||||
| 	LIBM := | ||||
| 	USE_LIBRETRO_VFS = 1 | ||||
| 	NO_ALIGN_FUNCTIONS = 1 | ||||
| 
 | ||||
| 	CFLAGS += -DHAVE_VSNPRINTF | ||||
| 	CFLAGS += $(MSVC2017CompileFlags) | ||||
| 	CXXFLAGS += $(MSVC2017CompileFlags) | ||||
| 
 | ||||
| 	TargetArchMoniker = $(subst $(WinPartition)_,,$(PlatformSuffix)) | ||||
| 
 | ||||
| 	CC  = cl.exe | ||||
| 	CXX = cl.exe | ||||
| 	LD = link.exe | ||||
| 
 | ||||
| 	reg_query = $(call filter_out2,$(subst $2,,$(shell reg query "$2" -v "$1" 2>nul))) | ||||
| 	fix_path = $(subst $(SPACE),\ ,$(subst \,/,$1)) | ||||
| 
 | ||||
| 	ProgramFiles86w := $(shell cmd //c "echo %PROGRAMFILES(x86)%") | ||||
| 	ProgramFiles86 := $(shell cygpath "$(ProgramFiles86w)") | ||||
| 
 | ||||
| 	WindowsSdkDir ?= $(call reg_query,InstallationFolder,HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Microsoft SDKs\Windows\v10.0) | ||||
| 	WindowsSdkDir ?= $(call reg_query,InstallationFolder,HKEY_CURRENT_USER\SOFTWARE\Wow6432Node\Microsoft\Microsoft SDKs\Windows\v10.0) | ||||
| 	WindowsSdkDir ?= $(call reg_query,InstallationFolder,HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SDKs\Windows\v10.0) | ||||
| 	WindowsSdkDir ?= $(call reg_query,InstallationFolder,HKEY_CURRENT_USER\SOFTWARE\Microsoft\Microsoft SDKs\Windows\v10.0) | ||||
| 	WindowsSdkDir := $(WindowsSdkDir) | ||||
| 
 | ||||
| 	WindowsSDKVersion ?= $(firstword $(foreach folder,$(subst $(subst \,/,$(WindowsSdkDir)Include/),,$(wildcard $(call fix_path,$(WindowsSdkDir)Include\*))),$(if $(wildcard $(call fix_path,$(WindowsSdkDir)Include/$(folder)/um/Windows.h)),$(folder),)))$(BACKSLASH) | ||||
| 	WindowsSDKVersion := $(WindowsSDKVersion) | ||||
| 
 | ||||
| 	VsInstallBuildTools = $(ProgramFiles86)/Microsoft Visual Studio/2017/BuildTools | ||||
| 	VsInstallEnterprise = $(ProgramFiles86)/Microsoft Visual Studio/2017/Enterprise | ||||
| 	VsInstallProfessional = $(ProgramFiles86)/Microsoft Visual Studio/2017/Professional | ||||
| 	VsInstallCommunity = $(ProgramFiles86)/Microsoft Visual Studio/2017/Community | ||||
| 
 | ||||
| 	VsInstallRoot ?= $(shell if [ -d "$(VsInstallBuildTools)" ]; then echo "$(VsInstallBuildTools)"; fi) | ||||
| 	ifeq ($(VsInstallRoot), ) | ||||
| 		VsInstallRoot = $(shell if [ -d "$(VsInstallEnterprise)" ]; then echo "$(VsInstallEnterprise)"; fi) | ||||
| 	endif | ||||
| 	ifeq ($(VsInstallRoot), ) | ||||
| 		VsInstallRoot = $(shell if [ -d "$(VsInstallProfessional)" ]; then echo "$(VsInstallProfessional)"; fi) | ||||
| 	endif | ||||
| 	ifeq ($(VsInstallRoot), ) | ||||
| 		VsInstallRoot = $(shell if [ -d "$(VsInstallCommunity)" ]; then echo "$(VsInstallCommunity)"; fi) | ||||
| 	endif | ||||
| 	VsInstallRoot := $(VsInstallRoot) | ||||
| 
 | ||||
| 	VcCompilerToolsVer := $(shell cat "$(VsInstallRoot)/VC/Auxiliary/Build/Microsoft.VCToolsVersion.default.txt" | grep -o '[0-9\.]*') | ||||
| 	VcCompilerToolsDir := $(VsInstallRoot)/VC/Tools/MSVC/$(VcCompilerToolsVer) | ||||
| 
 | ||||
| 	WindowsSDKSharedIncludeDir := $(shell cygpath -w "$(WindowsSdkDir)\Include\$(WindowsSDKVersion)\shared") | ||||
| 	WindowsSDKUCRTIncludeDir := $(shell cygpath -w "$(WindowsSdkDir)\Include\$(WindowsSDKVersion)\ucrt") | ||||
| 	WindowsSDKUMIncludeDir := $(shell cygpath -w "$(WindowsSdkDir)\Include\$(WindowsSDKVersion)\um") | ||||
| 	WindowsSDKUCRTLibDir := $(shell cygpath -w "$(WindowsSdkDir)\Lib\$(WindowsSDKVersion)\ucrt\$(TargetArchMoniker)") | ||||
| 	WindowsSDKUMLibDir := $(shell cygpath -w "$(WindowsSdkDir)\Lib\$(WindowsSDKVersion)\um\$(TargetArchMoniker)") | ||||
| 
 | ||||
| 	# For some reason the HostX86 compiler doesn't like compiling for x64 | ||||
| 	# ("no such file" opening a shared library), and vice-versa. | ||||
| 	# Work around it for now by using the strictly x86 compiler for x86, and x64 for x64. | ||||
| 	# NOTE: What about ARM? | ||||
| 	ifneq (,$(findstring x64,$(TargetArchMoniker))) | ||||
| 		VCCompilerToolsBinDir := $(VcCompilerToolsDir)\bin\HostX64 | ||||
| 	else | ||||
| 		VCCompilerToolsBinDir := $(VcCompilerToolsDir)\bin\HostX86 | ||||
| 	endif | ||||
| 
 | ||||
| 	PATH := $(shell IFS=$$'\n'; cygpath "$(VCCompilerToolsBinDir)/$(TargetArchMoniker)"):$(PATH) | ||||
| 	PATH := $(PATH):$(shell IFS=$$'\n'; cygpath "$(VsInstallRoot)/Common7/IDE") | ||||
| 	INCLUDE := $(shell IFS=$$'\n'; cygpath -w "$(VcCompilerToolsDir)/include") | ||||
| 	LIB := $(shell IFS=$$'\n'; cygpath -w "$(VcCompilerToolsDir)/lib/$(TargetArchMoniker)") | ||||
| 	ifneq (,$(findstring uwp,$(PlatformSuffix))) | ||||
| 		LIB := $(shell IFS=$$'\n'; cygpath -w "$(LIB)/store") | ||||
| 	endif | ||||
| 
 | ||||
| 	export INCLUDE := $(INCLUDE);$(WindowsSDKSharedIncludeDir);$(WindowsSDKUCRTIncludeDir);$(WindowsSDKUMIncludeDir) | ||||
| 	export LIB := $(LIB);$(WindowsSDKUCRTLibDir);$(WindowsSDKUMLibDir) | ||||
| 	TARGET := $(TARGET_NAME)_libretro.dll | ||||
| 	PSS_STYLE :=2 | ||||
| 	LDFLAGS += -DLL | ||||
| 
 | ||||
| # Windows | ||||
| else | ||||
|  | @ -291,7 +544,12 @@ else | |||
| 
 | ||||
| endif | ||||
| 
 | ||||
| CFLAGS += -DNO_ZLIB | ||||
| CFLAGS += -DNO_ZLIB -D__LIBRETRO__ | ||||
| 
 | ||||
| ifeq ($(USE_LIBRETRO_VFS),1) | ||||
| 	NO_MMAP = 1 | ||||
| 	CFLAGS += -DUSE_LIBRETRO_VFS | ||||
| endif | ||||
| 
 | ||||
| ifeq ($(NO_MMAP),1) | ||||
| 	CFLAGS += -DNO_MMAP | ||||
|  | @ -329,4 +587,58 @@ endif | |||
| PLATFORM = libretro | ||||
| NO_CONFIG_MAK = yes | ||||
| 
 | ||||
| OBJOUT   = -o | ||||
| LINKOUT  = -o  | ||||
| 
 | ||||
| ifneq (,$(findstring msvc,$(platform))) | ||||
| 	CFLAGS += -wd4702 -wd4711 -wd4202 -wd4101 | ||||
| endif | ||||
| 
 | ||||
| ifeq ($(DEBUG), 1) | ||||
| 	ifneq (,$(findstring msvc,$(platform))) | ||||
| 		ifeq ($(STATIC_LINKING),1) | ||||
| 			CFLAGS += -MTd | ||||
| 			CXXFLAGS += -MTd | ||||
| 		else | ||||
| 			CFLAGS += -MDd | ||||
| 			CXXFLAGS += -MDd | ||||
| 		endif | ||||
| 
 | ||||
| 		CFLAGS += -Od -Zi -DDEBUG -D_DEBUG | ||||
| 		CXXFLAGS += -Od -Zi -DDEBUG -D_DEBUG | ||||
| 	else | ||||
| 		CFLAGS += -O0 -g -DDEBUG | ||||
| 		CXXFLAGS += -O0 -g -DDEBUG | ||||
| 	endif | ||||
| else | ||||
| 	ifneq (,$(findstring msvc,$(platform))) | ||||
| 		ifeq ($(STATIC_LINKING),1) | ||||
| 			CFLAGS += -MT | ||||
| 			CXXFLAGS += -MT | ||||
| 		else | ||||
| 			CFLAGS += -MD | ||||
| 			CXXFLAGS += -MD | ||||
| 		endif | ||||
| 
 | ||||
| 		CFLAGS += -O2 -DNDEBUG | ||||
| 		CXXFLAGS += -O2 -DNDEBUG | ||||
| 	else | ||||
| 		CFLAGS += -O3 -DNDEBUG | ||||
| 		CXXFLAGS += -O3 -DNDEBUG | ||||
| 	endif | ||||
| endif | ||||
| 
 | ||||
| ifneq (,$(findstring msvc,$(platform))) | ||||
| 	OBJOUT = -Fo | ||||
| 	LINKOUT = -out: | ||||
| ifeq ($(STATIC_LINKING),1) | ||||
| 	LD ?= lib.exe | ||||
| 	STATIC_LINKING=0 | ||||
| else | ||||
| 	LD = link.exe | ||||
| endif | ||||
| else | ||||
| 	LD = $(CC) | ||||
| endif | ||||
| 
 | ||||
| include Makefile | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 kub
						kub