mirror of https://github.com/snes9xgit/snes9x.git
libretro: merge changes from libretro repo
This commit is contained in:
parent
f060f06d31
commit
ae201d0bf5
|
@ -1,9 +1,16 @@
|
||||||
|
DEBUG = 0
|
||||||
|
HAVE_EXCEPTIONS = 0
|
||||||
|
|
||||||
ifeq ($(platform),)
|
ifeq ($(platform),)
|
||||||
platform = unix
|
platform = unix
|
||||||
ifeq ($(shell uname -a),)
|
ifeq ($(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
|
||||||
|
arch = intel
|
||||||
|
ifeq ($(shell uname -p),powerpc)
|
||||||
|
arch = ppc
|
||||||
|
endif
|
||||||
else ifneq ($(findstring MINGW,$(shell uname -a)),)
|
else ifneq ($(findstring MINGW,$(shell uname -a)),)
|
||||||
platform = win
|
platform = win
|
||||||
else ifneq ($(findstring win,$(shell uname -a)),)
|
else ifneq ($(findstring win,$(shell uname -a)),)
|
||||||
|
@ -11,43 +18,105 @@ ifeq ($(platform),)
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
CXX = g++
|
CXX ?= g++
|
||||||
CC = gcc
|
CC ?= gcc
|
||||||
TARGET_NAME = snes9x
|
TARGET_NAME = snes9x
|
||||||
|
LIBM = -lm
|
||||||
|
|
||||||
|
# Unix
|
||||||
ifeq ($(platform), unix)
|
ifeq ($(platform), unix)
|
||||||
TARGET := $(TARGET_NAME)_libretro.so
|
TARGET := $(TARGET_NAME)_libretro.so
|
||||||
fpic := -fPIC
|
fpic := -fPIC
|
||||||
SHARED := -shared -Wl,--version-script=link.T
|
SHARED := -shared -Wl,--version-script=link.T
|
||||||
|
ifneq ($(findstring Haiku,$(shell uname -a)),)
|
||||||
|
LIBM :=
|
||||||
|
endif
|
||||||
|
|
||||||
|
# OS X
|
||||||
else ifeq ($(platform), osx)
|
else ifeq ($(platform), osx)
|
||||||
TARGET := $(TARGET_NAME)_libretro.dylib
|
TARGET := $(TARGET_NAME)_libretro.dylib
|
||||||
fpic := -fPIC -mmacosx-version-min=10.6
|
fpic := -fPIC
|
||||||
SHARED := -dynamiclib
|
SHARED := -dynamiclib
|
||||||
else ifeq ($(platform), ios)
|
|
||||||
|
arch = intel
|
||||||
|
ifeq ($(shell uname -p),powerpc)
|
||||||
|
arch = ppc
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq ($(arch),ppc)
|
||||||
|
CXXFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__
|
||||||
|
endif
|
||||||
|
OSXVER = `sw_vers -productVersion | cut -d. -f 2`
|
||||||
|
OSX_LT_MAVERICKS = `(( $(OSXVER) <= 9)) && echo "YES"`
|
||||||
|
fpic += -mmacosx-version-min=10.1
|
||||||
|
|
||||||
|
# iOS
|
||||||
|
else ifneq (,$(findstring ios,$(platform)))
|
||||||
TARGET := $(TARGET_NAME)_libretro_ios.dylib
|
TARGET := $(TARGET_NAME)_libretro_ios.dylib
|
||||||
fpic := -fPIC
|
fpic := -fPIC
|
||||||
SHARED := -dynamiclib
|
SHARED := -dynamiclib
|
||||||
|
|
||||||
CC = clang -arch armv7 -isysroot $(IOSSDK) -miphoneos-version-min=5.0
|
ifeq ($(IOSSDK),)
|
||||||
CXX = clang++ -arch armv7 -isysroot $(IOSSDK) -miphoneos-version-min=5.0
|
IOSSDK := $(shell xcodebuild -version -sdk iphoneos Path)
|
||||||
CXXFLAGS += -DIOS -miphoneos-version-min=5.0
|
endif
|
||||||
|
|
||||||
|
CC = clang -arch armv7 -isysroot $(IOSSDK)
|
||||||
|
CXX = clang++ -arch armv7 -isysroot $(IOSSDK)
|
||||||
|
CXXFLAGS += -DIOS
|
||||||
CXXFLAGS += -DARM
|
CXXFLAGS += -DARM
|
||||||
|
ifeq ($(platform),ios9)
|
||||||
|
CC += -miphoneos-version-min=8.0
|
||||||
|
CXX += -miphoneos-version-min=8.0
|
||||||
|
CFLAGS += -miphoneos-version-min=8.0
|
||||||
|
CXXFLAGS += -miphoneos-version-min=8.0
|
||||||
|
else
|
||||||
|
CC += -miphoneos-version-min=5.0
|
||||||
|
CXX += -miphoneos-version-min=5.0
|
||||||
|
CFLAGS += -miphoneos-version-min=5.0
|
||||||
|
CXXFLAGS += -miphoneos-version-min=5.0
|
||||||
|
endif
|
||||||
|
else ifeq ($(platform), theos_ios)
|
||||||
|
DEPLOYMENT_IOSVERSION = 5.0
|
||||||
|
TARGET = iphone:latest:$(DEPLOYMENT_IOSVERSION)
|
||||||
|
ARCHS = armv7 armv7s
|
||||||
|
TARGET_IPHONEOS_DEPLOYMENT_VERSION=$(DEPLOYMENT_IOSVERSION)
|
||||||
|
THEOS_BUILD_DIR := objs
|
||||||
|
include $(THEOS)/makefiles/common.mk
|
||||||
|
|
||||||
|
LIBRARY_NAME = $(TARGET_NAME)_libretro_ios
|
||||||
|
|
||||||
|
# QNX
|
||||||
else ifeq ($(platform), qnx)
|
else ifeq ($(platform), qnx)
|
||||||
TARGET := $(TARGET_NAME)_libretro_qnx.so
|
TARGET := $(TARGET_NAME)_libretro_$(platform).so
|
||||||
fpic := -fPIC
|
fpic := -fPIC
|
||||||
SHARED := -shared -Wl,--version-script=link.T
|
SHARED := -shared -Wl,--version-script=link.T
|
||||||
CC = qcc -Vgcc_notarmv7le
|
CC = qcc -Vgcc_notarmv7le
|
||||||
CC = QCC -Vgcc_notarmv7le_cpp
|
CXX = QCC -Vgcc_notarmv7le
|
||||||
AR = QCC -Vgcc_ntoarmv7le
|
AR = QCC -Vgcc_ntoarmv7le
|
||||||
CXXFLAGS += -D__BLACKBERRY_QNX__
|
CXXFLAGS += -D__BLACKBERRY_QNX__
|
||||||
CXXFLAGS += -DARM
|
CXXFLAGS += -DARM
|
||||||
|
HAVE_EXCEPTIONS = 1
|
||||||
|
|
||||||
|
# Vita
|
||||||
|
else ifeq ($(platform), vita)
|
||||||
|
TARGET := $(TARGET_NAME)_libretro_$(platform).so
|
||||||
|
fpic := -fPIC
|
||||||
|
CC = arm-vita-eabi-gcc$(EXE_EXT)
|
||||||
|
CXX = arm-vita-eabi-g++$(EXE_EXT)
|
||||||
|
AR = arm-vita-eabi-ar$(EXE_EXT)
|
||||||
|
CXXFLAGS += -DVITA
|
||||||
|
HAVE_EXCEPTIONS = 1
|
||||||
|
|
||||||
|
# PS3
|
||||||
else ifeq ($(platform), ps3)
|
else ifeq ($(platform), ps3)
|
||||||
TARGET := $(TARGET_NAME)_libretro_ps3.a
|
TARGET := $(TARGET_NAME)_libretro_$(platform).a
|
||||||
CC = $(CELL_SDK)/host-win32/ppu/bin/ppu-lv2-gcc.exe
|
CC = $(CELL_SDK)/host-win32/ppu/bin/ppu-lv2-gcc.exe
|
||||||
CXX = $(CELL_SDK)/host-win32/ppu/bin/ppu-lv2-g++.exe
|
CXX = $(CELL_SDK)/host-win32/ppu/bin/ppu-lv2-g++.exe
|
||||||
AR = $(CELL_SDK)/host-win32/ppu/bin/ppu-lv2-ar.exe
|
AR = $(CELL_SDK)/host-win32/ppu/bin/ppu-lv2-ar.exe
|
||||||
CXXFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__
|
CXXFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__
|
||||||
STATIC_LINKING = 1
|
STATIC_LINKING = 1
|
||||||
|
|
||||||
|
# sncps3
|
||||||
else ifeq ($(platform), sncps3)
|
else ifeq ($(platform), sncps3)
|
||||||
TARGET := $(TARGET_NAME)_libretro_ps3.a
|
TARGET := $(TARGET_NAME)_libretro_ps3.a
|
||||||
CC = $(CELL_SDK)/host-win32/sn/bin/ps3ppusnc.exe
|
CC = $(CELL_SDK)/host-win32/sn/bin/ps3ppusnc.exe
|
||||||
|
@ -55,13 +124,17 @@ else ifeq ($(platform), sncps3)
|
||||||
AR = $(CELL_SDK)/host-win32/sn/bin/ps3snarl.exe
|
AR = $(CELL_SDK)/host-win32/sn/bin/ps3snarl.exe
|
||||||
CXXFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__
|
CXXFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__
|
||||||
STATIC_LINKING = 1
|
STATIC_LINKING = 1
|
||||||
|
|
||||||
|
# Lightweight PS3 Homebrew SDK
|
||||||
else ifeq ($(platform), psl1ght)
|
else ifeq ($(platform), psl1ght)
|
||||||
TARGET := $(TARGET_NAME)_libretro_psl1ght.a
|
TARGET := $(TARGET_NAME)_libretro_$(platform).a
|
||||||
CC = $(PS3DEV)/ppu/bin/ppu-gcc$(EXE_EXT)
|
CC = $(PS3DEV)/ppu/bin/ppu-gcc$(EXE_EXT)
|
||||||
CXX = $(PS3DEV)/ppu/bin/ppu-g++$(EXE_EXT)
|
CXX = $(PS3DEV)/ppu/bin/ppu-g++$(EXE_EXT)
|
||||||
AR = $(PS3DEV)/ppu/bin/ppu-ar$(EXE_EXT)
|
AR = $(PS3DEV)/ppu/bin/ppu-ar$(EXE_EXT)
|
||||||
CXXFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__
|
CXXFLAGS += -DBLARGG_BIG_ENDIAN=1 -D__ppc__
|
||||||
STATIC_LINKING = 1
|
STATIC_LINKING = 1
|
||||||
|
|
||||||
|
# Xbox 360
|
||||||
else ifeq ($(platform), xenon)
|
else ifeq ($(platform), xenon)
|
||||||
TARGET := $(TARGET_NAME)_libretro_xenon360.a
|
TARGET := $(TARGET_NAME)_libretro_xenon360.a
|
||||||
CC = xenon-gcc$(EXE_EXT)
|
CC = xenon-gcc$(EXE_EXT)
|
||||||
|
@ -69,19 +142,27 @@ else ifeq ($(platform), xenon)
|
||||||
AR = xenon-ar$(EXE_EXT)
|
AR = xenon-ar$(EXE_EXT)
|
||||||
CXXFLAGS += -D__LIBXENON__ -m32 -D__ppc__
|
CXXFLAGS += -D__LIBXENON__ -m32 -D__ppc__
|
||||||
STATIC_LINKING = 1
|
STATIC_LINKING = 1
|
||||||
|
|
||||||
|
# Nintendo Wii
|
||||||
else ifeq ($(platform), wii)
|
else ifeq ($(platform), wii)
|
||||||
TARGET := $(TARGET_NAME)_libretro_wii.a
|
TARGET := $(TARGET_NAME)_libretro_$(platform).a
|
||||||
CC = $(DEVKITPPC)/bin/powerpc-eabi-gcc$(EXE_EXT)
|
CC = $(DEVKITPPC)/bin/powerpc-eabi-gcc$(EXE_EXT)
|
||||||
CXX = $(DEVKITPPC)/bin/powerpc-eabi-g++$(EXE_EXT)
|
CXX = $(DEVKITPPC)/bin/powerpc-eabi-g++$(EXE_EXT)
|
||||||
AR = $(DEVKITPPC)/bin/powerpc-eabi-ar$(EXE_EXT)
|
AR = $(DEVKITPPC)/bin/powerpc-eabi-ar$(EXE_EXT)
|
||||||
CXXFLAGS += -DGEKKO -mrvl -mcpu=750 -meabi -mhard-float -DBLARGG_BIG_ENDIAN=1 -D__ppc__
|
CXXFLAGS += -DGEKKO -mrvl -mcpu=750 -meabi -mhard-float -DBLARGG_BIG_ENDIAN=1 -D__ppc__
|
||||||
STATIC_LINKING = 1
|
STATIC_LINKING = 1
|
||||||
|
|
||||||
|
else ifeq ($(platform), emscripten)
|
||||||
|
TARGET := $(TARGET_NAME)_libretro_$(platform).bc
|
||||||
|
STATIC_LINKING = 1
|
||||||
|
|
||||||
|
# ARM
|
||||||
else ifneq (,$(findstring armv,$(platform)))
|
else ifneq (,$(findstring armv,$(platform)))
|
||||||
TARGET := $(TARGET_NAME)_libretro.so
|
TARGET := $(TARGET_NAME)_libretro.so
|
||||||
SHARED := -shared -Wl,--no-undefined
|
SHARED := -shared -Wl,--no-undefined
|
||||||
fpic := -fPIC
|
fpic := -fPIC
|
||||||
CC = gcc
|
CC ?= gcc
|
||||||
CXX = g++
|
CXX ?= g++
|
||||||
ifneq (,$(findstring cortexa8,$(platform)))
|
ifneq (,$(findstring cortexa8,$(platform)))
|
||||||
CXXFLAGS += -marm -mcpu=cortex-a8
|
CXXFLAGS += -marm -mcpu=cortex-a8
|
||||||
else ifneq (,$(findstring cortexa9,$(platform)))
|
else ifneq (,$(findstring cortexa9,$(platform)))
|
||||||
|
@ -98,17 +179,30 @@ else ifneq (,$(findstring hardfloat,$(platform)))
|
||||||
CXXFLAGS += -mfloat-abi=hard
|
CXXFLAGS += -mfloat-abi=hard
|
||||||
endif
|
endif
|
||||||
CXXFLAGS += -DARM
|
CXXFLAGS += -DARM
|
||||||
|
|
||||||
|
# Windows
|
||||||
else
|
else
|
||||||
TARGET := $(TARGET_NAME)_libretro.dll
|
TARGET := $(TARGET_NAME)_libretro.dll
|
||||||
CC = gcc
|
CC = gcc
|
||||||
CXX = g++
|
CXX = g++
|
||||||
SHARED := -shared -static-libgcc -static-libstdc++ -s -Wl,--version-script=link.T
|
SHARED := -shared -static-libgcc -static-libstdc++ -s -Wl,--version-script=link.T
|
||||||
CXXFLAGS += -D__WIN32__ -D__WIN32_LIBSNES__
|
CXXFLAGS += -D__WIN32__ -D__WIN32_LIBSNES__
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
OBJECTS = ../apu/apu.o ../apu/bapu/dsp/sdsp.o ../apu/bapu/dsp/SPC_DSP.o ../apu/bapu/smp/smp.o ../apu/bapu/smp/smp_state.o ../bsx.o ../c4.o ../c4emu.o ../cheats.o ../cheats2.o ../clip.o ../conffile.o ../controls.o ../cpu.o ../cpuexec.o ../cpuops.o ../crosshairs.o ../dma.o ../dsp.o ../dsp1.o ../dsp2.o ../dsp3.o ../dsp4.o ../fxinst.o ../fxemu.o ../gfx.o ../globals.o ../logger.o ../memmap.o ../movie.o ../obc1.o ../ppu.o ../stream.o ../sa1.o ../sa1cpu.o ../screenshot.o ../sdd1.o ../sdd1emu.o ../seta.o ../seta010.o ../seta011.o ../seta018.o ../snapshot.o ../snes9x.o ../spc7110.o ../srtc.o ../tile.o libretro.o
|
CORE_DIR := ..
|
||||||
|
|
||||||
INCLUDES = -I. -I.. -I../apu/ -I../apu/bapu
|
ifeq ($(DEBUG), 1)
|
||||||
|
CXXFLAGS += -O0 -g
|
||||||
|
CFLAGS += -O0 -g
|
||||||
|
else
|
||||||
|
CXXFLAGS += -O3 -DNDEBUG
|
||||||
|
CFLAGS += -O3 -DNDEBUG
|
||||||
|
endif
|
||||||
|
|
||||||
|
include Makefile.common
|
||||||
|
|
||||||
|
OBJECTS := $(SOURCES_CXX:.cpp=.o) $(SOURCES_C:.c=.o)
|
||||||
|
|
||||||
ifeq ($(platform), sncps3)
|
ifeq ($(platform), sncps3)
|
||||||
WARNINGS_DEFINES =
|
WARNINGS_DEFINES =
|
||||||
|
@ -118,25 +212,36 @@ else
|
||||||
CODE_DEFINES = -fomit-frame-pointer
|
CODE_DEFINES = -fomit-frame-pointer
|
||||||
endif
|
endif
|
||||||
|
|
||||||
CXXFLAGS += -O3 $(CODE_DEFINES) -fno-exceptions -fno-rtti -pedantic $(WARNINGS_DEFINES) $(fpic)
|
ifneq ($(HAVE_EXCEPTIONS), 1)
|
||||||
|
CXXFLAGS += -fno-exceptions
|
||||||
|
endif
|
||||||
|
|
||||||
|
CXXFLAGS += $(CODE_DEFINES) -fno-rtti -pedantic $(WARNINGS_DEFINES) $(fpic)
|
||||||
CXXFLAGS += -DHAVE_STRINGS_H -DHAVE_STDINT_H -DRIGHTSHIFT_IS_SAR -D__LIBRETRO__
|
CXXFLAGS += -DHAVE_STRINGS_H -DHAVE_STDINT_H -DRIGHTSHIFT_IS_SAR -D__LIBRETRO__
|
||||||
CFLAGS = $(CXXFLAGS)
|
CFLAGS = $(CXXFLAGS)
|
||||||
|
|
||||||
|
ifeq ($(platform), theos_ios)
|
||||||
|
COMMON_FLAGS := -DIOS -DARM $(COMMON_DEFINES) $(INCFLAGS) -I$(THEOS_INCLUDE_PATH) -Wno-error
|
||||||
|
$(LIBRARY_NAME)_CFLAGS += $(CFLAGS) $(COMMON_FLAGS)
|
||||||
|
$(LIBRARY_NAME)_CXXFLAGS += $(CXXFLAGS) $(COMMON_FLAGS)
|
||||||
|
${LIBRARY_NAME}_FILES = $(SOURCES_CXX) $(SOURCES_C)
|
||||||
|
include $(THEOS_MAKE_PATH)/library.mk
|
||||||
|
else
|
||||||
all: $(TARGET)
|
all: $(TARGET)
|
||||||
|
|
||||||
$(TARGET): $(OBJECTS)
|
$(TARGET): $(OBJECTS)
|
||||||
ifeq ($(STATIC_LINKING), 1)
|
ifeq ($(STATIC_LINKING), 1)
|
||||||
$(AR) rcs $@ $(OBJECTS)
|
$(AR) rcs $@ $(OBJECTS)
|
||||||
else
|
else
|
||||||
$(CXX) $(fpic) $(SHARED) $(INCLUDES) -o $@ $(OBJECTS) -lm
|
$(CXX) $(fpic) $(SHARED) $(INCFLAGS) -o $@ $(OBJECTS) $(LIBM)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
%.o: %.cpp
|
%.o: %.cpp
|
||||||
$(CXX) $(INCLUDES) $(CXXFLAGS) -c -o $@ $<
|
$(CXX) $(INCFLAGS) $(CXXFLAGS) -c -o $@ $<
|
||||||
|
|
||||||
%.o: %.c
|
%.o: %.c
|
||||||
$(CC) $(INCLUDES) $(CFLAGS) -c -o $@ $<
|
$(CC) $(INCFLAGS) $(CFLAGS) -c -o $@ $<
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f $(OBJECTS) $(TARGET)
|
rm -f $(OBJECTS) $(TARGET)
|
||||||
|
endif
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
<ProjectGuid>{4A2A7544-0547-4539-8B53-047FB9A15C75}</ProjectGuid>
|
<ProjectGuid>{4A2A7544-0547-4539-8B53-047FB9A15C75}</ProjectGuid>
|
||||||
<RootNamespace>libsneswin32</RootNamespace>
|
<RootNamespace>libsneswin32</RootNamespace>
|
||||||
<Keyword>Win32Proj</Keyword>
|
<Keyword>Win32Proj</Keyword>
|
||||||
|
<WindowsTargetPlatformVersion>8.1</WindowsTargetPlatformVersion>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='libsnes Release|Win32'" Label="Configuration">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='libsnes Release|Win32'" Label="Configuration">
|
||||||
|
@ -69,21 +70,25 @@
|
||||||
<OutDir>$(Platform)\$(Configuration)\</OutDir>
|
<OutDir>$(Platform)\$(Configuration)\</OutDir>
|
||||||
<IntDir>$(Platform)\$(Configuration)\</IntDir>
|
<IntDir>$(Platform)\$(Configuration)\</IntDir>
|
||||||
<LinkIncremental>true</LinkIncremental>
|
<LinkIncremental>true</LinkIncremental>
|
||||||
|
<TargetName>libretro_debug</TargetName>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='libsnes Debug|x64'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='libsnes Debug|x64'">
|
||||||
<OutDir>$(Platform)\$(Configuration)\</OutDir>
|
<OutDir>$(Platform)\$(Configuration)\</OutDir>
|
||||||
<IntDir>$(Platform)\$(Configuration)\</IntDir>
|
<IntDir>$(Platform)\$(Configuration)\</IntDir>
|
||||||
<LinkIncremental>true</LinkIncremental>
|
<LinkIncremental>true</LinkIncremental>
|
||||||
|
<TargetName>libretro_debug</TargetName>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='libsnes Release|Win32'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='libsnes Release|Win32'">
|
||||||
<OutDir>$(Platform)\$(Configuration)\</OutDir>
|
<OutDir>$(Platform)\$(Configuration)\</OutDir>
|
||||||
<IntDir>$(Platform)\$(Configuration)\</IntDir>
|
<IntDir>$(Platform)\$(Configuration)\</IntDir>
|
||||||
<LinkIncremental>false</LinkIncremental>
|
<LinkIncremental>false</LinkIncremental>
|
||||||
|
<TargetName>libretro</TargetName>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='libsnes Release|x64'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='libsnes Release|x64'">
|
||||||
<OutDir>$(Platform)\$(Configuration)\</OutDir>
|
<OutDir>$(Platform)\$(Configuration)\</OutDir>
|
||||||
<IntDir>$(Platform)\$(Configuration)\</IntDir>
|
<IntDir>$(Platform)\$(Configuration)\</IntDir>
|
||||||
<LinkIncremental>false</LinkIncremental>
|
<LinkIncremental>false</LinkIncremental>
|
||||||
|
<TargetName>libretro</TargetName>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='libsnes Debug|Win32'">
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='libsnes Debug|Win32'">
|
||||||
<ClCompile>
|
<ClCompile>
|
||||||
|
@ -98,8 +103,8 @@
|
||||||
<DebugInformationFormat>EditAndContinue</DebugInformationFormat>
|
<DebugInformationFormat>EditAndContinue</DebugInformationFormat>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<OutputFile>$(OutDir)libretro.dll</OutputFile>
|
<ModuleDefinitionFile>
|
||||||
<ModuleDefinitionFile>libretro.def</ModuleDefinitionFile>
|
</ModuleDefinitionFile>
|
||||||
<GenerateDebugInformation>true</GenerateDebugInformation>
|
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
<TargetMachine>MachineX86</TargetMachine>
|
<TargetMachine>MachineX86</TargetMachine>
|
||||||
|
@ -121,8 +126,8 @@
|
||||||
<DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
|
<DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<OutputFile>$(OutDir)libretro.dll</OutputFile>
|
<ModuleDefinitionFile>
|
||||||
<ModuleDefinitionFile>libretro.def</ModuleDefinitionFile>
|
</ModuleDefinitionFile>
|
||||||
<GenerateDebugInformation>true</GenerateDebugInformation>
|
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
<TargetMachine>MachineX64</TargetMachine>
|
<TargetMachine>MachineX64</TargetMachine>
|
||||||
|
@ -143,8 +148,8 @@
|
||||||
<DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
|
<DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<OutputFile>$(OutDir)libretro.dll</OutputFile>
|
<ModuleDefinitionFile>
|
||||||
<ModuleDefinitionFile>libretro.def</ModuleDefinitionFile>
|
</ModuleDefinitionFile>
|
||||||
<GenerateDebugInformation>true</GenerateDebugInformation>
|
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
<OptimizeReferences>true</OptimizeReferences>
|
<OptimizeReferences>true</OptimizeReferences>
|
||||||
|
@ -171,8 +176,8 @@
|
||||||
<DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
|
<DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<OutputFile>$(OutDir)libretro.dll</OutputFile>
|
<ModuleDefinitionFile>
|
||||||
<ModuleDefinitionFile>libretro.def</ModuleDefinitionFile>
|
</ModuleDefinitionFile>
|
||||||
<GenerateDebugInformation>true</GenerateDebugInformation>
|
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
<OptimizeReferences>true</OptimizeReferences>
|
<OptimizeReferences>true</OptimizeReferences>
|
||||||
|
@ -290,9 +295,6 @@
|
||||||
<ClCompile Include="..\tile.cpp" />
|
<ClCompile Include="..\tile.cpp" />
|
||||||
<ClCompile Include="libretro.cpp" />
|
<ClCompile Include="libretro.cpp" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
|
||||||
<None Include="libretro.def" />
|
|
||||||
</ItemGroup>
|
|
||||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
||||||
<ImportGroup Label="ExtensionTargets">
|
<ImportGroup Label="ExtensionTargets">
|
||||||
</ImportGroup>
|
</ImportGroup>
|
||||||
|
|
|
@ -39,35 +39,35 @@
|
||||||
#define RETRO_GAME_TYPE_SUPER_GAME_BOY 0x104
|
#define RETRO_GAME_TYPE_SUPER_GAME_BOY 0x104
|
||||||
|
|
||||||
static retro_log_printf_t log_cb = NULL;
|
static retro_log_printf_t log_cb = NULL;
|
||||||
static retro_video_refresh_t s9x_video_cb = NULL;
|
static retro_video_refresh_t video_cb = NULL;
|
||||||
static retro_audio_sample_t s9x_audio_cb = NULL;
|
static retro_audio_sample_t audio_cb = NULL;
|
||||||
static retro_audio_sample_batch_t s9x_audio_batch_cb = NULL;
|
static retro_audio_sample_batch_t audio_batch_cb = NULL;
|
||||||
static retro_input_poll_t s9x_poller_cb = NULL;
|
static retro_input_poll_t poll_cb = NULL;
|
||||||
static retro_input_state_t s9x_input_state_cb = NULL;
|
static retro_input_state_t input_state_cb = NULL;
|
||||||
|
|
||||||
void retro_set_video_refresh(retro_video_refresh_t cb)
|
void retro_set_video_refresh(retro_video_refresh_t cb)
|
||||||
{
|
{
|
||||||
s9x_video_cb = cb;
|
video_cb = cb;
|
||||||
}
|
}
|
||||||
|
|
||||||
void retro_set_audio_sample(retro_audio_sample_t cb)
|
void retro_set_audio_sample(retro_audio_sample_t cb)
|
||||||
{
|
{
|
||||||
s9x_audio_cb = cb;
|
audio_cb = cb;
|
||||||
}
|
}
|
||||||
|
|
||||||
void retro_set_audio_sample_batch(retro_audio_sample_batch_t cb)
|
void retro_set_audio_sample_batch(retro_audio_sample_batch_t cb)
|
||||||
{
|
{
|
||||||
s9x_audio_batch_cb = cb;
|
audio_batch_cb = cb;
|
||||||
}
|
}
|
||||||
|
|
||||||
void retro_set_input_poll(retro_input_poll_t cb)
|
void retro_set_input_poll(retro_input_poll_t cb)
|
||||||
{
|
{
|
||||||
s9x_poller_cb = cb;
|
poll_cb = cb;
|
||||||
}
|
}
|
||||||
|
|
||||||
void retro_set_input_state(retro_input_state_t cb)
|
void retro_set_input_state(retro_input_state_t cb)
|
||||||
{
|
{
|
||||||
s9x_input_state_cb = cb;
|
input_state_cb = cb;
|
||||||
}
|
}
|
||||||
|
|
||||||
static retro_environment_t environ_cb;
|
static retro_environment_t environ_cb;
|
||||||
|
@ -81,33 +81,33 @@ void retro_set_environment(retro_environment_t cb)
|
||||||
// These variable names and possible values constitute an ABI with ZMZ (ZSNES Libretro player).
|
// These variable names and possible values constitute an ABI with ZMZ (ZSNES Libretro player).
|
||||||
// Changing "Show layer 1" is fine, but don't change "layer_1"/etc or the possible values ("Yes|No").
|
// Changing "Show layer 1" is fine, but don't change "layer_1"/etc or the possible values ("Yes|No").
|
||||||
// Adding more variables and rearranging them is safe.
|
// Adding more variables and rearranging them is safe.
|
||||||
{ "s9x_layer_1", "Show layer 1; Yes|No" },
|
{ "snes9x_layer_1", "Show layer 1; Yes|No" },
|
||||||
{ "s9x_layer_2", "Show layer 2; Yes|No" },
|
{ "snes9x_layer_2", "Show layer 2; Yes|No" },
|
||||||
{ "s9x_layer_3", "Show layer 3; Yes|No" },
|
{ "snes9x_layer_3", "Show layer 3; Yes|No" },
|
||||||
{ "s9x_layer_4", "Show layer 4; Yes|No" },
|
{ "snes9x_layer_4", "Show layer 4; Yes|No" },
|
||||||
{ "s9x_layer_5", "Show sprite layer; Yes|No" },
|
{ "snes9x_layer_5", "Show sprite layer; Yes|No" },
|
||||||
{ "s9x_gfx_clip", "Enable graphic clip windows; Yes|No" },
|
{ "snes9x_gfx_clip", "Enable graphic clip windows; Yes|No" },
|
||||||
{ "s9x_gfx_transp", "Enable transparency effects; Yes|No" },
|
{ "snes9x_gfx_transp", "Enable transparency effects; Yes|No" },
|
||||||
{ "s9x_sndchan_1", "Enable sound channel 1; Yes|No" },
|
{ "snes9x_sndchan_1", "Enable sound channel 1; Yes|No" },
|
||||||
{ "s9x_sndchan_2", "Enable sound channel 2; Yes|No" },
|
{ "snes9x_sndchan_2", "Enable sound channel 2; Yes|No" },
|
||||||
{ "s9x_sndchan_3", "Enable sound channel 3; Yes|No" },
|
{ "snes9x_sndchan_3", "Enable sound channel 3; Yes|No" },
|
||||||
{ "s9x_sndchan_4", "Enable sound channel 4; Yes|No" },
|
{ "snes9x_sndchan_4", "Enable sound channel 4; Yes|No" },
|
||||||
{ "s9x_sndchan_5", "Enable sound channel 5; Yes|No" },
|
{ "snes9x_sndchan_5", "Enable sound channel 5; Yes|No" },
|
||||||
{ "s9x_sndchan_6", "Enable sound channel 6; Yes|No" },
|
{ "snes9x_sndchan_6", "Enable sound channel 6; Yes|No" },
|
||||||
{ "s9x_sndchan_7", "Enable sound channel 7; Yes|No" },
|
{ "snes9x_sndchan_7", "Enable sound channel 7; Yes|No" },
|
||||||
{ "s9x_sndchan_8", "Enable sound channel 8; Yes|No" },
|
{ "snes9x_sndchan_8", "Enable sound channel 8; Yes|No" },
|
||||||
{ NULL, NULL },
|
{ NULL, NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
environ_cb(RETRO_ENVIRONMENT_SET_VARIABLES, (void *)variables);
|
environ_cb(RETRO_ENVIRONMENT_SET_VARIABLES, (void *)variables);
|
||||||
|
|
||||||
static const struct retro_controller_description port_1[] = {
|
const struct retro_controller_description port_1[] = {
|
||||||
{ "SNES Joypad", RETRO_DEVICE_JOYPAD },
|
{ "SNES Joypad", RETRO_DEVICE_JOYPAD },
|
||||||
{ "SNES Mouse", RETRO_DEVICE_MOUSE },
|
{ "SNES Mouse", RETRO_DEVICE_MOUSE },
|
||||||
{ "Multitap", RETRO_DEVICE_JOYPAD_MULTITAP },
|
{ "Multitap", RETRO_DEVICE_JOYPAD_MULTITAP },
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct retro_controller_description port_2[] = {
|
const struct retro_controller_description port_2[] = {
|
||||||
{ "SNES Joypad", RETRO_DEVICE_JOYPAD },
|
{ "SNES Joypad", RETRO_DEVICE_JOYPAD },
|
||||||
{ "SNES Mouse", RETRO_DEVICE_MOUSE },
|
{ "SNES Mouse", RETRO_DEVICE_MOUSE },
|
||||||
{ "Multitap", RETRO_DEVICE_JOYPAD_MULTITAP },
|
{ "Multitap", RETRO_DEVICE_JOYPAD_MULTITAP },
|
||||||
|
@ -126,37 +126,37 @@ void retro_set_environment(retro_environment_t cb)
|
||||||
|
|
||||||
static void update_variables(void)
|
static void update_variables(void)
|
||||||
{
|
{
|
||||||
char key[14];
|
char key[256];
|
||||||
struct retro_variable var;
|
struct retro_variable var;
|
||||||
|
|
||||||
var.key=key;
|
var.key=key;
|
||||||
|
|
||||||
int disabled_channels=0;
|
int disabled_channels=0;
|
||||||
strcpy(key, "s9x_sndchan_x");
|
strcpy(key, "snes9x_sndchan_x");
|
||||||
for (int i=0;i<8;i++)
|
for (int i=0;i<8;i++)
|
||||||
{
|
{
|
||||||
key[strlen("s9x_sndchan_")]='1'+i;
|
key[strlen("snes9x_sndchan_")]='1'+i;
|
||||||
var.value=NULL;
|
var.value=NULL;
|
||||||
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value && var.value[0]=='N') disabled_channels|=1<<i;
|
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value && var.value[0]=='N') disabled_channels|=1<<i;
|
||||||
}
|
}
|
||||||
S9xSetSoundControl(disabled_channels^0xFF);
|
S9xSetSoundControl(disabled_channels^0xFF);
|
||||||
|
|
||||||
int disabled_layers=0;
|
int disabled_layers=0;
|
||||||
strcpy(key, "s9x_layer_x");
|
strcpy(key, "snes9x_layer_x");
|
||||||
for (int i=0;i<5;i++)
|
for (int i=0;i<5;i++)
|
||||||
{
|
{
|
||||||
key[strlen("s9x_layer_")]='1'+i;
|
key[strlen("snes9x_layer_")]='1'+i;
|
||||||
var.value=NULL;
|
var.value=NULL;
|
||||||
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value && var.value[0]=='N') disabled_layers|=1<<i;
|
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value && var.value[0]=='N') disabled_layers|=1<<i;
|
||||||
}
|
}
|
||||||
Settings.BG_Forced=disabled_layers;
|
Settings.BG_Forced=disabled_layers;
|
||||||
|
|
||||||
//for some reason, Transparency seems to control both the fixed color and the windowing registers?
|
//for some reason, Transparency seems to control both the fixed color and the windowing registers?
|
||||||
var.key="s9x_gfx_clip";
|
var.key="snes9x_gfx_clip";
|
||||||
var.value=NULL;
|
var.value=NULL;
|
||||||
Settings.DisableGraphicWindows=(environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value && var.value[0]=='N');
|
Settings.DisableGraphicWindows=(environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value && var.value[0]=='N');
|
||||||
|
|
||||||
var.key="s9x_gfx_transp";
|
var.key="snes9x_gfx_transp";
|
||||||
var.value=NULL;
|
var.value=NULL;
|
||||||
Settings.Transparency=!(environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value && var.value[0]=='N');
|
Settings.Transparency=!(environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value && var.value[0]=='N');
|
||||||
}
|
}
|
||||||
|
@ -169,14 +169,14 @@ static void S9xAudioCallback(void*)
|
||||||
S9xFinalizeSamples();
|
S9xFinalizeSamples();
|
||||||
size_t avail = S9xGetSampleCount();
|
size_t avail = S9xGetSampleCount();
|
||||||
S9xMixSamples((uint8*)audio_buf, avail);
|
S9xMixSamples((uint8*)audio_buf, avail);
|
||||||
s9x_audio_batch_cb(audio_buf,avail >> 1);
|
audio_batch_cb(audio_buf,avail >> 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void retro_get_system_info(struct retro_system_info *info)
|
void retro_get_system_info(struct retro_system_info *info)
|
||||||
{
|
{
|
||||||
memset(info,0,sizeof(retro_system_info));
|
memset(info,0,sizeof(retro_system_info));
|
||||||
|
|
||||||
info->library_name = "SNES9x";
|
info->library_name = "Snes9x";
|
||||||
info->library_version = VERSION;
|
info->library_version = VERSION;
|
||||||
info->valid_extensions = "smc|sfc|swc|fig";
|
info->valid_extensions = "smc|sfc|swc|fig";
|
||||||
info->need_fullpath = false;
|
info->need_fullpath = false;
|
||||||
|
@ -185,17 +185,6 @@ void retro_get_system_info(struct retro_system_info *info)
|
||||||
|
|
||||||
void retro_get_system_av_info(struct retro_system_av_info *info)
|
void retro_get_system_av_info(struct retro_system_av_info *info)
|
||||||
{
|
{
|
||||||
int pixel_format = RGB555;
|
|
||||||
if(environ_cb) {
|
|
||||||
pixel_format = RGB565;
|
|
||||||
enum retro_pixel_format fmt = RETRO_PIXEL_FORMAT_RGB565;
|
|
||||||
if (!environ_cb(RETRO_ENVIRONMENT_SET_PIXEL_FORMAT, &fmt))
|
|
||||||
pixel_format = RGB555;
|
|
||||||
}
|
|
||||||
S9xGraphicsDeinit();
|
|
||||||
S9xSetRenderPixelFormat(pixel_format);
|
|
||||||
S9xGraphicsInit();
|
|
||||||
|
|
||||||
memset(info,0,sizeof(retro_system_av_info));
|
memset(info,0,sizeof(retro_system_av_info));
|
||||||
|
|
||||||
info->geometry.base_width = SNES_WIDTH;
|
info->geometry.base_width = SNES_WIDTH;
|
||||||
|
@ -290,13 +279,99 @@ void retro_cheat_set(unsigned index, bool enabled, const char *code)
|
||||||
S9xApplyCheats();
|
S9xApplyCheats();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void init_descriptors(void)
|
||||||
|
{
|
||||||
|
struct retro_input_descriptor desc[] = {
|
||||||
|
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT, "D-Pad Left" },
|
||||||
|
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_UP, "D-Pad Up" },
|
||||||
|
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_DOWN, "D-Pad Down" },
|
||||||
|
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT, "D-Pad Right" },
|
||||||
|
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B, "B" },
|
||||||
|
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_A, "A" },
|
||||||
|
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_X, "X" },
|
||||||
|
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_Y, "Y" },
|
||||||
|
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_L, "L" },
|
||||||
|
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_R, "R" },
|
||||||
|
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_SELECT, "Select" },
|
||||||
|
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_START, "Start" },
|
||||||
|
|
||||||
|
{ 1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT, "D-Pad Left" },
|
||||||
|
{ 1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_UP, "D-Pad Up" },
|
||||||
|
{ 1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_DOWN, "D-Pad Down" },
|
||||||
|
{ 1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT, "D-Pad Right" },
|
||||||
|
{ 1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B, "B" },
|
||||||
|
{ 1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_A, "A" },
|
||||||
|
{ 1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_X, "X" },
|
||||||
|
{ 1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_Y, "Y" },
|
||||||
|
{ 1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_L, "L" },
|
||||||
|
{ 1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_R, "R" },
|
||||||
|
{ 1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_SELECT, "Select" },
|
||||||
|
{ 1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_START, "Start" },
|
||||||
|
|
||||||
|
{ 2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT, "D-Pad Left" },
|
||||||
|
{ 2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_UP, "D-Pad Up" },
|
||||||
|
{ 2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_DOWN, "D-Pad Down" },
|
||||||
|
{ 2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT, "D-Pad Right" },
|
||||||
|
{ 2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B, "B" },
|
||||||
|
{ 2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_A, "A" },
|
||||||
|
{ 2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_X, "X" },
|
||||||
|
{ 2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_Y, "Y" },
|
||||||
|
{ 2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_L, "L" },
|
||||||
|
{ 2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_R, "R" },
|
||||||
|
{ 2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_SELECT, "Select" },
|
||||||
|
{ 2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_START, "Start" },
|
||||||
|
|
||||||
|
{ 3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT, "D-Pad Left" },
|
||||||
|
{ 3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_UP, "D-Pad Up" },
|
||||||
|
{ 3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_DOWN, "D-Pad Down" },
|
||||||
|
{ 3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT, "D-Pad Right" },
|
||||||
|
{ 3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B, "B" },
|
||||||
|
{ 3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_A, "A" },
|
||||||
|
{ 3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_X, "X" },
|
||||||
|
{ 3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_Y, "Y" },
|
||||||
|
{ 3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_L, "L" },
|
||||||
|
{ 3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_R, "R" },
|
||||||
|
{ 3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_SELECT, "Select" },
|
||||||
|
{ 3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_START, "Start" },
|
||||||
|
|
||||||
|
{ 4, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT, "D-Pad Left" },
|
||||||
|
{ 4, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_UP, "D-Pad Up" },
|
||||||
|
{ 4, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_DOWN, "D-Pad Down" },
|
||||||
|
{ 4, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT, "D-Pad Right" },
|
||||||
|
{ 4, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B, "B" },
|
||||||
|
{ 4, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_A, "A" },
|
||||||
|
{ 4, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_X, "X" },
|
||||||
|
{ 4, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_Y, "Y" },
|
||||||
|
{ 4, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_L, "L" },
|
||||||
|
{ 4, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_R, "R" },
|
||||||
|
{ 4, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_SELECT, "Select" },
|
||||||
|
{ 4, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_START, "Start" },
|
||||||
|
|
||||||
|
{ 0 },
|
||||||
|
};
|
||||||
|
|
||||||
|
environ_cb(RETRO_ENVIRONMENT_SET_INPUT_DESCRIPTORS, desc);
|
||||||
|
}
|
||||||
|
|
||||||
bool retro_load_game(const struct retro_game_info *game)
|
bool retro_load_game(const struct retro_game_info *game)
|
||||||
{
|
{
|
||||||
|
init_descriptors();
|
||||||
if(game->data == NULL && game->size == 0 && game->path != NULL)
|
if(game->data == NULL && game->size == 0 && game->path != NULL)
|
||||||
rom_loaded = Memory.LoadROM(game->path);
|
rom_loaded = Memory.LoadROM(game->path);
|
||||||
else
|
else
|
||||||
rom_loaded = Memory.LoadROMMem((const uint8_t*)game->data ,game->size);
|
rom_loaded = Memory.LoadROMMem((const uint8_t*)game->data ,game->size);
|
||||||
|
|
||||||
|
int pixel_format = RGB555;
|
||||||
|
if(environ_cb) {
|
||||||
|
pixel_format = RGB565;
|
||||||
|
enum retro_pixel_format fmt = RETRO_PIXEL_FORMAT_RGB565;
|
||||||
|
if (!environ_cb(RETRO_ENVIRONMENT_SET_PIXEL_FORMAT, &fmt))
|
||||||
|
pixel_format = RGB555;
|
||||||
|
}
|
||||||
|
S9xGraphicsDeinit();
|
||||||
|
S9xSetRenderPixelFormat(pixel_format);
|
||||||
|
S9xGraphicsInit();
|
||||||
|
|
||||||
if (!rom_loaded && log_cb)
|
if (!rom_loaded && log_cb)
|
||||||
log_cb(RETRO_LOG_ERROR, "[libretro]: Rom loading failed...\n");
|
log_cb(RETRO_LOG_ERROR, "[libretro]: Rom loading failed...\n");
|
||||||
|
|
||||||
|
@ -309,6 +384,7 @@ void retro_unload_game(void)
|
||||||
bool retro_load_game_special(unsigned game_type,
|
bool retro_load_game_special(unsigned game_type,
|
||||||
const struct retro_game_info *info, size_t num_info) {
|
const struct retro_game_info *info, size_t num_info) {
|
||||||
|
|
||||||
|
init_descriptors();
|
||||||
switch (game_type) {
|
switch (game_type) {
|
||||||
case RETRO_GAME_TYPE_BSX:
|
case RETRO_GAME_TYPE_BSX:
|
||||||
|
|
||||||
|
@ -356,6 +432,12 @@ bool retro_load_game_special(unsigned game_type,
|
||||||
|
|
||||||
static void map_buttons();
|
static void map_buttons();
|
||||||
|
|
||||||
|
static void check_system_specs(void)
|
||||||
|
{
|
||||||
|
/* TODO - might have to variably set performance level based on SuperFX/SA-1/etc */
|
||||||
|
unsigned level = 12;
|
||||||
|
environ_cb(RETRO_ENVIRONMENT_SET_PERFORMANCE_LEVEL, &level);
|
||||||
|
}
|
||||||
|
|
||||||
void retro_init()
|
void retro_init()
|
||||||
{
|
{
|
||||||
|
@ -426,7 +508,7 @@ void retro_init()
|
||||||
|
|
||||||
S9xUnmapAllControls();
|
S9xUnmapAllControls();
|
||||||
map_buttons();
|
map_buttons();
|
||||||
|
check_system_specs();
|
||||||
}
|
}
|
||||||
|
|
||||||
#define MAP_BUTTON(id, name) S9xMapButton((id), S9xGetCommandT((name)), false)
|
#define MAP_BUTTON(id, name) S9xMapButton((id), S9xGetCommandT((name)), false)
|
||||||
|
@ -472,6 +554,7 @@ void retro_init()
|
||||||
#define JUSTIFIER_X RETRO_DEVICE_ID_JUSTIFIER_X
|
#define JUSTIFIER_X RETRO_DEVICE_ID_JUSTIFIER_X
|
||||||
#define JUSTIFIER_Y RETRO_DEVICE_ID_JUSTIFIER_Y
|
#define JUSTIFIER_Y RETRO_DEVICE_ID_JUSTIFIER_Y
|
||||||
#define JUSTIFIER_TRIGGER RETRO_DEVICE_ID_LIGHTGUN_TRIGGER
|
#define JUSTIFIER_TRIGGER RETRO_DEVICE_ID_LIGHTGUN_TRIGGER
|
||||||
|
#define JUSTIFIER_OFFSCREEN RETRO_DEVICE_ID_LIGHTGUN_TURBO
|
||||||
#define JUSTIFIER_START RETRO_DEVICE_ID_LIGHTGUN_PAUSE
|
#define JUSTIFIER_START RETRO_DEVICE_ID_LIGHTGUN_PAUSE
|
||||||
#define JUSTIFIER_FIRST JUSTIFIER_X
|
#define JUSTIFIER_FIRST JUSTIFIER_X
|
||||||
#define JUSTIFIER_LAST JUSTIFIER_START
|
#define JUSTIFIER_LAST JUSTIFIER_START
|
||||||
|
@ -506,7 +589,7 @@ static void map_buttons()
|
||||||
MAP_BUTTON(MAKE_BUTTON(PAD_2, BTN_R), "Joypad2 R");
|
MAP_BUTTON(MAKE_BUTTON(PAD_2, BTN_R), "Joypad2 R");
|
||||||
MAP_BUTTON(MAKE_BUTTON(PAD_2, BTN_LEFT), "Joypad2 Left");
|
MAP_BUTTON(MAKE_BUTTON(PAD_2, BTN_LEFT), "Joypad2 Left");
|
||||||
MAP_BUTTON(MAKE_BUTTON(PAD_2, BTN_RIGHT), "Joypad2 Right");
|
MAP_BUTTON(MAKE_BUTTON(PAD_2, BTN_RIGHT), "Joypad2 Right");
|
||||||
MAP_BUTTON(MAKE_BUTTON(PAD_2, BTN_UP), "{Joypad2 Up,Superscope ToggleTurbo}");
|
MAP_BUTTON(MAKE_BUTTON(PAD_2, BTN_UP), "{Joypad2 Up,Superscope ToggleTurbo,Justifier1 AimOffscreen}");
|
||||||
MAP_BUTTON(MAKE_BUTTON(PAD_2, BTN_DOWN), "{Joypad2 Down,Superscope Pause}");
|
MAP_BUTTON(MAKE_BUTTON(PAD_2, BTN_DOWN), "{Joypad2 Down,Superscope Pause}");
|
||||||
|
|
||||||
MAP_BUTTON(MAKE_BUTTON(PAD_3, BTN_A), "Joypad3 A");
|
MAP_BUTTON(MAKE_BUTTON(PAD_3, BTN_A), "Joypad3 A");
|
||||||
|
@ -566,40 +649,48 @@ static void report_buttons()
|
||||||
{
|
{
|
||||||
case RETRO_DEVICE_JOYPAD:
|
case RETRO_DEVICE_JOYPAD:
|
||||||
for (int i = BTN_FIRST; i <= BTN_LAST; i++)
|
for (int i = BTN_FIRST; i <= BTN_LAST; i++)
|
||||||
S9xReportButton(MAKE_BUTTON(port * offset + 1, i), s9x_input_state_cb(port * offset, RETRO_DEVICE_JOYPAD, 0, i));
|
S9xReportButton(MAKE_BUTTON(port * offset + 1, i), input_state_cb(port * offset, RETRO_DEVICE_JOYPAD, 0, i));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RETRO_DEVICE_JOYPAD_MULTITAP:
|
case RETRO_DEVICE_JOYPAD_MULTITAP:
|
||||||
for (int j = 0; j < 4; j++)
|
for (int j = 0; j < 4; j++)
|
||||||
for (int i = BTN_FIRST; i <= BTN_LAST; i++)
|
for (int i = BTN_FIRST; i <= BTN_LAST; i++)
|
||||||
S9xReportButton(MAKE_BUTTON(port * offset + j + 1, i), s9x_input_state_cb(port * offset + j, RETRO_DEVICE_JOYPAD, 0, i));
|
S9xReportButton(MAKE_BUTTON(port * offset + j + 1, i), input_state_cb(port * offset + j, RETRO_DEVICE_JOYPAD, 0, i));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RETRO_DEVICE_MOUSE:
|
case RETRO_DEVICE_MOUSE:
|
||||||
_x = s9x_input_state_cb(port, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_X);
|
_x = input_state_cb(port, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_X);
|
||||||
_y = s9x_input_state_cb(port, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_Y);
|
_y = input_state_cb(port, RETRO_DEVICE_MOUSE, 0, RETRO_DEVICE_ID_MOUSE_Y);
|
||||||
snes_mouse_state[port][0] += _x;
|
snes_mouse_state[port][0] += _x;
|
||||||
snes_mouse_state[port][1] += _y;
|
snes_mouse_state[port][1] += _y;
|
||||||
S9xReportPointer(BTN_POINTER + port, snes_mouse_state[port][0], snes_mouse_state[port][1]);
|
S9xReportPointer(BTN_POINTER + port, snes_mouse_state[port][0], snes_mouse_state[port][1]);
|
||||||
for (int i = MOUSE_LEFT; i <= MOUSE_LAST; i++)
|
for (int i = MOUSE_LEFT; i <= MOUSE_LAST; i++)
|
||||||
S9xReportButton(MAKE_BUTTON(port + 1, i), s9x_input_state_cb(port, RETRO_DEVICE_MOUSE, 0, i));
|
S9xReportButton(MAKE_BUTTON(port + 1, i), input_state_cb(port, RETRO_DEVICE_MOUSE, 0, i));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RETRO_DEVICE_LIGHTGUN_SUPER_SCOPE:
|
case RETRO_DEVICE_LIGHTGUN_SUPER_SCOPE:
|
||||||
snes_scope_state[0] += s9x_input_state_cb(port, RETRO_DEVICE_LIGHTGUN, 0, RETRO_DEVICE_ID_LIGHTGUN_X);
|
snes_scope_state[0] += input_state_cb(port, RETRO_DEVICE_LIGHTGUN_SUPER_SCOPE, 0, RETRO_DEVICE_ID_LIGHTGUN_X);
|
||||||
snes_scope_state[1] += s9x_input_state_cb(port, RETRO_DEVICE_LIGHTGUN, 0, RETRO_DEVICE_ID_LIGHTGUN_Y);
|
snes_scope_state[1] += input_state_cb(port, RETRO_DEVICE_LIGHTGUN_SUPER_SCOPE, 0, RETRO_DEVICE_ID_LIGHTGUN_Y);
|
||||||
|
if (snes_scope_state[0] < 0) snes_scope_state[0] = 0;
|
||||||
|
else if (snes_scope_state[0] > (SNES_WIDTH-1)) snes_scope_state[0] = SNES_WIDTH-1;
|
||||||
|
if (snes_scope_state[1] < 0) snes_scope_state[1] = 0;
|
||||||
|
else if (snes_scope_state[1] > (SNES_HEIGHT-1)) snes_scope_state[1] = SNES_HEIGHT-1;
|
||||||
S9xReportPointer(BTN_POINTER, snes_scope_state[0], snes_scope_state[1]);
|
S9xReportPointer(BTN_POINTER, snes_scope_state[0], snes_scope_state[1]);
|
||||||
for (int i = SCOPE_TRIGGER; i <= SCOPE_LAST; i++)
|
for (int i = SCOPE_TRIGGER; i <= SCOPE_LAST; i++)
|
||||||
S9xReportButton(MAKE_BUTTON(2, i), s9x_input_state_cb(port, RETRO_DEVICE_LIGHTGUN, 0, i));
|
S9xReportButton(MAKE_BUTTON(2, i), input_state_cb(port, RETRO_DEVICE_LIGHTGUN, 0, i));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RETRO_DEVICE_LIGHTGUN_JUSTIFIER:
|
case RETRO_DEVICE_LIGHTGUN_JUSTIFIER:
|
||||||
case RETRO_DEVICE_LIGHTGUN_JUSTIFIERS:
|
case RETRO_DEVICE_LIGHTGUN_JUSTIFIERS:
|
||||||
snes_justifier_state[0][0] += s9x_input_state_cb(port, RETRO_DEVICE_LIGHTGUN, 0, RETRO_DEVICE_ID_LIGHTGUN_X);
|
snes_justifier_state[port][0] += input_state_cb(port, RETRO_DEVICE_LIGHTGUN_JUSTIFIER, 0, RETRO_DEVICE_ID_LIGHTGUN_X);
|
||||||
snes_justifier_state[0][1] += s9x_input_state_cb(port, RETRO_DEVICE_LIGHTGUN, 0, RETRO_DEVICE_ID_LIGHTGUN_Y);
|
snes_justifier_state[port][1] += input_state_cb(port, RETRO_DEVICE_LIGHTGUN_JUSTIFIER, 0, RETRO_DEVICE_ID_LIGHTGUN_Y);
|
||||||
S9xReportPointer(BTN_POINTER, snes_justifier_state[0][0], snes_justifier_state[0][1]);
|
if (snes_justifier_state[port][0] < 0) snes_justifier_state[port][0] = 0;
|
||||||
|
else if (snes_justifier_state[port][0] > (SNES_WIDTH-1)) snes_justifier_state[port][0] = SNES_WIDTH-1;
|
||||||
|
if (snes_justifier_state[port][1] < 0) snes_justifier_state[port][1] = 0;
|
||||||
|
else if (snes_justifier_state[port][1] > (SNES_HEIGHT-1)) snes_justifier_state[port][1] = SNES_HEIGHT-1;
|
||||||
|
S9xReportPointer(BTN_POINTER, snes_justifier_state[port][0], snes_justifier_state[port][1]);
|
||||||
for (int i = JUSTIFIER_TRIGGER; i <= JUSTIFIER_LAST; i++)
|
for (int i = JUSTIFIER_TRIGGER; i <= JUSTIFIER_LAST; i++)
|
||||||
S9xReportButton(MAKE_BUTTON(2, i), s9x_input_state_cb(port, RETRO_DEVICE_LIGHTGUN, 0, i));
|
S9xReportButton(MAKE_BUTTON(2, i), input_state_cb(port, RETRO_DEVICE_LIGHTGUN, 0, i));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -616,7 +707,7 @@ void retro_run()
|
||||||
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE_UPDATE, &updated) && updated)
|
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE_UPDATE, &updated) && updated)
|
||||||
update_variables();
|
update_variables();
|
||||||
|
|
||||||
s9x_poller_cb();
|
poll_cb();
|
||||||
report_buttons();
|
report_buttons();
|
||||||
S9xMainLoop();
|
S9xMainLoop();
|
||||||
}
|
}
|
||||||
|
@ -746,7 +837,7 @@ bool8 S9xDeinitUpdate(int width, int height)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
s9x_video_cb(GFX.Screen, width, height, GFX.Pitch);
|
video_cb(GFX.Screen, width, height, GFX.Pitch);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,39 +0,0 @@
|
||||||
LIBRARY libretro
|
|
||||||
|
|
||||||
EXPORTS
|
|
||||||
|
|
||||||
retro_api_version
|
|
||||||
|
|
||||||
retro_get_system_info
|
|
||||||
retro_get_system_av_info
|
|
||||||
|
|
||||||
retro_set_video_refresh
|
|
||||||
retro_set_audio_sample
|
|
||||||
retro_set_audio_sample_batch
|
|
||||||
retro_set_input_poll
|
|
||||||
retro_set_input_state
|
|
||||||
|
|
||||||
retro_set_environment
|
|
||||||
|
|
||||||
retro_set_controller_port_device
|
|
||||||
|
|
||||||
retro_init
|
|
||||||
retro_deinit
|
|
||||||
|
|
||||||
retro_reset
|
|
||||||
retro_run
|
|
||||||
|
|
||||||
retro_serialize_size
|
|
||||||
retro_serialize
|
|
||||||
retro_unserialize
|
|
||||||
|
|
||||||
retro_cheat_reset
|
|
||||||
retro_cheat_set
|
|
||||||
|
|
||||||
retro_load_game
|
|
||||||
retro_unload_game
|
|
||||||
retro_load_game_special
|
|
||||||
|
|
||||||
retro_get_region
|
|
||||||
retro_get_memory_data
|
|
||||||
retro_get_memory_size
|
|
2221
libretro/libretro.h
2221
libretro/libretro.h
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue