aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornotaz2012-07-29 20:14:54 +0300
committernotaz2012-07-30 00:08:17 +0300
commit61bc6d40b4f6f846a0ae1b73ceecdca893c14df4 (patch)
tree566c7d54c16bd46de3804b23e917fd08cf43fa1d
parent38c2028e228dcf17f3b4b0ac7e6984d1e1c6df79 (diff)
downloadpcsx_rearmed-61bc6d40b4f6f846a0ae1b73ceecdca893c14df4.tar.gz
pcsx_rearmed-61bc6d40b4f6f846a0ae1b73ceecdca893c14df4.tar.bz2
pcsx_rearmed-61bc6d40b4f6f846a0ae1b73ceecdca893c14df4.zip
select builtin gpu plugin on configure
-rw-r--r--Makefile40
-rwxr-xr-xconfigure50
-rw-r--r--frontend/main.c3
3 files changed, 63 insertions, 30 deletions
diff --git a/Makefile b/Makefile
index 5739ef8..8c2628c 100644
--- a/Makefile
+++ b/Makefile
@@ -1,13 +1,13 @@
# Makefile for PCSX ReARMed
+# default stuff goes here, so that config can override
TARGET = pcsx
-
-# default CFLAGS go here, so that config can override them
CFLAGS += -Wall -ggdb -Ifrontend -ffast-math
LDLIBS += -lpthread -ldl -lpng -lz -lm
ifndef DEBUG
CFLAGS += -O2 -DNDEBUG
endif
+CXXFLAGS += $(CFLAGS)
#DRC_DBG = 1
#PCNT = 1
@@ -25,6 +25,8 @@ config.mak:
endif
-include Makefile.local
+CC_LINK = $(CC)
+
# core
OBJS += libpcsxcore/cdriso.o libpcsxcore/cdrom.o libpcsxcore/cheat.o libpcsxcore/debug.o \
libpcsxcore/decode_xa.o libpcsxcore/disr3000a.o libpcsxcore/mdec.o \
@@ -68,39 +70,45 @@ plugins/dfsound/spu.o: plugins/dfsound/adsr.c plugins/dfsound/reverb.c \
ifeq "$(ARCH)" "arm"
OBJS += plugins/dfsound/arm_utils.o
endif
-ifeq "$(USE_OSS)" "1"
+ifeq "$(SOUND_DRIVER)" "oss"
plugins/dfsound/%.o: CFLAGS += -DUSEOSS
OBJS += plugins/dfsound/oss.o
endif
-ifeq "$(USE_ALSA)" "1"
+ifeq "$(SOUND_DRIVER)" "alsa"
plugins/dfsound/%.o: CFLAGS += -DUSEALSA
OBJS += plugins/dfsound/alsa.o
LDLIBS += -lasound
endif
-ifeq "$(USE_NO_SOUND)" "1"
+ifeq "$(SOUND_DRIVER)" "none"
OBJS += plugins/dfsound/nullsnd.o
endif
-# gpu
-OBJS += plugins/gpulib/gpu.o
+# builtin gpu
+OBJS += plugins/gpulib/gpu.o plugins/gpulib/vout_pl.o
ifeq "$(HAVE_NEON)" "1"
OBJS += plugins/gpulib/cspace_neon.o
+else
+OBJS += plugins/gpulib/cspace.o
+endif
+ifeq "$(BUILTIN_GPU)" "neon"
OBJS += plugins/gpu_neon/psx_gpu_if.o plugins/gpu_neon/psx_gpu/psx_gpu_arm_neon.o
plugins/gpu_neon/psx_gpu_if.o: CFLAGS += -DNEON_BUILD -DTEXTURE_CACHE_4BPP -DTEXTURE_CACHE_8BPP
plugins/gpu_neon/psx_gpu_if.o: plugins/gpu_neon/psx_gpu/*.c
-else
-OBJS += plugins/gpulib/cspace.o
+endif
+ifeq "$(BUILTIN_GPU)" "peops"
# note: code is not safe for strict-aliasing? (Castlevania problems)
plugins/dfxvideo/gpulib_if.o: CFLAGS += -fno-strict-aliasing
plugins/dfxvideo/gpulib_if.o: plugins/dfxvideo/prim.c plugins/dfxvideo/soft.c
OBJS += plugins/dfxvideo/gpulib_if.o
endif
-ifdef X11
-LDLIBS += -lX11 `sdl-config --libs`
-OBJS += plugins/gpulib/vout_sdl.o
-plugins/gpulib/vout_sdl.o: CFLAGS += `sdl-config --cflags`
-else
-OBJS += plugins/gpulib/vout_pl.o
+ifeq "$(BUILTIN_GPU)" "unai"
+OBJS += plugins/gpulib/cspace.o
+OBJS += plugins/gpu_unai/gpulib_if.o
+ifeq "$(ARCH)" "arm"
+OBJS += plugins/gpu_unai/gpu_arm.o
+endif
+plugins/gpu_unai/gpulib_if.o: CFLAGS += -DREARMED
+CC_LINK = $(CXX)
endif
# cdrcimg
@@ -174,7 +182,7 @@ frontend/revision.h: FORCE
target_: $(TARGET)
$(TARGET): $(OBJS)
- $(CC) -o $@ $^ $(LDFLAGS) $(LDLIBS) -Wl,-Map=$@.map
+ $(CC_LINK) -o $@ $^ $(LDFLAGS) $(LDLIBS) -Wl,-Map=$@.map
clean: $(PLAT_CLEAN) clean_plugins
$(RM) $(TARGET) $(OBJS) $(TARGET).map
diff --git a/configure b/configure
index 6552ef5..8c40b7d 100755
--- a/configure
+++ b/configure
@@ -26,6 +26,8 @@ check_define()
platform_list="generic pandora maemo caanoo libretro"
platform="generic"
+builtin_gpu_list="peops unai neon"
+builtin_gpu=""
sound_driver_list="oss alsa libretro none"
sound_driver="alsa"
plugins="plugins/spunull/spunull.so \
@@ -91,6 +93,8 @@ for opt do
;;
--platform=*) set_platform "$optarg"
;;
+ --gpu=*) builtin_gpu="$optarg"
+ ;;
--sound-driver=*) sound_driver="$optarg"
;;
--enable-neon) have_arm_neon="yes"
@@ -109,6 +113,8 @@ if [ "$show_help" = "yes" ]; then
echo " --help print this message"
echo " --platform=NAME target platform [$platform]"
echo " available: $platform_list"
+ echo " --gpu=NAME builtin gpu plugin [guessed]"
+ echo " available: $builtin_gpu_list"
echo " --sound-driver=NAME sound output driver [$sound_driver]"
echo " available: $sound_driver_list"
echo " --enable-neon"
@@ -120,6 +126,17 @@ if [ "$show_help" = "yes" ]; then
exit 1
fi
+if [ "x$builtin_gpu" != "x" ]; then
+ case "$builtin_gpu" in
+ peops|unai|neon)
+ ;;
+ *)
+ echo "unsupported builtin gpu plugin: $builtin_gpu"
+ exit 1
+ ;;
+ esac
+fi
+
case "$sound_driver" in
oss|alsa|libretro|none)
;;
@@ -160,6 +177,17 @@ if [ "$ARCH" = "arm" ]; then
fi
fi
+ if [ "x$builtin_gpu" = "x" ]; then
+ if [ "$have_arm_neon" = "yes" ]; then
+ builtin_gpu="neon"
+ elif [ "$have_armv7" != "yes" ]; then
+ # pre-ARMv7 hardware is usually not fast enough for peops
+ builtin_gpu="unai"
+ else
+ builtin_gpu="peops"
+ fi
+ fi
+
# set mfpu and mfloat-abi if they are not set
if [ "$have_arm_neon" = "yes" ]; then
echo "$CFLAGS" | grep -q -- '-mfpu=' || CFLAGS="$CFLAGS -mfpu=neon"
@@ -188,6 +216,10 @@ else
enable_dynarec="no"
fi
+if [ "x$builtin_gpu" = "x" ]; then
+ builtin_gpu="peops"
+fi
+
if [ "$ARCH" = "x86_64" ]; then
# currently we are full of 32bit assumptions,
# at least savestate compatibility will break without these
@@ -249,6 +281,10 @@ if compile_object; then
plugins="$plugins plugins/gpu-gles/gpu_gles.so"
fi
+if [ "$have_arm_neon" = "yes" -a "$builtin_gpu" != "neon" ]; then
+ plugins="$plugins plugins/gpu_neon/gpu_neon.so"
+fi
+
# short plugin list for display
for p in $plugins; do
p1=`basename $p`
@@ -262,6 +298,7 @@ test "x$have_arm_neon" != "x" || have_arm_neon="no"
echo "architecture $ARCH"
echo "platform $platform"
+echo "built-in GPU $builtin_gpu"
echo "sound driver $sound_driver"
echo "plugins $plugins_short"
echo "C compiler $CC"
@@ -292,17 +329,8 @@ if [ "$platform" = "libretro" ]; then
fi
echo "ARCH = $ARCH" >> $config_mak
echo "PLATFORM = $platform" >> $config_mak
-case "$sound_driver" in
-oss)
- echo "USE_OSS = 1" >> $config_mak
- ;;
-alsa)
- echo "USE_ALSA = 1" >> $config_mak
- ;;
-none)
- echo "USE_NO_SOUND = 1" >> $config_mak
- ;;
-esac
+echo "BUILTIN_GPU = $builtin_gpu" >> $config_mak
+echo "SOUND_DRIVER = $sound_driver" >> $config_mak
if [ "$ARCH" = "arm" ]; then
echo "PLUGINS = $plugins" >> $config_mak
else
diff --git a/frontend/main.c b/frontend/main.c
index bb6aaa9..59fa24a 100644
--- a/frontend/main.c
+++ b/frontend/main.c
@@ -130,9 +130,6 @@ static void set_default_paths(void)
strcpy(Config.Pad1, "builtin_pad");
strcpy(Config.Pad2, "builtin_pad");
strcpy(Config.Net, "Disabled");
-#if defined(__arm__) && !defined(__ARM_ARCH_7A__) /* XXX */
- strcpy(Config.Gpu, "gpu_unai.so");
-#endif
snprintf(Config.PatchesDir, sizeof(Config.PatchesDir), "." PATCHES_DIR);
}