mirror of
				https://github.com/RaySollium99/picodrive.git
				synced 2025-10-26 08:19:38 -04:00 
			
		
		
		
	re-import all libretro code from it's fork
Verbatim copy from https://github.com/libretro/picodrive/ commit 9ae88ef15ff00cacc3877c7ecc13b0092bab50b8 , so look there for the history of libretro specific changes. Unfortunately there is too much noise and divergence to merge this in a proper way.
This commit is contained in:
		
							parent
							
								
									126eb5f469
								
							
						
					
					
						commit
						7612bf90be
					
				
					 17 changed files with 6402 additions and 1810 deletions
				
			
		
							
								
								
									
										6
									
								
								Makefile
									
										
									
									
									
								
							
							
						
						
									
										6
									
								
								Makefile
									
										
									
									
									
								
							|  | @ -111,7 +111,7 @@ USE_FRONTEND = 1 | ||||||
| PLATFORM_MP3 = 1 | PLATFORM_MP3 = 1 | ||||||
| endif | endif | ||||||
| ifeq "$(PLATFORM)" "libretro" | ifeq "$(PLATFORM)" "libretro" | ||||||
| OBJS += platform/libretro.o  | OBJS += platform/libretro/libretro.o | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifeq "$(USE_FRONTEND)" "1" | ifeq "$(USE_FRONTEND)" "1" | ||||||
|  | @ -181,7 +181,11 @@ clean: | ||||||
| 	$(RM) -r .opk_data | 	$(RM) -r .opk_data | ||||||
| 
 | 
 | ||||||
| $(TARGET): $(OBJS) | $(TARGET): $(OBJS) | ||||||
|  | ifeq ($(STATIC_LINKING), 1) | ||||||
|  | 	$(AR) rcs $@ $^ | ||||||
|  | else | ||||||
| 	$(CC) -o $@ $(CFLAGS) $^ $(LDFLAGS) $(LDLIBS) | 	$(CC) -o $@ $(CFLAGS) $^ $(LDFLAGS) $(LDLIBS) | ||||||
|  | endif | ||||||
| 
 | 
 | ||||||
| pprof: platform/linux/pprof.c | pprof: platform/linux/pprof.c | ||||||
| 	$(CC) -O2 -ggdb -DPPROF -DPPROF_TOOL -I../../ -I. $^ -o $@ | 	$(CC) -O2 -ggdb -DPPROF -DPPROF_TOOL -I../../ -I. $^ -o $@ | ||||||
|  |  | ||||||
|  | @ -1,16 +1,20 @@ | ||||||
| # Makefile for PicoDrive (libretro) | # Makefile for PicoDrive (libretro) | ||||||
| 
 | 
 | ||||||
| ifeq ($(platform),) | ifeq ($(platform),) | ||||||
| platform = unix | 	platform = unix | ||||||
| ifeq ($(shell uname -a),) | 	ifeq ($(shell uname -a),) | ||||||
|    platform = win | 		platform = win | ||||||
| else ifneq ($(findstring MINGW,$(shell uname -a)),) | 	else ifneq ($(findstring MINGW,$(shell uname -a)),) | ||||||
|    platform = win | 		platform = win | ||||||
| else ifneq ($(findstring Darwin,$(shell uname -a)),) | 	else ifneq ($(findstring Darwin,$(shell uname -a)),) | ||||||
|    platform = osx | 		platform = osx | ||||||
| else ifneq ($(findstring win,$(shell uname -a)),) | 		arch = intel | ||||||
|    platform = win | 		ifeq ($(shell uname -p),powerpc) | ||||||
| endif | 			arch = ppc | ||||||
|  | 		endif | ||||||
|  | 	else ifneq ($(findstring win,$(shell uname -a)),) | ||||||
|  | 		platform = win | ||||||
|  | 	endif | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| CC ?= gcc | CC ?= gcc | ||||||
|  | @ -19,7 +23,13 @@ AS ?= as | ||||||
| CC_AS ?= $(CC) | CC_AS ?= $(CC) | ||||||
| CFLAGS ?= | CFLAGS ?= | ||||||
| 
 | 
 | ||||||
|  | STATIC_LINKING:= 0 | ||||||
| TARGET_NAME := picodrive | TARGET_NAME := picodrive | ||||||
|  | LIBM := -lm | ||||||
|  | GIT_VERSION := " $(shell git rev-parse --short HEAD || echo unknown)" | ||||||
|  | ifneq ($(GIT_VERSION)," unknown") | ||||||
|  | 	CFLAGS += -DGIT_VERSION=\"$(GIT_VERSION)\" | ||||||
|  | endif | ||||||
| 
 | 
 | ||||||
| asm_memory = 0 | asm_memory = 0 | ||||||
| asm_render = 0 | asm_render = 0 | ||||||
|  | @ -28,108 +38,410 @@ asm_misc = 0 | ||||||
| asm_cdmemory = 0 | asm_cdmemory = 0 | ||||||
| asm_mix = 0 | asm_mix = 0 | ||||||
| 
 | 
 | ||||||
|  | fpic := | ||||||
|  | 
 | ||||||
|  | ifeq ($(STATIC_LINKING),1) | ||||||
|  | EXT=a | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | # Unix | ||||||
| ifeq ($(platform), unix) | ifeq ($(platform), unix) | ||||||
|    TARGET := $(TARGET_NAME)_libretro.so | 	EXT ?= so | ||||||
|    SHARED := -shared | 	TARGET := $(TARGET_NAME)_libretro.$(EXT) | ||||||
|  |    fpic := -fPIC | ||||||
|  | 	SHARED := -shared | ||||||
|  | 	DONT_COMPILE_IN_ZLIB = 1 | ||||||
|  | 	CFLAGS += -DFAMEC_NO_GOTOS | ||||||
|  | 
 | ||||||
|  | # Portable Linux | ||||||
|  | else ifeq ($(platform), linux-portable) | ||||||
|  | 	EXT ?= so | ||||||
|  | 	TARGET := $(TARGET_NAME)_libretro.$(EXT) | ||||||
|  | 	SHARED := -shared -nostdlib | ||||||
|  |    fpic := -fPIC | ||||||
|  | 	LIBM := | ||||||
|  | 	DONT_COMPILE_IN_ZLIB = 1 | ||||||
|  | 	CFLAGS += -DFAMEC_NO_GOTOS | ||||||
|  | 
 | ||||||
|  | # OS X | ||||||
| else ifeq ($(platform), osx) | else ifeq ($(platform), osx) | ||||||
|    TARGET := $(TARGET_NAME)_libretro.dylib | 	EXT ?= dylib | ||||||
|    SHARED := -dynamiclib | 	TARGET := $(TARGET_NAME)_libretro.$(EXT) | ||||||
| else ifeq ($(platform), ios) | 	SHARED := -dynamiclib | ||||||
|    TARGET := $(TARGET_NAME)_libretro_ios.dylib |    fpic := -fPIC | ||||||
|    SHARED := -dynamiclib | 	APPLE := 1 | ||||||
|  | 	arch = intel | ||||||
|  | 	ifeq ($(shell uname -p),powerpc) | ||||||
|  | 		arch = ppc | ||||||
|  | 	endif | ||||||
|  | 	ifeq ($(arch),ppc) | ||||||
|  | 		CFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__ -DFAMEC_NO_GOTOS | ||||||
|  | 	endif | ||||||
|  | 	OSXVER = `sw_vers -productVersion | cut -d. -f 2` | ||||||
|  | 	OSX_LT_MAVERICKS = `(( $(OSXVER) <= 9)) && echo "YES"` | ||||||
|  | 	SHARED += -mmacosx-version-min=10.1 | ||||||
| 
 | 
 | ||||||
|    CC = clang -arch armv7 -isysroot $(IOSSDK) -miphoneos-version-min=5.0 | else ifeq ($(platform), staticios) | ||||||
|    CXX = clang++ -arch armv7 -isysroot $(IOSSDK) -miphoneos-version-min=5.0 | 	TARGET := $(TARGET_NAME)_libretro_ios.a | ||||||
|    CC_AS = perl ./tools/gas-preprocessor.pl $(CC) -miphoneos-version-min=5.0 | 	APPLE := 1 | ||||||
|    CFLAGS += -mcpu=cortex-a8 -mtune=cortex-a8 -mfpu=neon -marm  | 	ifeq ($(IOSSDK),) | ||||||
|    ASFLAGS += -mcpu=cortex-a8 -mtune=cortex-a8 -mfpu=neon | 		IOSSDK := $(shell xcodebuild -version -sdk iphoneos Path) | ||||||
|    CFLAGS += -DIOS -miphoneos-version-min=5.0 | 	endif | ||||||
|  | 	CC = clang -arch armv7 -arch arm64 -isysroot $(IOSSDK) | ||||||
|  | 	CXX = clang++ -arch armv7 -arch arm64 -isysroot $(IOSSDK) | ||||||
|  | 	CC_AS = perl ./tools/gas-preprocessor.pl $(CC) | ||||||
|  | 	CFLAGS += -marm  | ||||||
|  | 	CFLAGS += -DIOS | ||||||
| 
 | 
 | ||||||
|    ARCH := arm | 	CC     += -miphoneos-version-min=8.0 | ||||||
|  | 	CXX    += -miphoneos-version-min=8.0 | ||||||
|  | 	CC_AS  += -miphoneos-version-min=8.0 | ||||||
|  | 	CFLAGS += -miphoneos-version-min=8.0 | ||||||
|  | 	ARCH := arm | ||||||
| 
 | 
 | ||||||
|    use_cyclone = 0 | 	STATIC_LINKING = 1 | ||||||
|    use_fame = 1 | 	use_cyclone = 0 | ||||||
|    use_drz80 = 0 | 	use_fame = 1 | ||||||
|    use_cz80 = 1 | 	use_drz80 = 0 | ||||||
|  | 	use_cz80 = 1 | ||||||
|  | 	use_sh2drc = 0 | ||||||
|  | 	use_svpdrc = 0 | ||||||
|  | 
 | ||||||
|  | # iOS | ||||||
|  | else ifneq (,$(findstring ios,$(platform))) | ||||||
|  | 	TARGET := $(TARGET_NAME)_libretro_ios.dylib | ||||||
|  | 	SHARED := -dynamiclib | ||||||
|  |    fpic := -fPIC | ||||||
|  | 	APPLE := 1 | ||||||
|  | 	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 | ||||||
|  | 	CFLAGS += -DIOS | ||||||
|  | 
 | ||||||
|  | ifeq ($(platform),ios9) | ||||||
|  | 	CC     += -miphoneos-version-min=8.0 | ||||||
|  | 	CXX    += -miphoneos-version-min=8.0 | ||||||
|  | 	CC_AS  += -miphoneos-version-min=8.0 | ||||||
|  | 	CFLAGS += -miphoneos-version-min=8.0 | ||||||
|  | else | ||||||
|  | 	CC     += -miphoneos-version-min=5.0 | ||||||
|  | 	CXX    += -miphoneos-version-min=5.0 | ||||||
|  | 	CC_AS  += -miphoneos-version-min=5.0 | ||||||
|  | 	CFLAGS += -miphoneos-version-min=5.0 | ||||||
|  | endif | ||||||
|  | 	ARCH := arm | ||||||
|  | 
 | ||||||
|  | 	use_cyclone = 0 | ||||||
|  | 	use_fame = 1 | ||||||
|  | 	use_drz80 = 0 | ||||||
|  | 	use_cz80 = 1 | ||||||
|  | 	use_sh2drc = 1 | ||||||
|  | 	use_svpdrc = 1 | ||||||
|  | 
 | ||||||
|  | # PS3 | ||||||
|  | else ifeq ($(platform), ps3) | ||||||
|  | 	TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||||
|  | 	CC = $(CELL_SDK)/host-win32/ppu/bin/ppu-lv2-gcc.exe | ||||||
|  | 	AR = $(CELL_SDK)/host-win32/ppu/bin/ppu-lv2-ar.exe | ||||||
|  | 	CFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__ -DFAMEC_NO_GOTOS | ||||||
|  | 	STATIC_LINKING = 1 | ||||||
|  | 	NO_MMAP = 1 | ||||||
|  | 	DONT_COMPILE_IN_ZLIB = 1 | ||||||
|  | 
 | ||||||
|  | 	asm_memory = 0 | ||||||
|  | 	asm_render = 0 | ||||||
|  | 	asm_ym2612 = 0 | ||||||
|  | 	asm_misc = 0 | ||||||
|  | 	asm_cdpico = 0 | ||||||
|  | 	asm_cdmemory = 0 | ||||||
|  | 	asm_mix = 0 | ||||||
|  | 	use_cyclone = 0 | ||||||
|  | 	use_fame = 1 | ||||||
|  | 	use_drz80 = 0 | ||||||
|  | 	use_cz80 = 1 | ||||||
|  | 
 | ||||||
|  | # sncps3 | ||||||
|  | else ifeq ($(platform), sncps3) | ||||||
|  | 	TARGET := $(TARGET_NAME)_libretro_ps3.a | ||||||
|  | 	CC = $(CELL_SDK)/host-win32/sn/bin/ps3ppusnc.exe | ||||||
|  | 	AR = $(CELL_SDK)/host-win32/sn/bin/ps3snarl.exe | ||||||
|  | 	CFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__ -DFAMEC_NO_GOTOS | ||||||
|  | 	STATIC_LINKING = 1 | ||||||
|  | 	NO_MMAP = 1 | ||||||
|  | 	DONT_COMPILE_IN_ZLIB = 1 | ||||||
|  | 
 | ||||||
|  | 	asm_memory = 0 | ||||||
|  | 	asm_render = 0 | ||||||
|  | 	asm_ym2612 = 0 | ||||||
|  | 	asm_misc = 0 | ||||||
|  | 	asm_cdpico = 0 | ||||||
|  | 	asm_cdmemory = 0 | ||||||
|  | 	asm_mix = 0 | ||||||
|  | 	use_cyclone = 0 | ||||||
|  | 	use_fame = 1 | ||||||
|  | 	use_drz80 = 0 | ||||||
|  | 	use_cz80 = 1 | ||||||
|  | 
 | ||||||
|  | # Lightweight PS3 Homebrew SDK | ||||||
|  | else ifeq ($(platform), psl1ght) | ||||||
|  | 	TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||||
|  | 	CC = $(PS3DEV)/ppu/bin/ppu-gcc$(EXE_EXT) | ||||||
|  | 	AR = $(PS3DEV)/ppu/bin/ppu-ar$(EXE_EXT) | ||||||
|  | 	CFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__ -DFAMEC_NO_GOTOS | ||||||
|  | 	STATIC_LINKING = 1 | ||||||
|  | 	NO_MMAP = 1 | ||||||
|  | 	DONT_COMPILE_IN_ZLIB = 1 | ||||||
|  | 	 | ||||||
|  | 	asm_memory = 0 | ||||||
|  | 	asm_render = 0 | ||||||
|  | 	asm_ym2612 = 0 | ||||||
|  | 	asm_misc = 0 | ||||||
|  | 	asm_cdpico = 0 | ||||||
|  | 	asm_cdmemory = 0 | ||||||
|  | 	asm_mix = 0 | ||||||
|  | 	use_cyclone = 0 | ||||||
|  | 	use_fame = 1 | ||||||
|  | 	use_drz80 = 0 | ||||||
|  | 	use_cz80 = 1 | ||||||
|  | 
 | ||||||
|  | # PSP | ||||||
|  | else ifeq ($(platform), psp1) | ||||||
|  |     TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||||
|  |     CC = psp-gcc$(EXE_EXT) | ||||||
|  |     AR = psp-ar$(EXE_EXT) | ||||||
|  |     CFLAGS += -G0 -ftracer | ||||||
|  |     CFLAGS += -DPSP -D_ASM_DRAW_C_AMIPS | ||||||
|  |     STATIC_LINKING = 1 | ||||||
|  |     NO_MMAP = 1 | ||||||
|  |     DONT_COMPILE_IN_ZLIB = 1 | ||||||
|  | 
 | ||||||
|  |     asm_memory = 0 | ||||||
|  |     asm_render = 1 | ||||||
|  |     asm_ym2612 = 0 | ||||||
|  |     asm_misc = 0 | ||||||
|  |     asm_cdpico = 0 | ||||||
|  |     asm_cdmemory = 0 | ||||||
|  |     asm_mix = 0 | ||||||
|  |     use_cyclone = 0 | ||||||
|  |     use_fame = 1 | ||||||
|  |     use_drz80 = 0 | ||||||
|  |     use_cz80 = 1 | ||||||
|  | 
 | ||||||
|  |     OBJS +=platform/libretro/psp/draw_amips.o | ||||||
|  | 
 | ||||||
|  | # CTR (3DS) | ||||||
|  | else ifeq ($(platform), ctr) | ||||||
|  |    TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||||
|  |    CC = $(DEVKITARM)/bin/arm-none-eabi-gcc$(EXE_EXT) | ||||||
|  |    CXX = $(DEVKITARM)/bin/arm-none-eabi-g++$(EXE_EXT) | ||||||
|  |    AR = $(DEVKITARM)/bin/arm-none-eabi-ar$(EXE_EXT) | ||||||
|  |    CFLAGS += -DARM11 -D_3DS | ||||||
|  |    CFLAGS += -march=armv6k -mtune=mpcore -mfloat-abi=hard -marm -mfpu=vfp | ||||||
|  |    CFLAGS += -Wall -mword-relocations | ||||||
|  |    CFLAGS += -fomit-frame-pointer -ffast-math | ||||||
|  |    STATIC_LINKING = 1 | ||||||
|  |    NO_MMAP = 1 | ||||||
|  |    DONT_COMPILE_IN_ZLIB = 1 | ||||||
|  |    ARCH = arm | ||||||
|  |    ARM_ASM = 1 | ||||||
|  | 
 | ||||||
|  |    asm_memory = 1 | ||||||
|  |    asm_render = 1 | ||||||
|  |    asm_ym2612 = 1 | ||||||
|  |    asm_misc = 1 | ||||||
|  |    asm_cdpico = 1 | ||||||
|  |    asm_cdmemory = 1 | ||||||
|  |    asm_mix = 1 | ||||||
|  | 
 | ||||||
|  |    use_cyclone = 1 | ||||||
|  |    use_fame = 0 | ||||||
|  |    use_drz80 = 1 | ||||||
|  |    use_cz80 = 0 | ||||||
|    use_sh2drc = 1 |    use_sh2drc = 1 | ||||||
|    use_svpdrc = 1 |    use_svpdrc = 1 | ||||||
| 
 | 
 | ||||||
| else ifeq ($(platform), ps3) |    OBJS +=platform/libretro/3ds/3ds_utils.o | ||||||
|    TARGET := $(TARGET_NAME)_libretro_ps3.a |  | ||||||
|    CC = $(CELL_SDK)/host-win32/ppu/bin/ppu-lv2-gcc.exe |  | ||||||
|    AR = $(CELL_SDK)/host-win32/ppu/bin/ppu-lv2-ar.exe |  | ||||||
|    CFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__ |  | ||||||
| else ifeq ($(platform), sncps3) |  | ||||||
|    TARGET := $(TARGET_NAME)_libretro_ps3.a |  | ||||||
|    CC = $(CELL_SDK)/host-win32/sn/bin/ps3ppusnc.exe |  | ||||||
|    AR = $(CELL_SDK)/host-win32/sn/bin/ps3snarl.exe |  | ||||||
|    CFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__ |  | ||||||
| else ifeq ($(platform), psl1ght) |  | ||||||
|    TARGET := $(TARGET_NAME)_libretro_psl1ght.a |  | ||||||
|    CC = $(PS3DEV)/ppu/bin/ppu-gcc$(EXE_EXT) |  | ||||||
|    AR = $(PS3DEV)/ppu/bin/ppu-ar$(EXE_EXT) |  | ||||||
|    CFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__ |  | ||||||
| else ifeq ($(platform), psp1) |  | ||||||
|    TARGET := $(TARGET_NAME)_libretro_psp1.a |  | ||||||
|    CC = psp-gcc$(EXE_EXT) |  | ||||||
|    AR = psp-ar$(EXE_EXT) |  | ||||||
|    CFLAGS += -DPSP -G0 |  | ||||||
| else ifeq ($(platform), xenon) |  | ||||||
|    TARGET := $(TARGET_NAME)_libretro_xenon360.a |  | ||||||
|    CC = xenon-gcc$(EXE_EXT) |  | ||||||
|    AR = xenon-ar$(EXE_EXT) |  | ||||||
|    CFLAGS += -D__LIBXENON__ -m32 -D__ppc__ |  | ||||||
| else ifeq ($(platform), ngc) |  | ||||||
|    TARGET := $(TARGET_NAME)_libretro_ngc.a |  | ||||||
|    CC = $(DEVKITPPC)/bin/powerpc-eabi-gcc$(EXE_EXT) |  | ||||||
|    AR = $(DEVKITPPC)/bin/powerpc-eabi-ar$(EXE_EXT) |  | ||||||
|    CFLAGS += -DGEKKO -DHW_DOL -mrvl -mcpu=750 -meabi -mhard-float -DBLARGG_BIG_ENDIAN=1 -D__ppc__ |  | ||||||
| else ifeq ($(platform), wii) |  | ||||||
|    TARGET := libretro_$(TARGET_NAME)_wii.a |  | ||||||
|    CC = $(DEVKITPPC)/bin/powerpc-eabi-gcc$(EXE_EXT) |  | ||||||
|    AR = $(DEVKITPPC)/bin/powerpc-eabi-ar$(EXE_EXT) |  | ||||||
|    CFLAGS += -DGEKKO -DHW_RVL -mrvl -mcpu=750 -meabi -mhard-float -DBLARGG_BIG_ENDIAN=1 -D__ppc__ |  | ||||||
| else ifeq ($(platform), qnx) |  | ||||||
|    TARGET := $(TARGET_NAME)_libretro_qnx.so |  | ||||||
|    CC = qcc -Vgcc_ntoarmv7le |  | ||||||
|    CC_AS = $(CC) |  | ||||||
|    CFLAGS += -DBASE_ADDR_FIXED=0 -D__BLACKBERRY_QNX__ -marm -mcpu=cortex-a9 -mtune=cortex-a9 -mfpu=neon -mfloat-abi=softfp |  | ||||||
|    ASFLAGS +=  -mcpu=cortex-a9 -mfpu=neon -mfloat-abi=softfp |  | ||||||
| 
 | 
 | ||||||
|  | # Raspberry Pi (original model) Raspbian | ||||||
|  | else ifeq ($(platform), raspberrypi) | ||||||
|  |    CFLAGS += -marm -mfpu=vfp -mfloat-abi=hard -march=armv6j | ||||||
|  |    CFLAGS += -Wall -mword-relocations | ||||||
|  |    CFLAGS += -fomit-frame-pointer -ffast-math | ||||||
|    ARCH = arm |    ARCH = arm | ||||||
|    ARM_ASM = 1 |    ARM_ASM = 1 | ||||||
| else ifneq (,$(findstring armv,$(platform))) | 
 | ||||||
|    TARGET := $(TARGET_NAME)_libretro.so |    TARGET := $(TARGET_NAME)_libretro.so | ||||||
|    SHARED := -shared -Wl,--no-undefined |    SHARED := -shared | ||||||
| ifneq (,$(findstring cortexa8,$(platform))) |    fpic := -fPIC | ||||||
|    CFLAGS += -marm -mcpu=cortex-a8 |    DONT_COMPILE_IN_ZLIB = 1 | ||||||
|    ASFLAGS += -mcpu=cortex-a8 | 
 | ||||||
| else ifneq (,$(findstring cortexa9,$(platform))) |    asm_memory = 1 | ||||||
|    CFLAGS += -marm -mcpu=cortex-a9 |    asm_render = 1 | ||||||
|    ASFLAGS += -mcpu=cortex-a9 |    asm_ym2612 = 1 | ||||||
| endif |    asm_misc = 1 | ||||||
|    CFLAGS += -marm |    asm_cdpico = 1 | ||||||
| ifneq (,$(findstring neon,$(platform))) |    asm_cdmemory = 1 | ||||||
|    CFLAGS += -mfpu=neon |    asm_mix = 1 | ||||||
|    ASFLAGS += -mfpu=neon | 
 | ||||||
| endif |    use_cyclone = 1 | ||||||
| ifneq (,$(findstring softfloat,$(platform))) |    use_fame = 0 | ||||||
|    CFLAGS += -mfloat-abi=softfp |    use_drz80 = 1 | ||||||
|    ASFLAGS += -mfloat-abi=softfp |    use_cz80 = 0 | ||||||
| else ifneq (,$(findstring hardfloat,$(platform))) |    use_sh2drc = 1 | ||||||
|    CFLAGS += -mfloat-abi=hard |    use_svpdrc = 1 | ||||||
|    ASFLAGS += -mfloat-abi=hard | 
 | ||||||
| endif | # Vita | ||||||
| ifneq (,$(findstring armasm,$(platform))) | else ifeq ($(platform), vita) | ||||||
|    ARM_ASM = 1 | 	TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||||
| endif | 	CC = arm-vita-eabi-gcc$(EXE_EXT) | ||||||
|    ARCH = arm | 	AR = arm-vita-eabi-ar$(EXE_EXT) | ||||||
|  | 	CFLAGS += -DVITA | ||||||
|  | 	CFLAGS += -marm -mfpu=neon -mcpu=cortex-a9 -march=armv7-a -mfloat-abi=hard -ffast-math | ||||||
|  | 	CFLAGS += -fno-asynchronous-unwind-tables -ftree-vectorize -funroll-loops | ||||||
|  | 	CFLAGS += -mword-relocations -fno-unwind-tables | ||||||
|  | 	CFLAGS += -fno-optimize-sibling-calls | ||||||
|  | 	STATIC_LINKING = 1 | ||||||
|  | 	NO_MMAP = 1 | ||||||
|  | 	DONT_COMPILE_IN_ZLIB = 1 | ||||||
|  | 	ARCH = arm | ||||||
|  | 
 | ||||||
|  | 	asm_memory = 1 | ||||||
|  | 	asm_render = 1 | ||||||
|  | 	asm_ym2612 = 1 | ||||||
|  | 	asm_misc = 1 | ||||||
|  | 	asm_cdpico = 1 | ||||||
|  | 	asm_cdmemory = 1 | ||||||
|  | 	asm_mix = 1 | ||||||
|  | 	use_cyclone = 1 | ||||||
|  | 	use_fame = 0 | ||||||
|  | 	use_drz80 = 1 | ||||||
|  | 	use_cz80 = 0 | ||||||
|  | 	use_sh2drc = 1 | ||||||
|  | 	use_svpdrc = 1 | ||||||
|  | 
 | ||||||
|  | # Xbox 360 | ||||||
|  | else ifeq ($(platform), xenon) | ||||||
|  | 	TARGET := $(TARGET_NAME)_libretro_xenon360.a | ||||||
|  | 	CC = xenon-gcc$(EXE_EXT) | ||||||
|  | 	AR = xenon-ar$(EXE_EXT) | ||||||
|  | 	CFLAGS += -D__LIBXENON__ -m32 -D__ppc__ | ||||||
|  | 
 | ||||||
|  | # Nintendo Game Cube | ||||||
|  | else ifeq ($(platform), ngc) | ||||||
|  | 	TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||||
|  | 	CC = $(DEVKITPPC)/bin/powerpc-eabi-gcc$(EXE_EXT) | ||||||
|  | 	AR = $(DEVKITPPC)/bin/powerpc-eabi-ar$(EXE_EXT) | ||||||
|  | 	CFLAGS += -DGEKKO -DHW_DOL -mrvl -mcpu=750 -meabi -mhard-float -DBLARGG_BIG_ENDIAN=1 -D__ppc__ | ||||||
|  | 
 | ||||||
|  | # Nintendo Wii | ||||||
|  | else ifeq ($(platform), wii) | ||||||
|  | 	TARGET := $(TARGET_NAME)_libretro_$(platform).a | ||||||
|  | 	CC = $(DEVKITPPC)/bin/powerpc-eabi-gcc$(EXE_EXT) | ||||||
|  | 	AR = $(DEVKITPPC)/bin/powerpc-eabi-ar$(EXE_EXT) | ||||||
|  | 	CFLAGS += -DGEKKO -DHW_RVL -mrvl -mcpu=750 -meabi -mhard-float -DBLARGG_BIG_ENDIAN=1 -D__ppc__ | ||||||
|  | 
 | ||||||
|  | # QNX | ||||||
|  | else ifeq ($(platform), qnx) | ||||||
|  | 	TARGET := $(TARGET_NAME)_libretro_$(platform).so | ||||||
|  |    fpic := -fPIC | ||||||
|  | 	CC = qcc -Vgcc_ntoarmv7le | ||||||
|  | 	CC_AS = $(CC) | ||||||
|  | 	CFLAGS += -DBASE_ADDR_FIXED=0 -D__BLACKBERRY_QNX__ -marm -mcpu=cortex-a9 -mtune=cortex-a9 -mfpu=neon -mfloat-abi=softfp | ||||||
|  | 	ASFLAGS +=  -mcpu=cortex-a9 -mfpu=neon -mfloat-abi=softfp | ||||||
|  | 	ARCH = arm | ||||||
|  | 	ARM_ASM = 1 | ||||||
|  | 
 | ||||||
|  | 	use_cyclone = 0 | ||||||
|  | 	use_fame = 1 | ||||||
|  | 	use_drz80 = 0 | ||||||
|  | 	use_cz80 = 1 | ||||||
|  | 	use_sh2drc = 1 | ||||||
|  | 	use_svpdrc = 1 | ||||||
|  | 
 | ||||||
|  | # ARM | ||||||
|  | else ifneq (,$(findstring armv,$(platform))) | ||||||
|  | 	TARGET := $(TARGET_NAME)_libretro.so | ||||||
|  | 	SHARED := -shared -Wl,--no-undefined,-Bsymbolic | ||||||
|  |    fpic := -fPIC | ||||||
|  | 	ifneq (,$(findstring cortexa5,$(platform))) | ||||||
|  | 		CFLAGS += -marm -mcpu=cortex-a5 | ||||||
|  | 		ASFLAGS += -mcpu=cortex-a5 | ||||||
|  | 	else ifneq (,$(findstring cortexa8,$(platform))) | ||||||
|  | 		CFLAGS += -marm -mcpu=cortex-a8 | ||||||
|  | 		ASFLAGS += -mcpu=cortex-a8 | ||||||
|  | 	else ifneq (,$(findstring cortexa9,$(platform))) | ||||||
|  | 		CFLAGS += -marm -mcpu=cortex-a9 | ||||||
|  | 		ASFLAGS += -mcpu=cortex-a9 | ||||||
|  | 	else ifneq (,$(findstring cortexa15a7,$(platform))) | ||||||
|  | 		CFLAGS += -marm -mcpu=cortex-a15.cortex-a7 | ||||||
|  | 		ASFLAGS += -mcpu=cortex-a15.cortex-a7 | ||||||
|  | 	else | ||||||
|  | 		CFLAGS += -marm | ||||||
|  | 	endif | ||||||
|  | 	ifneq (,$(findstring neon,$(platform))) | ||||||
|  | 		CFLAGS += -mfpu=neon | ||||||
|  | 		ASFLAGS += -mfpu=neon | ||||||
|  | 	endif | ||||||
|  | 	ifneq (,$(findstring softfloat,$(platform))) | ||||||
|  | 		CFLAGS += -mfloat-abi=softfp | ||||||
|  | 		ASFLAGS += -mfloat-abi=softfp | ||||||
|  | 	else ifneq (,$(findstring hardfloat,$(platform))) | ||||||
|  | 		CFLAGS += -mfloat-abi=hard | ||||||
|  | 		ASFLAGS += -mfloat-abi=hard | ||||||
|  | 	endif | ||||||
|  | 	ifneq (,$(findstring armasm,$(platform))) | ||||||
|  | 		ARM_ASM = 1 | ||||||
|  | 	endif | ||||||
|  | 	ARCH = arm | ||||||
|  | 
 | ||||||
|  | # Emscripten | ||||||
|  | else ifeq ($(platform), emscripten)  | ||||||
|  | 	TARGET := $(TARGET_NAME)_libretro_$(platform).bc | ||||||
|  | 	STATIC_LINKING = 1 | ||||||
|  | 	DONT_COMPILE_IN_ZLIB = 1 | ||||||
|  | 
 | ||||||
|  | # GCW0 | ||||||
|  | else ifeq ($(platform), gcw0) | ||||||
|  | 	TARGET := $(TARGET_NAME)_libretro.so | ||||||
|  | 	CC = /opt/gcw0-toolchain/usr/bin/mipsel-linux-gcc | ||||||
|  | 	AR = /opt/gcw0-toolchain/usr/bin/mipsel-linux-ar | ||||||
|  | 	SHARED := -shared -nostdlib | ||||||
|  |         fpic := -fPIC | ||||||
|  | 	LIBM := | ||||||
|  | 	DONT_COMPILE_IN_ZLIB = 1 | ||||||
|  | 	CFLAGS += -ffast-math -march=mips32 -mtune=mips32r2 -mhard-float | ||||||
|  | 
 | ||||||
|  | 	asm_memory = 0 | ||||||
|  | 	asm_render = 0 | ||||||
|  | 	asm_ym2612 = 0 | ||||||
|  | 	asm_misc = 0 | ||||||
|  | 	asm_cdpico = 0 | ||||||
|  | 	asm_cdmemory = 0 | ||||||
|  | 	asm_mix = 0 | ||||||
|  | 	use_cyclone = 0 | ||||||
|  | 	use_fame = 1 | ||||||
|  | 	use_drz80 = 0 | ||||||
|  | 	use_cz80 = 1 | ||||||
|  | 
 | ||||||
|  | # Windows | ||||||
| else | else | ||||||
|    TARGET := $(TARGET_NAME)_libretro.dll | 	TARGET := $(TARGET_NAME)_libretro.dll | ||||||
|    CC = gcc | 	CC = gcc | ||||||
|    LD_FLAGS := -fPIC | 	fpic := -fPIC | ||||||
|    SHARED := -shared -static-libgcc -static-libstdc++ | 	SHARED := -shared -static-libgcc -static-libstdc++ | ||||||
|    CFLAGS += -D__WIN32__ -D__WIN32_LIBRETRO__ | 	CFLAGS += -D__WIN32__ -D__WIN32_LIBRETRO__ | ||||||
|  | 
 | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | CFLAGS += -DNO_ZLIB | ||||||
|  | 
 | ||||||
|  | ifeq ($(NO_MMAP),1) | ||||||
|  | 	CFLAGS += -DNO_MMAP | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifeq ($(ARM_ASM),1) | ifeq ($(ARM_ASM),1) | ||||||
|  | @ -141,10 +453,14 @@ asm_cdmemory = 1 | ||||||
| asm_mix = 1 | asm_mix = 1 | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| CFLAGS += -fPIC | CFLAGS += $(fpic) | ||||||
| LDLIBS += -lm | 
 | ||||||
|  | ifeq ($(findstring Haiku,$(shell uname -a)),) | ||||||
|  | 	LDLIBS += $(LIBM) | ||||||
|  | endif | ||||||
|  | 
 | ||||||
| SHARED ?= -shared | SHARED ?= -shared | ||||||
| LDFLAGS += $(SHARED) | LDFLAGS += $(SHARED) $(fpic) | ||||||
| 
 | 
 | ||||||
| PLATFORM = libretro | PLATFORM = libretro | ||||||
| NO_CONFIG_MAK = yes | NO_CONFIG_MAK = yes | ||||||
|  |  | ||||||
|  | @ -2,12 +2,13 @@ LOCAL_PATH := $(call my-dir) | ||||||
| 
 | 
 | ||||||
| include $(CLEAR_VARS) | include $(CLEAR_VARS) | ||||||
| 
 | 
 | ||||||
| ifeq ($(NEON_BUILD)$(TARGET_ARCH_ABI),1armeabi-v7a) | GIT_VERSION := " $(shell git rev-parse --short HEAD || echo unknown)" | ||||||
|   LOCAL_MODULE := retro_picodrive-neon | ifneq ($(GIT_VERSION)," unknown") | ||||||
| else | 	LOCAL_CFLAGS += -DGIT_VERSION=\"$(GIT_VERSION)\" | ||||||
|   LOCAL_MODULE := retro_picodrive |  | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
|  | LOCAL_MODULE := retro | ||||||
|  | 
 | ||||||
| R := ../ | R := ../ | ||||||
| FR := $(LOCAL_PATH)/$(R) | FR := $(LOCAL_PATH)/$(R) | ||||||
| 
 | 
 | ||||||
|  | @ -64,7 +65,7 @@ ARCH := $(TARGET_ARCH) | ||||||
| include $(R)platform/common/common.mak | include $(R)platform/common/common.mak | ||||||
| 
 | 
 | ||||||
| LOCAL_SRC_FILES += $(SRCS_COMMON) | LOCAL_SRC_FILES += $(SRCS_COMMON) | ||||||
| LOCAL_SRC_FILES += $(R)platform/libretro.c | LOCAL_SRC_FILES += $(R)platform/libretro/libretro.c | ||||||
| LOCAL_SRC_FILES += $(R)platform/common/mp3.c | LOCAL_SRC_FILES += $(R)platform/common/mp3.c | ||||||
| LOCAL_SRC_FILES += $(R)platform/common/mp3_dummy.c | LOCAL_SRC_FILES += $(R)platform/common/mp3_dummy.c | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,915 +0,0 @@ | ||||||
| /*
 |  | ||||||
|  * libretro core glue for PicoDrive |  | ||||||
|  * (C) notaz, 2013 |  | ||||||
|  * |  | ||||||
|  * This work is licensed under the terms of MAME license. |  | ||||||
|  * See COPYING file in the top-level directory. |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| #define _GNU_SOURCE 1 // mremap
 |  | ||||||
| #include <stdio.h> |  | ||||||
| #include <stdarg.h> |  | ||||||
| #include <string.h> |  | ||||||
| #ifndef _WIN32 |  | ||||||
| #include <sys/mman.h> |  | ||||||
| #else |  | ||||||
| #include <io.h> |  | ||||||
| #include <windows.h> |  | ||||||
| #include <sys/types.h> |  | ||||||
| #endif |  | ||||||
| #include <errno.h> |  | ||||||
| #ifdef __MACH__ |  | ||||||
| #include <libkern/OSCacheControl.h> |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #include <pico/pico_int.h> |  | ||||||
| #include <pico/state.h> |  | ||||||
| #include "common/input_pico.h" |  | ||||||
| #include "common/version.h" |  | ||||||
| #include "libretro.h" |  | ||||||
| 
 |  | ||||||
| static retro_video_refresh_t video_cb; |  | ||||||
| static retro_input_poll_t input_poll_cb; |  | ||||||
| static retro_input_state_t input_state_cb; |  | ||||||
| static retro_environment_t environ_cb; |  | ||||||
| static retro_audio_sample_batch_t audio_batch_cb; |  | ||||||
| 
 |  | ||||||
| static FILE *emu_log; |  | ||||||
| 
 |  | ||||||
| #define VOUT_MAX_WIDTH 320 |  | ||||||
| #define VOUT_MAX_HEIGHT 240 |  | ||||||
| static void *vout_buf; |  | ||||||
| static int vout_width, vout_height, vout_offset; |  | ||||||
| 
 |  | ||||||
| static short __attribute__((aligned(4))) sndBuffer[2*44100/50]; |  | ||||||
| 
 |  | ||||||
| static void snd_write(int len); |  | ||||||
| 
 |  | ||||||
| #ifdef _WIN32 |  | ||||||
| #define SLASH '\\' |  | ||||||
| #else |  | ||||||
| #define SLASH '/' |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| /* functions called by the core */ |  | ||||||
| 
 |  | ||||||
| void cache_flush_d_inval_i(void *start, void *end) |  | ||||||
| { |  | ||||||
| #ifdef __arm__ |  | ||||||
| #if defined(__BLACKBERRY_QNX__) |  | ||||||
| 	msync(start, end - start, MS_SYNC | MS_CACHE_ONLY | MS_INVALIDATE_ICACHE); |  | ||||||
| #elif defined(__MACH__) |  | ||||||
| 	size_t len = (char *)end - (char *)start; |  | ||||||
| 	sys_dcache_flush(start, len); |  | ||||||
| 	sys_icache_invalidate(start, len); |  | ||||||
| #else |  | ||||||
| 	__clear_cache(start, end); |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #ifdef _WIN32 |  | ||||||
| /* mmap() replacement for Windows
 |  | ||||||
|  * |  | ||||||
|  * Author: Mike Frysinger <vapier@gentoo.org> |  | ||||||
|  * Placed into the public domain |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| /* References:
 |  | ||||||
|  * CreateFileMapping: http://msdn.microsoft.com/en-us/library/aa366537(VS.85).aspx
 |  | ||||||
|  * CloseHandle:       http://msdn.microsoft.com/en-us/library/ms724211(VS.85).aspx
 |  | ||||||
|  * MapViewOfFile:     http://msdn.microsoft.com/en-us/library/aa366761(VS.85).aspx
 |  | ||||||
|  * UnmapViewOfFile:   http://msdn.microsoft.com/en-us/library/aa366882(VS.85).aspx
 |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| #define PROT_READ     0x1 |  | ||||||
| #define PROT_WRITE    0x2 |  | ||||||
| /* This flag is only available in WinXP+ */ |  | ||||||
| #ifdef FILE_MAP_EXECUTE |  | ||||||
| #define PROT_EXEC     0x4 |  | ||||||
| #else |  | ||||||
| #define PROT_EXEC        0x0 |  | ||||||
| #define FILE_MAP_EXECUTE 0 |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #define MAP_SHARED    0x01 |  | ||||||
| #define MAP_PRIVATE   0x02 |  | ||||||
| #define MAP_ANONYMOUS 0x20 |  | ||||||
| #define MAP_ANON      MAP_ANONYMOUS |  | ||||||
| #define MAP_FAILED    ((void *) -1) |  | ||||||
| 
 |  | ||||||
| #ifdef __USE_FILE_OFFSET64 |  | ||||||
| # define DWORD_HI(x) (x >> 32) |  | ||||||
| # define DWORD_LO(x) ((x) & 0xffffffff) |  | ||||||
| #else |  | ||||||
| # define DWORD_HI(x) (0) |  | ||||||
| # define DWORD_LO(x) (x) |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| static void *mmap(void *start, size_t length, int prot, int flags, int fd, off_t offset) |  | ||||||
| { |  | ||||||
| 	if (prot & ~(PROT_READ | PROT_WRITE | PROT_EXEC)) |  | ||||||
| 		return MAP_FAILED; |  | ||||||
| 	if (fd == -1) { |  | ||||||
| 		if (!(flags & MAP_ANON) || offset) |  | ||||||
| 			return MAP_FAILED; |  | ||||||
| 	} else if (flags & MAP_ANON) |  | ||||||
| 		return MAP_FAILED; |  | ||||||
| 
 |  | ||||||
| 	DWORD flProtect; |  | ||||||
| 	if (prot & PROT_WRITE) { |  | ||||||
| 		if (prot & PROT_EXEC) |  | ||||||
| 			flProtect = PAGE_EXECUTE_READWRITE; |  | ||||||
| 		else |  | ||||||
| 			flProtect = PAGE_READWRITE; |  | ||||||
| 	} else if (prot & PROT_EXEC) { |  | ||||||
| 		if (prot & PROT_READ) |  | ||||||
| 			flProtect = PAGE_EXECUTE_READ; |  | ||||||
| 		else if (prot & PROT_EXEC) |  | ||||||
| 			flProtect = PAGE_EXECUTE; |  | ||||||
| 	} else |  | ||||||
| 		flProtect = PAGE_READONLY; |  | ||||||
| 
 |  | ||||||
| 	off_t end = length + offset; |  | ||||||
| 	HANDLE mmap_fd, h; |  | ||||||
| 	if (fd == -1) |  | ||||||
| 		mmap_fd = INVALID_HANDLE_VALUE; |  | ||||||
| 	else |  | ||||||
| 		mmap_fd = (HANDLE)_get_osfhandle(fd); |  | ||||||
| 	h = CreateFileMapping(mmap_fd, NULL, flProtect, DWORD_HI(end), DWORD_LO(end), NULL); |  | ||||||
| 	if (h == NULL) |  | ||||||
| 		return MAP_FAILED; |  | ||||||
| 
 |  | ||||||
| 	DWORD dwDesiredAccess; |  | ||||||
| 	if (prot & PROT_WRITE) |  | ||||||
| 		dwDesiredAccess = FILE_MAP_WRITE; |  | ||||||
| 	else |  | ||||||
| 		dwDesiredAccess = FILE_MAP_READ; |  | ||||||
| 	if (prot & PROT_EXEC) |  | ||||||
| 		dwDesiredAccess |= FILE_MAP_EXECUTE; |  | ||||||
| 	if (flags & MAP_PRIVATE) |  | ||||||
| 		dwDesiredAccess |= FILE_MAP_COPY; |  | ||||||
| 	void *ret = MapViewOfFile(h, dwDesiredAccess, DWORD_HI(offset), DWORD_LO(offset), length); |  | ||||||
| 	if (ret == NULL) { |  | ||||||
| 		CloseHandle(h); |  | ||||||
| 		ret = MAP_FAILED; |  | ||||||
| 	} |  | ||||||
| 	return ret; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static void munmap(void *addr, size_t length) |  | ||||||
| { |  | ||||||
| 	UnmapViewOfFile(addr); |  | ||||||
| 	/* ruh-ro, we leaked handle from CreateFileMapping() ... */ |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #ifndef MAP_ANONYMOUS |  | ||||||
| #define MAP_ANONYMOUS MAP_ANON |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| void *plat_mmap(unsigned long addr, size_t size, int need_exec, int is_fixed) |  | ||||||
| { |  | ||||||
|    int flags = MAP_PRIVATE | MAP_ANONYMOUS; |  | ||||||
|    void *req, *ret; |  | ||||||
| 
 |  | ||||||
|    req = (void *)addr; |  | ||||||
|    ret = mmap(req, size, PROT_READ | PROT_WRITE, flags, -1, 0); |  | ||||||
|    if (ret == MAP_FAILED) { |  | ||||||
|       lprintf("mmap(%08lx, %zd) failed: %d\n", addr, size, errno); |  | ||||||
|       return NULL; |  | ||||||
|    } |  | ||||||
| 
 |  | ||||||
|    if (addr != 0 && ret != (void *)addr) { |  | ||||||
|       lprintf("warning: wanted to map @%08lx, got %p\n", |  | ||||||
|             addr, ret); |  | ||||||
| 
 |  | ||||||
|       if (is_fixed) { |  | ||||||
|          munmap(ret, size); |  | ||||||
|          return NULL; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
| 
 |  | ||||||
| 	return ret; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void *plat_mremap(void *ptr, size_t oldsize, size_t newsize) |  | ||||||
| { |  | ||||||
| #ifdef __linux__ |  | ||||||
| 	void *ret = mremap(ptr, oldsize, newsize, 0); |  | ||||||
| 	if (ret == MAP_FAILED) |  | ||||||
| 		return NULL; |  | ||||||
| 
 |  | ||||||
| 	return ret; |  | ||||||
| #else |  | ||||||
| 	void *tmp, *ret; |  | ||||||
| 	size_t preserve_size; |  | ||||||
| 	 |  | ||||||
| 	preserve_size = oldsize; |  | ||||||
| 	if (preserve_size > newsize) |  | ||||||
| 		preserve_size = newsize; |  | ||||||
| 	tmp = malloc(preserve_size); |  | ||||||
| 	if (tmp == NULL) |  | ||||||
| 		return NULL; |  | ||||||
| 	memcpy(tmp, ptr, preserve_size); |  | ||||||
| 
 |  | ||||||
| 	munmap(ptr, oldsize); |  | ||||||
| 	ret = mmap(ptr, newsize, PROT_READ | PROT_WRITE, |  | ||||||
| 		   MAP_PRIVATE | MAP_ANONYMOUS, -1, 0); |  | ||||||
| 	if (ret == MAP_FAILED) { |  | ||||||
| 		free(tmp); |  | ||||||
| 		return NULL; |  | ||||||
| 	} |  | ||||||
| 	memcpy(ret, tmp, preserve_size); |  | ||||||
| 	free(tmp); |  | ||||||
| 	return ret; |  | ||||||
| #endif |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void plat_munmap(void *ptr, size_t size) |  | ||||||
| { |  | ||||||
| 	if (ptr != NULL) |  | ||||||
| 		munmap(ptr, size); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| int plat_mem_set_exec(void *ptr, size_t size) |  | ||||||
| { |  | ||||||
| #ifdef _WIN32 |  | ||||||
|    int ret = VirtualProtect(ptr,size,PAGE_EXECUTE_READWRITE,0); |  | ||||||
|    if (ret == 0) |  | ||||||
|       lprintf("mprotect(%p, %zd) failed: %d\n", ptr, size, 0); |  | ||||||
| #else |  | ||||||
|    int ret = mprotect(ptr, size, PROT_READ | PROT_WRITE | PROT_EXEC); |  | ||||||
|    if (ret != 0) |  | ||||||
|       lprintf("mprotect(%p, %zd) failed: %d\n", ptr, size, errno); |  | ||||||
| #endif |  | ||||||
| 	return ret; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void emu_video_mode_change(int start_line, int line_count, int is_32cols) |  | ||||||
| { |  | ||||||
| 	memset(vout_buf, 0, 320 * 240 * 2); |  | ||||||
| 	vout_width = is_32cols ? 256 : 320; |  | ||||||
| 	PicoDrawSetOutBuf(vout_buf, vout_width * 2); |  | ||||||
| 
 |  | ||||||
| 	vout_height = line_count; |  | ||||||
| 	vout_offset = vout_width * start_line; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void emu_32x_startup(void) |  | ||||||
| { |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #ifndef ANDROID |  | ||||||
| 
 |  | ||||||
| void lprintf(const char *fmt, ...) |  | ||||||
| { |  | ||||||
| 	va_list list; |  | ||||||
| 
 |  | ||||||
| 	va_start(list, fmt); |  | ||||||
| 	fprintf(emu_log, "PicoDrive: "); |  | ||||||
| 	vfprintf(emu_log, fmt, list); |  | ||||||
| 	va_end(list); |  | ||||||
| 	fflush(emu_log); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #else |  | ||||||
| 
 |  | ||||||
| #include <android/log.h> |  | ||||||
| 
 |  | ||||||
| void lprintf(const char *fmt, ...) |  | ||||||
| { |  | ||||||
| 	va_list list; |  | ||||||
| 
 |  | ||||||
| 	va_start(list, fmt); |  | ||||||
| 	__android_log_vprint(ANDROID_LOG_INFO, "PicoDrive", fmt, list); |  | ||||||
| 	va_end(list); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| /* libretro */ |  | ||||||
| void retro_set_environment(retro_environment_t cb) |  | ||||||
| { |  | ||||||
| 	static const struct retro_variable vars[] = { |  | ||||||
| 		//{ "region", "Region; Auto|NTSC|PAL" },
 |  | ||||||
| 		{ "picodrive_input1", "Input device 1; 3 button pad|6 button pad|None" }, |  | ||||||
| 		{ "picodrive_input2", "Input device 2; 3 button pad|6 button pad|None" }, |  | ||||||
| 		{ "picodrive_sprlim", "No sprite limit; disabled|enabled" }, |  | ||||||
| 		{ "picodrive_ramcart", "MegaCD RAM cart; disabled|enabled" }, |  | ||||||
| #ifdef DRC_SH2 |  | ||||||
| 		{ "picodrive_drc", "Dynamic recompilers; enabled|disabled" }, |  | ||||||
| #endif |  | ||||||
| 		{ NULL, NULL }, |  | ||||||
| 	}; |  | ||||||
| 
 |  | ||||||
| 	environ_cb = cb; |  | ||||||
| 
 |  | ||||||
| 	cb(RETRO_ENVIRONMENT_SET_VARIABLES, (void *)vars); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void retro_set_video_refresh(retro_video_refresh_t cb) { video_cb = cb; } |  | ||||||
| void retro_set_audio_sample(retro_audio_sample_t cb) { (void)cb; } |  | ||||||
| void retro_set_audio_sample_batch(retro_audio_sample_batch_t cb) { audio_batch_cb = cb; } |  | ||||||
| void retro_set_input_poll(retro_input_poll_t cb) { input_poll_cb = cb; } |  | ||||||
| void retro_set_input_state(retro_input_state_t cb) { input_state_cb = cb; } |  | ||||||
| 
 |  | ||||||
| unsigned retro_api_version(void) |  | ||||||
| { |  | ||||||
| 	return RETRO_API_VERSION; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void retro_set_controller_port_device(unsigned port, unsigned device) |  | ||||||
| { |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void retro_get_system_info(struct retro_system_info *info) |  | ||||||
| { |  | ||||||
| 	memset(info, 0, sizeof(*info)); |  | ||||||
| 	info->library_name = "PicoDrive"; |  | ||||||
| 	info->library_version = VERSION; |  | ||||||
| 	info->valid_extensions = "bin|gen|smd|md|32x|cue|iso|sms"; |  | ||||||
| 	info->need_fullpath = true; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void retro_get_system_av_info(struct retro_system_av_info *info) |  | ||||||
| { |  | ||||||
| 	memset(info, 0, sizeof(*info)); |  | ||||||
| 	info->timing.fps            = Pico.m.pal ? 50 : 60; |  | ||||||
| 	info->timing.sample_rate    = 44100; |  | ||||||
| 	info->geometry.base_width   = 320; |  | ||||||
| 	info->geometry.base_height  = vout_height; |  | ||||||
| 	info->geometry.max_width    = VOUT_MAX_WIDTH; |  | ||||||
| 	info->geometry.max_height   = VOUT_MAX_HEIGHT; |  | ||||||
| 	info->geometry.aspect_ratio = 0.0f; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* savestates */ |  | ||||||
| struct savestate_state { |  | ||||||
| 	const char *load_buf; |  | ||||||
| 	char *save_buf; |  | ||||||
| 	size_t size; |  | ||||||
| 	size_t pos; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| size_t state_read(void *p, size_t size, size_t nmemb, void *file) |  | ||||||
| { |  | ||||||
| 	struct savestate_state *state = file; |  | ||||||
| 	size_t bsize = size * nmemb; |  | ||||||
| 
 |  | ||||||
| 	if (state->pos + bsize > state->size) { |  | ||||||
| 		lprintf("savestate error: %u/%u\n", |  | ||||||
| 			state->pos + bsize, state->size); |  | ||||||
| 		bsize = state->size - state->pos; |  | ||||||
| 		if ((int)bsize <= 0) |  | ||||||
| 			return 0; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	memcpy(p, state->load_buf + state->pos, bsize); |  | ||||||
| 	state->pos += bsize; |  | ||||||
| 	return bsize; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| size_t state_write(void *p, size_t size, size_t nmemb, void *file) |  | ||||||
| { |  | ||||||
| 	struct savestate_state *state = file; |  | ||||||
| 	size_t bsize = size * nmemb; |  | ||||||
| 
 |  | ||||||
| 	if (state->pos + bsize > state->size) { |  | ||||||
| 		lprintf("savestate error: %u/%u\n", |  | ||||||
| 			state->pos + bsize, state->size); |  | ||||||
| 		bsize = state->size - state->pos; |  | ||||||
| 		if ((int)bsize <= 0) |  | ||||||
| 			return 0; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	memcpy(state->save_buf + state->pos, p, bsize); |  | ||||||
| 	state->pos += bsize; |  | ||||||
| 	return bsize; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| size_t state_skip(void *p, size_t size, size_t nmemb, void *file) |  | ||||||
| { |  | ||||||
| 	struct savestate_state *state = file; |  | ||||||
| 	size_t bsize = size * nmemb; |  | ||||||
| 
 |  | ||||||
| 	state->pos += bsize; |  | ||||||
| 	return bsize; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| size_t state_eof(void *file) |  | ||||||
| { |  | ||||||
| 	struct savestate_state *state = file; |  | ||||||
| 
 |  | ||||||
| 	return state->pos >= state->size; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| int state_fseek(void *file, long offset, int whence) |  | ||||||
| { |  | ||||||
| 	struct savestate_state *state = file; |  | ||||||
| 
 |  | ||||||
| 	switch (whence) { |  | ||||||
| 	case SEEK_SET: |  | ||||||
| 		state->pos = offset; |  | ||||||
| 		break; |  | ||||||
| 	case SEEK_CUR: |  | ||||||
| 		state->pos += offset; |  | ||||||
| 		break; |  | ||||||
| 	case SEEK_END: |  | ||||||
| 		state->pos = state->size + offset; |  | ||||||
| 		break; |  | ||||||
| 	} |  | ||||||
| 	return (int)state->pos; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* savestate sizes vary wildly depending if cd/32x or
 |  | ||||||
|  * carthw is active, so run the whole thing to get size */ |  | ||||||
| size_t retro_serialize_size(void)  |  | ||||||
| {  |  | ||||||
| 	struct savestate_state state = { 0, }; |  | ||||||
| 	int ret; |  | ||||||
| 
 |  | ||||||
| 	ret = PicoStateFP(&state, 1, NULL, state_skip, NULL, state_fseek); |  | ||||||
| 	if (ret != 0) |  | ||||||
| 		return 0; |  | ||||||
| 
 |  | ||||||
| 	return state.pos; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| bool retro_serialize(void *data, size_t size) |  | ||||||
| {  |  | ||||||
| 	struct savestate_state state = { 0, }; |  | ||||||
| 	int ret; |  | ||||||
| 
 |  | ||||||
| 	state.save_buf = data; |  | ||||||
| 	state.size = size; |  | ||||||
| 	state.pos = 0; |  | ||||||
| 
 |  | ||||||
| 	ret = PicoStateFP(&state, 1, NULL, state_write, |  | ||||||
| 		NULL, state_fseek); |  | ||||||
| 	return ret == 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| bool retro_unserialize(const void *data, size_t size) |  | ||||||
| { |  | ||||||
| 	struct savestate_state state = { 0, }; |  | ||||||
| 	int ret; |  | ||||||
| 
 |  | ||||||
| 	state.load_buf = data; |  | ||||||
| 	state.size = size; |  | ||||||
| 	state.pos = 0; |  | ||||||
| 
 |  | ||||||
| 	ret = PicoStateFP(&state, 0, state_read, NULL, |  | ||||||
| 		state_eof, state_fseek); |  | ||||||
| 	return ret == 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* cheats - TODO */ |  | ||||||
| void retro_cheat_reset(void) |  | ||||||
| { |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void retro_cheat_set(unsigned index, bool enabled, const char *code) |  | ||||||
| { |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* multidisk support */ |  | ||||||
| static bool disk_ejected; |  | ||||||
| static unsigned int disk_current_index; |  | ||||||
| static unsigned int disk_count; |  | ||||||
| static struct disks_state { |  | ||||||
| 	char *fname; |  | ||||||
| } disks[8]; |  | ||||||
| 
 |  | ||||||
| static bool disk_set_eject_state(bool ejected) |  | ||||||
| { |  | ||||||
| 	// TODO?
 |  | ||||||
| 	disk_ejected = ejected; |  | ||||||
| 	return true; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static bool disk_get_eject_state(void) |  | ||||||
| { |  | ||||||
| 	return disk_ejected; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static unsigned int disk_get_image_index(void) |  | ||||||
| { |  | ||||||
| 	return disk_current_index; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static bool disk_set_image_index(unsigned int index) |  | ||||||
| { |  | ||||||
| 	enum cd_img_type cd_type; |  | ||||||
| 	int ret; |  | ||||||
| 
 |  | ||||||
| 	if (index >= sizeof(disks) / sizeof(disks[0])) |  | ||||||
| 		return false; |  | ||||||
| 
 |  | ||||||
| 	if (disks[index].fname == NULL) { |  | ||||||
| 		lprintf("missing disk #%u\n", index); |  | ||||||
| 
 |  | ||||||
| 		// RetroArch specifies "no disk" with index == count,
 |  | ||||||
| 		// so don't fail here..
 |  | ||||||
| 		disk_current_index = index; |  | ||||||
| 		return true; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	lprintf("switching to disk %u: \"%s\"\n", index, |  | ||||||
| 		disks[index].fname); |  | ||||||
| 
 |  | ||||||
| 	ret = -1; |  | ||||||
| 	cd_type = PicoCdCheck(disks[index].fname, NULL); |  | ||||||
| 	if (cd_type != CIT_NOT_CD) |  | ||||||
| 		ret = cdd_load(disks[index].fname, cd_type); |  | ||||||
| 	if (ret != 0) { |  | ||||||
| 		lprintf("Load failed, invalid CD image?\n"); |  | ||||||
| 		return 0; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	disk_current_index = index; |  | ||||||
| 	return true; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static unsigned int disk_get_num_images(void) |  | ||||||
| { |  | ||||||
| 	return disk_count; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static bool disk_replace_image_index(unsigned index, |  | ||||||
| 	const struct retro_game_info *info) |  | ||||||
| { |  | ||||||
| 	bool ret = true; |  | ||||||
| 
 |  | ||||||
| 	if (index >= sizeof(disks) / sizeof(disks[0])) |  | ||||||
| 		return false; |  | ||||||
| 
 |  | ||||||
| 	if (disks[index].fname != NULL) |  | ||||||
| 		free(disks[index].fname); |  | ||||||
| 	disks[index].fname = NULL; |  | ||||||
| 
 |  | ||||||
| 	if (info != NULL) { |  | ||||||
| 		disks[index].fname = strdup(info->path); |  | ||||||
| 		if (index == disk_current_index) |  | ||||||
| 			ret = disk_set_image_index(index); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return ret; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static bool disk_add_image_index(void) |  | ||||||
| { |  | ||||||
| 	if (disk_count >= sizeof(disks) / sizeof(disks[0])) |  | ||||||
| 		return false; |  | ||||||
| 
 |  | ||||||
| 	disk_count++; |  | ||||||
| 	return true; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static struct retro_disk_control_callback disk_control = { |  | ||||||
| 	.set_eject_state = disk_set_eject_state, |  | ||||||
| 	.get_eject_state = disk_get_eject_state, |  | ||||||
| 	.get_image_index = disk_get_image_index, |  | ||||||
| 	.set_image_index = disk_set_image_index, |  | ||||||
| 	.get_num_images = disk_get_num_images, |  | ||||||
| 	.replace_image_index = disk_replace_image_index, |  | ||||||
| 	.add_image_index = disk_add_image_index, |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| static void disk_tray_open(void) |  | ||||||
| { |  | ||||||
| 	lprintf("cd tray open\n"); |  | ||||||
| 	disk_ejected = 1; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static void disk_tray_close(void) |  | ||||||
| { |  | ||||||
| 	lprintf("cd tray close\n"); |  | ||||||
| 	disk_ejected = 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| static const char * const biosfiles_us[] = { |  | ||||||
| 	"us_scd2_9306", "SegaCDBIOS9303", "us_scd1_9210", "bios_CD_U" |  | ||||||
| }; |  | ||||||
| static const char * const biosfiles_eu[] = { |  | ||||||
| 	"eu_mcd2_9306", "eu_mcd2_9303", "eu_mcd1_9210", "bios_CD_E" |  | ||||||
| }; |  | ||||||
| static const char * const biosfiles_jp[] = { |  | ||||||
| 	"jp_mcd2_921222", "jp_mcd1_9112", "jp_mcd1_9111", "bios_CD_J" |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| static void make_system_path(char *buf, size_t buf_size, |  | ||||||
| 	const char *name, const char *ext) |  | ||||||
| { |  | ||||||
| 	const char *dir = NULL; |  | ||||||
| 
 |  | ||||||
| 	if (environ_cb(RETRO_ENVIRONMENT_GET_SYSTEM_DIRECTORY, &dir) && dir) { |  | ||||||
| 		snprintf(buf, buf_size, "%s%c%s%s", dir, SLASH, name, ext); |  | ||||||
| 	} |  | ||||||
| 	else { |  | ||||||
| 		snprintf(buf, buf_size, "%s%s", name, ext); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static const char *find_bios(int *region, const char *cd_fname) |  | ||||||
| { |  | ||||||
| 	const char * const *files; |  | ||||||
| 	static char path[256]; |  | ||||||
| 	int i, count; |  | ||||||
| 	FILE *f = NULL; |  | ||||||
| 
 |  | ||||||
| 	if (*region == 4) { // US
 |  | ||||||
| 		files = biosfiles_us; |  | ||||||
| 		count = sizeof(biosfiles_us) / sizeof(char *); |  | ||||||
| 	} else if (*region == 8) { // EU
 |  | ||||||
| 		files = biosfiles_eu; |  | ||||||
| 		count = sizeof(biosfiles_eu) / sizeof(char *); |  | ||||||
| 	} else if (*region == 1 || *region == 2) { |  | ||||||
| 		files = biosfiles_jp; |  | ||||||
| 		count = sizeof(biosfiles_jp) / sizeof(char *); |  | ||||||
| 	} else { |  | ||||||
| 		return NULL; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	for (i = 0; i < count; i++) |  | ||||||
| 	{ |  | ||||||
| 		make_system_path(path, sizeof(path), files[i], ".bin"); |  | ||||||
| 		f = fopen(path, "rb"); |  | ||||||
| 		if (f != NULL) |  | ||||||
| 			break; |  | ||||||
| 
 |  | ||||||
| 		make_system_path(path, sizeof(path), files[i], ".zip"); |  | ||||||
| 		f = fopen(path, "rb"); |  | ||||||
| 		if (f != NULL) |  | ||||||
| 			break; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if (f != NULL) { |  | ||||||
| 		lprintf("using bios: %s\n", path); |  | ||||||
| 		fclose(f); |  | ||||||
| 		return path; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return NULL; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| bool retro_load_game(const struct retro_game_info *info) |  | ||||||
| { |  | ||||||
| 	enum media_type_e media_type; |  | ||||||
| 	static char carthw_path[256]; |  | ||||||
| 	size_t i; |  | ||||||
| 
 |  | ||||||
| 	enum retro_pixel_format fmt = RETRO_PIXEL_FORMAT_RGB565; |  | ||||||
| 	if (!environ_cb(RETRO_ENVIRONMENT_SET_PIXEL_FORMAT, &fmt)) { |  | ||||||
| 		lprintf("RGB565 support required, sorry\n"); |  | ||||||
| 		return false; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if (info == NULL || info->path == NULL) { |  | ||||||
| 		lprintf("info->path required\n"); |  | ||||||
| 		return false; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	for (i = 0; i < sizeof(disks) / sizeof(disks[0]); i++) { |  | ||||||
| 		if (disks[i].fname != NULL) { |  | ||||||
| 			free(disks[i].fname); |  | ||||||
| 			disks[i].fname = NULL; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	disk_current_index = 0; |  | ||||||
| 	disk_count = 1; |  | ||||||
| 	disks[0].fname = strdup(info->path); |  | ||||||
| 
 |  | ||||||
| 	make_system_path(carthw_path, sizeof(carthw_path), "carthw", ".cfg"); |  | ||||||
| 
 |  | ||||||
| 	media_type = PicoLoadMedia(info->path, carthw_path, |  | ||||||
| 			find_bios, NULL); |  | ||||||
| 
 |  | ||||||
| 	switch (media_type) { |  | ||||||
| 	case PM_BAD_DETECT: |  | ||||||
| 		lprintf("Failed to detect ROM/CD image type.\n"); |  | ||||||
| 		return false; |  | ||||||
| 	case PM_BAD_CD: |  | ||||||
| 		lprintf("Invalid CD image\n"); |  | ||||||
| 		return false; |  | ||||||
| 	case PM_BAD_CD_NO_BIOS: |  | ||||||
| 		lprintf("Missing BIOS\n"); |  | ||||||
| 		return false; |  | ||||||
| 	case PM_ERROR: |  | ||||||
| 		lprintf("Load error\n"); |  | ||||||
| 		return false; |  | ||||||
| 	default: |  | ||||||
| 		break; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	PicoLoopPrepare(); |  | ||||||
| 
 |  | ||||||
| 	PicoWriteSound = snd_write; |  | ||||||
| 	memset(sndBuffer, 0, sizeof(sndBuffer)); |  | ||||||
| 	PsndOut = sndBuffer; |  | ||||||
| 	PsndRerate(0); |  | ||||||
| 
 |  | ||||||
| 	return true; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| bool retro_load_game_special(unsigned game_type, const struct retro_game_info *info, size_t num_info) |  | ||||||
| { |  | ||||||
| 	return false; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void retro_unload_game(void)  |  | ||||||
| { |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| unsigned retro_get_region(void) |  | ||||||
| { |  | ||||||
| 	return Pico.m.pal ? RETRO_REGION_PAL : RETRO_REGION_NTSC; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void *retro_get_memory_data(unsigned id) |  | ||||||
| { |  | ||||||
| 	if (id != RETRO_MEMORY_SAVE_RAM) |  | ||||||
| 		return NULL; |  | ||||||
| 
 |  | ||||||
| 	if (PicoAHW & PAHW_MCD) |  | ||||||
| 		return Pico_mcd->bram; |  | ||||||
| 	else |  | ||||||
| 		return SRam.data; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| size_t retro_get_memory_size(unsigned id) |  | ||||||
| { |  | ||||||
| 	unsigned int i; |  | ||||||
| 	int sum; |  | ||||||
| 
 |  | ||||||
| 	if (id != RETRO_MEMORY_SAVE_RAM) |  | ||||||
| 		return 0; |  | ||||||
| 
 |  | ||||||
| 	if (PicoAHW & PAHW_MCD) |  | ||||||
| 		// bram
 |  | ||||||
| 		return 0x2000; |  | ||||||
| 
 |  | ||||||
| 	if (Pico.m.frame_count == 0) |  | ||||||
| 		return SRam.size; |  | ||||||
| 
 |  | ||||||
| 	// if game doesn't write to sram, don't report it to
 |  | ||||||
| 	// libretro so that RA doesn't write out zeroed .srm
 |  | ||||||
| 	for (i = 0, sum = 0; i < SRam.size; i++) |  | ||||||
| 		sum |= SRam.data[i]; |  | ||||||
| 
 |  | ||||||
| 	return (sum != 0) ? SRam.size : 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void retro_reset(void) |  | ||||||
| { |  | ||||||
| 	PicoReset(); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static const unsigned short retro_pico_map[] = { |  | ||||||
| 	[RETRO_DEVICE_ID_JOYPAD_B]	= 1 << GBTN_B, |  | ||||||
| 	[RETRO_DEVICE_ID_JOYPAD_Y]	= 1 << GBTN_A, |  | ||||||
| 	[RETRO_DEVICE_ID_JOYPAD_SELECT]	= 1 << GBTN_MODE, |  | ||||||
| 	[RETRO_DEVICE_ID_JOYPAD_START]	= 1 << GBTN_START, |  | ||||||
| 	[RETRO_DEVICE_ID_JOYPAD_UP]	= 1 << GBTN_UP, |  | ||||||
| 	[RETRO_DEVICE_ID_JOYPAD_DOWN]	= 1 << GBTN_DOWN, |  | ||||||
| 	[RETRO_DEVICE_ID_JOYPAD_LEFT]	= 1 << GBTN_LEFT, |  | ||||||
| 	[RETRO_DEVICE_ID_JOYPAD_RIGHT]	= 1 << GBTN_RIGHT, |  | ||||||
| 	[RETRO_DEVICE_ID_JOYPAD_A]	= 1 << GBTN_C, |  | ||||||
| 	[RETRO_DEVICE_ID_JOYPAD_X]	= 1 << GBTN_Y, |  | ||||||
| 	[RETRO_DEVICE_ID_JOYPAD_L]	= 1 << GBTN_X, |  | ||||||
| 	[RETRO_DEVICE_ID_JOYPAD_R]	= 1 << GBTN_Z, |  | ||||||
| }; |  | ||||||
| #define RETRO_PICO_MAP_LEN (sizeof(retro_pico_map) / sizeof(retro_pico_map[0])) |  | ||||||
| 
 |  | ||||||
| static void snd_write(int len) |  | ||||||
| { |  | ||||||
| 	audio_batch_cb(PsndOut, len / 4); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static enum input_device input_name_to_val(const char *name) |  | ||||||
| { |  | ||||||
| 	if (strcmp(name, "3 button pad") == 0) |  | ||||||
| 		return PICO_INPUT_PAD_3BTN; |  | ||||||
| 	if (strcmp(name, "6 button pad") == 0) |  | ||||||
| 		return PICO_INPUT_PAD_6BTN; |  | ||||||
| 	if (strcmp(name, "None") == 0) |  | ||||||
| 		return PICO_INPUT_NOTHING; |  | ||||||
| 
 |  | ||||||
| 	lprintf("invalid picodrive_input: '%s'\n", name); |  | ||||||
| 	return PICO_INPUT_PAD_3BTN; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static void update_variables(void) |  | ||||||
| { |  | ||||||
| 	struct retro_variable var; |  | ||||||
| 
 |  | ||||||
| 	var.value = NULL; |  | ||||||
| 	var.key = "picodrive_input1"; |  | ||||||
| 	if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value) |  | ||||||
| 		PicoSetInputDevice(0, input_name_to_val(var.value)); |  | ||||||
| 
 |  | ||||||
| 	var.value = NULL; |  | ||||||
| 	var.key = "picodrive_input2"; |  | ||||||
| 	if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value) |  | ||||||
| 		PicoSetInputDevice(1, input_name_to_val(var.value)); |  | ||||||
| 
 |  | ||||||
| 	var.value = NULL; |  | ||||||
| 	var.key = "picodrive_sprlim"; |  | ||||||
| 	if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value) { |  | ||||||
| 		if (strcmp(var.value, "enabled") == 0) |  | ||||||
| 			PicoOpt |= POPT_DIS_SPRITE_LIM; |  | ||||||
| 		else |  | ||||||
| 			PicoOpt &= ~POPT_DIS_SPRITE_LIM; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	var.value = NULL; |  | ||||||
| 	var.key = "picodrive_ramcart"; |  | ||||||
| 	if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value) { |  | ||||||
| 		if (strcmp(var.value, "enabled") == 0) |  | ||||||
| 			PicoOpt |= POPT_EN_MCD_RAMCART; |  | ||||||
| 		else |  | ||||||
| 			PicoOpt &= ~POPT_EN_MCD_RAMCART; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| #ifdef DRC_SH2 |  | ||||||
| 	var.value = NULL; |  | ||||||
| 	var.key = "picodrive_drc"; |  | ||||||
| 	if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value) { |  | ||||||
| 		if (strcmp(var.value, "enabled") == 0) |  | ||||||
| 			PicoOpt |= POPT_EN_DRC; |  | ||||||
| 		else |  | ||||||
| 			PicoOpt &= ~POPT_EN_DRC; |  | ||||||
| 	} |  | ||||||
| #endif |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void retro_run(void)  |  | ||||||
| { |  | ||||||
| 	bool updated = false; |  | ||||||
| 	int pad, i; |  | ||||||
| 
 |  | ||||||
| 	if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE_UPDATE, &updated) && updated) |  | ||||||
| 		update_variables(); |  | ||||||
| 
 |  | ||||||
| 	input_poll_cb(); |  | ||||||
| 
 |  | ||||||
| 	PicoPad[0] = PicoPad[1] = 0; |  | ||||||
| 	for (pad = 0; pad < 2; pad++) |  | ||||||
| 		for (i = 0; i < RETRO_PICO_MAP_LEN; i++) |  | ||||||
| 			if (input_state_cb(pad, RETRO_DEVICE_JOYPAD, 0, i)) |  | ||||||
| 				PicoPad[pad] |= retro_pico_map[i]; |  | ||||||
| 
 |  | ||||||
| 	PicoFrame(); |  | ||||||
| 
 |  | ||||||
| 	video_cb((short *)vout_buf + vout_offset, |  | ||||||
| 		vout_width, vout_height, vout_width * 2); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void retro_init(void) |  | ||||||
| { |  | ||||||
| 	int level; |  | ||||||
| 
 |  | ||||||
| #ifdef IOS |  | ||||||
| 	emu_log = fopen("/User/Documents/PicoDrive.log", "w"); |  | ||||||
| 	if (emu_log == NULL) |  | ||||||
| 		emu_log = fopen("PicoDrive.log", "w"); |  | ||||||
| 	if (emu_log == NULL) |  | ||||||
| #endif |  | ||||||
| 	emu_log = stdout; |  | ||||||
| 
 |  | ||||||
| 	level = 0; |  | ||||||
| 	environ_cb(RETRO_ENVIRONMENT_SET_PERFORMANCE_LEVEL, &level); |  | ||||||
| 
 |  | ||||||
| 	environ_cb(RETRO_ENVIRONMENT_SET_DISK_CONTROL_INTERFACE, &disk_control); |  | ||||||
| 
 |  | ||||||
| 	PicoOpt = POPT_EN_STEREO|POPT_EN_FM|POPT_EN_PSG|POPT_EN_Z80 |  | ||||||
| 		| POPT_EN_MCD_PCM|POPT_EN_MCD_CDDA|POPT_EN_MCD_GFX |  | ||||||
| 		| POPT_EN_32X|POPT_EN_PWM |  | ||||||
| 		| POPT_ACC_SPRITES|POPT_DIS_32C_BORDER; |  | ||||||
| #ifdef __arm__ |  | ||||||
| 	PicoOpt |= POPT_EN_DRC; |  | ||||||
| #endif |  | ||||||
| 	PsndRate = 44100; |  | ||||||
| 	PicoAutoRgnOrder = 0x184; // US, EU, JP
 |  | ||||||
| 
 |  | ||||||
| 	vout_width = 320; |  | ||||||
| 	vout_height = 240; |  | ||||||
| 	vout_buf = malloc(VOUT_MAX_WIDTH * VOUT_MAX_HEIGHT * 2); |  | ||||||
| 
 |  | ||||||
| 	PicoInit(); |  | ||||||
| 	PicoDrawSetOutFormat(PDF_RGB555, 0); |  | ||||||
| 	PicoDrawSetOutBuf(vout_buf, vout_width * 2); |  | ||||||
| 
 |  | ||||||
| 	//PicoMessage = plat_status_msg_busy_next;
 |  | ||||||
| 	PicoMCDopenTray = disk_tray_open; |  | ||||||
| 	PicoMCDcloseTray = disk_tray_close; |  | ||||||
| 
 |  | ||||||
| 	update_variables(); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void retro_deinit(void) |  | ||||||
| { |  | ||||||
| 	PicoExit(); |  | ||||||
| } |  | ||||||
|  | @ -1,787 +0,0 @@ | ||||||
| /* Copyright (C) 2010-2013 The RetroArch team
 |  | ||||||
|  * |  | ||||||
|  * --------------------------------------------------------------------------------------- |  | ||||||
|  * The following license statement only applies to this libretro API header (libretro.h). |  | ||||||
|  * --------------------------------------------------------------------------------------- |  | ||||||
|  * |  | ||||||
|  * Permission is hereby granted, free of charge, |  | ||||||
|  * to any person obtaining a copy of this software and associated documentation files (the "Software"), |  | ||||||
|  * to deal in the Software without restriction, including without limitation the rights to |  | ||||||
|  * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, |  | ||||||
|  * and to permit persons to whom the Software is furnished to do so, subject to the following conditions: |  | ||||||
|  * |  | ||||||
|  * The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. |  | ||||||
|  * |  | ||||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, |  | ||||||
|  * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |  | ||||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. |  | ||||||
|  * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, |  | ||||||
|  * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |  | ||||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| #ifndef LIBRETRO_H__ |  | ||||||
| #define LIBRETRO_H__ |  | ||||||
| 
 |  | ||||||
| #include <stdint.h> |  | ||||||
| #include <stddef.h> |  | ||||||
| #include <limits.h> |  | ||||||
| 
 |  | ||||||
| // Hack applied for MSVC when compiling in C89 mode as it isn't C99 compliant.
 |  | ||||||
| #ifdef __cplusplus |  | ||||||
| extern "C" { |  | ||||||
| #else |  | ||||||
| #if defined(_MSC_VER) && !defined(SN_TARGET_PS3) && !defined(__cplusplus) |  | ||||||
| #define bool unsigned char |  | ||||||
| #define true 1 |  | ||||||
| #define false 0 |  | ||||||
| #else |  | ||||||
| #include <stdbool.h> |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| // Used for checking API/ABI mismatches that can break libretro implementations.
 |  | ||||||
| // It is not incremented for compatible changes to the API.
 |  | ||||||
| #define RETRO_API_VERSION         1 |  | ||||||
| 
 |  | ||||||
| // Libretro's fundamental device abstractions.
 |  | ||||||
| #define RETRO_DEVICE_MASK         0xff |  | ||||||
| #define RETRO_DEVICE_NONE         0 |  | ||||||
| 
 |  | ||||||
| // The JOYPAD is called RetroPad. It is essentially a Super Nintendo controller,
 |  | ||||||
| // but with additional L2/R2/L3/R3 buttons, similar to a PS1 DualShock.
 |  | ||||||
| #define RETRO_DEVICE_JOYPAD       1 |  | ||||||
| 
 |  | ||||||
| // The mouse is a simple mouse, similar to Super Nintendo's mouse.
 |  | ||||||
| // X and Y coordinates are reported relatively to last poll (poll callback).
 |  | ||||||
| // It is up to the libretro implementation to keep track of where the mouse pointer is supposed to be on the screen.
 |  | ||||||
| // The frontend must make sure not to interfere with its own hardware mouse pointer.
 |  | ||||||
| #define RETRO_DEVICE_MOUSE        2 |  | ||||||
| 
 |  | ||||||
| // KEYBOARD device lets one poll for raw key pressed.
 |  | ||||||
| // It is poll based, so input callback will return with the current pressed state.
 |  | ||||||
| #define RETRO_DEVICE_KEYBOARD     3 |  | ||||||
| 
 |  | ||||||
| // Lightgun X/Y coordinates are reported relatively to last poll, similar to mouse.
 |  | ||||||
| #define RETRO_DEVICE_LIGHTGUN     4 |  | ||||||
| 
 |  | ||||||
| // The ANALOG device is an extension to JOYPAD (RetroPad).
 |  | ||||||
| // Similar to DualShock it adds two analog sticks.
 |  | ||||||
| // This is treated as a separate device type as it returns values in the full analog range
 |  | ||||||
| // of [-0x8000, 0x7fff]. Positive X axis is right. Positive Y axis is down.
 |  | ||||||
| // Only use ANALOG type when polling for analog values of the axes.
 |  | ||||||
| #define RETRO_DEVICE_ANALOG       5 |  | ||||||
| 
 |  | ||||||
| // Abstracts the concept of a pointing mechanism, e.g. touch.
 |  | ||||||
| // This allows libretro to query in absolute coordinates where on the screen a mouse (or something similar) is being placed.
 |  | ||||||
| // For a touch centric device, coordinates reported are the coordinates of the press.
 |  | ||||||
| //
 |  | ||||||
| // Coordinates in X and Y are reported as:
 |  | ||||||
| // [-0x7fff, 0x7fff]: -0x7fff corresponds to the far left/top of the screen,
 |  | ||||||
| // and 0x7fff corresponds to the far right/bottom of the screen.
 |  | ||||||
| // The "screen" is here defined as area that is passed to the frontend and later displayed on the monitor.
 |  | ||||||
| // The frontend is free to scale/resize this screen as it sees fit, however,
 |  | ||||||
| // (X, Y) = (-0x7fff, -0x7fff) will correspond to the top-left pixel of the game image, etc.
 |  | ||||||
| //
 |  | ||||||
| // To check if the pointer coordinates are valid (e.g. a touch display actually being touched),
 |  | ||||||
| // PRESSED returns 1 or 0.
 |  | ||||||
| // If using a mouse, PRESSED will usually correspond to the left mouse button.
 |  | ||||||
| // PRESSED will only return 1 if the pointer is inside the game screen.
 |  | ||||||
| //
 |  | ||||||
| // For multi-touch, the index variable can be used to successively query more presses.
 |  | ||||||
| // If index = 0 returns true for _PRESSED, coordinates can be extracted
 |  | ||||||
| // with _X, _Y for index = 0. One can then query _PRESSED, _X, _Y with index = 1, and so on.
 |  | ||||||
| // Eventually _PRESSED will return false for an index. No further presses are registered at this point.
 |  | ||||||
| #define RETRO_DEVICE_POINTER      6 |  | ||||||
| 
 |  | ||||||
| // These device types are specializations of the base types above.
 |  | ||||||
| // They should only be used in retro_set_controller_type() to inform libretro implementations
 |  | ||||||
| // about use of a very specific device type.
 |  | ||||||
| //
 |  | ||||||
| // In input state callback, however, only the base type should be used in the 'device' field.
 |  | ||||||
| #define RETRO_DEVICE_JOYPAD_MULTITAP        ((1 << 8) | RETRO_DEVICE_JOYPAD) |  | ||||||
| #define RETRO_DEVICE_LIGHTGUN_SUPER_SCOPE   ((1 << 8) | RETRO_DEVICE_LIGHTGUN) |  | ||||||
| #define RETRO_DEVICE_LIGHTGUN_JUSTIFIER     ((2 << 8) | RETRO_DEVICE_LIGHTGUN) |  | ||||||
| #define RETRO_DEVICE_LIGHTGUN_JUSTIFIERS    ((3 << 8) | RETRO_DEVICE_LIGHTGUN) |  | ||||||
| 
 |  | ||||||
| // Buttons for the RetroPad (JOYPAD).
 |  | ||||||
| // The placement of these is equivalent to placements on the Super Nintendo controller.
 |  | ||||||
| // L2/R2/L3/R3 buttons correspond to the PS1 DualShock.
 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_B        0 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_Y        1 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_SELECT   2 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_START    3 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_UP       4 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_DOWN     5 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_LEFT     6 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_RIGHT    7 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_A        8 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_X        9 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_L       10 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_R       11 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_L2      12 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_R2      13 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_L3      14 |  | ||||||
| #define RETRO_DEVICE_ID_JOYPAD_R3      15 |  | ||||||
| 
 |  | ||||||
| // Index / Id values for ANALOG device.
 |  | ||||||
| #define RETRO_DEVICE_INDEX_ANALOG_LEFT   0 |  | ||||||
| #define RETRO_DEVICE_INDEX_ANALOG_RIGHT  1 |  | ||||||
| #define RETRO_DEVICE_ID_ANALOG_X         0 |  | ||||||
| #define RETRO_DEVICE_ID_ANALOG_Y         1 |  | ||||||
| 
 |  | ||||||
| // Id values for MOUSE.
 |  | ||||||
| #define RETRO_DEVICE_ID_MOUSE_X      0 |  | ||||||
| #define RETRO_DEVICE_ID_MOUSE_Y      1 |  | ||||||
| #define RETRO_DEVICE_ID_MOUSE_LEFT   2 |  | ||||||
| #define RETRO_DEVICE_ID_MOUSE_RIGHT  3 |  | ||||||
| 
 |  | ||||||
| // Id values for LIGHTGUN types.
 |  | ||||||
| #define RETRO_DEVICE_ID_LIGHTGUN_X        0 |  | ||||||
| #define RETRO_DEVICE_ID_LIGHTGUN_Y        1 |  | ||||||
| #define RETRO_DEVICE_ID_LIGHTGUN_TRIGGER  2 |  | ||||||
| #define RETRO_DEVICE_ID_LIGHTGUN_CURSOR   3 |  | ||||||
| #define RETRO_DEVICE_ID_LIGHTGUN_TURBO    4 |  | ||||||
| #define RETRO_DEVICE_ID_LIGHTGUN_PAUSE    5 |  | ||||||
| #define RETRO_DEVICE_ID_LIGHTGUN_START    6 |  | ||||||
| 
 |  | ||||||
| // Id values for POINTER.
 |  | ||||||
| #define RETRO_DEVICE_ID_POINTER_X         0 |  | ||||||
| #define RETRO_DEVICE_ID_POINTER_Y         1 |  | ||||||
| #define RETRO_DEVICE_ID_POINTER_PRESSED   2 |  | ||||||
| 
 |  | ||||||
| // Returned from retro_get_region().
 |  | ||||||
| #define RETRO_REGION_NTSC  0 |  | ||||||
| #define RETRO_REGION_PAL   1 |  | ||||||
| 
 |  | ||||||
| // Passed to retro_get_memory_data/size().
 |  | ||||||
| // If the memory type doesn't apply to the implementation NULL/0 can be returned.
 |  | ||||||
| #define RETRO_MEMORY_MASK        0xff |  | ||||||
| 
 |  | ||||||
| // Regular save ram. This ram is usually found on a game cartridge, backed up by a battery.
 |  | ||||||
| // If save game data is too complex for a single memory buffer,
 |  | ||||||
| // the SYSTEM_DIRECTORY environment callback can be used.
 |  | ||||||
| #define RETRO_MEMORY_SAVE_RAM    0 |  | ||||||
| 
 |  | ||||||
| // Some games have a built-in clock to keep track of time.
 |  | ||||||
| // This memory is usually just a couple of bytes to keep track of time.
 |  | ||||||
| #define RETRO_MEMORY_RTC         1 |  | ||||||
| 
 |  | ||||||
| // System ram lets a frontend peek into a game systems main RAM.
 |  | ||||||
| #define RETRO_MEMORY_SYSTEM_RAM  2 |  | ||||||
| 
 |  | ||||||
| // Video ram lets a frontend peek into a game systems video RAM (VRAM).
 |  | ||||||
| #define RETRO_MEMORY_VIDEO_RAM   3 |  | ||||||
| 
 |  | ||||||
| // Special memory types.
 |  | ||||||
| #define RETRO_MEMORY_SNES_BSX_RAM             ((1 << 8) | RETRO_MEMORY_SAVE_RAM) |  | ||||||
| #define RETRO_MEMORY_SNES_BSX_PRAM            ((2 << 8) | RETRO_MEMORY_SAVE_RAM) |  | ||||||
| #define RETRO_MEMORY_SNES_SUFAMI_TURBO_A_RAM  ((3 << 8) | RETRO_MEMORY_SAVE_RAM) |  | ||||||
| #define RETRO_MEMORY_SNES_SUFAMI_TURBO_B_RAM  ((4 << 8) | RETRO_MEMORY_SAVE_RAM) |  | ||||||
| #define RETRO_MEMORY_SNES_GAME_BOY_RAM        ((5 << 8) | RETRO_MEMORY_SAVE_RAM) |  | ||||||
| #define RETRO_MEMORY_SNES_GAME_BOY_RTC        ((6 << 8) | RETRO_MEMORY_RTC) |  | ||||||
| 
 |  | ||||||
| // Special game types passed into retro_load_game_special().
 |  | ||||||
| // Only used when multiple ROMs are required.
 |  | ||||||
| #define RETRO_GAME_TYPE_BSX             0x101 |  | ||||||
| #define RETRO_GAME_TYPE_BSX_SLOTTED     0x102 |  | ||||||
| #define RETRO_GAME_TYPE_SUFAMI_TURBO    0x103 |  | ||||||
| #define RETRO_GAME_TYPE_SUPER_GAME_BOY  0x104 |  | ||||||
| 
 |  | ||||||
| // Keysyms used for ID in input state callback when polling RETRO_KEYBOARD.
 |  | ||||||
| enum retro_key |  | ||||||
| { |  | ||||||
|    RETROK_UNKNOWN        = 0, |  | ||||||
|    RETROK_FIRST          = 0, |  | ||||||
|    RETROK_BACKSPACE      = 8, |  | ||||||
|    RETROK_TAB            = 9, |  | ||||||
|    RETROK_CLEAR          = 12, |  | ||||||
|    RETROK_RETURN         = 13, |  | ||||||
|    RETROK_PAUSE          = 19, |  | ||||||
|    RETROK_ESCAPE         = 27, |  | ||||||
|    RETROK_SPACE          = 32, |  | ||||||
|    RETROK_EXCLAIM        = 33, |  | ||||||
|    RETROK_QUOTEDBL       = 34, |  | ||||||
|    RETROK_HASH           = 35, |  | ||||||
|    RETROK_DOLLAR         = 36, |  | ||||||
|    RETROK_AMPERSAND      = 38, |  | ||||||
|    RETROK_QUOTE          = 39, |  | ||||||
|    RETROK_LEFTPAREN      = 40, |  | ||||||
|    RETROK_RIGHTPAREN     = 41, |  | ||||||
|    RETROK_ASTERISK       = 42, |  | ||||||
|    RETROK_PLUS           = 43, |  | ||||||
|    RETROK_COMMA          = 44, |  | ||||||
|    RETROK_MINUS          = 45, |  | ||||||
|    RETROK_PERIOD         = 46, |  | ||||||
|    RETROK_SLASH          = 47, |  | ||||||
|    RETROK_0              = 48, |  | ||||||
|    RETROK_1              = 49, |  | ||||||
|    RETROK_2              = 50, |  | ||||||
|    RETROK_3              = 51, |  | ||||||
|    RETROK_4              = 52, |  | ||||||
|    RETROK_5              = 53, |  | ||||||
|    RETROK_6              = 54, |  | ||||||
|    RETROK_7              = 55, |  | ||||||
|    RETROK_8              = 56, |  | ||||||
|    RETROK_9              = 57, |  | ||||||
|    RETROK_COLON          = 58, |  | ||||||
|    RETROK_SEMICOLON      = 59, |  | ||||||
|    RETROK_LESS           = 60, |  | ||||||
|    RETROK_EQUALS         = 61, |  | ||||||
|    RETROK_GREATER        = 62, |  | ||||||
|    RETROK_QUESTION       = 63, |  | ||||||
|    RETROK_AT             = 64, |  | ||||||
|    RETROK_LEFTBRACKET    = 91, |  | ||||||
|    RETROK_BACKSLASH      = 92, |  | ||||||
|    RETROK_RIGHTBRACKET   = 93, |  | ||||||
|    RETROK_CARET          = 94, |  | ||||||
|    RETROK_UNDERSCORE     = 95, |  | ||||||
|    RETROK_BACKQUOTE      = 96, |  | ||||||
|    RETROK_a              = 97, |  | ||||||
|    RETROK_b              = 98, |  | ||||||
|    RETROK_c              = 99, |  | ||||||
|    RETROK_d              = 100, |  | ||||||
|    RETROK_e              = 101, |  | ||||||
|    RETROK_f              = 102, |  | ||||||
|    RETROK_g              = 103, |  | ||||||
|    RETROK_h              = 104, |  | ||||||
|    RETROK_i              = 105, |  | ||||||
|    RETROK_j              = 106, |  | ||||||
|    RETROK_k              = 107, |  | ||||||
|    RETROK_l              = 108, |  | ||||||
|    RETROK_m              = 109, |  | ||||||
|    RETROK_n              = 110, |  | ||||||
|    RETROK_o              = 111, |  | ||||||
|    RETROK_p              = 112, |  | ||||||
|    RETROK_q              = 113, |  | ||||||
|    RETROK_r              = 114, |  | ||||||
|    RETROK_s              = 115, |  | ||||||
|    RETROK_t              = 116, |  | ||||||
|    RETROK_u              = 117, |  | ||||||
|    RETROK_v              = 118, |  | ||||||
|    RETROK_w              = 119, |  | ||||||
|    RETROK_x              = 120, |  | ||||||
|    RETROK_y              = 121, |  | ||||||
|    RETROK_z              = 122, |  | ||||||
|    RETROK_DELETE         = 127, |  | ||||||
| 
 |  | ||||||
|    RETROK_KP0            = 256, |  | ||||||
|    RETROK_KP1            = 257, |  | ||||||
|    RETROK_KP2            = 258, |  | ||||||
|    RETROK_KP3            = 259, |  | ||||||
|    RETROK_KP4            = 260, |  | ||||||
|    RETROK_KP5            = 261, |  | ||||||
|    RETROK_KP6            = 262, |  | ||||||
|    RETROK_KP7            = 263, |  | ||||||
|    RETROK_KP8            = 264, |  | ||||||
|    RETROK_KP9            = 265, |  | ||||||
|    RETROK_KP_PERIOD      = 266, |  | ||||||
|    RETROK_KP_DIVIDE      = 267, |  | ||||||
|    RETROK_KP_MULTIPLY    = 268, |  | ||||||
|    RETROK_KP_MINUS       = 269, |  | ||||||
|    RETROK_KP_PLUS        = 270, |  | ||||||
|    RETROK_KP_ENTER       = 271, |  | ||||||
|    RETROK_KP_EQUALS      = 272, |  | ||||||
| 
 |  | ||||||
|    RETROK_UP             = 273, |  | ||||||
|    RETROK_DOWN           = 274, |  | ||||||
|    RETROK_RIGHT          = 275, |  | ||||||
|    RETROK_LEFT           = 276, |  | ||||||
|    RETROK_INSERT         = 277, |  | ||||||
|    RETROK_HOME           = 278, |  | ||||||
|    RETROK_END            = 279, |  | ||||||
|    RETROK_PAGEUP         = 280, |  | ||||||
|    RETROK_PAGEDOWN       = 281, |  | ||||||
| 
 |  | ||||||
|    RETROK_F1             = 282, |  | ||||||
|    RETROK_F2             = 283, |  | ||||||
|    RETROK_F3             = 284, |  | ||||||
|    RETROK_F4             = 285, |  | ||||||
|    RETROK_F5             = 286, |  | ||||||
|    RETROK_F6             = 287, |  | ||||||
|    RETROK_F7             = 288, |  | ||||||
|    RETROK_F8             = 289, |  | ||||||
|    RETROK_F9             = 290, |  | ||||||
|    RETROK_F10            = 291, |  | ||||||
|    RETROK_F11            = 292, |  | ||||||
|    RETROK_F12            = 293, |  | ||||||
|    RETROK_F13            = 294, |  | ||||||
|    RETROK_F14            = 295, |  | ||||||
|    RETROK_F15            = 296, |  | ||||||
| 
 |  | ||||||
|    RETROK_NUMLOCK        = 300, |  | ||||||
|    RETROK_CAPSLOCK       = 301, |  | ||||||
|    RETROK_SCROLLOCK      = 302, |  | ||||||
|    RETROK_RSHIFT         = 303, |  | ||||||
|    RETROK_LSHIFT         = 304, |  | ||||||
|    RETROK_RCTRL          = 305, |  | ||||||
|    RETROK_LCTRL          = 306, |  | ||||||
|    RETROK_RALT           = 307, |  | ||||||
|    RETROK_LALT           = 308, |  | ||||||
|    RETROK_RMETA          = 309, |  | ||||||
|    RETROK_LMETA          = 310, |  | ||||||
|    RETROK_LSUPER         = 311, |  | ||||||
|    RETROK_RSUPER         = 312, |  | ||||||
|    RETROK_MODE           = 313, |  | ||||||
|    RETROK_COMPOSE        = 314, |  | ||||||
| 
 |  | ||||||
|    RETROK_HELP           = 315, |  | ||||||
|    RETROK_PRINT          = 316, |  | ||||||
|    RETROK_SYSREQ         = 317, |  | ||||||
|    RETROK_BREAK          = 318, |  | ||||||
|    RETROK_MENU           = 319, |  | ||||||
|    RETROK_POWER          = 320, |  | ||||||
|    RETROK_EURO           = 321, |  | ||||||
|    RETROK_UNDO           = 322, |  | ||||||
| 
 |  | ||||||
|    RETROK_LAST, |  | ||||||
| 
 |  | ||||||
|    RETROK_DUMMY          = INT_MAX // Ensure sizeof(enum) == sizeof(int)
 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| enum retro_mod |  | ||||||
| { |  | ||||||
|    RETROKMOD_NONE       = 0x0000, |  | ||||||
| 
 |  | ||||||
|    RETROKMOD_SHIFT      = 0x01, |  | ||||||
|    RETROKMOD_CTRL       = 0x02, |  | ||||||
|    RETROKMOD_ALT        = 0x04, |  | ||||||
|    RETROKMOD_META       = 0x08, |  | ||||||
| 
 |  | ||||||
|    RETROKMOD_NUMLOCK    = 0x10, |  | ||||||
|    RETROKMOD_CAPSLOCK   = 0x20, |  | ||||||
|    RETROKMOD_SCROLLOCK  = 0x40, |  | ||||||
| 
 |  | ||||||
|    RETROKMOD_DUMMY = INT_MAX // Ensure sizeof(enum) == sizeof(int)
 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| // If set, this call is not part of the public libretro API yet. It can change or be removed at any time.
 |  | ||||||
| #define RETRO_ENVIRONMENT_EXPERIMENTAL 0x10000 |  | ||||||
| 
 |  | ||||||
| // Environment commands.
 |  | ||||||
| #define RETRO_ENVIRONMENT_SET_ROTATION  1  // const unsigned * --
 |  | ||||||
|                                            // Sets screen rotation of graphics.
 |  | ||||||
|                                            // Is only implemented if rotation can be accelerated by hardware.
 |  | ||||||
|                                            // Valid values are 0, 1, 2, 3, which rotates screen by 0, 90, 180, 270 degrees
 |  | ||||||
|                                            // counter-clockwise respectively.
 |  | ||||||
|                                            //
 |  | ||||||
| #define RETRO_ENVIRONMENT_GET_OVERSCAN  2  // bool * --
 |  | ||||||
|                                            // Boolean value whether or not the implementation should use overscan, or crop away overscan.
 |  | ||||||
|                                            //
 |  | ||||||
| #define RETRO_ENVIRONMENT_GET_CAN_DUPE  3  // bool * --
 |  | ||||||
|                                            // Boolean value whether or not frontend supports frame duping,
 |  | ||||||
|                                            // passing NULL to video frame callback.
 |  | ||||||
|                                            //
 |  | ||||||
| // Environ 4, 5 are no longer supported (GET_VARIABLE / SET_VARIABLES), and reserved to avoid possible ABI clash.
 |  | ||||||
| #define RETRO_ENVIRONMENT_SET_MESSAGE   6  // const struct retro_message * --
 |  | ||||||
|                                            // Sets a message to be displayed in implementation-specific manner for a certain amount of 'frames'.
 |  | ||||||
|                                            // Should not be used for trivial messages, which should simply be logged to stderr.
 |  | ||||||
| #define RETRO_ENVIRONMENT_SHUTDOWN      7  // N/A (NULL) --
 |  | ||||||
|                                            // Requests the frontend to shutdown.
 |  | ||||||
|                                            // Should only be used if game has a specific
 |  | ||||||
|                                            // way to shutdown the game from a menu item or similar.
 |  | ||||||
|                                            //
 |  | ||||||
| #define RETRO_ENVIRONMENT_SET_PERFORMANCE_LEVEL 8 |  | ||||||
|                                            // const unsigned * --
 |  | ||||||
|                                            // Gives a hint to the frontend how demanding this implementation
 |  | ||||||
|                                            // is on a system. E.g. reporting a level of 2 means
 |  | ||||||
|                                            // this implementation should run decently on all frontends
 |  | ||||||
|                                            // of level 2 and up.
 |  | ||||||
|                                            //
 |  | ||||||
|                                            // It can be used by the frontend to potentially warn
 |  | ||||||
|                                            // about too demanding implementations.
 |  | ||||||
|                                            //
 |  | ||||||
|                                            // The levels are "floating", but roughly defined as:
 |  | ||||||
|                                            // 0: Low-powered embedded devices such as Raspberry Pi
 |  | ||||||
|                                            // 1: 6th generation consoles, such as Wii/Xbox 1, and phones, tablets, etc.
 |  | ||||||
|                                            // 2: 7th generation consoles, such as PS3/360, with sub-par CPUs.
 |  | ||||||
|                                            // 3: Modern desktop/laptops with reasonably powerful CPUs.
 |  | ||||||
|                                            // 4: High-end desktops with very powerful CPUs.
 |  | ||||||
|                                            //
 |  | ||||||
|                                            // This function can be called on a per-game basis,
 |  | ||||||
|                                            // as certain games an implementation can play might be
 |  | ||||||
|                                            // particularily demanding.
 |  | ||||||
|                                            // If called, it should be called in retro_load_game().
 |  | ||||||
|                                            //
 |  | ||||||
| #define RETRO_ENVIRONMENT_GET_SYSTEM_DIRECTORY 9 |  | ||||||
|                                            // const char ** --
 |  | ||||||
|                                            // Returns the "system" directory of the frontend.
 |  | ||||||
|                                            // This directory can be used to store system specific ROMs such as BIOSes, configuration data, etc.
 |  | ||||||
|                                            // The returned value can be NULL.
 |  | ||||||
|                                            // If so, no such directory is defined,
 |  | ||||||
|                                            // and it's up to the implementation to find a suitable directory.
 |  | ||||||
|                                            //
 |  | ||||||
| #define RETRO_ENVIRONMENT_SET_PIXEL_FORMAT 10 |  | ||||||
|                                            // const enum retro_pixel_format * --
 |  | ||||||
|                                            // Sets the internal pixel format used by the implementation.
 |  | ||||||
|                                            // The default pixel format is RETRO_PIXEL_FORMAT_0RGB1555.
 |  | ||||||
|                                            // This pixel format however, is deprecated (see enum retro_pixel_format).
 |  | ||||||
|                                            // If the call returns false, the frontend does not support this pixel format.
 |  | ||||||
|                                            // This function should be called inside retro_load_game() or retro_get_system_av_info().
 |  | ||||||
|                                            //
 |  | ||||||
| #define RETRO_ENVIRONMENT_SET_INPUT_DESCRIPTORS 11 |  | ||||||
|                                            // const struct retro_input_descriptor * --
 |  | ||||||
|                                            // Sets an array of retro_input_descriptors.
 |  | ||||||
|                                            // It is up to the frontend to present this in a usable way.
 |  | ||||||
|                                            // The array is terminated by retro_input_descriptor::description being set to NULL.
 |  | ||||||
|                                            // This function can be called at any time, but it is recommended to call it as early as possible.
 |  | ||||||
| #define RETRO_ENVIRONMENT_SET_KEYBOARD_CALLBACK 12 |  | ||||||
|                                            // const struct retro_keyboard_callback * --
 |  | ||||||
|                                            // Sets a callback function used to notify core about keyboard events.
 |  | ||||||
|                                            //
 |  | ||||||
| #define RETRO_ENVIRONMENT_SET_DISK_CONTROL_INTERFACE 13 |  | ||||||
|                                            // const struct retro_disk_control_callback * --
 |  | ||||||
|                                            // Sets an interface which frontend can use to eject and insert disk images.
 |  | ||||||
|                                            // This is used for games which consist of multiple images and must be manually
 |  | ||||||
|                                            // swapped out by the user (e.g. PSX).
 |  | ||||||
| #define RETRO_ENVIRONMENT_SET_HW_RENDER    (14 | RETRO_ENVIRONMENT_EXPERIMENTAL) |  | ||||||
|                                            // struct retro_hw_render_callback * --
 |  | ||||||
|                                            // NOTE: This call is currently very experimental, and should not be considered part of the public API.
 |  | ||||||
|                                            // The interface could be changed or removed at any time.
 |  | ||||||
|                                            // Sets an interface to let a libretro core render with hardware acceleration.
 |  | ||||||
|                                            // Should be called in retro_load_game().
 |  | ||||||
|                                            // If successful, libretro cores will be able to render to a frontend-provided framebuffer.
 |  | ||||||
|                                            // The size of this framebuffer will be at least as large as max_width/max_height provided in get_av_info().
 |  | ||||||
|                                            // If HW rendering is used, pass only RETRO_HW_FRAME_BUFFER_VALID or NULL to retro_video_refresh_t.
 |  | ||||||
| #define RETRO_ENVIRONMENT_GET_VARIABLE 15 |  | ||||||
|                                            // struct retro_variable * --
 |  | ||||||
|                                            // Interface to aquire user-defined information from environment
 |  | ||||||
|                                            // that cannot feasibly be supported in a multi-system way.
 |  | ||||||
|                                            // 'key' should be set to a key which has already been set by SET_VARIABLES.
 |  | ||||||
|                                            // 'data' will be set to a value or NULL.
 |  | ||||||
|                                            //
 |  | ||||||
| #define RETRO_ENVIRONMENT_SET_VARIABLES 16 |  | ||||||
|                                            // const struct retro_variable * --
 |  | ||||||
|                                            // Allows an implementation to signal the environment
 |  | ||||||
|                                            // which variables it might want to check for later using GET_VARIABLE.
 |  | ||||||
|                                            // This allows the frontend to present these variables to a user dynamically.
 |  | ||||||
|                                            // This should be called as early as possible (ideally in retro_set_environment).
 |  | ||||||
|                                            //
 |  | ||||||
|                                            // 'data' points to an array of retro_variable structs terminated by a { NULL, NULL } element.
 |  | ||||||
|                                            // retro_variable::key should be namespaced to not collide with other implementations' keys. E.g. A core called 'foo' should use keys named as 'foo_option'.
 |  | ||||||
|                                            // retro_variable::value should contain a human readable description of the key as well as a '|' delimited list of expected values.
 |  | ||||||
|                                            // The number of possible options should be very limited, i.e. it should be feasible to cycle through options without a keyboard.
 |  | ||||||
|                                            // First entry should be treated as a default.
 |  | ||||||
|                                            //
 |  | ||||||
|                                            // Example entry:
 |  | ||||||
|                                            // { "foo_option", "Speed hack coprocessor X; false|true" }
 |  | ||||||
|                                            //
 |  | ||||||
|                                            // Text before first ';' is description. This ';' must be followed by a space, and followed by a list of possible values split up with '|'.
 |  | ||||||
|                                            // Only strings are operated on. The possible values will generally be displayed and stored as-is by the frontend.
 |  | ||||||
|                                            //
 |  | ||||||
| #define RETRO_ENVIRONMENT_GET_VARIABLE_UPDATE 17 |  | ||||||
|                                            // bool * --
 |  | ||||||
|                                            // Result is set to true if some variables are updated by
 |  | ||||||
|                                            // frontend since last call to RETRO_ENVIRONMENT_GET_VARIABLE.
 |  | ||||||
|                                            // Variables should be queried with GET_VARIABLE.
 |  | ||||||
|                                            //
 |  | ||||||
| #define RETRO_ENVIRONMENT_SET_SUPPORT_NO_GAME 18 |  | ||||||
|                                            // const bool * --
 |  | ||||||
|                                            // If true, the libretro implementation supports calls to retro_load_game() with NULL as argument.
 |  | ||||||
|                                            // Used by cores which can run without particular game data.
 |  | ||||||
|                                            // This should be called within retro_set_environment() only.
 |  | ||||||
|                                            |  | ||||||
| 
 |  | ||||||
| // Pass this to retro_video_refresh_t if rendering to hardware.
 |  | ||||||
| // Passing NULL to retro_video_refresh_t is still a frame dupe as normal.
 |  | ||||||
| #define RETRO_HW_FRAME_BUFFER_VALID ((void*)-1) |  | ||||||
| 
 |  | ||||||
| // Invalidates the current HW context.
 |  | ||||||
| // If called, all GPU resources must be reinitialized.
 |  | ||||||
| // Usually called when frontend reinits video driver.
 |  | ||||||
| // Also called first time video driver is initialized, allowing libretro core to init resources.
 |  | ||||||
| typedef void (*retro_hw_context_reset_t)(void); |  | ||||||
| // Gets current framebuffer which is to be rendered to. Could change every frame potentially.
 |  | ||||||
| typedef uintptr_t (*retro_hw_get_current_framebuffer_t)(void); |  | ||||||
| 
 |  | ||||||
| // Get a symbol from HW context.
 |  | ||||||
| typedef void (*retro_proc_address_t)(void); |  | ||||||
| typedef retro_proc_address_t (*retro_hw_get_proc_address_t)(const char *sym); |  | ||||||
| 
 |  | ||||||
| enum retro_hw_context_type |  | ||||||
| { |  | ||||||
|    RETRO_HW_CONTEXT_NONE = 0, |  | ||||||
|    RETRO_HW_CONTEXT_OPENGL, // OpenGL 2.x. Latest version available before 3.x+.
 |  | ||||||
|    RETRO_HW_CONTEXT_OPENGLES2, // GLES 2.0
 |  | ||||||
| 
 |  | ||||||
|    RETRO_HW_CONTEXT_DUMMY = INT_MAX |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| struct retro_hw_render_callback |  | ||||||
| { |  | ||||||
|    enum retro_hw_context_type context_type; // Which API to use. Set by libretro core.
 |  | ||||||
|    retro_hw_context_reset_t context_reset; // Set by libretro core.
 |  | ||||||
|    retro_hw_get_current_framebuffer_t get_current_framebuffer; // Set by frontend.
 |  | ||||||
|    retro_hw_get_proc_address_t get_proc_address; // Set by frontend.
 |  | ||||||
|    bool depth; // Set if render buffers should have depth component attached.
 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| // Callback type passed in RETRO_ENVIRONMENT_SET_KEYBOARD_CALLBACK. Called by the frontend in response to keyboard events.
 |  | ||||||
| // down is set if the key is being pressed, or false if it is being released.
 |  | ||||||
| // keycode is the RETROK value of the char.
 |  | ||||||
| // character is the text character of the pressed key. (UTF-32).
 |  | ||||||
| // key_modifiers is a set of RETROKMOD values or'ed together.
 |  | ||||||
| typedef void (*retro_keyboard_event_t)(bool down, unsigned keycode, uint32_t character, uint16_t key_modifiers); |  | ||||||
| 
 |  | ||||||
| struct retro_keyboard_callback |  | ||||||
| { |  | ||||||
|    retro_keyboard_event_t callback; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| // Callbacks for RETRO_ENVIRONMENT_SET_DISK_CONTROL_INTERFACE.
 |  | ||||||
| // Should be set for implementations which can swap out multiple disk images in runtime.
 |  | ||||||
| // If the implementation can do this automatically, it should strive to do so.
 |  | ||||||
| // However, there are cases where the user must manually do so.
 |  | ||||||
| //
 |  | ||||||
| // Overview: To swap a disk image, eject the disk image with set_eject_state(true).
 |  | ||||||
| // Set the disk index with set_image_index(index). Insert the disk again with set_eject_state(false).
 |  | ||||||
| 
 |  | ||||||
| // If ejected is true, "ejects" the virtual disk tray.
 |  | ||||||
| // When ejected, the disk image index can be set.
 |  | ||||||
| typedef bool (*retro_set_eject_state_t)(bool ejected); |  | ||||||
| // Gets current eject state. The initial state is 'not ejected'.
 |  | ||||||
| typedef bool (*retro_get_eject_state_t)(void); |  | ||||||
| // Gets current disk index. First disk is index 0.
 |  | ||||||
| // If return value is >= get_num_images(), no disk is currently inserted.
 |  | ||||||
| typedef unsigned (*retro_get_image_index_t)(void); |  | ||||||
| // Sets image index. Can only be called when disk is ejected.
 |  | ||||||
| // The implementation supports setting "no disk" by using an index >= get_num_images().
 |  | ||||||
| typedef bool (*retro_set_image_index_t)(unsigned index); |  | ||||||
| // Gets total number of images which are available to use.
 |  | ||||||
| typedef unsigned (*retro_get_num_images_t)(void); |  | ||||||
| //
 |  | ||||||
| // Replaces the disk image associated with index.
 |  | ||||||
| // Arguments to pass in info have same requirements as retro_load_game().
 |  | ||||||
| // Virtual disk tray must be ejected when calling this.
 |  | ||||||
| // Replacing a disk image with info = NULL will remove the disk image from the internal list.
 |  | ||||||
| // As a result, calls to get_image_index() can change.
 |  | ||||||
| //
 |  | ||||||
| // E.g. replace_image_index(1, NULL), and previous get_image_index() returned 4 before.
 |  | ||||||
| // Index 1 will be removed, and the new index is 3.
 |  | ||||||
| struct retro_game_info; |  | ||||||
| typedef bool (*retro_replace_image_index_t)(unsigned index, const struct retro_game_info *info); |  | ||||||
| // Adds a new valid index (get_num_images()) to the internal disk list.
 |  | ||||||
| // This will increment subsequent return values from get_num_images() by 1.
 |  | ||||||
| // This image index cannot be used until a disk image has been set with replace_image_index.
 |  | ||||||
| typedef bool (*retro_add_image_index_t)(void); |  | ||||||
| 
 |  | ||||||
| struct retro_disk_control_callback |  | ||||||
| { |  | ||||||
|    retro_set_eject_state_t set_eject_state; |  | ||||||
|    retro_get_eject_state_t get_eject_state; |  | ||||||
| 
 |  | ||||||
|    retro_get_image_index_t get_image_index; |  | ||||||
|    retro_set_image_index_t set_image_index; |  | ||||||
|    retro_get_num_images_t  get_num_images; |  | ||||||
| 
 |  | ||||||
|    retro_replace_image_index_t replace_image_index; |  | ||||||
|    retro_add_image_index_t add_image_index; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| enum retro_pixel_format |  | ||||||
| { |  | ||||||
|    // 0RGB1555, native endian. 0 bit must be set to 0.
 |  | ||||||
|    // This pixel format is default for compatibility concerns only.
 |  | ||||||
|    // If a 15/16-bit pixel format is desired, consider using RGB565.
 |  | ||||||
|    RETRO_PIXEL_FORMAT_0RGB1555 = 0, |  | ||||||
| 
 |  | ||||||
|    // XRGB8888, native endian. X bits are ignored.
 |  | ||||||
|    RETRO_PIXEL_FORMAT_XRGB8888 = 1, |  | ||||||
| 
 |  | ||||||
|    // RGB565, native endian. This pixel format is the recommended format to use if a 15/16-bit format is desired
 |  | ||||||
|    // as it is the pixel format that is typically available on a wide range of low-power devices.
 |  | ||||||
|    // It is also natively supported in APIs like OpenGL ES.
 |  | ||||||
|    RETRO_PIXEL_FORMAT_RGB565   = 2, |  | ||||||
| 
 |  | ||||||
|    // Ensure sizeof() == sizeof(int).
 |  | ||||||
|    RETRO_PIXEL_FORMAT_UNKNOWN  = INT_MAX |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| struct retro_message |  | ||||||
| { |  | ||||||
|    const char *msg;        // Message to be displayed.
 |  | ||||||
|    unsigned    frames;     // Duration in frames of message.
 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| // Describes how the libretro implementation maps a libretro input bind
 |  | ||||||
| // to its internal input system through a human readable string.
 |  | ||||||
| // This string can be used to better let a user configure input.
 |  | ||||||
| struct retro_input_descriptor |  | ||||||
| { |  | ||||||
|    // Associates given parameters with a description.
 |  | ||||||
|    unsigned port; |  | ||||||
|    unsigned device; |  | ||||||
|    unsigned index; |  | ||||||
|    unsigned id; |  | ||||||
| 
 |  | ||||||
|    const char *description; // Human readable description for parameters.
 |  | ||||||
|                             // The pointer must remain valid until retro_unload_game() is called.
 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| struct retro_system_info |  | ||||||
| { |  | ||||||
|    // All pointers are owned by libretro implementation, and pointers must remain valid until retro_deinit() is called.
 |  | ||||||
| 
 |  | ||||||
|    const char *library_name;      // Descriptive name of library. Should not contain any version numbers, etc.
 |  | ||||||
|    const char *library_version;   // Descriptive version of core.
 |  | ||||||
| 
 |  | ||||||
|    const char *valid_extensions;  // A string listing probably rom extensions the core will be able to load, separated with pipe.
 |  | ||||||
|                                   // I.e. "bin|rom|iso".
 |  | ||||||
|                                   // Typically used for a GUI to filter out extensions.
 |  | ||||||
| 
 |  | ||||||
|    bool        need_fullpath;     // If true, retro_load_game() is guaranteed to provide a valid pathname in retro_game_info::path.
 |  | ||||||
|                                   // ::data and ::size are both invalid.
 |  | ||||||
|                                   // If false, ::data and ::size are guaranteed to be valid, but ::path might not be valid.
 |  | ||||||
|                                   // This is typically set to true for libretro implementations that must load from file.
 |  | ||||||
|                                   // Implementations should strive for setting this to false, as it allows the frontend to perform patching, etc.
 |  | ||||||
| 
 |  | ||||||
|    bool        block_extract;     // If true, the frontend is not allowed to extract any archives before loading the real ROM.
 |  | ||||||
|                                   // Necessary for certain libretro implementations that load games from zipped archives.
 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| struct retro_game_geometry |  | ||||||
| { |  | ||||||
|    unsigned base_width;    // Nominal video width of game.
 |  | ||||||
|    unsigned base_height;   // Nominal video height of game.
 |  | ||||||
|    unsigned max_width;     // Maximum possible width of game.
 |  | ||||||
|    unsigned max_height;    // Maximum possible height of game.
 |  | ||||||
| 
 |  | ||||||
|    float    aspect_ratio;  // Nominal aspect ratio of game. If aspect_ratio is <= 0.0,
 |  | ||||||
|                            // an aspect ratio of base_width / base_height is assumed.
 |  | ||||||
|                            // A frontend could override this setting if desired.
 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| struct retro_system_timing |  | ||||||
| { |  | ||||||
|    double fps;             // FPS of video content.
 |  | ||||||
|    double sample_rate;     // Sampling rate of audio.
 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| struct retro_system_av_info |  | ||||||
| { |  | ||||||
|    struct retro_game_geometry geometry; |  | ||||||
|    struct retro_system_timing timing; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| struct retro_variable |  | ||||||
| { |  | ||||||
|    const char *key;        // Variable to query in RETRO_ENVIRONMENT_GET_VARIABLE.
 |  | ||||||
|                            // If NULL, obtains the complete environment string if more complex parsing is necessary.
 |  | ||||||
|                            // The environment string is formatted as key-value pairs delimited by semicolons as so:
 |  | ||||||
|                            // "key1=value1;key2=value2;..."
 |  | ||||||
|    const char *value;      // Value to be obtained. If key does not exist, it is set to NULL.
 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| struct retro_game_info |  | ||||||
| { |  | ||||||
|    const char *path;       // Path to game, UTF-8 encoded. Usually used as a reference.
 |  | ||||||
|                            // May be NULL if rom was loaded from stdin or similar.
 |  | ||||||
|                            // retro_system_info::need_fullpath guaranteed that this path is valid.
 |  | ||||||
|    const void *data;       // Memory buffer of loaded game. Will be NULL if need_fullpath was set.
 |  | ||||||
|    size_t      size;       // Size of memory buffer.
 |  | ||||||
|    const char *meta;       // String of implementation specific meta-data.
 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| // Callbacks
 |  | ||||||
| //
 |  | ||||||
| // Environment callback. Gives implementations a way of performing uncommon tasks. Extensible.
 |  | ||||||
| typedef bool (*retro_environment_t)(unsigned cmd, void *data); |  | ||||||
| 
 |  | ||||||
| // Render a frame. Pixel format is 15-bit 0RGB1555 native endian unless changed (see RETRO_ENVIRONMENT_SET_PIXEL_FORMAT).
 |  | ||||||
| // Width and height specify dimensions of buffer.
 |  | ||||||
| // Pitch specifices length in bytes between two lines in buffer.
 |  | ||||||
| // For performance reasons, it is highly recommended to have a frame that is packed in memory, i.e. pitch == width * byte_per_pixel.
 |  | ||||||
| // Certain graphic APIs, such as OpenGL ES, do not like textures that are not packed in memory.
 |  | ||||||
| typedef void (*retro_video_refresh_t)(const void *data, unsigned width, unsigned height, size_t pitch); |  | ||||||
| 
 |  | ||||||
| // Renders a single audio frame. Should only be used if implementation generates a single sample at a time.
 |  | ||||||
| // Format is signed 16-bit native endian.
 |  | ||||||
| typedef void (*retro_audio_sample_t)(int16_t left, int16_t right); |  | ||||||
| // Renders multiple audio frames in one go. One frame is defined as a sample of left and right channels, interleaved.
 |  | ||||||
| // I.e. int16_t buf[4] = { l, r, l, r }; would be 2 frames.
 |  | ||||||
| // Only one of the audio callbacks must ever be used.
 |  | ||||||
| typedef size_t (*retro_audio_sample_batch_t)(const int16_t *data, size_t frames); |  | ||||||
| 
 |  | ||||||
| // Polls input.
 |  | ||||||
| typedef void (*retro_input_poll_t)(void); |  | ||||||
| // Queries for input for player 'port'. device will be masked with RETRO_DEVICE_MASK.
 |  | ||||||
| // Specialization of devices such as RETRO_DEVICE_JOYPAD_MULTITAP that have been set with retro_set_controller_port_device()
 |  | ||||||
| // will still use the higher level RETRO_DEVICE_JOYPAD to request input.
 |  | ||||||
| typedef int16_t (*retro_input_state_t)(unsigned port, unsigned device, unsigned index, unsigned id); |  | ||||||
| 
 |  | ||||||
| // Sets callbacks. retro_set_environment() is guaranteed to be called before retro_init().
 |  | ||||||
| // The rest of the set_* functions are guaranteed to have been called before the first call to retro_run() is made.
 |  | ||||||
| void retro_set_environment(retro_environment_t); |  | ||||||
| void retro_set_video_refresh(retro_video_refresh_t); |  | ||||||
| void retro_set_audio_sample(retro_audio_sample_t); |  | ||||||
| void retro_set_audio_sample_batch(retro_audio_sample_batch_t); |  | ||||||
| void retro_set_input_poll(retro_input_poll_t); |  | ||||||
| void retro_set_input_state(retro_input_state_t); |  | ||||||
| 
 |  | ||||||
| // Library global initialization/deinitialization.
 |  | ||||||
| void retro_init(void); |  | ||||||
| void retro_deinit(void); |  | ||||||
| 
 |  | ||||||
| // Must return RETRO_API_VERSION. Used to validate ABI compatibility when the API is revised.
 |  | ||||||
| unsigned retro_api_version(void); |  | ||||||
| 
 |  | ||||||
| // Gets statically known system info. Pointers provided in *info must be statically allocated.
 |  | ||||||
| // Can be called at any time, even before retro_init().
 |  | ||||||
| void retro_get_system_info(struct retro_system_info *info); |  | ||||||
| 
 |  | ||||||
| // Gets information about system audio/video timings and geometry.
 |  | ||||||
| // Can be called only after retro_load_game() has successfully completed.
 |  | ||||||
| // NOTE: The implementation of this function might not initialize every variable if needed.
 |  | ||||||
| // E.g. geom.aspect_ratio might not be initialized if core doesn't desire a particular aspect ratio.
 |  | ||||||
| void retro_get_system_av_info(struct retro_system_av_info *info); |  | ||||||
| 
 |  | ||||||
| // Sets device to be used for player 'port'.
 |  | ||||||
| void retro_set_controller_port_device(unsigned port, unsigned device); |  | ||||||
| 
 |  | ||||||
| // Resets the current game.
 |  | ||||||
| void retro_reset(void); |  | ||||||
| 
 |  | ||||||
| // Runs the game for one video frame.
 |  | ||||||
| // During retro_run(), input_poll callback must be called at least once.
 |  | ||||||
| //
 |  | ||||||
| // If a frame is not rendered for reasons where a game "dropped" a frame,
 |  | ||||||
| // this still counts as a frame, and retro_run() should explicitly dupe a frame if GET_CAN_DUPE returns true.
 |  | ||||||
| // In this case, the video callback can take a NULL argument for data.
 |  | ||||||
| void retro_run(void); |  | ||||||
| 
 |  | ||||||
| // Returns the amount of data the implementation requires to serialize internal state (save states).
 |  | ||||||
| // Beetween calls to retro_load_game() and retro_unload_game(), the returned size is never allowed to be larger than a previous returned value, to
 |  | ||||||
| // ensure that the frontend can allocate a save state buffer once.
 |  | ||||||
| size_t retro_serialize_size(void); |  | ||||||
| 
 |  | ||||||
| // Serializes internal state. If failed, or size is lower than retro_serialize_size(), it should return false, true otherwise.
 |  | ||||||
| bool retro_serialize(void *data, size_t size); |  | ||||||
| bool retro_unserialize(const void *data, size_t size); |  | ||||||
| 
 |  | ||||||
| void retro_cheat_reset(void); |  | ||||||
| void retro_cheat_set(unsigned index, bool enabled, const char *code); |  | ||||||
| 
 |  | ||||||
| // Loads a game.
 |  | ||||||
| bool retro_load_game(const struct retro_game_info *game); |  | ||||||
| 
 |  | ||||||
| // Loads a "special" kind of game. Should not be used except in extreme cases.
 |  | ||||||
| bool retro_load_game_special( |  | ||||||
|   unsigned game_type, |  | ||||||
|   const struct retro_game_info *info, size_t num_info |  | ||||||
| ); |  | ||||||
| 
 |  | ||||||
| // Unloads a currently loaded game.
 |  | ||||||
| void retro_unload_game(void); |  | ||||||
| 
 |  | ||||||
| // Gets region of game.
 |  | ||||||
| unsigned retro_get_region(void); |  | ||||||
| 
 |  | ||||||
| // Gets region of memory.
 |  | ||||||
| void *retro_get_memory_data(unsigned id); |  | ||||||
| size_t retro_get_memory_size(unsigned id); |  | ||||||
| 
 |  | ||||||
| #ifdef __cplusplus |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #endif |  | ||||||
							
								
								
									
										78
									
								
								platform/libretro/3ds/3ds_utils.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								platform/libretro/3ds/3ds_utils.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,78 @@ | ||||||
|  | 
 | ||||||
|  | #include "3ds_utils.h" | ||||||
|  | 
 | ||||||
|  | typedef int (*ctr_callback_type)(void); | ||||||
|  | 
 | ||||||
|  | int srvGetServiceHandle(unsigned int* out, const char* name); | ||||||
|  | int svcCloseHandle(unsigned int handle); | ||||||
|  | int svcBackdoor(ctr_callback_type); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | static void ctr_enable_all_svc_kernel(void) | ||||||
|  | { | ||||||
|  |    __asm__ volatile("cpsid aif"); | ||||||
|  | 
 | ||||||
|  |    unsigned int*  svc_access_control = *(*(unsigned int***)0xFFFF9000 + 0x22) - 0x6; | ||||||
|  | 
 | ||||||
|  |    svc_access_control[0]=0xFFFFFFFE; | ||||||
|  |    svc_access_control[1]=0xFFFFFFFF; | ||||||
|  |    svc_access_control[2]=0xFFFFFFFF; | ||||||
|  |    svc_access_control[3]=0x3FFFFFFF; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | static void ctr_invalidate_ICache_kernel(void) | ||||||
|  | { | ||||||
|  |    __asm__ volatile( | ||||||
|  |       "cpsid aif\n\t" | ||||||
|  |       "mov r0, #0\n\t" | ||||||
|  |       "mcr p15, 0, r0, c7, c5, 0\n\t"); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static void ctr_flush_DCache_kernel(void) | ||||||
|  | { | ||||||
|  |    __asm__ volatile( | ||||||
|  |       "cpsid aif\n\t" | ||||||
|  |       "mov r0, #0\n\t" | ||||||
|  |       "mcr p15, 0, r0, c7, c10, 0\n\t"); | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | static void ctr_enable_all_svc(void) | ||||||
|  | { | ||||||
|  |    svcBackdoor((ctr_callback_type)ctr_enable_all_svc_kernel); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void ctr_invalidate_ICache(void) | ||||||
|  | { | ||||||
|  | //   __asm__ volatile("svc 0x2E\n\t");
 | ||||||
|  |    svcBackdoor((ctr_callback_type)ctr_invalidate_ICache_kernel); | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void ctr_flush_DCache(void) | ||||||
|  | { | ||||||
|  | //   __asm__ volatile("svc 0x4B\n\t");
 | ||||||
|  |    svcBackdoor((ctr_callback_type)ctr_flush_DCache_kernel); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | void ctr_flush_invalidate_cache(void) | ||||||
|  | { | ||||||
|  |    ctr_flush_DCache(); | ||||||
|  |    ctr_invalidate_ICache(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int ctr_svchack_init(void) | ||||||
|  | { | ||||||
|  |    extern unsigned int __service_ptr; | ||||||
|  | 
 | ||||||
|  |    if(__service_ptr) | ||||||
|  |       return 0; | ||||||
|  | 
 | ||||||
|  |    /* CFW */ | ||||||
|  |    ctr_enable_all_svc(); | ||||||
|  |    return 1; | ||||||
|  | } | ||||||
|  | 
 | ||||||
							
								
								
									
										16
									
								
								platform/libretro/3ds/3ds_utils.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								platform/libretro/3ds/3ds_utils.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,16 @@ | ||||||
|  | #ifndef _3DS_UTILS_H | ||||||
|  | #define _3DS_UTILS_H | ||||||
|  | 
 | ||||||
|  | void ctr_invalidate_ICache(void); | ||||||
|  | void ctr_flush_DCache(void); | ||||||
|  | 
 | ||||||
|  | void ctr_flush_invalidate_cache(void); | ||||||
|  | 
 | ||||||
|  | int ctr_svchack_init(void); | ||||||
|  | 
 | ||||||
|  | #include <stdio.h> | ||||||
|  | #define DEBUG_HOLD() do{printf("%s@%s:%d.\n",__FUNCTION__, __FILE__, __LINE__);fflush(stdout);wait_for_input();}while(0) | ||||||
|  | 
 | ||||||
|  | void wait_for_input(void); | ||||||
|  | 
 | ||||||
|  | #endif // _3DS_UTILS_H
 | ||||||
							
								
								
									
										1421
									
								
								platform/libretro/libretro.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1421
									
								
								platform/libretro/libretro.c
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										1926
									
								
								platform/libretro/libretro.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1926
									
								
								platform/libretro/libretro.h
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										47
									
								
								platform/libretro/msvc/msvc-2003-xbox1.bat
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								platform/libretro/msvc/msvc-2003-xbox1.bat
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,47 @@ | ||||||
|  | @SET VSINSTALLDIR=C:\Program Files\Microsoft Visual Studio .NET 2003\Common7\IDE | ||||||
|  | @SET VCINSTALLDIR=C:\Program Files\Microsoft Visual Studio .NET 2003 | ||||||
|  | @SET FrameworkDir=C:\WINDOWS\Microsoft.NET\Framework | ||||||
|  | @SET FrameworkVersion=v1.1.4322 | ||||||
|  | @SET FrameworkSDKDir=C:\Program Files\Microsoft Visual Studio .NET 2003\SDK\v1.1 | ||||||
|  | @rem Root of Visual Studio common files. | ||||||
|  | 
 | ||||||
|  | @if "%VSINSTALLDIR%"=="" goto Usage | ||||||
|  | @if "%VCINSTALLDIR%"=="" set VCINSTALLDIR=%VSINSTALLDIR% | ||||||
|  | 
 | ||||||
|  | @rem | ||||||
|  | @rem Root of Visual Studio ide installed files. | ||||||
|  | @rem | ||||||
|  | @set DevEnvDir=%VSINSTALLDIR% | ||||||
|  | 
 | ||||||
|  | @rem | ||||||
|  | @rem Root of Visual C++ installed files. | ||||||
|  | @rem | ||||||
|  | @set MSVCDir=%VCINSTALLDIR%\VC7 | ||||||
|  | 
 | ||||||
|  | @rem | ||||||
|  | @echo Setting environment for using Microsoft Visual Studio .NET 2003 tools. | ||||||
|  | @echo (If you have another version of Visual Studio or Visual C++ installed and wish | ||||||
|  | @echo to use its tools from the command line, run vcvars32.bat for that version.) | ||||||
|  | @rem | ||||||
|  | 
 | ||||||
|  | @REM %VCINSTALLDIR%\Common7\Tools dir is added only for real setup. | ||||||
|  | 
 | ||||||
|  | @set PATH=%DevEnvDir%;%MSVCDir%\BIN;%VCINSTALLDIR%\Common7\Tools;%VCINSTALLDIR%\Common7\Tools\bin\prerelease;%VCINSTALLDIR%\Common7\Tools\bin;%FrameworkSDKDir%\bin;%FrameworkDir%\%FrameworkVersion%;%PATH%; | ||||||
|  | @set INCLUDE=%MSVCDir%\ATLMFC\INCLUDE;%MSVCDir%\INCLUDE;%FrameworkSDKDir%\include;%INCLUDE%;%XDK%\xbox\include | ||||||
|  | @set LIB=%MSVCDir%\ATLMFC\LIB;%MSVCDir%\LIB;%MSVCDir%\PlatformSDK\lib;%XDK%\lib;%XDK%\xbox\lib;%LIB% | ||||||
|  | 
 | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | :Usage | ||||||
|  | 
 | ||||||
|  | @echo. VSINSTALLDIR variable is not set.  | ||||||
|  | @echo. | ||||||
|  | @echo SYNTAX: %0 | ||||||
|  | 
 | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | :end | ||||||
|  | 
 | ||||||
|  | devenv /clean Release_LTCG msvc-2003-xbox1.sln | ||||||
|  | devenv /build Release_LTCG msvc-2003-xbox1.sln | ||||||
|  | exit | ||||||
							
								
								
									
										124
									
								
								platform/libretro/msvc/msvc-2010-360.bat
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										124
									
								
								platform/libretro/msvc/msvc-2010-360.bat
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,124 @@ | ||||||
|  | @echo off | ||||||
|  | 
 | ||||||
|  | @echo Setting environment for using Microsoft Visual Studio 2010 x86 tools. | ||||||
|  | 
 | ||||||
|  | @call :GetVSCommonToolsDir | ||||||
|  | @if "%VS100COMNTOOLS%"=="" goto error_no_VS100COMNTOOLSDIR | ||||||
|  | 
 | ||||||
|  | @call "%VS100COMNTOOLS%VCVarsQueryRegistry.bat" 32bit No64bit | ||||||
|  | 
 | ||||||
|  | @if "%VSINSTALLDIR%"=="" goto error_no_VSINSTALLDIR | ||||||
|  | @if "%FrameworkDir32%"=="" goto error_no_FrameworkDIR32 | ||||||
|  | @if "%FrameworkVersion32%"=="" goto error_no_FrameworkVer32 | ||||||
|  | @if "%Framework35Version%"=="" goto error_no_Framework35Version | ||||||
|  | 
 | ||||||
|  | @set FrameworkDir=%FrameworkDir32% | ||||||
|  | @set FrameworkVersion=%FrameworkVersion32% | ||||||
|  | 
 | ||||||
|  | @if not "%WindowsSdkDir%" == "" ( | ||||||
|  | 	@set "PATH=%WindowsSdkDir%bin\NETFX 4.0 Tools;%WindowsSdkDir%bin;%PATH%" | ||||||
|  | 	@set "INCLUDE=%WindowsSdkDir%include;%INCLUDE%" | ||||||
|  | 	@set "LIB=%WindowsSdkDir%lib;%LIB%" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | @rem | ||||||
|  | @rem Root of Visual Studio IDE installed files. | ||||||
|  | @rem | ||||||
|  | @set DevEnvDir=%VSINSTALLDIR%Common7\IDE\ | ||||||
|  | 
 | ||||||
|  | @rem PATH | ||||||
|  | @rem ---- | ||||||
|  | @if exist "%VSINSTALLDIR%Team Tools\Performance Tools" ( | ||||||
|  | 	@set "PATH=%VSINSTALLDIR%Team Tools\Performance Tools;%PATH%" | ||||||
|  | ) | ||||||
|  | @if exist "%ProgramFiles%\HTML Help Workshop" set PATH=%ProgramFiles%\HTML Help Workshop;%PATH% | ||||||
|  | @if exist "%ProgramFiles(x86)%\HTML Help Workshop" set PATH=%ProgramFiles(x86)%\HTML Help Workshop;%PATH% | ||||||
|  | @if exist "%VCINSTALLDIR%VCPackages" set PATH=%VCINSTALLDIR%VCPackages;%PATH% | ||||||
|  | @set PATH=%FrameworkDir%%Framework35Version%;%PATH% | ||||||
|  | @set PATH=%FrameworkDir%%FrameworkVersion%;%PATH% | ||||||
|  | @set PATH=%VSINSTALLDIR%Common7\Tools;%PATH% | ||||||
|  | @if exist "%VCINSTALLDIR%BIN" set PATH=%VCINSTALLDIR%BIN;%PATH% | ||||||
|  | @set PATH=%DevEnvDir%;%PATH% | ||||||
|  | 
 | ||||||
|  | @if exist "%VSINSTALLDIR%VSTSDB\Deploy" ( | ||||||
|  | 	@set "PATH=%VSINSTALLDIR%VSTSDB\Deploy;%PATH%" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | @if not "%FSHARPINSTALLDIR%" == "" ( | ||||||
|  | 	@set "PATH=%FSHARPINSTALLDIR%;%PATH%" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | @rem INCLUDE | ||||||
|  | @rem ------- | ||||||
|  | @if exist "%VCINSTALLDIR%ATLMFC\INCLUDE" set INCLUDE=%VCINSTALLDIR%ATLMFC\INCLUDE;%INCLUDE% | ||||||
|  | @if exist "%VCINSTALLDIR%INCLUDE" set INCLUDE=%VCINSTALLDIR%INCLUDE;%INCLUDE% | ||||||
|  | 
 | ||||||
|  | @rem LIB | ||||||
|  | @rem --- | ||||||
|  | @if exist "%VCINSTALLDIR%ATLMFC\LIB" set LIB=%VCINSTALLDIR%ATLMFC\LIB;%LIB% | ||||||
|  | @if exist "%VCINSTALLDIR%LIB" set LIB=%VCINSTALLDIR%LIB;%LIB% | ||||||
|  | 
 | ||||||
|  | @rem LIBPATH | ||||||
|  | @rem ------- | ||||||
|  | @if exist "%VCINSTALLDIR%ATLMFC\LIB" set LIBPATH=%VCINSTALLDIR%ATLMFC\LIB;%LIBPATH% | ||||||
|  | @if exist "%VCINSTALLDIR%LIB" set LIBPATH=%VCINSTALLDIR%LIB;%LIBPATH% | ||||||
|  | @set LIBPATH=%FrameworkDir%%Framework35Version%;%LIBPATH% | ||||||
|  | @set LIBPATH=%FrameworkDir%%FrameworkVersion%;%LIBPATH% | ||||||
|  | 
 | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | @REM ----------------------------------------------------------------------- | ||||||
|  | :GetVSCommonToolsDir | ||||||
|  | @set VS100COMNTOOLS= | ||||||
|  | @call :GetVSCommonToolsDirHelper32 HKLM > nul 2>&1 | ||||||
|  | @if errorlevel 1 call :GetVSCommonToolsDirHelper32 HKCU > nul 2>&1 | ||||||
|  | @if errorlevel 1 call :GetVSCommonToolsDirHelper64  HKLM > nul 2>&1 | ||||||
|  | @if errorlevel 1 call :GetVSCommonToolsDirHelper64  HKCU > nul 2>&1 | ||||||
|  | @exit /B 0 | ||||||
|  | 
 | ||||||
|  | :GetVSCommonToolsDirHelper32 | ||||||
|  | @for /F "tokens=1,2*" %%i in ('reg query "%1\SOFTWARE\Microsoft\VisualStudio\SxS\VS7" /v "10.0"') DO ( | ||||||
|  | 	@if "%%i"=="10.0" ( | ||||||
|  | 		@SET "VS100COMNTOOLS=%%k" | ||||||
|  | 	) | ||||||
|  | ) | ||||||
|  | @if "%VS100COMNTOOLS%"=="" exit /B 1 | ||||||
|  | @SET "VS100COMNTOOLS=%VS100COMNTOOLS%Common7\Tools\" | ||||||
|  | @exit /B 0 | ||||||
|  | 
 | ||||||
|  | :GetVSCommonToolsDirHelper64 | ||||||
|  | @for /F "tokens=1,2*" %%i in ('reg query "%1\SOFTWARE\Wow6432Node\Microsoft\VisualStudio\SxS\VS7" /v "10.0"') DO ( | ||||||
|  | 	@if "%%i"=="10.0" ( | ||||||
|  | 		@SET "VS100COMNTOOLS=%%k" | ||||||
|  | 	) | ||||||
|  | ) | ||||||
|  | @if "%VS100COMNTOOLS%"=="" exit /B 1 | ||||||
|  | @SET "VS100COMNTOOLS=%VS100COMNTOOLS%Common7\Tools\" | ||||||
|  | @exit /B 0 | ||||||
|  | 
 | ||||||
|  | @REM ----------------------------------------------------------------------- | ||||||
|  | :error_no_VS100COMNTOOLSDIR | ||||||
|  | @echo ERROR: Cannot determine the location of the VS Common Tools folder. | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | :error_no_VSINSTALLDIR | ||||||
|  | @echo ERROR: Cannot determine the location of the VS installation. | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | :error_no_FrameworkDIR32 | ||||||
|  | @echo ERROR: Cannot determine the location of the .NET Framework 32bit installation. | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | :error_no_FrameworkVer32 | ||||||
|  | @echo ERROR: Cannot determine the version of the .NET Framework 32bit installation. | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | :error_no_Framework35Version | ||||||
|  | @echo ERROR: Cannot determine the .NET Framework 3.5 version. | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | :end | ||||||
|  | 
 | ||||||
|  | msbuild msvc-2010-360.sln /p:Configuration=Release_LTCG /target:clean | ||||||
|  | msbuild msvc-2010-360.sln /p:Configuration=Release_LTCG | ||||||
|  | exit | ||||||
							
								
								
									
										124
									
								
								platform/libretro/msvc/msvc-2010.bat
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										124
									
								
								platform/libretro/msvc/msvc-2010.bat
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,124 @@ | ||||||
|  | @echo off | ||||||
|  | 
 | ||||||
|  | @echo Setting environment for using Microsoft Visual Studio 2010 x86 tools. | ||||||
|  | 
 | ||||||
|  | @call :GetVSCommonToolsDir | ||||||
|  | @if "%VS100COMNTOOLS%"=="" goto error_no_VS100COMNTOOLSDIR | ||||||
|  | 
 | ||||||
|  | @call "%VS100COMNTOOLS%VCVarsQueryRegistry.bat" 32bit No64bit | ||||||
|  | 
 | ||||||
|  | @if "%VSINSTALLDIR%"=="" goto error_no_VSINSTALLDIR | ||||||
|  | @if "%FrameworkDir32%"=="" goto error_no_FrameworkDIR32 | ||||||
|  | @if "%FrameworkVersion32%"=="" goto error_no_FrameworkVer32 | ||||||
|  | @if "%Framework35Version%"=="" goto error_no_Framework35Version | ||||||
|  | 
 | ||||||
|  | @set FrameworkDir=%FrameworkDir32% | ||||||
|  | @set FrameworkVersion=%FrameworkVersion32% | ||||||
|  | 
 | ||||||
|  | @if not "%WindowsSdkDir%" == "" ( | ||||||
|  | 	@set "PATH=%WindowsSdkDir%bin\NETFX 4.0 Tools;%WindowsSdkDir%bin;%PATH%" | ||||||
|  | 	@set "INCLUDE=%WindowsSdkDir%include;%INCLUDE%" | ||||||
|  | 	@set "LIB=%WindowsSdkDir%lib;%LIB%" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | @rem | ||||||
|  | @rem Root of Visual Studio IDE installed files. | ||||||
|  | @rem | ||||||
|  | @set DevEnvDir=%VSINSTALLDIR%Common7\IDE\ | ||||||
|  | 
 | ||||||
|  | @rem PATH | ||||||
|  | @rem ---- | ||||||
|  | @if exist "%VSINSTALLDIR%Team Tools\Performance Tools" ( | ||||||
|  | 	@set "PATH=%VSINSTALLDIR%Team Tools\Performance Tools;%PATH%" | ||||||
|  | ) | ||||||
|  | @if exist "%ProgramFiles%\HTML Help Workshop" set PATH=%ProgramFiles%\HTML Help Workshop;%PATH% | ||||||
|  | @if exist "%ProgramFiles(x86)%\HTML Help Workshop" set PATH=%ProgramFiles(x86)%\HTML Help Workshop;%PATH% | ||||||
|  | @if exist "%VCINSTALLDIR%VCPackages" set PATH=%VCINSTALLDIR%VCPackages;%PATH% | ||||||
|  | @set PATH=%FrameworkDir%%Framework35Version%;%PATH% | ||||||
|  | @set PATH=%FrameworkDir%%FrameworkVersion%;%PATH% | ||||||
|  | @set PATH=%VSINSTALLDIR%Common7\Tools;%PATH% | ||||||
|  | @if exist "%VCINSTALLDIR%BIN" set PATH=%VCINSTALLDIR%BIN;%PATH% | ||||||
|  | @set PATH=%DevEnvDir%;%PATH% | ||||||
|  | 
 | ||||||
|  | @if exist "%VSINSTALLDIR%VSTSDB\Deploy" ( | ||||||
|  | 	@set "PATH=%VSINSTALLDIR%VSTSDB\Deploy;%PATH%" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | @if not "%FSHARPINSTALLDIR%" == "" ( | ||||||
|  | 	@set "PATH=%FSHARPINSTALLDIR%;%PATH%" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | @rem INCLUDE | ||||||
|  | @rem ------- | ||||||
|  | @if exist "%VCINSTALLDIR%ATLMFC\INCLUDE" set INCLUDE=%VCINSTALLDIR%ATLMFC\INCLUDE;%INCLUDE% | ||||||
|  | @if exist "%VCINSTALLDIR%INCLUDE" set INCLUDE=%VCINSTALLDIR%INCLUDE;%INCLUDE% | ||||||
|  | 
 | ||||||
|  | @rem LIB | ||||||
|  | @rem --- | ||||||
|  | @if exist "%VCINSTALLDIR%ATLMFC\LIB" set LIB=%VCINSTALLDIR%ATLMFC\LIB;%LIB% | ||||||
|  | @if exist "%VCINSTALLDIR%LIB" set LIB=%VCINSTALLDIR%LIB;%LIB% | ||||||
|  | 
 | ||||||
|  | @rem LIBPATH | ||||||
|  | @rem ------- | ||||||
|  | @if exist "%VCINSTALLDIR%ATLMFC\LIB" set LIBPATH=%VCINSTALLDIR%ATLMFC\LIB;%LIBPATH% | ||||||
|  | @if exist "%VCINSTALLDIR%LIB" set LIBPATH=%VCINSTALLDIR%LIB;%LIBPATH% | ||||||
|  | @set LIBPATH=%FrameworkDir%%Framework35Version%;%LIBPATH% | ||||||
|  | @set LIBPATH=%FrameworkDir%%FrameworkVersion%;%LIBPATH% | ||||||
|  | 
 | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | @REM ----------------------------------------------------------------------- | ||||||
|  | :GetVSCommonToolsDir | ||||||
|  | @set VS100COMNTOOLS= | ||||||
|  | @call :GetVSCommonToolsDirHelper32 HKLM > nul 2>&1 | ||||||
|  | @if errorlevel 1 call :GetVSCommonToolsDirHelper32 HKCU > nul 2>&1 | ||||||
|  | @if errorlevel 1 call :GetVSCommonToolsDirHelper64  HKLM > nul 2>&1 | ||||||
|  | @if errorlevel 1 call :GetVSCommonToolsDirHelper64  HKCU > nul 2>&1 | ||||||
|  | @exit /B 0 | ||||||
|  | 
 | ||||||
|  | :GetVSCommonToolsDirHelper32 | ||||||
|  | @for /F "tokens=1,2*" %%i in ('reg query "%1\SOFTWARE\Microsoft\VisualStudio\SxS\VS7" /v "10.0"') DO ( | ||||||
|  | 	@if "%%i"=="10.0" ( | ||||||
|  | 		@SET "VS100COMNTOOLS=%%k" | ||||||
|  | 	) | ||||||
|  | ) | ||||||
|  | @if "%VS100COMNTOOLS%"=="" exit /B 1 | ||||||
|  | @SET "VS100COMNTOOLS=%VS100COMNTOOLS%Common7\Tools\" | ||||||
|  | @exit /B 0 | ||||||
|  | 
 | ||||||
|  | :GetVSCommonToolsDirHelper64 | ||||||
|  | @for /F "tokens=1,2*" %%i in ('reg query "%1\SOFTWARE\Wow6432Node\Microsoft\VisualStudio\SxS\VS7" /v "10.0"') DO ( | ||||||
|  | 	@if "%%i"=="10.0" ( | ||||||
|  | 		@SET "VS100COMNTOOLS=%%k" | ||||||
|  | 	) | ||||||
|  | ) | ||||||
|  | @if "%VS100COMNTOOLS%"=="" exit /B 1 | ||||||
|  | @SET "VS100COMNTOOLS=%VS100COMNTOOLS%Common7\Tools\" | ||||||
|  | @exit /B 0 | ||||||
|  | 
 | ||||||
|  | @REM ----------------------------------------------------------------------- | ||||||
|  | :error_no_VS100COMNTOOLSDIR | ||||||
|  | @echo ERROR: Cannot determine the location of the VS Common Tools folder. | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | :error_no_VSINSTALLDIR | ||||||
|  | @echo ERROR: Cannot determine the location of the VS installation. | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | :error_no_FrameworkDIR32 | ||||||
|  | @echo ERROR: Cannot determine the location of the .NET Framework 32bit installation. | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | :error_no_FrameworkVer32 | ||||||
|  | @echo ERROR: Cannot determine the version of the .NET Framework 32bit installation. | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | :error_no_Framework35Version | ||||||
|  | @echo ERROR: Cannot determine the .NET Framework 3.5 version. | ||||||
|  | @goto end | ||||||
|  | 
 | ||||||
|  | :end | ||||||
|  | 
 | ||||||
|  | msbuild msvc-2010.sln /p:Configuration=Release /target:clean | ||||||
|  | msbuild msvc-2010.sln /p:Configuration=Release | ||||||
|  | exit | ||||||
							
								
								
									
										20
									
								
								platform/libretro/msvc/msvc-2010.sln
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								platform/libretro/msvc/msvc-2010.sln
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,20 @@ | ||||||
|  |  | ||||||
|  | Microsoft Visual Studio Solution File, Format Version 11.00 | ||||||
|  | # Visual Studio 2010 | ||||||
|  | Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "msvc-2010", "msvc-2010\msvc-2010.vcxproj", "{D4156C25-0E30-4407-9198-1F51EF74AA84}" | ||||||
|  | EndProject | ||||||
|  | Global | ||||||
|  | 	GlobalSection(SolutionConfigurationPlatforms) = preSolution | ||||||
|  | 		Debug|Win32 = Debug|Win32 | ||||||
|  | 		Release|Win32 = Release|Win32 | ||||||
|  | 	EndGlobalSection | ||||||
|  | 	GlobalSection(ProjectConfigurationPlatforms) = postSolution | ||||||
|  | 		{D4156C25-0E30-4407-9198-1F51EF74AA84}.Debug|Win32.ActiveCfg = Debug|Win32 | ||||||
|  | 		{D4156C25-0E30-4407-9198-1F51EF74AA84}.Debug|Win32.Build.0 = Debug|Win32 | ||||||
|  | 		{D4156C25-0E30-4407-9198-1F51EF74AA84}.Release|Win32.ActiveCfg = Release|Win32 | ||||||
|  | 		{D4156C25-0E30-4407-9198-1F51EF74AA84}.Release|Win32.Build.0 = Release|Win32 | ||||||
|  | 	EndGlobalSection | ||||||
|  | 	GlobalSection(SolutionProperties) = preSolution | ||||||
|  | 		HideSolutionNode = FALSE | ||||||
|  | 	EndGlobalSection | ||||||
|  | EndGlobal | ||||||
							
								
								
									
										27
									
								
								platform/libretro/msvc/msvc-2010/libretro.def
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								platform/libretro/msvc/msvc-2010/libretro.def
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,27 @@ | ||||||
|  | LIBRARY "msvc-2010" | ||||||
|  | EXPORTS | ||||||
|  | retro_set_environment | ||||||
|  | retro_set_video_refresh | ||||||
|  | retro_set_audio_sample | ||||||
|  | retro_set_audio_sample_batch | ||||||
|  | retro_set_input_poll | ||||||
|  | retro_set_input_state | ||||||
|  | retro_init | ||||||
|  | retro_deinit | ||||||
|  | retro_api_version | ||||||
|  | retro_get_system_info | ||||||
|  | retro_get_system_av_info | ||||||
|  | retro_set_controller_port_device | ||||||
|  | retro_reset | ||||||
|  | retro_run | ||||||
|  | retro_serialize_size | ||||||
|  | retro_serialize | ||||||
|  | retro_unserialize | ||||||
|  | retro_cheat_reset | ||||||
|  | retro_cheat_set | ||||||
|  | retro_load_game | ||||||
|  | retro_load_game_special | ||||||
|  | retro_unload_game | ||||||
|  | retro_get_region | ||||||
|  | retro_get_memory_data | ||||||
|  | retro_get_memory_size | ||||||
							
								
								
									
										157
									
								
								platform/libretro/msvc/msvc-2010/msvc-2010.vcxproj
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										157
									
								
								platform/libretro/msvc/msvc-2010/msvc-2010.vcxproj
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,157 @@ | ||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> | ||||||
|  |   <ItemGroup Label="ProjectConfigurations"> | ||||||
|  |     <ProjectConfiguration Include="Debug|Win32"> | ||||||
|  |       <Configuration>Debug</Configuration> | ||||||
|  |       <Platform>Win32</Platform> | ||||||
|  |     </ProjectConfiguration> | ||||||
|  |     <ProjectConfiguration Include="Release|Win32"> | ||||||
|  |       <Configuration>Release</Configuration> | ||||||
|  |       <Platform>Win32</Platform> | ||||||
|  |     </ProjectConfiguration> | ||||||
|  |   </ItemGroup> | ||||||
|  |   <PropertyGroup Label="Globals"> | ||||||
|  |     <ProjectGuid>{D4156C25-0E30-4407-9198-1F51EF74AA84}</ProjectGuid> | ||||||
|  |     <Keyword>Win32Proj</Keyword> | ||||||
|  |     <RootNamespace>msvc2010</RootNamespace> | ||||||
|  |   </PropertyGroup> | ||||||
|  |   <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> | ||||||
|  |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> | ||||||
|  |     <ConfigurationType>DynamicLibrary</ConfigurationType> | ||||||
|  |     <UseDebugLibraries>true</UseDebugLibraries> | ||||||
|  |     <CharacterSet>Unicode</CharacterSet> | ||||||
|  |   </PropertyGroup> | ||||||
|  |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> | ||||||
|  |     <ConfigurationType>DynamicLibrary</ConfigurationType> | ||||||
|  |     <UseDebugLibraries>false</UseDebugLibraries> | ||||||
|  |     <WholeProgramOptimization>true</WholeProgramOptimization> | ||||||
|  |     <CharacterSet>Unicode</CharacterSet> | ||||||
|  |   </PropertyGroup> | ||||||
|  |   <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" /> | ||||||
|  |   <ImportGroup Label="ExtensionSettings"> | ||||||
|  |   </ImportGroup> | ||||||
|  |   <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> | ||||||
|  |     <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> | ||||||
|  |   </ImportGroup> | ||||||
|  |   <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> | ||||||
|  |     <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> | ||||||
|  |   </ImportGroup> | ||||||
|  |   <PropertyGroup Label="UserMacros" /> | ||||||
|  |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> | ||||||
|  |     <LinkIncremental>true</LinkIncremental> | ||||||
|  |     <OutDir>$(SolutionDir)msvc-2010\$(Configuration)\</OutDir> | ||||||
|  |   </PropertyGroup> | ||||||
|  |   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> | ||||||
|  |     <LinkIncremental>false</LinkIncremental> | ||||||
|  |     <OutDir>$(SolutionDir)msvc-2010\$(Configuration)\</OutDir> | ||||||
|  |   </PropertyGroup> | ||||||
|  |   <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> | ||||||
|  |     <ClCompile> | ||||||
|  |       <PrecompiledHeader> | ||||||
|  |       </PrecompiledHeader> | ||||||
|  |       <WarningLevel>Level3</WarningLevel> | ||||||
|  |       <Optimization>Disabled</Optimization> | ||||||
|  |       <PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;_USRDLL;MSVC2010_EXPORTS;%(PreprocessorDefinitions);INLINE=_inline;_CRT_SECURE_NO_WARNINGS;EMU_F68K;_USE_CZ80;NO_ZLIB;FAMEC_NO_GOTOS</PreprocessorDefinitions> | ||||||
|  |       <CompileAs>CompileAsC</CompileAs> | ||||||
|  |       <AdditionalIncludeDirectories>$(SolutionDir)\..\..\..\;$(SolutionDIr)\..\..\..\pico;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> | ||||||
|  |     </ClCompile> | ||||||
|  |     <Link> | ||||||
|  |       <SubSystem>Windows</SubSystem> | ||||||
|  |       <GenerateDebugInformation>true</GenerateDebugInformation> | ||||||
|  |       <ModuleDefinitionFile>libretro.def</ModuleDefinitionFile> | ||||||
|  |     </Link> | ||||||
|  |   </ItemDefinitionGroup> | ||||||
|  |   <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> | ||||||
|  |     <ClCompile> | ||||||
|  |       <WarningLevel>Level3</WarningLevel> | ||||||
|  |       <PrecompiledHeader> | ||||||
|  |       </PrecompiledHeader> | ||||||
|  |       <Optimization>MaxSpeed</Optimization> | ||||||
|  |       <FunctionLevelLinking>true</FunctionLevelLinking> | ||||||
|  |       <IntrinsicFunctions>true</IntrinsicFunctions> | ||||||
|  |       <PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;MSVC2010_EXPORTS;%(PreprocessorDefinitions);INLINE=_inline;_CRT_SECURE_NO_WARNINGS;EMU_F68K;_USE_CZ80;NO_ZLIB;FAMEC_NO_GOTOS</PreprocessorDefinitions> | ||||||
|  |       <CompileAs>CompileAsC</CompileAs> | ||||||
|  |       <AdditionalIncludeDirectories>$(SolutionDir)\..\..\..\;$(SolutionDIr)\..\..\..\pico;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> | ||||||
|  |     </ClCompile> | ||||||
|  |     <Link> | ||||||
|  |       <SubSystem>Windows</SubSystem> | ||||||
|  |       <GenerateDebugInformation>true</GenerateDebugInformation> | ||||||
|  |       <EnableCOMDATFolding>true</EnableCOMDATFolding> | ||||||
|  |       <OptimizeReferences>true</OptimizeReferences> | ||||||
|  |       <ModuleDefinitionFile>libretro.def</ModuleDefinitionFile> | ||||||
|  |     </Link> | ||||||
|  |   </ItemDefinitionGroup> | ||||||
|  |   <ItemGroup> | ||||||
|  |     <ClCompile Include="..\..\..\..\cpu\cz80\cz80.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\cpu\drc\cmn.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\cpu\fame\famec.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\cpu\sh2\mame\sh2pico.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\cpu\sh2\sh2.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\32x\32x.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\32x\32x_draw.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\32x\32x_memory.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\32x\pwm.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\32x\sh2soc.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cart.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\carthw\carthw.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\carthw\svp\svp_memory.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\carthw\svp\ssp16.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\carthw\svp\svp.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\carthw_cfg.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cdc.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cdd.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cd_image.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cell_map.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cue.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\gfx.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\gfx_dma.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\mcd.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cd_memory.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cd_misc.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\pcm.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cd_sek.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\debug.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\draw.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\draw2.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\eeprom.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\media.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\memory.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\misc.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\mode4.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\patch.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\pico.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\pico\pico_memory.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\pico\pico_pico.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\pico\xpcm.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\sek.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\sms.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\sound\mix.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\sound\sn76496.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\sound\sound.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\sound\ym2612.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\state.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\videoport.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\z80if.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\unzip\unzip.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\unzip\unzip_stream.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\adler32.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\compress.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\crc32.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\deflate.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\example.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\gzio.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\infback.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\inffast.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\inflate.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\inftrees.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\trees.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\uncompr.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\zutil.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\common\mp3.c" /> | ||||||
|  |     <ClCompile Include="..\..\..\common\mp3_dummy.c" /> | ||||||
|  |     <ClCompile Include="..\..\libretro.c" /> | ||||||
|  |   </ItemGroup> | ||||||
|  |   <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" /> | ||||||
|  |   <ImportGroup Label="ExtensionTargets"> | ||||||
|  |   </ImportGroup> | ||||||
|  | </Project> | ||||||
							
								
								
									
										277
									
								
								platform/libretro/msvc/msvc-2010/msvc-2010.vcxproj.filters
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										277
									
								
								platform/libretro/msvc/msvc-2010/msvc-2010.vcxproj.filters
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,277 @@ | ||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> | ||||||
|  |   <ItemGroup> | ||||||
|  |     <Filter Include="Source Files"> | ||||||
|  |       <UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier> | ||||||
|  |       <Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Header Files"> | ||||||
|  |       <UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier> | ||||||
|  |       <Extensions>h;hpp;hxx;hm;inl;inc;xsd</Extensions> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Resource Files"> | ||||||
|  |       <UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier> | ||||||
|  |       <Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\platform"> | ||||||
|  |       <UniqueIdentifier>{13ad8d51-3614-47ce-9d0d-8eb47a4cfabe}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\platform\libretro"> | ||||||
|  |       <UniqueIdentifier>{56e5d1cc-a749-46f0-9c75-e26037b4e2b3}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\platform\common"> | ||||||
|  |       <UniqueIdentifier>{ab1e9796-fcf3-49c2-92f2-cbce4ad50f7f}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\zlib"> | ||||||
|  |       <UniqueIdentifier>{d7cd40e2-d074-4967-84ad-89488a9eed11}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\unzip"> | ||||||
|  |       <UniqueIdentifier>{76c63342-13b7-413c-b44b-52ef07b4dccc}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\pico"> | ||||||
|  |       <UniqueIdentifier>{04bd626c-6833-49c7-8256-dc94935efe03}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\pico\cd"> | ||||||
|  |       <UniqueIdentifier>{3b94bd08-c15d-46a4-9672-094f4cafbc06}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\pico\32x"> | ||||||
|  |       <UniqueIdentifier>{403b507e-7278-436e-b8a5-5a0deb70dfae}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\pico\carthw"> | ||||||
|  |       <UniqueIdentifier>{27323686-5607-4502-9488-ac65c90e6969}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\pico\carthw\svp"> | ||||||
|  |       <UniqueIdentifier>{2e0a2f96-c25d-473e-9456-5e25b6eb8036}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\pico\sound"> | ||||||
|  |       <UniqueIdentifier>{a208ee7f-75c1-4ff9-9ed5-ea2d42832fc6}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\cpu"> | ||||||
|  |       <UniqueIdentifier>{04862576-b191-4769-a0f8-bb6400cfa861}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\cpu\famec"> | ||||||
|  |       <UniqueIdentifier>{337acc4a-3fe4-4547-b655-058d31318ffc}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\cpu\cz80"> | ||||||
|  |       <UniqueIdentifier>{63c3bec2-54b1-4831-a420-5e1aa120738b}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\cpu\drc"> | ||||||
|  |       <UniqueIdentifier>{85be1810-42b8-4ec7-bbd5-6c7d1dc5b763}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\cpu\sh2"> | ||||||
|  |       <UniqueIdentifier>{055bac11-1f11-4fe7-be7b-09ebaeab74d5}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\cpu\sh2\mame"> | ||||||
|  |       <UniqueIdentifier>{dd1911b8-6d08-42aa-ab21-0ba1154613e1}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |     <Filter Include="Source Files\pico\pico"> | ||||||
|  |       <UniqueIdentifier>{a635c355-0290-4923-84c6-8290ea8b0065}</UniqueIdentifier> | ||||||
|  |     </Filter> | ||||||
|  |   </ItemGroup> | ||||||
|  |   <ItemGroup> | ||||||
|  |     <ClCompile Include="..\..\libretro.c"> | ||||||
|  |       <Filter>Source Files\platform\libretro</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\common\mp3.c"> | ||||||
|  |       <Filter>Source Files\platform\common</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\common\mp3_dummy.c"> | ||||||
|  |       <Filter>Source Files\platform\common</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\adler32.c"> | ||||||
|  |       <Filter>Source Files\zlib</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\compress.c"> | ||||||
|  |       <Filter>Source Files\zlib</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\crc32.c"> | ||||||
|  |       <Filter>Source Files\zlib</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\deflate.c"> | ||||||
|  |       <Filter>Source Files\zlib</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\example.c"> | ||||||
|  |       <Filter>Source Files\zlib</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\gzio.c"> | ||||||
|  |       <Filter>Source Files\zlib</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\infback.c"> | ||||||
|  |       <Filter>Source Files\zlib</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\inffast.c"> | ||||||
|  |       <Filter>Source Files\zlib</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\inflate.c"> | ||||||
|  |       <Filter>Source Files\zlib</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\inftrees.c"> | ||||||
|  |       <Filter>Source Files\zlib</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\trees.c"> | ||||||
|  |       <Filter>Source Files\zlib</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\uncompr.c"> | ||||||
|  |       <Filter>Source Files\zlib</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\zlib\zutil.c"> | ||||||
|  |       <Filter>Source Files\zlib</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\unzip\unzip.c"> | ||||||
|  |       <Filter>Source Files\unzip</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\unzip\unzip_stream.c"> | ||||||
|  |       <Filter>Source Files\unzip</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cart.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\carthw_cfg.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\debug.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\draw.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\draw2.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\eeprom.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\media.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\memory.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\misc.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\mode4.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\patch.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\pico.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\sek.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\sms.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\state.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\videoport.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\z80if.c"> | ||||||
|  |       <Filter>Source Files\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cd_image.c"> | ||||||
|  |       <Filter>Source Files\pico\cd</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cdc.c"> | ||||||
|  |       <Filter>Source Files\pico\cd</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cdd.c"> | ||||||
|  |       <Filter>Source Files\pico\cd</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cell_map.c"> | ||||||
|  |       <Filter>Source Files\pico\cd</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cue.c"> | ||||||
|  |       <Filter>Source Files\pico\cd</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\gfx.c"> | ||||||
|  |       <Filter>Source Files\pico\cd</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\gfx_dma.c"> | ||||||
|  |       <Filter>Source Files\pico\cd</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\mcd.c"> | ||||||
|  |       <Filter>Source Files\pico\cd</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cd_memory.c"> | ||||||
|  |       <Filter>Source Files\pico\cd</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cd_misc.c"> | ||||||
|  |       <Filter>Source Files\pico\cd</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\pcm.c"> | ||||||
|  |       <Filter>Source Files\pico\cd</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\cd\cd_sek.c"> | ||||||
|  |       <Filter>Source Files\pico\cd</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\32x\32x.c"> | ||||||
|  |       <Filter>Source Files\pico\32x</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\32x\32x_memory.c"> | ||||||
|  |       <Filter>Source Files\pico\32x</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\32x\pwm.c"> | ||||||
|  |       <Filter>Source Files\pico\32x</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\32x\sh2soc.c"> | ||||||
|  |       <Filter>Source Files\pico\32x</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\carthw\carthw.c"> | ||||||
|  |       <Filter>Source Files\pico\carthw</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\carthw\svp\svp_memory.c"> | ||||||
|  |       <Filter>Source Files\pico\carthw\svp</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\carthw\svp\ssp16.c"> | ||||||
|  |       <Filter>Source Files\pico\carthw\svp</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\carthw\svp\svp.c"> | ||||||
|  |       <Filter>Source Files\pico\carthw\svp</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\sound\mix.c"> | ||||||
|  |       <Filter>Source Files\pico\sound</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\sound\sn76496.c"> | ||||||
|  |       <Filter>Source Files\pico\sound</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\sound\sound.c"> | ||||||
|  |       <Filter>Source Files\pico\sound</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\sound\ym2612.c"> | ||||||
|  |       <Filter>Source Files\pico\sound</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\cpu\fame\famec.c"> | ||||||
|  |       <Filter>Source Files\cpu\famec</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\cpu\cz80\cz80.c"> | ||||||
|  |       <Filter>Source Files\cpu\cz80</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\cpu\drc\cmn.c"> | ||||||
|  |       <Filter>Source Files\cpu\drc</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\cpu\sh2\sh2.c"> | ||||||
|  |       <Filter>Source Files\cpu\sh2</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\cpu\sh2\mame\sh2pico.c"> | ||||||
|  |       <Filter>Source Files\cpu\sh2\mame</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\32x\32x_draw.c"> | ||||||
|  |       <Filter>Source Files</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\pico\pico_memory.c"> | ||||||
|  |       <Filter>Source Files\pico\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\pico\pico_pico.c"> | ||||||
|  |       <Filter>Source Files\pico\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |     <ClCompile Include="..\..\..\..\pico\pico\xpcm.c"> | ||||||
|  |       <Filter>Source Files\pico\pico</Filter> | ||||||
|  |     </ClCompile> | ||||||
|  |   </ItemGroup> | ||||||
|  | </Project> | ||||||
							
								
								
									
										1756
									
								
								platform/libretro/psp/draw_amips.s
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1756
									
								
								platform/libretro/psp/draw_amips.s
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 notaz
						notaz